ACG Second Challenge Write-up
Introduction
This is a write up on how to solve our second ctf challenge called “PHP-T3st3r” which is an online vulnerable PHP interpreter.
As mentioned in the description of the task our mission is to read a sensitive file stored in /psycor/flag.php.
Steps
The first thing that comes to mind is to try reading the file directly using the readfile function, however the readfile function does not work when the wrapper ‘file://’ is disabled, same thing for file_get_contents function and other file access functions are also disabled 🙁
data:image/s3,"s3://crabby-images/6ae15/6ae150f4c8f83255869b98f4686cdf468dc32133" alt=""
If we try to execute a command using the system function we get a warning indicating that this function is also disabled.
data:image/s3,"s3://crabby-images/f05f8/f05f8119f67a92dd896c612dd00a279afdbfe006" alt=""
Okay, let’s dig a little deeper and check what functions are disabled and other juicy information using the phpinfo function.
data:image/s3,"s3://crabby-images/297cd/297cd618c39a8ac8fc9c5b0e9fd55f6db10a62f8" alt=""
data:image/s3,"s3://crabby-images/a585c/a585c9c66eacb592ed69611fc91d8fd598a371fb" alt=""
The most useful functions are disabled, so let’s change the tactic and go through more serious stuff.
What is PHP-FPM?
data:image/s3,"s3://crabby-images/77c1a/77c1ab830d6916d01dc7d7299420f877a0f684b8" alt=""
PHP-FPM is the process manager of FastCGI protocol.
- PHP-FPM is a service of multiple processes: several workers to deal with requests and one master to manage those workers. To get the information of each worker processes, FPM even uses structures of fpm_scoreboard_s and fpm_scoreboard_proc_s to record their statuses.
data:image/s3,"s3://crabby-images/252e7/252e73f92d62a38ee15d0d2e5ce3bb1753de2ec9" alt=""
- This is a nice picture to understand the request flow of PHP-FPM. First, our HTTP request would be converted to the format of FastCGI by Nginx worker and be sent to FPM worker. There are two kinds of socket implemented on FPM: one is TCP socket(127.0.0.1:9000) and another is UNIX socket(unix:///var/run/php7.0-fpm.sock), this can be set by fastcgi_pass in the nginx conf file.
In the task we switched PHP-FPM to listen on a unix socket rather than a TCP socket.
Note : The phpinfo function clearly indicates the php version, so looking a little more deeply we found that the default path for the socket was in /run/php/php7.0-fpm.sock .
data:image/s3,"s3://crabby-images/31307/313073fc83523fa41421392b78789db1808725c7" alt=""
Now we can communicate with the socket and kindly ask it to return the file /psyco/flag.php 🙂
The picture below describes the nginx and PHP interaction process.
data:image/s3,"s3://crabby-images/79db2/79db2dbe4a2ecc0fed37b33b6637b948a292a7b1" alt=""
Here we can communicate with the socket only in binary mode, so we can use this ruby script to return the call in binary format. https://raw.githubusercontent.com/ONsec-Lab/scripts/master/fastcgipacket.rb
data:image/s3,"s3://crabby-images/203e2/203e20e2fa73f92cd1c3f143118d6d55e69e606a" alt=""
data:image/s3,"s3://crabby-images/f1473/f14739a660b03df3db92356b451523a743ca1c1c" alt=""
Now, it’s time to run our final php code and get the flag.
data:image/s3,"s3://crabby-images/31007/31007745a5217fc70474e9c5575505f4fcec8be0" alt=""
During the challenge we received another solution from BENAMAROUCHE ABDELMOUMEN, it consists to use this exploit https://github.com/mm0r1/exploits/blob/master/php7-gc-bypass/exploit.php to bypass all disabled functions
This exploit should work on all PHP 7.0-7.3 versions with nginx only.
data:image/s3,"s3://crabby-images/9a20d/9a20dc2c70018b3915080a8497e6bf1e00b761b3" alt=""
We hope you enjoyed reading this write up, see you on next challenges
Created By Rayen MESSAOUDI