POPCORN
- Layout for this exercise:
data:image/s3,"s3://crabby-images/5153d/5153d3a29dcb447b2961698c0e30534254d0c621" alt=""
1 - INTRODUCTION
- The goal for this exercise is to develop a hacking process for the vulnerable machine Popcorn, what is a retired machine from the Hack The Box pentesting platform:
https://www.hackthebox.eu/
data:image/s3,"s3://crabby-images/b563a/b563a2dfb0df6d6acbd14f3a303214ad7540a5a3" alt=""
2 - ENUMERATION
- Popcorn's IP is 10.10.10.6:
data:image/s3,"s3://crabby-images/235c5/235c577806842caeba66587879c623b081ddd30f" alt=""
- Scanning with Nmap:
data:image/s3,"s3://crabby-images/edf29/edf2921ae79a3d7d40fc9ad147740e46703d3d39" alt=""
- Connecting with the browser:
data:image/s3,"s3://crabby-images/d6df2/d6df2abbdfffd32ed01a5cfc0e35c1ea44a6b07c" alt=""
- Dirbusting the web server:
data:image/s3,"s3://crabby-images/38e5f/38e5f459102a83a0f4daba33a7f5f023eca6cd67" alt=""
- There is an interesting directory torrent what holds a Torrent Hoster application:
data:image/s3,"s3://crabby-images/a12ef/a12efb9a0422add2381507a586cfb1e4db4f76e5" alt=""
- The Upload tab might be promising:
data:image/s3,"s3://crabby-images/1501d/1501d280cbb238bd94f889028a832daa28480073" alt=""
- A login form is presented to the user:
data:image/s3,"s3://crabby-images/72d8f/72d8fa3ac5023d8422d017f405cf3ea77f1c2560" alt=""
- Creating a new user whitelist:whitelist with Sign Up:
data:image/s3,"s3://crabby-images/b747b/b747b72fb4749f73224d9f95d096525f43cdefba" alt=""
data:image/s3,"s3://crabby-images/51df8/51df83461f3d1687ff9473635a8ce9ae249d5d40" alt=""
- Login as whitelist:
data:image/s3,"s3://crabby-images/1548b/1548bee32c5e3e87621bb4e5a87df6165a3f48e4" alt=""
- Clicking Upload to upload torrent files:
data:image/s3,"s3://crabby-images/d639f/d639fa2a5ba20ad08adf075fd5104d83b8341326" alt=""
- Downloading Kali's torrent file from the original repository:
data:image/s3,"s3://crabby-images/e7e57/e7e57c76b996a1592bc22418ae4913aa9ecd57b0" alt=""
data:image/s3,"s3://crabby-images/750ec/750ec2402a13a17235524c6f2c9d2aff37edc2df" alt=""
- Uploading Kali's torrent to Popcorn:
data:image/s3,"s3://crabby-images/50d03/50d0380a17695fbd899622a10d44a07db8eeadc6" alt=""
data:image/s3,"s3://crabby-images/3071d/3071d74870ea4c413ae6d98d324ba91348300e7c" alt=""
- Changing category to Other/Other (otherwise the upload doesn't work):
data:image/s3,"s3://crabby-images/f5ea0/f5ea020cb001435dd0c1c45bc7beddf9c268ddfa" alt=""
- The upload is successful:
data:image/s3,"s3://crabby-images/57ffe/57ffeaa91e9d5333f8a9224f02e1afb0754ca6b3" alt=""
data:image/s3,"s3://crabby-images/786b4/786b4bb2c37f96742ec9eabd2fd2d36a31d64cbe" alt=""
- Clicking the filename, it seems that the Screenshot can be edited by uploading new images with extensions like jpg, jpeg, gif, png:
data:image/s3,"s3://crabby-images/7d2d1/7d2d18c5ff7f578f9636cb4aac9381e989287b76" alt=""
data:image/s3,"s3://crabby-images/e70c3/e70c32bf699193e541eb3647c791f975dbf4c514" alt=""
3 - EXPLOITATION
- The exploitation attack consists on uploading an exploit to Popcorn's web server, running it and then getting a reverse shell connection.
- Creating an exploit with Msfvenom and saving it as exploit.php:
data:image/s3,"s3://crabby-images/c0c4a/c0c4aa73f007c6b2e9c8e796698984f39ce60d01" alt=""
data:image/s3,"s3://crabby-images/56686/5668661ae42289ce2e32f104ae1ea38b6688407f" alt=""
- However exploit.php will be probably filtered because it does not have an image extension:
data:image/s3,"s3://crabby-images/bbba6/bbba6bca1c4b7659fc13c13b979be948a40afa1c" alt=""
data:image/s3,"s3://crabby-images/3e7ca/3e7ca3e4932277324f4a204f8bb474829e28ebf7" alt=""
- Let's intercept the submission with Burp:
data:image/s3,"s3://crabby-images/c43b6/c43b68a883f511caab12f4aa326cf15f226678ba" alt=""
- Submitting exploit.php:
data:image/s3,"s3://crabby-images/a2d59/a2d59de8b395f24f4e6f105c597bf99d27ea360f" alt=""
- Let's focus in this line:
data:image/s3,"s3://crabby-images/7ea24/7ea24f79ee7a1a6e8801502fed8ba8e2a867e8da" alt=""
- Changing to:
data:image/s3,"s3://crabby-images/53482/53482b3718facbbf5201e000b1579885f84668c9" alt=""
- Forwarding:
data:image/s3,"s3://crabby-images/a28de/a28de3d6940747a0a2d48728517f61135cca9432" alt=""
- The submission is successful:
data:image/s3,"s3://crabby-images/a7d56/a7d56243f5579cf4928878599aa2b15fde3652d4" alt=""
- Now, where has exploit.php been uploaded?
- Dirbusting the folder /torrent we find a directory called upload:
data:image/s3,"s3://crabby-images/bd246/bd246ec603a2991135d3cfcfeff97a87ea56326d" alt=""
data:image/s3,"s3://crabby-images/e00fc/e00fc7ac4a72616e9866fbf09a68d2111ca801a2" alt=""
- Connecting to /upload we locate exploit.php:
data:image/s3,"s3://crabby-images/82c74/82c7495ef8318f4447fb6e07fef970d7db980e78" alt=""
data:image/s3,"s3://crabby-images/ac9b2/ac9b27a58f1813c0a19e4b8d9c12c79bffff2c19" alt=""
- Now, setting a Meterpreter listening session:
data:image/s3,"s3://crabby-images/6fb37/6fb37a9d0f8968221f3c5b90041ede98c0ca42d3" alt=""
- To run exploit.php just click it:
data:image/s3,"s3://crabby-images/9bc8b/9bc8b2a93c1ec7326c66ed888b6ff1a31af8b4b4" alt=""
- The Meterpreter session is achieved:
data:image/s3,"s3://crabby-images/eaf62/eaf62f441d5daafc1d4f44b3892034d06d9bd31f" alt=""
- Reading information about the system:
data:image/s3,"s3://crabby-images/2cd6c/2cd6c0b7338907f5324fb9b21efda24fcf667f5d" alt=""
data:image/s3,"s3://crabby-images/93e59/93e59fa8480b0c33961b3946d11328955cf0ce0e" alt=""
- Getting a remote shell:
data:image/s3,"s3://crabby-images/30266/30266476b6145158bdd6fba00662d6c49d8ea31c" alt=""
- Improving the shell with:
data:image/s3,"s3://crabby-images/0c711/0c711b28e92ae229cc6da980c18d31848331ccc5" alt=""
- Going to /home and listing content:
data:image/s3,"s3://crabby-images/6925c/6925cc02d47deea741f6f64e0cc83a251da4cdc3" alt=""
- Going to user george's folder:
data:image/s3,"s3://crabby-images/0784c/0784ca64d6d32145be606f09c208b33d494f302c" alt=""
- Reading user's flag:
data:image/s3,"s3://crabby-images/a07f8/a07f824f03102b9c9ec5a3046adb0a9e66545df8" alt=""
4 - PRIVILEGE ESCALATION
- Let's exploit the kernel in two ways:
4.1 - Dirtycow
- The kernel 2.6.31 is vulnerable to the exploit dirtycow.c:
data:image/s3,"s3://crabby-images/aed7a/aed7aed61935d62a259cb01ecb8f0487dd92825e" alt=""
- Dirty COW (Dirty copy-on-write) is a computer security vulnerability for the Linux kernel, a local privilege escalation bug that exploits a race condition in the implementation of the copy-on-write mechanism in the kernel's memory-management subsystem.
https://en.wikipedia.org/wiki/Dirty_COW
data:image/s3,"s3://crabby-images/03c51/03c51c57a0d9c1d091716a564233d36fe96ff6e1" alt=""
- According to the instructions of dirty.c it creates a new user called firefart with a password provided by the attacker.
- Copying the exploit and storing locally at Kali:
data:image/s3,"s3://crabby-images/2d3e6/2d3e63f2e999fefa714b43acebc4dc21a9d0a151" alt=""
data:image/s3,"s3://crabby-images/fd79c/fd79cac9cd38e39b482e7a20f1a60a15e3f86d2c" alt=""
- Transferring dirty.c to Popcorn:
data:image/s3,"s3://crabby-images/581c2/581c2284e7fa35c56f929105dbe266e7a9fdc693" alt=""
data:image/s3,"s3://crabby-images/2fca3/2fca3a8eb8865305711c108fcfb62c288ef060f1" alt=""
- Compiling dirty.c by following the instructions:
data:image/s3,"s3://crabby-images/57050/57050e4dfc99ffd0ac5a9e61b6a5d706c090137b" alt=""
data:image/s3,"s3://crabby-images/b8c7d/b8c7d43375581a5bc55397e88367a7e2a344a1f4" alt=""
- Running dirty and entering the new password hola:
data:image/s3,"s3://crabby-images/4c973/4c973fd3891cb1d8dc7306c57e66152f41a8fea3" alt=""
- Switching to the user firefart:hola we get a remote root shell:
data:image/s3,"s3://crabby-images/071ef/071efe1f1cf1353fdf9a19514f00c57c199d1145" alt=""
4.2 - Full-Nelson.c Local Privilege Escalation
- Also, the kernel 2.6.31 is vulnerable to the exploit 15704.c:
data:image/s3,"s3://crabby-images/b5d01/b5d01434fd3d333d190b4e674851ff35bd358d04" alt=""
- Downloading 15704.c to Kali:
data:image/s3,"s3://crabby-images/3e5bd/3e5bd8823848cfc4882e2f2518810220db62a128" alt=""
- Transferring 15704.c from Kali to Popcorn /tmp folder:
data:image/s3,"s3://crabby-images/de189/de18992970859c9909e9ce9223fa736e637f6315" alt=""
data:image/s3,"s3://crabby-images/8837c/8837c9d34bff3e5f93c3a1e16948d73bb66c4a04" alt=""
- Compiling 15704.c according to the instructions:
data:image/s3,"s3://crabby-images/3e1ce/3e1ce11a1f4d46d40f033b6986bdbf04a530c959" alt=""
data:image/s3,"s3://crabby-images/2cdae/2cdae7914960d0ca46476100578a2aca816eb2c6" alt=""
- Running the exploit a root shell is achieved:
data:image/s3,"s3://crabby-images/95da3/95da3362d7529d6720dc5a07ef035ebf34144b7a" alt=""
5 - CAPTURING THE FLAG
- Reading root.txt:
data:image/s3,"s3://crabby-images/2c138/2c138dde2043c199b07c4612ccad1712ff2e3270" alt=""