BASHED
- Layout for this exercise:
data:image/s3,"s3://crabby-images/6a422/6a422613638fbfbdfb9fbd3f73aa5f5aa3e9590c" alt=""
1 - INTRODUCTION
- The goal of this exercise is to develop a hacking process for the vulnerable machine Bashed, what is a retired machine from the Hack The Box pentesting platform:
https://www.hackthebox.eu
2 - ENUMERATION
- Bashed's IP is 10.10.10.68:
data:image/s3,"s3://crabby-images/bbaaa/bbaaa7b4696f3f0dbb8565cfcb15bd52b71d7ef7" alt=""
- Scanning with Nmap the only open port is 80:
data:image/s3,"s3://crabby-images/e2621/e2621edd484587221d01b62fba0a89047b8686d6" alt=""
- Scanning deeper the port 80:
data:image/s3,"s3://crabby-images/3c03b/3c03b3931e3a4c81377884de66c5e66e77c70f89" alt=""
data:image/s3,"s3://crabby-images/83fb7/83fb72e350beae78130e6af9a3f59e2338726b60" alt=""
- Dirbusting:
data:image/s3,"s3://crabby-images/9c97a/9c97af9464598ddf6d44cfc9d278e9c254ba9ca6" alt=""
- Checking the folder /dev we find two PHP scripts:
data:image/s3,"s3://crabby-images/0e740/0e7405b1d910b6d170113d24f61b50c6f827e857" alt=""
- Clicking either phpbash.php or phpbash.min.php the result is a PHP bash:
data:image/s3,"s3://crabby-images/e9660/e96604bb0e613d277270da39ab33322809a6c294" alt=""
data:image/s3,"s3://crabby-images/c3ee2/c3ee2b444378ba27f6534020737529cd515cf79b" alt=""
data:image/s3,"s3://crabby-images/ff026/ff0267c4dc040bdee4301152ab7f0307dbccefb1" alt=""
data:image/s3,"s3://crabby-images/72837/72837b6946e8caec87f428a6d997c85567c4e7e6" alt=""
data:image/s3,"s3://crabby-images/63d0c/63d0c3d561b2e72c5e1dbf246a422be73955cff1" alt=""
- Good news are that Netcat is available:
data:image/s3,"s3://crabby-images/91833/91833f93eab93f6512ffc20705bf056d9c32b434" alt=""
3 - EXPLOITATION
- Msfvenom helps creating an exploit called myshell.php:
data:image/s3,"s3://crabby-images/37677/376771b15112828ce0fe6f4739a0a3c160e49c42" alt=""
data:image/s3,"s3://crabby-images/6964a/6964a039cbf09448750fe01ce7cc0021cf591839" alt=""
- Uploading myshell.php from Kali to Bashed:
data:image/s3,"s3://crabby-images/0c8d0/0c8d0ae2af0f2d3c77d42705ace2f3466eca6c73" alt=""
data:image/s3,"s3://crabby-images/c42af/c42af9991558b626c493ae8dda81fb88c0d87edf" alt=""
data:image/s3,"s3://crabby-images/44910/449107a2eef49a93eb6c7ea500aa7ed9edb4310c" alt=""
- Setting up a Meterpreter listener session:
data:image/s3,"s3://crabby-images/e2599/e25995db8f4d9289bc84ff9ec79967204457666a" alt=""
- Running myshell.php from the browser:
data:image/s3,"s3://crabby-images/0de55/0de55424edddac76a5c245f9118da99a21ec7df4" alt=""
- The exploitation is successful and we get a Meterpreter session:
data:image/s3,"s3://crabby-images/61e81/61e8186c5efdde68d618686d0ec04bb041ee4dc7" alt=""
- Spawning a shell and improving it:
data:image/s3,"s3://crabby-images/4b193/4b19344c24edba658efda8efd3e70d1ab76af5c5" alt=""
4 - CAPTURING THE 1st FLAG
- Reading user.txt:
data:image/s3,"s3://crabby-images/c6785/c67859e2b8d11a2b2f402a0cd427d838e05f3234" alt=""
5 - PRIVILEGE ESCALATION
- Let's try two ways for achieving Privilege Escalation
5.1 - Exploiting the kernel
- Checking the Ubuntu release version:
data:image/s3,"s3://crabby-images/88b0d/88b0db964183ec960eda8f32df1023c63174dd4f" alt=""
- Kernel exploit for this operating system:
data:image/s3,"s3://crabby-images/09d01/09d01222f0bc365c13918ee0158d9a3f7eff5b67" alt=""
data:image/s3,"s3://crabby-images/d6f61/d6f615ea3f807f0ec4294d2936e6214ee774fb8c" alt=""
- Copying the exploit poc.c to Kali and compiling it according to the instructions:
data:image/s3,"s3://crabby-images/6466c/6466c8c183e8e08580dc2b56727942d5d3987bc5" alt=""
data:image/s3,"s3://crabby-images/a4a97/a4a97875a9819bdc1815cbcacede824162a67619" alt=""
data:image/s3,"s3://crabby-images/eda32/eda32541dcc1dafdfafb8f2dea3f4e4df8e7492c" alt=""
- Transferring the binary pwn from Kali to Bashed:
data:image/s3,"s3://crabby-images/9dc4f/9dc4fb5fa3174be83baef554000cfcb7af1dc9ce" alt=""
- Giving execution permissions:
data:image/s3,"s3://crabby-images/4a080/4a080073ca6b8a6290092f618c2d84863ae66a95" alt=""
- Running pwn we eventually get a remote root shell:
data:image/s3,"s3://crabby-images/aedd7/aedd7eca200b1a78d82054179f9f8fd71913f030" alt=""
5.2 - Sudoer privileges
- The current user is www-data:
data:image/s3,"s3://crabby-images/369fc/369fc664f9797a95650f3c5ca04e7474c7827dd2" alt=""
- Sudoer privileges for www-data allows to run all commands as the scriptmanager user:
data:image/s3,"s3://crabby-images/2eafa/2eafa2dd03c051e1748336c11690edc15203970d" alt=""
data:image/s3,"s3://crabby-images/bd2d1/bd2d1d21278de6e6d0cf512b4fd0ab7e72fb48b4" alt=""
- Listing content inside folder /scriptmanager:
data:image/s3,"s3://crabby-images/11fe5/11fe5f41aead606f45c41dfe2128d2c88d8dbd16" alt=""
- Listing content of / there is a folder called scripts:
data:image/s3,"s3://crabby-images/212a9/212a9d57af89f1ed308636ef66b0029dafba7d64" alt=""
- User www-data cannot access directly the contents of folder scripts:
data:image/s3,"s3://crabby-images/eb213/eb21367c7f0621f21d8d66cca7a185ad306c9374" alt=""
- However www-data can use his sudoer privileges to open scripts:
data:image/s3,"s3://crabby-images/4f1e3/4f1e38be72878731c335991bca5b7d42b7ad94a8" alt=""
- Reading test.py and test.txt:
data:image/s3,"s3://crabby-images/41c57/41c5789985e98c32b9245e85182e2333ab742309" alt=""
data:image/s3,"s3://crabby-images/d71e4/d71e4ec3dd4e7327052b4fd0b6f99fe29628b667" alt=""
- At this point of the exploitation process the strategy will be to replace test.py with some exploitation code, for instance:
data:image/s3,"s3://crabby-images/99535/9953557d2e12930af1c7352382fba758f6c81202" alt=""
- Transferring myexploit.py to Bashed:
data:image/s3,"s3://crabby-images/fc8db/fc8db2cc71d0769fedf0104123cb26b3284e3776" alt=""
- Copying myexploit.py over test.py:
data:image/s3,"s3://crabby-images/da767/da76726c9d4d7b700a417e7a737fa33446570718" alt=""
data:image/s3,"s3://crabby-images/6228f/6228f6a28882593c0534cfa1e674fa142b52aa0a" alt=""
- Setting a Netcat listener session on Kali's port 5555:
data:image/s3,"s3://crabby-images/c0e79/c0e79e86d2dbe662287a1c667ad8bb673be68ce8" alt=""
- After some seconds a remote root shell is successfully achieved:
data:image/s3,"s3://crabby-images/ac005/ac0059f47b280845b19bb55e031f159192ee8626" alt=""
6 - CAPTURING THE 2nd FLAG
- Reading root.txt:
data:image/s3,"s3://crabby-images/9e443/9e4431fbb14e789d9e3c0373329da03f0f2434f5" alt=""