data:image/s3,"s3://crabby-images/c8cd6/c8cd64340b4f1c921001ebbf2ce3cf2e54bd7b9b" alt=""
Hack The Box – Bank Walkthrough
Introduction
This was an easy Linux machine that involved exploiting a file upload functionality to gain initial access and a binary with the SETUID bit assigned to escalate privileges to root.
Enumeration
The first thing to do is to run a TCP Nmap scan against the 1000 most common ports, and using the following flags:
- -sC to run default scripts
- -sV to enumerate applications versions
data:image/s3,"s3://crabby-images/8df78/8df789fddf3de1584ab2bc4a56321643ed08f87c" alt=""
The scan has revealed three open ports: port 22 (SSH), port 53 (DNS) and 80 (HTTP)
Enumerating HTTP
When navigating to the web server, the default Apache2 web page is displayed:
data:image/s3,"s3://crabby-images/95cda/95cda5303d3d36e36b10f7ea608f61e14e3afe98" alt=""
Since the name of the box is bank, tried adding “bank.htb” to the /etc/hosts file:
data:image/s3,"s3://crabby-images/4b4b3/4b4b397a4e4be6595c5efa2adf5d8d24900f201a" alt=""
A login page is displayed when accessing the bank.htb site:
data:image/s3,"s3://crabby-images/658ed/658eda87c4b668e482027bcb1c3985f3f27696dc" alt=""
The next step is to run a scan to find hidden files or directories using Gobuster, with the following flags:
- dir to specify the scan should be done against directories and files
- -u to specify the target URL
- -w to specify the word list to use
- -x to specify the extensions to enumerate
- -t to specify the number of concurrent threads
data:image/s3,"s3://crabby-images/5bba4/5bba43dfa75257340016b068ff292ad1a157562b" alt=""
The scan has identified a /balance-transfer directory, which when accessed displays a bunch of files:
data:image/s3,"s3://crabby-images/9aab0/9aab0fe0c8b1219149affdc2c6b0b389699d93d6" alt=""
When accessing any of them, they appear to contain encrypted usernames and passwords:
data:image/s3,"s3://crabby-images/1c5e1/1c5e10efc043e98fcb2934d928b54f2181967cc1" alt=""
When sorting the files by size, it looks like one of them is only 257 bytes, whereas all of the other ones are around 580 bytes:
data:image/s3,"s3://crabby-images/ceb31/ceb31a4f3e8be430709b59848c2a96b861411107" alt=""
This file contains clear-text credentials:
data:image/s3,"s3://crabby-images/f3443/f3443a36b22b4e96cc2ffd61236c8c86a1cfddd1" alt=""
Authenticating into the web application with the credentials found above:
data:image/s3,"s3://crabby-images/546fb/546fb3533dda197f5f09d034210a336a27e6f8d9" alt=""
data:image/s3,"s3://crabby-images/419d0/419d030d19d97c4057111359da2f7c2c95db371f" alt=""
Navigating to the support page shows what looks like a list of tickets (which is currently empty) and a functionality to submit tickets, that currently allows to attach files:
data:image/s3,"s3://crabby-images/d628c/d628c58895bae44bdadfdd4d2c8aa4ab02bd263c" alt=""
Copying the Laudanum PHP Reverse Shell to the current working directory:
data:image/s3,"s3://crabby-images/025d7/025d7a72d4217ba0646c187777a0e5a08f2da4d4" alt=""
Changing the IP address and port accordingly:
data:image/s3,"s3://crabby-images/a358f/a358f642105eff5b773b545fab5b83898c8e78dd" alt=""
Logging a support request and attaching the PHP reverse shell:
data:image/s3,"s3://crabby-images/944c1/944c1e14e68acc5ef7ee8e92d264d7622efebd81" alt=""
It looks like the site does not allow PHP files to be uploaded:
data:image/s3,"s3://crabby-images/89f58/89f580362498fd975c44326cf7fb29536c139c56" alt=""
When inspecting the source code, noticed a comment mentioning how .htb extension files can be used for PHP code execution:
data:image/s3,"s3://crabby-images/a3a8f/a3a8f682718c1909786f511af5311269b0a0d47a" alt=""
Renaming the file to have the .htb extension accordingly:
data:image/s3,"s3://crabby-images/8b69e/8b69e7fcdf3bf73331a44de954b41be25e03a9c0" alt=""
Re-uploading the PHP reverse shell with the .htb extension:
data:image/s3,"s3://crabby-images/3e1ce/3e1ce606b3ebe552ecd3719d034e21343ef16f9b" alt=""
This time, the reverse shell was successfully uploaded:
data:image/s3,"s3://crabby-images/225f3/225f3a8ca32f7f6df478827d8d8936c88d8c2748" alt=""
The next step is to set up a Netcat listener, which will catch the reverse shell when it is executed by the victim host, using the following flags:
- -l to listen for incoming connections
- -v for verbose output
- -n to skip the DNS lookup
- -p to specify the port to listen on
data:image/s3,"s3://crabby-images/6b649/6b649e60ac2456b9b595b80b433811976891ced5" alt=""
Since Gobuster found an /uploads folder earlier, the assumption is that this is being used to store uploaded files, navigating to the PHP reverse shell to execute it:
data:image/s3,"s3://crabby-images/71ac5/71ac575a30b09ed45e226578d62fda73fb47b41e" alt=""
A callback was received on the Netcat listener, granting a shell as the www-data user:
data:image/s3,"s3://crabby-images/8c615/8c61574a8aebe12c520e0decf8b9a2842de633b5" alt=""
The following steps can be done to obtain an interactive shell:
- Running “python -c ‘import pty; pty.spawn(“/bin/sh”)’” on the victim host
- Hitting CTRL+Z to background the process and go back to the local host
- Running “stty raw -echo” on the local host
- Hitting “fg + ENTER” to go back to the reverse shell
- export TERM=XTERM
data:image/s3,"s3://crabby-images/5c646/5c6467894cd429773716a3ff7ef64df41dbc84ab" alt=""
Privilege Escalation
Running the following command to identify and binaries with the SETUID and SETGID bit set:
find / -perm -u=s -type f 2>/dev/null; find / -perm -4000 -o- -perm -2000 -o- -perm -6000
data:image/s3,"s3://crabby-images/4db37/4db37fe71a60183eeef0a415dae414a7953724cb" alt=""
There appears to be an unusual “/var/htb/bin/emergency” binary with the SUID bit assigned. When executing it, a Bash shell is returned:
data:image/s3,"s3://crabby-images/82223/8222379bf39ed86a0bd063c4270e4a7e2eadc51e" alt=""
This has provided root-level access to the machine.
Conclusion
This box was quite CTF-like and not very realistic, apart from the file upload exploitation part. Nonetheless it was still a pretty fun challenge.