NETMON
- Layout for this exercise:
data:image/s3,"s3://crabby-images/c6074/c6074c4b12959881aaf072bd5a9a597a01ea8c6e" alt=""
1 - INTRODUCTION
- The goal of this exercise is to develop a hacking process for the vulnerable machine Netmon, what is a machine from the Hack the Box pentesting platform:
https://www.hackthebox.eu
2 - ENUMERATION
2.1 - Scanning ports
- The IP for Netmon is 10.10.10.152:
- Scanning ports with Nmap:
data:image/s3,"s3://crabby-images/3504e/3504ee9717fe89bc4d6905352003f932d48bbc20" alt=""
- Going deeper with port 21 we find Anonymous login FTP:
data:image/s3,"s3://crabby-images/70b55/70b555d3b8a286b61c89f9369aa00de095168fd2" alt=""
- Going deeper with port 80 we find PRTG Network Monitor (NETMON):
data:image/s3,"s3://crabby-images/56ea6/56ea6fe072d61d5eaaad0fb57f74e9577ff98a22" alt=""
- PRTG Network Monitor (Paessler Router Traffic Grapher) is an agentless network monitoring software from Paessler AG.
- It can monitor and classify system conditions like bandwidth usage or uptime and collect statistics from miscellaneous hosts as switches, routers, servers and other devices and applications.
https://en.wikipedia.org/wiki/PRTG_Network_Monitor
2.2 - FTP enumeration
- Let's use the Anonymous login FTP:
data:image/s3,"s3://crabby-images/7f29c/7f29c83956fe8c6521f8bdeea9556d5fd47c4258" alt=""
- The 1st flag user.txt is publicily available:
data:image/s3,"s3://crabby-images/1a16a/1a16a6308a76a547878db45ac7093a97c3842be7" alt=""
- Looking for online information about where PRTG stores information:
https://kb.paessler.com/en/topic/463-how-and-where-does-prtg-store-its-data
data:image/s3,"s3://crabby-images/eca6b/eca6bc6734c121e5742d2e63593111440cf7b256" alt=""
- Going to ProgramData\Paessler\PRTG Network Monitor:
data:image/s3,"s3://crabby-images/6263a/6263ad8d861ba041e77f3135878c931cd75128bb" alt=""
data:image/s3,"s3://crabby-images/f73e9/f73e9a77650a4b6472c88fa039427a5a1a63bf93" alt=""
data:image/s3,"s3://crabby-images/b7584/b7584f9278fdbe41da876efe0b3299ddef6788b1" alt=""
- There is a backup from an old configurarion file:
data:image/s3,"s3://crabby-images/74d5c/74d5c5086d4039fd65f0f1d0d34d979066e150e5" alt=""
- Downloading to Kali the PRTG Configuration.old.bak:
data:image/s3,"s3://crabby-images/19f1a/19f1a104048bf2f49350c41a6974240d7b4608e7" alt=""
data:image/s3,"s3://crabby-images/4fb17/4fb17696e707918328f8faf6184b42c336e97e2c" alt=""
3 - GETTING CREDENTIALS FROM BACKUP CONFIGURATION FILE
- Reading the backup file we find interesting credentials prtgadmin:PrTg@dmin2018:
data:image/s3,"s3://crabby-images/db239/db239a338d7f877d9082c44fd7f34fd1846b08e8" alt=""
..................................................................
data:image/s3,"s3://crabby-images/c7179/c717937c7b61e4d7cadc133c0613ff86ef9db07c" alt=""
...................................................................
- Let's use these credentials to access the PRTG administration console:
- Browsing to port 80 when entering prtgadmin:PrTg@dmin2018 the authentication fails:
data:image/s3,"s3://crabby-images/a53cd/a53cdff5a9b16e1ac5879f76dc2329b59139c15b" alt=""
data:image/s3,"s3://crabby-images/cbc79/cbc79ffacfaae51827ef4a3e708fc0424d80aceb" alt=""
- Maybe because we are in 2019 instead of 2018? Yes, changing to prtgadmin:PrTg@dmin2019 the authentication works:
data:image/s3,"s3://crabby-images/e823a/e823a6b598f8284b3cce0586de00fc8117bc2fe5" alt=""
4 - EXPLOITING THE PRTG NETWORK MONITOR
- It seems that the installed version is 18.1.37:
data:image/s3,"s3://crabby-images/3047c/3047ca5a282bb018d197a8306b5bd7ebfeb061ed" alt=""
- There is an exploit associated with PRTG Network Monitor 18.2.38 because this version is vulnerable to Remote Code Execution, maybe it can be useful for our purposes:
https://www.exploit-db.com/exploits/46527
data:image/s3,"s3://crabby-images/2464d/2464d9fdcce595efeb9c198e6697656fcc93f7c1" alt=""
- The directions about how to use the exploit are clear:
data:image/s3,"s3://crabby-images/4bf5b/4bf5b1b1b8d0832f0bfc2bcab4284b8b6394835e" alt=""
- Before starting the attack let's copy locally the exploit, and also give it execution permissions:
data:image/s3,"s3://crabby-images/2c933/2c9339845204c82e57d3b8f04c36112ff3cbe38b" alt=""
data:image/s3,"s3://crabby-images/574ee/574eec5da67da5b06dd00f280f43a95038df0e86" alt=""
- Running without options we learn how to use the exploit:
data:image/s3,"s3://crabby-images/a6527/a6527fd05c955e362ad9a01de7527138ba37c70d" alt=""
data:image/s3,"s3://crabby-images/049d6/049d62dc1db5639aeaa429ad79f853ae2251c00d" alt=""
data:image/s3,"s3://crabby-images/21b70/21b70f86ddb3c3ff46d3005ef41543e4b464ca8a" alt=""
- So according with the instructions first of all we need to authenticate with previously discovered credentials prtgadmin:PrTg@dmin2019 and grab the authentication cookie, for instance intercepting with Burp:
data:image/s3,"s3://crabby-images/a0434/a043482f85d3ba00e234dd9214a1b45c19b8db61" alt=""
data:image/s3,"s3://crabby-images/ffe12/ffe123ad9199914bb2aee917a831478d4d68fee5" alt=""
data:image/s3,"s3://crabby-images/c7714/c7714e0e404436dc5060b11dbb763882ed395688" alt=""
- Inserting the authentication cookie as an option for the exploit:
data:image/s3,"s3://crabby-images/dbc6b/dbc6bb04632313543998f581da26eff7f687f049" alt=""
data:image/s3,"s3://crabby-images/5708a/5708a1d168e7be90a7123b96d4054b7d338e4d99" alt=""
- Finally, a user pentest is successfully created with password P3nT3st! and added to the Admnistrators group.
5 - GETTING A REMOTE SHELL
- Once we have the credentials pentest:P3nT3st! we can achieve a remote shell with the script psexec.py:
data:image/s3,"s3://crabby-images/3722b/3722b0ff7f419c1e19462edc3bfb1634cd09cc83" alt=""
- As expected, the shell has full privileges:
data:image/s3,"s3://crabby-images/94144/94144b7ac1223f702b2cc592ca7c541a28c7c1c2" alt=""
6 - CAPTURING THE 1st FLAG
- Reading user.txt:
data:image/s3,"s3://crabby-images/d4e2a/d4e2a6e6625e472a8ee4146669ec60e3215a6c73" alt=""
7 - CAPTURING THE 2nd FLAG
- Reading root.txt:
data:image/s3,"s3://crabby-images/bd7d6/bd7d6139cc2edad120e958cbd9a8dbbb65804334" alt=""