This is a retired Linux machine rated as Easy in HackTheBox.
Although the machine is tagged as Easy, the privilege escalation vectors found in the machine is a great way to be exposed to common and application-specific vulnerabilities and exploitation.
We are given a web application located in soccer.htb.
By using gobuster, we can find /tiny as a valid URL path
|
|
Navigating through /tiny, we can find that the running application in the endpoint is Tiny File Manager with version 2.4.3
Searching in Google tells us that default credentials for Tiny File Manager is admin/admin@123.
This could be of use in the future.
Since we have the version number of our running application (2.4.3), we can search for common exploits in ExploitDB using the command
|
|
When we do so, we can find an exploit for version 2.4.6.
Checking the .sh file we see that the CVE is CVE-2021-40964, and on NVD - CVE-2021-40964 (nist.gov), we see that the exploit in question involves versions under 2.4.6 as well. This means that 2.4.3 potentially vulnerable to this exploit as well:
When running the script, an error occurs with a function name on Line 46.
Renaming “log-in” to “login” in the file fixes it.
When attempting to upload a webshell using the exploit, an error occurs indicating that we are unable to upload it to /var/www/html.
As a result, we can attempt to upload it to /tiny/uploads. This will provide us with a command shell using a one-liner PHP shell (code below).
|
|
I created a meterpreter_ _shell for persistence and better session handling. With the meterpreter shell, I uploaded it to /var/tmp (a directory which commonly has read and write permissions for all users) and ran it using the webshell and we get a local shell.
Checking /etc/passwd, we find that there are users in the machine named player and laurel.
While using LinPEAS to search for privilege escalation vectors, we find a vulnerability that affects the Polkit authentication service.
The vulnerability is identified as CVE-2021-3560 and it is known to allow attackers to gain elevated privileges on a Linux system.
However, since this is a Buffer Under-read Vulnerability, there is a high chance that it may lead to a system crash or similar issues. As such, it may be best to hold this path as a last resort.
While checking the output of our LinPEAS scan, we find another potential web application hosted on the machine called soc-player.soccer.htb:
After adding the domain to our /etc/hosts file, we can visit the site using a web browser.
The site looks similar to soccer.htb albeit with new features as shown in the Dashboard below:
Doing some random input validation checks in form fields, SQL Injection works for the /check endpoint:
As shown below, the webpage is delayed by 3 seconds as dictated by the sleep command in SQL:
Using Burp Suite, we find that these forms use WebSockets instead of a usual POST request to transmit data from our machine to the server (i.e., the target machine).
Using information from this article from rayhan0x01, we can use this modified exploit to exploit the websockets in /check:
|
|
Start by running the middleware server, and afterwards SQLMap:
|
|
After a while we find that it is injectable as time-based Blind (as per our testing earlier)
Let’s try dumping the database:
While waiting for the grueling time-based blind exploitation, SQLMap reached the accounts table:
We find potential credentials that we can use from our SQL Injection
|
|
Tried logging into the found credentials (player:PlayerOftheMatch2022) in SSH and it works:
We got local flag!
As mentioned previously, one possible method for privilege escalation is to exploit the Polkit vulnerability. However, another option has been found in LinPEAS:
It seems that doas is installed. For reference, _doas _was made as an alternative to sudo to resolve complexity in its syntax. Further information can be found in this article. Let’s try using both methods for this machine!
Using various scripts in GitHub, I was not able to exploit CVE-2021-3560 due to gnome-control-center not being installed in the target machine:
Sadly, this method doesn’t seem to be the way to root.
Since player can run dstat as root (as shown below), let’s see if we can find a way to exploit this functionality.
dstat seems to be a Python script, which is easy root if we could edit it but unfortunately, we do not have write permissions on dstat:
Given these, we could try to find a separate way to exploit our permissions to dstat.
From this article, it seems we can create a custom plugin which dstat can then execute.
With this knowledge, we can create a malicious Python script as our plugin, which will then run as root.
Following the steps in the article, let’s first find the dstat directory which stores the plugins:
|
|
Fortunately, the location is the same as in the article, which is in /usr/local/share/dstat
where we also have write permissions and the group is set to us, player
Afterwards, create a plugin file with template name <dstat_xxx>, for my purposes I used _dstat_exploit.py. _Then afterwards, ran the plugin using —exploit:
And we got root!
Transferred my public key then so that I could SSH, and we got the root flag: