Description
What happens when a group of broke Computer Science students try to make a password manager?
Obviously a perfect commercial success!
Enumeration
Nmap Scan
|
|
|
|
Dirbuster Scan
data:image/s3,"s3://crabby-images/51abe/51abeced83d1b101e0b2c957ce3ced62c4375c47" alt="Administrator Page found!"
Looks like there is a route to http://10.10.88.227/admin.html
.
Inspecting the sources (login.js
), we can see the vulnerable code block:
data:image/s3,"s3://crabby-images/3ac4a/3ac4ab3f7da4f791dcd17a0572f3d0c65bac2c6a" alt="Look at the `else` block"
The if-else
blocks only checks for “Incorrect Credentials” in the POST response, we could probably modify the response via Burpsuite to force a creation of a SessionToken
cookie (or manually create 1 ourselves).
Burpsuite Intercept
data:image/s3,"s3://crabby-images/9a093/9a0938c50e22ba4448c10aad733fe3a88e9bb77e" alt="Modify Burpsuite Response"
Intercepting the traffic, we can get the Response to this request
in the ui:
data:image/s3,"s3://crabby-images/51351/51351e65986cc1c09f25d73c9649dde4bed23348" alt="Response to this request"
Forwarding the traffic, we can see the modified response
data:image/s3,"s3://crabby-images/417e1/417e1a4b08e7e57dfc175dc76bdb920b5d8b4949" alt="Modified Request"
We can then try to refresh the page in Burpsuite’s Browser and find that we are logged in!
data:image/s3,"s3://crabby-images/40932/409323306e97aea5fde1b9586b052883e8cc8247" alt="Successful Login!"
We can see that a SessionToken
cookie is created in the browser
Looks like an SSH RSA Private Key. We might be able to use this to access the server?
SSH
Trying this:
|
|
I get the following response:
data:image/s3,"s3://crabby-images/aea93/aea9341bf17dabd16ea41438d3b645ab4a89cac3" alt="SSH Requires a passphrase"
Cracking the SSH key passphrase
I first used ssh2john
to convert it to a key hash:
|
|
Removing the rsa.key:
from the hash, and using hashcat to identify the id of the hash to crack:
data:image/s3,"s3://crabby-images/92a79/92a7935c3f15b6f6e4e295505753d4bae3c43e84" alt="Hash Generation and Identification"
I then use hashcat
to crack the hash with the rockyou
wordlist:
|
|
data:image/s3,"s3://crabby-images/bf85b/bf85bb65ccb31bf5e66aeb9055ea7551ff8c11e4" alt="Cracked Key!"
Passphrase: james13
Login attempt
Using the same command, I tried to SSH into the machine with the key and passphrase:
data:image/s3,"s3://crabby-images/b4bfb/b4bfbba7c6f748da007dd23168b8df9b38dc6e9d" alt="Successful Login with the passphrase!"
We got the user flag:
|
|
Privilege Escalation
Using Linpeas, we can find possible routes to privilige escalation. Following this tutorial, I started a webserver in the host machine and curl-ed the script in the victim machine:
|
|
Crontab
data:image/s3,"s3://crabby-images/574b1/574b108bec9028ff1dbee87c4b5a8fb29f4dc7d9" alt="Crontab"
Looks like the final line in the crontab runs as root
, getting a bash script from a particular server and executing it
Hosts File
data:image/s3,"s3://crabby-images/1b6b8/1b6b8be85eae0f05c205e394ab461ec0fabf9043" alt="Host File"
The hosts file seems to be writable by everyone. Looks like I could modify the overpass.thm
in the hosts file to do a callback to the host machine to run a malicious callback script.
Escalation Process
We first created the necessary directories and buildscript.sh
file:
|
|
and also started 2 servers:
|
|
It doesn’t seem like the Python3 server works, so I used python2 with SimpleHTTPServer
instead.. (More info later)
The script used was a bash reverse shell
, folloing the tutorial here, I created the file with this as the content:
|
|
In the Victim Machine, I modified the hosts file
|
|
data:image/s3,"s3://crabby-images/f50f9/f50f95836bf973bcf496507f7af2b898c8b36059" alt="Modifed Hosts file in victim machine"
And then we wait.. The script will be executed after the request from crontab.
data:image/s3,"s3://crabby-images/ba0a3/ba0a3eb93a5676fc358050b25019c87717bd8837" alt="Python3 doesn't seem to work"
After a few seconds, we get a reverse shell running as root! We can get the root flag from the current directory:
data:image/s3,"s3://crabby-images/3593d/3593d9e6e2641589874cc9a8b538b8746173e645" alt="Root Flag!"
We can see that we are root, the root.txt
flag is in the directory and we can get the root flag!