Foothold
First, let's scan the ip address.
data:image/s3,"s3://crabby-images/f275c/f275c8290f35ec5cf8fb0a1ca6e7feb2a58b058a" alt=""
nmap -A -T5 -sC -p19-65000 10.10.10.199
And so, as we see, scanning with nmap showed us that the operating system is OpenBSD installed on the machine.Also i added openkeys.htb at my /etc/hosts file. Now it's worth checking the web server
data:image/s3,"s3://crabby-images/429dd/429dd965389b7e3125417ae20af55573fff697ae" alt=""
vim /etc/hosts
I wonder if this is the login page.
data:image/s3,"s3://crabby-images/b61f5/b61f59b38b9df12352ff1d7229486f1d4006316b" alt=""
User
First, I'll run ffuf to find interesting files or directories and while ffuf is fuzzing the web page, I will proceed to study the login page with burp suite.
ffuf -u http://openkeys.htb/FUZZ -w /usr/share/wordlists/dirb/big.txt -e .txt,.html,.php -c
data:image/s3,"s3://crabby-images/41caa/41caa3d84b5a69eddbedaa9067ccad3523c599fd" alt=""
As you can see, the post request is quite simple and we can try using hydra to brute force credentials, but I think this is not our way. Now I think we need to take a look at what ffuf found
data:image/s3,"s3://crabby-images/b36e9/b36e93d0b49fa0f41b0ebf26da2482f84b0c0ff2" alt=""
I think we should check the includes web directory
data:image/s3,"s3://crabby-images/701a5/701a523ceee8bc2fc05d88d930d5688021bff5fe" alt=""
In the includes directory I found auth.php and auth.php.swp. In order to restore the contents of the auth.php file, I will use the auth.php.swp file
wget http://openkeys.htb/includes/auth.php.swp && vim -r auth.php.swp
Just click enter and we get the auth.php source code
data:image/s3,"s3://crabby-images/4b46b/4b46b76cefed20ced8a0259a207b55ead899a369" alt=""
It looks like the authorization mechanism is related to the file ../auth_helpers/check_auth, so we should download it and study
data:image/s3,"s3://crabby-images/d4cac/d4cac8bad7095181f1db2cf6c455dbf7b73b9eaa" alt=""
curl openkeys.htb/../auth_helpers/check_auth -o check_auth && file check_auth
After I downloaded this file using curl I used the utility file to find out what the file is. File showed me that it was an executable file, but I could not run it. At first I thought it was time for RE, but then I came to the conclusion that RE is a rabbit hole so I need to take a different path. After some time, I came to the conclusion that I need to check these files using the string utility. Using it, in the auth.php.swp file I found a potential username jennifer, and in the check_auth file I found the libc.so.95.1 library
data:image/s3,"s3://crabby-images/ba7bf/ba7bfe5ff50b266637e460392b49decff8b94373" alt=""
Googling I found an article describing and exploiting a vulnerability in the libc library in OpenBSD. It wrote that using -schallenge you can bypass the authentication mechanism. Now let's try to exploit this vulnerability on the login page
data:image/s3,"s3://crabby-images/d3d62/d3d624741b16062f93d273f7439637f417ae8691" alt=""
Now exploiting the vulnerability, I successfully login in web app
data:image/s3,"s3://crabby-images/dfce8/dfce86b6af3d6f565f02e235f11e2c4cbabc9d89" alt=""
"No keys found for user -schallenge". It looks like we need to get the ssh authentication key, but how do we do that if we can only bypass the authentication mechanism if we use the username -schallenge? After some thought, I came to the conclusion to put the username in the cookie with firefox extension Cookie-Editor and I successfully logged in as jennifer and get id_rsa key (the username I got from the auth.php.swp file)
data:image/s3,"s3://crabby-images/31dc7/31dc73680c9c9d9a8c32be389be700ad629cf59c" alt=""
Now connect via ssh
chmod 700 id_rsa
ssh jennifer@openkeys.htb -p 22 -i id_rsa
data:image/s3,"s3://crabby-images/31a43/31a434b6d088109aca7cb50bd9dd0702e78d580f" alt=""
Privilege Escalation
After googling i found exploit for CVE-2019-19520 in github.
data:image/s3,"s3://crabby-images/72932/72932f80a54268e2b19f3ce41b2f130de36f62b6" alt=""
Now I download it from my machine using Curl and SimpleHTTPServer and then run and get root
data:image/s3,"s3://crabby-images/01674/01674c038858b01cef25f9ca9b58b9849f3089f4" alt=""
data:image/s3,"s3://crabby-images/c488d/c488de606a137fd93dacf504c33f77b73b3bc711" alt=""
That's all. Thanks for your attention.