Vulnhub: INFOSEC PREP: OSCP [by dollarboysushil]
data:image/s3,"s3://crabby-images/0dbe5/0dbe5f32eda318ee7297801678778505fa438b3c" alt=""
Link to Vulnhub: https://www.vulnhub.com/entry/infosec-prep-oscp,508/
This is very easy vulnhub machine if you have solved couple of easy levels before.
Difficulty:
Beginner/Intermediate
Goal:
Read flag from /
Victim IP: 192.168.1.132
Attacker IP (Kali Linux): 192.168.1.128
data:image/s3,"s3://crabby-images/dde6a/dde6a128d1112fdd4fee748b2c5999ea938d3c70" alt=""
Reconnaissance
data:image/s3,"s3://crabby-images/568e4/568e4a2812c619679e4f2678dbb92bc168ff6ef8" alt=""
nmap -sC -sV 192.168.1.132
-sC
for default scripts,-sV
for version enumeration and -p-
to scan all ports.
data:image/s3,"s3://crabby-images/dd6ae/dd6ae2492fe093091bff1ebf4e637a7f973be56b" alt=""
Visiting the ip we can see wordpress site, the key thing to notice from the wordpress site is: The only user on this box is “oscp”
The first thing whenever I see a website running is to check the page source and let gobuster run.
I didn’t found anything on page source. While the gobuster was running I usually check for /robots.txt
Enumeration
data:image/s3,"s3://crabby-images/ef5fd/ef5fd8656ae973fa3fd08883400c4bdc21d291b6" alt=""
Under /robots.txt
we have /secret.txt
disallowed
data:image/s3,"s3://crabby-images/d3bab/d3bab7130913958405dfb25e652470462fe9a4ff" alt=""
Visiting the /secret.txt
we have some kind of encrypted text, looking at the == at list, I can assume this is base64 encoded
data:image/s3,"s3://crabby-images/54950/54950990d0dd224dc60b5f645def3c86bfbbfd2f" alt=""
Using cyberchef we can decode this string.
The decoded string is rsa key for ssh login.
data:image/s3,"s3://crabby-images/c37ab/c37ab2dd71bc9f70b4e2c10a310f3b4c6daf2698" alt=""
Save this rsa file.
data:image/s3,"s3://crabby-images/0047c/0047c95d78bda45411eb8cf242c8dfa83dce8481" alt=""
the command chmod 600
makes a file readable and writable only by its owner, with no permissions for the group or others, this permission is required for rsa file.
Previously we saw there was only 1 user which is oscp
and we have rsa key. So lets try to login.
data:image/s3,"s3://crabby-images/b8e4b/b8e4b9746f2ceb4bf710171f39803ddc50dcf344" alt=""
And we are successfully logged in as user oscp.
Privilege Escalation
For privilege escalation I usually choose linpeas script.
Before using script I usually check for suid permission set files , cron jobs etc.
data:image/s3,"s3://crabby-images/ef253/ef2538823f9c7ab0198818228e65e1a65704d08a" alt=""
Then I ran find / -type f -perm /4000 2>/dev/null
to list all suid set files
find
: The command used to search for files and directories./
: The starting directory for the search (root directory).-type f
: Specifies that the search is for regular files only.-perm /4000
: Specifies that the files should have the SUID bit set (permission 4000).2>/dev/null
: Redirects standard error (file descriptor 2) to/dev/null
, suppressing error messages.
Looking at the result we can see we can see bash has suid permission, which is unusual.
data:image/s3,"s3://crabby-images/80fb0/80fb076119c879c4d90781e12984866da0eadef9" alt=""
Using GTFOBins we can elevate privelege
data:image/s3,"s3://crabby-images/17784/17784fd0fb2c07249a837872222db84adbd097d2" alt=""
/usr/bin/bash -p
Running /usr/bin/bash -p
will start an interactive Bash shell in privileged (restricted) mode. The -p
option stands for "privileged”.
data:image/s3,"s3://crabby-images/95081/950819a330dae0cceaf41d342ee16520891dbe83" alt=""
Now we can read the flag present in root directory.
d73b04b0e696b0945283defa3eee4538
For any correction / query /suggestion contact on
Instagram dollarboysushil
Twitter (X) dollarboysushil
Youtube dollarboysushil