PLUCK: 1
- Layout for this exercise:
data:image/s3,"s3://crabby-images/42c0b/42c0b9c0e27e6768fdf48702f28af577eaaa79c0" alt=""
1 - INTRODUCTION
- The goal of this exercise is to develop a hacking process for the vulnerable machine Pluck.
- Pluck can be downloaded from here:
https://www.vulnhub.com/entry/pluck-1,178/
- Once downloaded, extracted and imported with VirtualBox:
data:image/s3,"s3://crabby-images/2dd5b/2dd5bb3d91f1a58e5182c8b2da3373a73f73993c" alt=""
2 - ENUMERATION
- Using netdiscover let's confirm that the IP is 192.168.1.115:
data:image/s3,"s3://crabby-images/b29cc/b29cc6b3db3cb61ac80d56994f62010bb02e0115" alt=""
- Scanning with nmap:
data:image/s3,"s3://crabby-images/b30a1/b30a1fc8e42d6c83e1da79c51c8d1f4bcb68de08" alt=""
- Browsing the web server:
data:image/s3,"s3://crabby-images/7c613/7c613584ee34d16faa8dd097cb40e78d484f759c" alt=""
- nikto helps discovering a very promising LFI (Local File Inclusion) vulnerability at the web application:
data:image/s3,"s3://crabby-images/05c2e/05c2ec88665a9f9e351b5adba6d25ba63dc21299" alt=""
data:image/s3,"s3://crabby-images/a7a63/a7a638f2008c7957358e6305e465ba64518a42c7" alt=""
- Let's check that LFI works, for instance reading /etc/passwd:
data:image/s3,"s3://crabby-images/abd4d/abd4daeb1a6b8c282f9e91c3a1ba5fe71b1340bd" alt=""
- From /etc/passwd we learn that there are users like bob, peter, paul, backup-user, ..
- Also, reading the last line it seems that there is a script for performing backups::
data:image/s3,"s3://crabby-images/8b03d/8b03d84d6b62805cbaab9460acd1d7c39ffef80d" alt=""
- Taking advantage of the LFI to read the script backup.sh:
data:image/s3,"s3://crabby-images/ecde8/ecde8df5e4d5dc7b6d12b91c91abd998a08942d7" alt=""
- The backup script informs us about three issues:
- backups can be transferred with TFTP
- the compressed backup file is located at /backups/backup.tar
- both folders /home and /var/www/html are usually backup
- Obviously, our next goal must be to download backup.tar
3 - EXPLOITATION
3.1 - Local File Inclusion
3.1 - Local File Inclusion
- Trying to get backup.tar using the browser and taking advantage of the LFI is a little bit messy, due to the hugh size of the file:
- tftp does a better job:
- Also, curl would be a good alternative:
data:image/s3,"s3://crabby-images/5f664/5f6647bf851b44ad72474b0f25ab100c7f1af67a" alt=""
- Opening backup.tar:
data:image/s3,"s3://crabby-images/68b75/68b751d26e0495f8f3eae8dbee2a908b5cd2c208" alt=""
- Now we have Pluck's backup folders available at our Kali machine:
data:image/s3,"s3://crabby-images/dce38/dce38f72d3acfc9cc03b79e023ffeba890105c5e" alt=""
- Searching for information inside bob and peter's home folders, there is nothing out of the ordinary:
data:image/s3,"s3://crabby-images/8c3c4/8c3c4f47e7d31b41dddef9d4aec40f1a3c00483e" alt=""
data:image/s3,"s3://crabby-images/c1f26/c1f265472db2b8555c78965570ee247fb711217d" alt=""
- However we find a collection of 6 private and public keys inside paul's home folder:
data:image/s3,"s3://crabby-images/fad8b/fad8bd00b6b9c237fac4ecfe31895b2b94808cd6" alt=""
data:image/s3,"s3://crabby-images/b0547/b0547c5c411ea941d757fae943c439177c2a68b0" alt=""
- Checking what type of file are these keys, they are valid for SSH connections:
data:image/s3,"s3://crabby-images/de2f4/de2f4f0d2c75ccb25dfd5cfb3293366cc55dce49" alt=""
- Now, we can use these keys with option -i identity_file to establish SSH conections:
data:image/s3,"s3://crabby-images/219e8/219e82a6cfa25da8d80eadee5bbe3db5887e2e03" alt=""
- First attempt with id_key1 is unsuccessful:
data:image/s3,"s3://crabby-images/89f0d/89f0d38d8fccd5f55523606169967612891b6bf8" alt=""
- Same thing with id_key2 and id_key3:
data:image/s3,"s3://crabby-images/5e271/5e271a1464db39ba853de4cbdb68847f33886f76" alt=""
data:image/s3,"s3://crabby-images/6bff5/6bff59f32983042f6ef877d3fb705bc19d313fa2" alt=""
- However, id_key4 leads to a Pdmenu:
data:image/s3,"s3://crabby-images/a13d1/a13d10bce5f00fd2710014adaa81919ce0529951" alt=""
data:image/s3,"s3://crabby-images/2b881/2b881287816b86304bc72844153c56cfb78b0f87" alt=""
- Pdmenu is a simple menu program that displays a menu from which the user can pick programs to run, for instance to edit files:
data:image/s3,"s3://crabby-images/1af6d/1af6d389622a0fb999078781310e0982397cf976" alt=""
3.2 - Limited remote shell with PHP reverse shell
- Now, using the Pdmenu we are going to create remotely a file called myshell.php at /home/paul folder, just buy adapting the well-known PHP script php-reverse-shell.php to our needs:
data:image/s3,"s3://crabby-images/10ca3/10ca3b88d901ed6c43a0258ff07360dbe26b40fc" alt=""
data:image/s3,"s3://crabby-images/87fce/87fce95b9eb12f239e947c104c919d8ff31e7f42" alt=""
data:image/s3,"s3://crabby-images/0ed01/0ed016d63c5cf8b212cd7228eb6699ba7a204aea" alt=""
data:image/s3,"s3://crabby-images/16145/16145ece35aaffae06cac622ffe8f5850d0eff5f" alt=""
- Editing remotely with Pdmenu the file /home/paul/myshell.php and copying into it the content of the local myshell.php:
data:image/s3,"s3://crabby-images/d2094/d2094d08c6a691cdf76823e0e43d4c29b802b0db" alt=""
data:image/s3,"s3://crabby-images/e090a/e090a51e0ba59044ab4993fa2a488d4738d0e8ec" alt=""
- Let's notice that the text editor is vim, so we save the file with writing and quitting :wq!
- Now, it is time to start the actual explotaition, first by setting a listening nc session, and second by running myshell.php with curl:
data:image/s3,"s3://crabby-images/c7774/c77749dd8bdc146f472d1ac0eb2ff9bfc254d939" alt=""
data:image/s3,"s3://crabby-images/fde69/fde693c38f6f1c9978e2a927d228967dd491cb5e" alt=""
- The exploitation is successful and we get a limited remote shell:
data:image/s3,"s3://crabby-images/a2ef2/a2ef22b45c3cd1ab0901f0ed128f2398eead9604" alt=""
3.3 - Limited remote shell with VIM and external commands
- As an alternative now we are going to use Pdmenu to insert the command /bin/bash in the Vim editor, following these directions:
https://www.linux.com/learn/vim-tips-working-external-commands
data:image/s3,"s3://crabby-images/2d20f/2d20ff026d8850aff2868d5562ebd027be4e9a23" alt=""
data:image/s3,"s3://crabby-images/ce386/ce3868daaec12db67b71f7f58c736be395d22888" alt=""
- Just quitting Vim and Pdmenu comes back with a remote limited shell:
data:image/s3,"s3://crabby-images/f9e7d/f9e7d37eaf420a1aa4042ac0e6e3de0480d584c1" alt=""
data:image/s3,"s3://crabby-images/f4a90/f4a9027c6938a3e0ea9a925742064ea936a0a770" alt=""
4 - PRIVILEGE ESCALATION
4.1 - Local Privilege Escalation with exim-4.84.7 exploit
- Finding the SUID files that exist on the system, we discover exim-4.84-7:
data:image/s3,"s3://crabby-images/5a484/5a4844fd3d1fce0d5214e18fe5393939d1ed8eb4" alt=""
- Exim (current version 4.91) is an SMTP email message transfer agent (MTA) for use on Unix systems under GPL, similar in style to Smail 3.
- Exim before 4.86.2, when installed setuid root, allows local users to gain privileges via the perl_startup argument:
https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2016-1531
- There is a Local Privilege Escalation exploit related to this vulnerability:
data:image/s3,"s3://crabby-images/aa0e9/aa0e92dfbf292746d7f44361b7f057a956ea51f3" alt=""
- Copying the script to a new file exim_exploit.sh:
data:image/s3,"s3://crabby-images/147c4/147c4ae4a230cb58f302fd9efde263575d1f7105" alt=""
data:image/s3,"s3://crabby-images/4d01b/4d01b2bf967eeaa4807800fde403bcfca3219b63" alt=""
- Transferring exim_exploit.sh from Kali to Pluck, specifically to /tmp folder:
data:image/s3,"s3://crabby-images/5e7f0/5e7f010f6bd1ed7947fab5e5d04788f51cae89f8" alt=""
data:image/s3,"s3://crabby-images/72e43/72e43821e61be2d4c72ac5f3d627f9cc33d6bd1b" alt=""
- The transfer is successful, but exim_exploit.sh has no execution permissions:
data:image/s3,"s3://crabby-images/2ee25/2ee25ac6b2698639b7e9f36509bb66ace45a4403" alt=""
- Giving execution permissions to exim_exploit.sh:
data:image/s3,"s3://crabby-images/92f8f/92f8fcc40634a873c7030e90910308cc5d8f2be2" alt=""
- Running the script finally we get a remote root shell:
data:image/s3,"s3://crabby-images/b4b54/b4b542f153be680f0749536f13bfe6080821b467" alt=""
4.2 - Local Privilege Escalation with Dirty Cow Kernel Exploit
- An alternative to method explained at 4.1 would be to use this exploit:
data:image/s3,"s3://crabby-images/6d7bc/6d7bcf73327f296ab45a0718017766ac19c26af0" alt=""
- Downloading to Kali:
data:image/s3,"s3://crabby-images/6e367/6e36700d5826d53a1d573f1d9f262de48ddb4635" alt=""
- Transferring to Pluck:
data:image/s3,"s3://crabby-images/9274e/9274e07ae5fe57ab1b2d6c0497df84912b689621" alt=""
data:image/s3,"s3://crabby-images/5933c/5933cef5908cdd11f6ab3462ba83e584e2efe954" alt=""
- Compiling:
data:image/s3,"s3://crabby-images/936f0/936f0366d0eb8c8f4f304e169ba38dba60c2df2c" alt=""
data:image/s3,"s3://crabby-images/cdb50/cdb50ef3337fee1a24024f2b6fa3f34d50208310" alt=""
- Running cowroot we get a remote root shell:
data:image/s3,"s3://crabby-images/66b94/66b94e939e744c5336c3315c39ad9ee22e911efe" alt=""
data:image/s3,"s3://crabby-images/67230/67230371bb64d5fa43b21011c842ffb5b3368d0c" alt=""
- Apparently cowroot destabilizes the system, so we follow these directions to achieve a more stable shell:
data:image/s3,"s3://crabby-images/70acd/70acd080f6252bf1edaa75566b68a7d4cc4f14dc" alt=""
data:image/s3,"s3://crabby-images/46be0/46be0efdcae2eec316f4710757df3b62b31b4f7f" alt=""
5 - CAPTURING THE FLAG
- Reading flag.txt:
data:image/s3,"s3://crabby-images/29789/297897fc63b0e566a0a069e75b3e5f695d63bbf3" alt=""