TENTEN
- Layout for this exercise:
data:image/s3,"s3://crabby-images/9e354/9e3543b18e4572bb077ed0c0e9e80d3dbf113f26" alt=""
1 - INTRODUCTION
- The goal of this exercise is to develop a hacking process for the vulnerable machine Tenten, what is a retired machine from the Hack the Box pentesting platform:
https://www.hackthebox.eu
2 - ENUMERATION
- Scanning with Nmap, there are just two open ports 22 and 80:
data:image/s3,"s3://crabby-images/1600d/1600d94ee8c80e01b9e9f726cbbbb33efe511856" alt=""
- Scanning deeper those two ports it seems that the web server is running WordPress 4.7.3:
data:image/s3,"s3://crabby-images/38e4f/38e4f5fea921d694a19508f6866f1d9dce010982" alt=""
- WPScan is a WordPress Security Scanner:
data:image/s3,"s3://crabby-images/1cb63/1cb63b7bbb0a99e77364fc9a56fef5d2931b6860" alt=""
data:image/s3,"s3://crabby-images/1340a/1340aa89d6fe0f5b39e8ab8d8aa005706de0c6ad" alt=""
- Launching WPScan against Tenten to enumerate users we discover user takis:
data:image/s3,"s3://crabby-images/10908/109084e2df6814afdb369f451b26141cd85af360" alt=""
data:image/s3,"s3://crabby-images/21ba8/21ba8dbed5fc581a45b937535c540ac69968d812" alt=""
- Same thing for plugins we discover Job Manager and one associated vulnerability:
data:image/s3,"s3://crabby-images/a6c0d/a6c0d25b89bb57faa7ff299d9c6b3164740a5625" alt=""
data:image/s3,"s3://crabby-images/1aa85/1aa855e3646257c581ea22ae62428f3838f6e813" alt=""
- Checking the last reference:
https://vagmour.eu/cve-2015-6668-cv-filename-disclosure-on-job-manager-wordpress-plugin/
data:image/s3,"s3://crabby-images/4fa50/4fa50d435e96b68a49d0a43d8742c0c497ef8eb5" alt=""
- So this vulnerability allows to enumerate the CV filename and bruteforce the upload directory structure, where sensitive information can be found:
data:image/s3,"s3://crabby-images/5ebed/5ebedf93b7f4ab44c1eb54d2f1e067d01fa48c55" alt=""
- The Wordpress directory structure for uploaded files is like this:
data:image/s3,"s3://crabby-images/d2de7/d2de7b9361cb2a2519b4357efb6ea2c97202cc22" alt=""
- Now, dirbusting /wp-content/uploads to discover year (from 2010 to 2019) and month (from 01 to 12) where any upload is available:
data:image/s3,"s3://crabby-images/2bc9a/2bc9aecee1e1dae7aa721b993d2bea11ead97314" alt=""
data:image/s3,"s3://crabby-images/75b7c/75b7c8fbf7a10f5ec333638b1b1e1da592b28b0d" alt=""
data:image/s3,"s3://crabby-images/ad260/ad2603154b8fa5f7fc9e6893276ec02ae3e52b8f" alt=""
- So finally we know that April 2017 is the date when uploads are available.
- Exploring jobs, for instance the 1st one:
data:image/s3,"s3://crabby-images/8dd96/8dd96c727ec34913d8701ab25c6d0d2864e58dc5" alt=""
- Viewing the source, the job application identification name (Hello World! for 1st job) is after the tag <title>:
data:image/s3,"s3://crabby-images/bb36e/bb36e99b6bdaee83c550a2a80896fdfd7dce3a65" alt=""
- Extracting all job names the 13rd one is called HackedAccessGranted:
data:image/s3,"s3://crabby-images/2eaab/2eaab2f98471886256039149a3106a316d300cb1" alt=""
data:image/s3,"s3://crabby-images/c2e30/c2e309ca62288e2c6c4658987ca17260b7f6638f" alt=""
3 - EXPLOITATION
3.1 - Exploiting WordPress
- Copying the exploit and expanding to file extensions jpeg, jpg and png:
https://vagmour.eu/cve-2015-6668-cv-filename-disclosure-on-job-manager-wordpress-plugin/
data:image/s3,"s3://crabby-images/5ddcb/5ddcb8fea4f598a6b4a5286291683385bd986bb4" alt=""
data:image/s3,"s3://crabby-images/b8006/b8006f60b3e134b8fbe877838f72387468aaf8ca" alt=""
- Giving execution permissions:
data:image/s3,"s3://crabby-images/a2c16/a2c1694d825005f5fe8470aac2eaadb5510895d1" alt=""
- Running the Python script exploit against Tenten:
data:image/s3,"s3://crabby-images/9d860/9d8609dc1c6c925adad7cf46bfb825199bb00bd9" alt=""
- Finally we have found the URL where a picture HackerAccessGranted.jpg is located, what was uploaded on April 2017, as we already knew.
3.2 - Exploiting Stenography inside a picture
- Downloading the image HackerAccessGranted.jpg:
data:image/s3,"s3://crabby-images/e3d14/e3d142eaa1e52b79a5edbbddd06f9fa5ec8bf42e" alt=""
data:image/s3,"s3://crabby-images/8e597/8e5976d9f6bc28ecb490464b139d74180c4abc26" alt=""
data:image/s3,"s3://crabby-images/7331c/7331c9c9ce8d1da136f706cfc8e3c5dd8573b4c8" alt=""
- steghide is a steganography program that is able to hide/unide data in various kinds of image and audio files:
http://steghide.sourceforge.net/
- Applying steghide over HackerAccessGranted.jpg and using blank password:
data:image/s3,"s3://crabby-images/8aeab/8aeabfe8ea77481230c3bb23c38291974c729bf2" alt=""
- The private key id_rsa is extracted from the .jpeg image:
data:image/s3,"s3://crabby-images/53d76/53d76adef1a7f536a9e451176abc051aa7133f5b" alt=""
3.3 - Cracking an encrypted Private Key
- However id_rsa is encrypted:
data:image/s3,"s3://crabby-images/5e32a/5e32a89f857a458956bb23488daa6aceee66fc71" alt=""
- The Python script sshng2john.py helps to adapt id_rsa to John The Ripper's format:
https://github.com/stricture/hashstack-server-plugin-jtr/blob/master/scrapers/sshng2john.py
http://grayhat.shoutwiki.com/wiki/SSH_tricks
data:image/s3,"s3://crabby-images/64794/64794acaef932c51b0010bd99dddd97784aa63cd" alt=""
- Applying sshng2john.py over id_rsa the result is id_rsa_hashed:
data:image/s3,"s3://crabby-images/c924c/c924cfbfabae65e88b543f10d2e7dffce4b078f6" alt=""
data:image/s3,"s3://crabby-images/40f37/40f37ddae59b242f6d12a6ed5e504e9c92c6fb92" alt=""
- Now, passing id_rsa_hashed to John The Ripper the password superpassword is discovered just in seconds:
data:image/s3,"s3://crabby-images/9d579/9d579ee146bdbd3686705de111ebd7306be8c35c" alt=""
- Giving reading and writing permissions to the owner for id_rsa:
data:image/s3,"s3://crabby-images/26a16/26a1601bec9e353cbac4045d25f5d6de40f72fd3" alt=""
3.4 - Getting a remote shell
- We already know from before that there is an user called takis:
data:image/s3,"s3://crabby-images/f1454/f1454c5f18ef6fed1583ead74b305a435b5fd0ea" alt=""
- Connecting to Tenten with SSH by providing id_rsa plus password for user takis:
data:image/s3,"s3://crabby-images/70ae4/70ae455bd4207a82abd8a22cdd69337ab86d61e3" alt=""
4 - CAPTURING THE 1st FLAG
- Reading user.txt:
data:image/s3,"s3://crabby-images/b4a47/b4a477abfca1547a4d329b713df0927d83cc0b2d" alt=""
5 - PRIVILEGE ESCALATION
- Privilege Escalation is easy because user takis has got some sudoer privileges:
data:image/s3,"s3://crabby-images/8b668/8b66845e6b86ec5d09a7a53a2cd50952c5ea7fc5" alt=""
- Reading content and searching information about file fuckin:
data:image/s3,"s3://crabby-images/a1226/a12262b3f60369db5be9efba725d2c94fe407760" alt=""
- Running fuckin eventually we get a root shell:
data:image/s3,"s3://crabby-images/c078b/c078b7d410ee0a213f50fdb899f3cb0650d959d8" alt=""
6 - CAPTURING THE 2nd FLAG
- Reading root.txt:
data:image/s3,"s3://crabby-images/cd41a/cd41a2acf4f7839fbfde3ef932e8040ed9b3d03f" alt=""