data:image/s3,"s3://crabby-images/dd667/dd667aff3b639687c689fd3d0baddba51bf2c604" alt=""
VulnHub – FristiLeaks 1.3 Walkthrough
Introduction
This was an intermediate box that involved decoding a base64-encoded password to access a file upload page, through which a PHP reverse shell can be uploaded to gain an initial access. From there, a password has to be de-ciphered using ROT13 in order to obtain root access to the machine.
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
- -Pn to skip the host discovery phase, as some hosts will not respond to ping requests
- -oA to save the output in all formats available
data:image/s3,"s3://crabby-images/b1bb9/b1bb92f521d2591abe10ae6a8ced3f082bc7e58c" alt=""
From this initial scan I was only able to find port 80, so I decided to run another scan, using the following flags:
- -p- to scan all ports
- -O to enumerate the operating system
- -A to run all scripts and scan options, it stands for aggressive scan
- -sV to enumerate applications versions
- -oA to save the output in all formats available
data:image/s3,"s3://crabby-images/54fc5/54fc510e08c4cf82fe3867d2d5c91867bc8fa52a" alt=""
Unfortunately this did not find any new ports, that means the next step is to start enumerating port 80.
Enumerating port 80
Having a look at the website hosted on port 80, this is what comes up:
data:image/s3,"s3://crabby-images/dfabe/dfabe8cd93ddc6eedbe866c61d0f68c3f7e7ba13" alt=""
After inspecting the source code of this page, nothing really stands out
data:image/s3,"s3://crabby-images/2f5dd/2f5dd5a991866bb4ebbc522c05296e9d6bfd9f76" alt=""
When inspecting the robots.txt file, which is used to tell search engine crawlers which pages or files they can request from a site, three options can be viewed.
data:image/s3,"s3://crabby-images/cd95d/cd95df047b1ec519ba9370eaaf7a1044a260d805" alt=""
After inspecting all three pages, all that was there was this image:
data:image/s3,"s3://crabby-images/0252e/0252edfae8593fa27cd1a66e188a2bcbe7d1b564" alt=""
Since these entries are all names of drinks, and the site previously mentioned fristi, I tried navigating to the /fristi page, which displayed a login screen
data:image/s3,"s3://crabby-images/731a5/731a555f6f8b5224d5d2a3c814cec94a6557a773" alt=""
When inspecting the source code of this page, there is a comment from a developer which mentions some junk in the page
data:image/s3,"s3://crabby-images/31fc6/31fc67c030d7e066cc2884380347c06ada11e79d" alt=""
After scrolling to the end of the page, a base64-encoded string can be found:
data:image/s3,"s3://crabby-images/1162f/1162f0c0138bec307eb4a6ec933a54777ba3b820" alt=""
Since the site is using base64 to encode image, after replacing the image used in the login page with the base64-encoded comment, a different image now appears.
data:image/s3,"s3://crabby-images/cf659/cf65994b0f47b2c3134c5a84ebdd28967943a879" alt=""
The source code for this page mentioned the name of the developer who built it, so when trying to login with “eezeepz” and the base64-encoded string found in the comment the site grants us access
data:image/s3,"s3://crabby-images/1f587/1f587b2d5e43781b2831d51c5326bcf1975ce78c" alt=""
data:image/s3,"s3://crabby-images/a8320/a8320435eb02d9e89d0f2ead978500aa675b6b0f" alt=""
File Upload Exploitation
When clicking on the “upload file” hyperlink, this takes to a file upload page. This could be used to upload a PHP reverse shell and obtain remote access.
data:image/s3,"s3://crabby-images/aa80c/aa80c9c737e29a65f9f08e34e34779ab0433813a" alt=""
Copying a PHP reverse shell to the working directory and updating the IP address and port based on the local machine
data:image/s3,"s3://crabby-images/10a0a/10a0ab74f07cff45b26c1a6eea2dd77f821abf04" alt=""
Uploading the PHP reverse shell file in the file upload page
data:image/s3,"s3://crabby-images/22563/225638e585820fb6e929579b73a2c5ab624a5686" alt=""
It looks like the site has some sort of protection against certain file extensions or file types
data:image/s3,"s3://crabby-images/bad10/bad109c74ffadd5d97c1b09d82690b3d03fe1fcb" alt=""
As an initial test, changing the file extension and appending .jpg might work
data:image/s3,"s3://crabby-images/1ff09/1ff0962acf8de2eea3f191d427e5d4ce9ad31e4d" alt=""
It appears that this was enough to bypass this restriction
data:image/s3,"s3://crabby-images/6141e/6141e019ee751f426535292336c005a882de840f" alt=""
data:image/s3,"s3://crabby-images/fc8f3/fc8f367025c725ffb615f689be3e64f637263d66" alt=""
The next step is to set up a Netcat listener, which will catch our 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/43e24/43e24b8fa3f2ba43602966dcf87fdfbee5d918d1" alt=""
Navigating to the PHP reverse shell will execute the code and connect to our listener. Navigating to /fristi/uploads/reverse-shell.php.jpg
data:image/s3,"s3://crabby-images/fbe01/fbe011cfe7b43bc7023a3eef94856ecbe897a6f3" alt=""
The victim machine connected to the reverse shell granting remote access
data:image/s3,"s3://crabby-images/57cb9/57cb985fc5323c85b3b2c87d7f197f2a2278ccd8" alt=""
The following steps can be done to obtain an interactive shell:
- Running “python -c ‘import pty; pty.spawn(“/bin/sh”)'” on the victim host
- Hitting CTRL+Z to background the process and go back to our host
- Running “stty raw -echo” on our host
- Hitting “fg + ENTER” to go back to our reverse shell
data:image/s3,"s3://crabby-images/8f6ed/8f6edc39c0928a0f2c6a2d66d26fe6ae90d75841" alt=""
Privilege Escalation
After navigating to /var/www/html, which is the root directory for the web server, what appears to be a MySQL password can be found in checklogin.php, which is used to authenticate users to the site. Unfortunately after examining the database nothing useful was found.
data:image/s3,"s3://crabby-images/34c93/34c93446b290d917926ba13317c081362b6178e4" alt=""
In the home directory of the “eezeepz” user, notes.txt can be found
data:image/s3,"s3://crabby-images/fb537/fb537a93f47310283f317d1e38b1b95e12e45530" alt=""
The file mentions that the current user has access to run certain binaries from the /home/admin directories through a cron job
data:image/s3,"s3://crabby-images/1ee68/1ee6862b7a3e8c9b35317ba2cff9c851cc2f264a" alt=""
To and access the /home/admin directory, a file called “runthis”, containing commands to be executed, can be created in the /tmp directory
data:image/s3,"s3://crabby-images/c69b8/c69b8fa2d17728493703952ba2ce21f9e38a28a6" alt=""
When navigating to /home/admin, a base64-encoded string can be found:
data:image/s3,"s3://crabby-images/217ee/217eefd3858b3de52ddc2fb4073e10c3b9cefa99" alt=""
There is also a python script used to encrypt passwords using rot13:
data:image/s3,"s3://crabby-images/ffeb8/ffeb86166d6aaef72431643007fd2076a5444f84" alt=""
A new python script can be written to perform the same steps in reverse:
data:image/s3,"s3://crabby-images/5f8b1/5f8b1f96d0c9c13b5937318b6c892e6c4fcf5ae4" alt=""
This can be tested against any base64-encoded string:
data:image/s3,"s3://crabby-images/7ea6c/7ea6cd9601df10f65df5453d1bac3066b94334c8" alt=""
After running the script against the encoded string, the password for the fristigod user will be revealed:
data:image/s3,"s3://crabby-images/20c02/20c02929a7f2e27bc1c0180b0299776b9b9e5b8d" alt=""
The su command can then be used to switch to the fristigod user
data:image/s3,"s3://crabby-images/5432d/5432d94e9fc45bc0507d47e09254fd0ecc36a01b" alt=""
After inspecting the files in fristigod’s home directory, something in the bash history stands out. It looks like we can execute commands as root when running the “/var/fristigod/.secret_admin_stuff/doCom” binary
data:image/s3,"s3://crabby-images/b4ef4/b4ef45b7beddb73fabbad17ceee1458f125118d6" alt=""
This can simply be used to run /bin/sh and therefor obtaining a root shell
data:image/s3,"s3://crabby-images/2b6ec/2b6ec5a44c8c0cb0962fbcfd7ae1a5643d8e1641" alt=""
Conclusion
I found this machine very interesting, even though the initial foothold phase was quite trivial, the privilege escalation was multilayered and involved encryption which is something you don’t see very often.