Precious is a live (as of writing) Hack The Box machine labelled easy and released on the 26th of November 2022 is a very basic box to crack having fewer technical requirements than most, with a sound methodology an attacker only needs to use basic Linux core utilities and some experience with poorly explained exploits. It’s also a Linux box worth 20 points.
Walk-through.
We begin scanning the machine using nmap with the flags “-sV” for service enumeration and “-oN quickNmap” to save the output to a file and then the IP address of the target machine which is “10.10.11.189”.
data:image/s3,"s3://crabby-images/e5313/e5313a326e27b4f63272fd11dda4cc97c1c93888" alt=""
Attempting to go to the web sever on port 80 redirects us to http://precious.htb/. Since this doesn’t resolve we’ll need to add the IP and address to the “/etc/hosts” file on your host machine. I’m using neovim to edit the file, use the command “sudo nvim /etc/hosts” to open and add the line to the file.
data:image/s3,"s3://crabby-images/6b4c7/6b4c7259a8b76c4602d8403275fea99d2c90b6f1" alt=""
With that line added we’ll now be able to access the site at http://precious.htb/.
data:image/s3,"s3://crabby-images/3fa93/3fa9322722d5490d11e67fba3a68b0f3971dbdf8" alt=""
Taking a look at the site it converts web pages to a PDF document. We’ll test it out by hosting a python HTTP server using the command “python -m http.sever 9001” then on the website enter “http://<host ip>:9001/” where <host ip> is your hosts IP address.
data:image/s3,"s3://crabby-images/a7944/a79442f07546848e90739fb61c7c193859d3ca92" alt=""
Next, download the PDF document. We are going to analyse the PDF document that was created using exiftool.
data:image/s3,"s3://crabby-images/8ab5b/8ab5b27b2dd0565681451137a5c6e7b64275873d" alt=""
From the output of exiftool we can see that the application was generated by pdfkit version 0.8.6. The first result online for vulnerabilities takes to a GitHub repository named CVE-2022-25765-pdfkit-Exploit-Reverse-Shell which details an exploit that will lead to a reverse shell.
The first step to this exploit is to set up a listener for our shell. Use the command “nc -lnvp 9002” to do this.
data:image/s3,"s3://crabby-images/cfa14/cfa14c07a9b742b1e51819487830bdeb91c292d2" alt=""
Once the listener is up we’ll need to create a file named “?name=%20” and add into that file a ruby reverse shell one liner pointing to our listener
data:image/s3,"s3://crabby-images/f1b52/f1b52f5c793e25f5f0cc686b2d4a0dbb72f6cae7" alt=""
The last part of the setup is to set up a python web server to host the file so that the target can receive it.
data:image/s3,"s3://crabby-images/6e30f/6e30f7e2d619c5826c5f4db6e142dab83606b24e" alt=""
Now to run the exploit. To do this there is a curl command on the GitHub repository where we need to enter a few specific details such as the target URL and local IPs and ports. Pay close attention to which port your listener is and where the web server is.
data:image/s3,"s3://crabby-images/2b965/2b9655cd7f7c8a01c85ab7509119bea46b86b534" alt=""
Once that’s run you’ll have a low privilege reverse shell where you listener was as the user ruby.
data:image/s3,"s3://crabby-images/31bd1/31bd1f323dcf4f3dac32c51f4c62dabb782e4fd5" alt=""
Taking a look in our home directory we can find a .bundle directory which usually contains configuration files. Reading the config file within gets us the credentials to the henry account on the system.
data:image/s3,"s3://crabby-images/11570/11570fbad62c9ed764bfe672331424ea0dc24ff5" alt=""
On the henry account running “sudo -l” to list sudo priviliges we can see that this user can run ruby and “/opt/update_dependencies.rb” Taking an immediate look at the “update_dependencies.rb” script we can see that it just compares what is installed with those specified in “dependencies.yml”
data:image/s3,"s3://crabby-images/05767/05767a418fbbf88fd31afc9cdb0b4d513b6fb610" alt=""
reading the sample dependencies file we can see that it’s using yaml version 0.1.1 and YAML.load to get the dependencies file which is vulnerable to a deserialization attack.
data:image/s3,"s3://crabby-images/0c262/0c26257b48aac938d820185d91123a10a071896d" alt=""
Taking a look at a blog post Blind Remote Code Execution through YAML Deserialization we can see how this attack works. Basically we replace the contents of the target file and replace it with a set script. Once that’s done the “git_set:” option needs to be changed from the example “sleep 600” to “chmod +s /bin/bash” which will set the suid bit to the bash prompt to give us root.
data:image/s3,"s3://crabby-images/be31b/be31ba5dcec29beac81eda19a7896303f52287a7" alt=""
Once the change has been made run “sudo ruby /opt/update_dependencies.rb” then run “/bin/bash -p”
data:image/s3,"s3://crabby-images/59734/5973452a40dfdc3146a65f09fb4b24ba5b75a365" alt=""
ROOT! Now we’ve got root we can read the flag and finish the box.
This was a brilliant introductory machine for getting started with Hack The Box, precious has been my first root on HTB and has will definitely not be the last.