VULNIX
- Layout for this exercise:
data:image/s3,"s3://crabby-images/202ec/202ecd7e123ddbb989c37ade2413aa63af5b04ce" alt=""
1 - INTRODUCTION
- The goal of this exercise is to develop a hacking process for the vulnerable machine Vulnix.
- According to Vulnix's author there is a trophy hidden into the /root folder.
- Vulnix can be downloaded from here:
https://www.vulnhub.com/entry/hacklab-vulnix,48/
- Once downloaded and extracted with VMware:
data:image/s3,"s3://crabby-images/7ec09/7ec090cb6964b813605234286a8726a97b7f17df" alt=""
2 - ENUMERATION
- Using netdiscover to find the vulnerable machine's IP:
data:image/s3,"s3://crabby-images/d55d8/d55d8623c5e4dadca6989080d2f96f2c83585a3a" alt=""
data:image/s3,"s3://crabby-images/758c0/758c083aee9ce74734dbdfde3d0fad0ed6e0be06" alt=""
- Scanning with Nmap we find that there are a lot of open services available:
data:image/s3,"s3://crabby-images/6232c/6232cfec75bc26398d27620288cd8a45c7970dee" alt=""
2.1 - Enumerating rpcbind
- rpcbind maps RPC services to the ports on which they listen, redirecting a client to the proper port number so it can communicate with the requested service.
- rpcinfo with option -p tells that there is an NFS (Network File System) server running on Vulnix at port 2049:
data:image/s3,"s3://crabby-images/35880/358805afcba632b9d8d571f4cbb60d66050660f0" alt=""
data:image/s3,"s3://crabby-images/d4793/d479367a92b87eb21000b79b4ec29ca726727ecb" alt=""
2.2 - Enumerating NFS
- The NFS protocol is developed for sharing files an folders between systems, so a local file system is mounted over a network and remote hosts can interact as if they are mounted locally on the same system.
- showmount shows mount information for the NFS server, with option -e for the export list:
data:image/s3,"s3://crabby-images/b4249/b4249ee4bc4e8b0d641ccaa60593a06127e08c25" alt=""
- So the NFS service is available to share files located at /home/vulnix, what can be accessed from any host.
- Bye the way, we also learn the existence of a user called vulnix.
2.3 - Enumerating SMTP
- Trying to find some info using Metasploit against the SMTP server:
data:image/s3,"s3://crabby-images/601f3/601f3243e1b2dcba4c54aa2f5db4c427b42a0119" alt=""
- Same thing with telnet:
data:image/s3,"s3://crabby-images/d5b95/d5b9559ae698acc0b72844dbd05a36260a5d1ff5" alt=""
2.4 - Enumerating finger
- At port 79 the service finger gives information about the users, for instance:
data:image/s3,"s3://crabby-images/3c77a/3c77a6879a5ad024556e69a764efd30f7c02a76a" alt=""
data:image/s3,"s3://crabby-images/31a2d/31a2dc8cc0c00b7782e2ca69a5a1eb20587b60de" alt=""
data:image/s3,"s3://crabby-images/452ab/452aba0b8515e6f3a7e1c63e1088bfc3520971ff" alt=""
- Let's notice that all users have got /bin/bash as default shell.
3 - EXPLOITATION
3.1 - Low privilege shell with SSH
- Let's launch Hydra against the SSH service with a lists of users and the wordlist rockyou.txt for passwords:
data:image/s3,"s3://crabby-images/28671/28671303c7052b2ce8d3da7b20ba926995235fab" alt=""
data:image/s3,"s3://crabby-images/7c0ee/7c0eedaccd4a74404344bcde3011ce4568383e77" alt=""
data:image/s3,"s3://crabby-images/af29c/af29cd24ed03283b6c5cfa375da95b54efa5dc29" alt=""
- Now, we can successfully log into Vulnix using the credentials user:letmein
data:image/s3,"s3://crabby-images/ea56c/ea56c922bc25e6d0e7f856c27b0e58ae541e0e4d" alt=""
data:image/s3,"s3://crabby-images/c2549/c2549608e63d84b639dca620d6c3898073ed31a2" alt=""
data:image/s3,"s3://crabby-images/3cead/3cead19aaa334d077ba2860896dea7d9b307ae72" alt=""
data:image/s3,"s3://crabby-images/49d06/49d06de5fce53ba75d041f1ef02bbd8e17e942cc" alt=""
- However this is a low privilege shell and we cannot access the vulnix home shared folder:
data:image/s3,"s3://crabby-images/94ad3/94ad3a571aaf8689134579d82125b09d789f7a56" alt=""
- Neither user is a sudoer:
data:image/s3,"s3://crabby-images/04aeb/04aebd7883a3069b14efdf844e931e74ed303d1c" alt=""
3.2 - User vulnix
- Let's find more info about the user vulnix, for instance his UID is 2008:
data:image/s3,"s3://crabby-images/e88dc/e88dce760b9e4fe9e38f0d7e2f4650898002528b" alt=""
- Now, let's mount at our local machine /mnt/vulnix the remote /home/vulnix:
data:image/s3,"s3://crabby-images/2f205/2f2053dd946419020cdb75a78a2f1f996cb97064" alt=""
- Also, at Kali let's create a new user called vulnix with the same UID 2008 than the remote one:
data:image/s3,"s3://crabby-images/32930/3293076098e347c2abe18a86c183c0efb81ef3cc" alt=""
- Moreover, let's generate a public/private RSA key pair, with the future goal of trying to log in with SSH into the Vulnix vulnerable machine as the user vulnix:
data:image/s3,"s3://crabby-images/45c10/45c108251b0761f1ef7a6caf335cd5173ca353f2" alt=""
- Let's notice that the public key has been saved to /root/.ssh/id_rsa.pub
data:image/s3,"s3://crabby-images/33a6d/33a6d931b71041bf181c1f1831c18a14d1b2773f" alt=""
- Copying the newly created public key id_rsa.pub to the remote /tmp folder:
data:image/s3,"s3://crabby-images/d99eb/d99eb532c4e20c09b6e86c97516ab179a5d47fc2" alt=""
- Assigning ownership of the key to user vulnix:
data:image/s3,"s3://crabby-images/e3114/e3114f769e170be3ea49bd274b0fb246f1f56ac6" alt=""
- Creating a new folder .ssh at the remote machine:
data:image/s3,"s3://crabby-images/f491f/f491f849a2167fd9a64f11adffa7a557d07c2738" alt=""
- Exporting content of the key to the authorized_keys file, which specifies the SSH keys that can be used for logging into the user account for which the file is configured, vulnix in our case:
data:image/s3,"s3://crabby-images/cf013/cf0138632399e02d91289fc7cf23fd4419037909" alt=""
- Now, we can log into Vulnix as user vulnix without a password, because we have inserted as authorized his public key:
data:image/s3,"s3://crabby-images/27eba/27eba3ce71073e94c6e310412fafd82dce8024a5" alt=""
data:image/s3,"s3://crabby-images/db280/db280ffd036c4fc2e22b87554c3408eafe8c0b8f" alt=""
4 - PRIVILEGE ESCALATION
4.1 - no_root_squash
- Let's start our Privilege Escalation process by checking what are vulnix user's sudoer permissions:
data:image/s3,"s3://crabby-images/74beb/74bebbf7f513d905202e0e6c7ab98828c7ec99ee" alt=""
- It seems that vulnix can run the command sudoedit /etc/exports as a root without using any password.
- Checking /etc/exports we notice that /home/vulnix is assigned with root_squash, meaning that the client cannot run commands as root at the remote server when using the NFS services:
data:image/s3,"s3://crabby-images/53043/53043902465bfab226a410c91af0f1f02b9867c5" alt=""
- However, because user vulnix has got /etc/exports "sudoediting" privileges this can easily be changed to no_root_squash:
data:image/s3,"s3://crabby-images/a9f32/a9f32a7406a64a3127734e8d34e69c997597e4e9" alt=""
data:image/s3,"s3://crabby-images/f5290/f52901be574c568a805be31ce04dcf4ba78e6d6e" alt=""
- Now, to make theses changes effective a reboot of Vulnix is needed so that NFS services restart, let's do it manually:
data:image/s3,"s3://crabby-images/9fa03/9fa0349bf34857be07b16cecb6907f31df2b8a7c" alt=""
4.2 - Creating a root_shell
- Mounting again the shared folder:
data:image/s3,"s3://crabby-images/e73e5/e73e514c4fdd937379400cd1af8a9762a634fa19" alt=""
- SSH-ing again at vulnix:
data:image/s3,"s3://crabby-images/3e7ab/3e7ab5075e9b9c94a24c3f0e3842c3b1b3742b16" alt=""
- At the remote machine, copying his local bash to a new file victim_shell:
data:image/s3,"s3://crabby-images/3c3ee/3c3eea66976e6e48e185a62852dcf93f4027e14c" alt=""
- We immediately have it shared at the local machine:
data:image/s3,"s3://crabby-images/34058/340587b28809ce48b56dc9463412379aea035e50" alt=""
- As expected, victim_shell has got only vulnix user's permissions:
data:image/s3,"s3://crabby-images/01f0e/01f0e4af7a5ca680d67d565aca6e04c51caf8786" alt=""
- Copying content to a new file root_shell:
data:image/s3,"s3://crabby-images/de2b8/de2b8572597ba59d68d0a6a80170acd12a7aaefe" alt=""
- Setting root privileges for root_shell:
data:image/s3,"s3://crabby-images/b28ee/b28ee978e6780cf30b26af98e32c35792c642d4a" alt=""
- Comparing permissions for both shells:
data:image/s3,"s3://crabby-images/2347f/2347f374d90e59f7f6409b66bce14f4186dfb004" alt=""
data:image/s3,"s3://crabby-images/348bc/348bc272f2ee17a7945bb68b45752648af9f7a3d" alt=""
- Executing root_shell with option -p (ensures that the original file's permissions and credentials are kept) we eventually get a root shell available at the vulnerable machine Vulnix:
data:image/s3,"s3://crabby-images/75be2/75be255d3046913387c47bc316099ec6ce669471" alt=""
data:image/s3,"s3://crabby-images/68ee8/68ee8a5e66ae32a27d6dc908640783617d35d4d9" alt=""
5 - CAPTURING THE FLAG
- Going to the root folder we find the trophy:
data:image/s3,"s3://crabby-images/72f42/72f42b25fbe0274d4ddb231a92876e9f920a2d85" alt=""