- Layout for this exercise:
data:image/s3,"s3://crabby-images/21f1a/21f1a196ad8ee01cb17de21b134e03b90fc046dd" alt=""
1 - INTRODUCTION
- The goal of this exercise is the study of the hacking process for the vulnerable machine Fristileaks 1.3:
data:image/s3,"s3://crabby-images/640c2/640c2d1f3b9c7447f8203bf3c6b4fbabf4fe49be" alt=""
- Fristileaks 1.3 can be downloaded from here:
https://www.vulnhub.com/entry/fristileaks-13,133/
- Once downloaded and extracted with VirtualBox:
data:image/s3,"s3://crabby-images/ff265/ff2658bf673d2d91661a60ab61c60c3e1fef75d6" alt=""
2 - ENUMERATION
- Using netdiscover to confirm the presence of host 192.168.1.9 that corresponds to the vulnerable machine Fristileaks 1.3:
data:image/s3,"s3://crabby-images/4e2c0/4e2c0b63313eea6f4ab304f36d505108066eda69" alt=""
data:image/s3,"s3://crabby-images/c0ff2/c0ff284b070fd9e63943436f4689ad933e0fd072" alt=""
- Scanning with Nmap:
data:image/s3,"s3://crabby-images/7ae71/7ae7198c761b91aa81f55d6b15175058832cdfd3" alt=""
- Connecting with the browser to the only open port 80:
data:image/s3,"s3://crabby-images/9ea54/9ea5444da94026a4671fde22ec24753b9922c49f" alt=""
- Launching nikto to the host we find three folders inside robots.txt:
data:image/s3,"s3://crabby-images/73ee2/73ee2792eedbd9094454ecb57d4c74b9288190ea" alt=""
data:image/s3,"s3://crabby-images/944af/944af1d7d0a6377976a1a227c67825d10e48639b" alt=""
- Looking at robots.txt:
data:image/s3,"s3://crabby-images/61ffc/61ffcfeaa0758af3e75442994ca095f6fd756784" alt=""
- Either connecting to /cola, /sisi or /beer the result is the same:
data:image/s3,"s3://crabby-images/51121/511217c34d898ee02ceca7d83ae645360fb685e2" alt=""
- Following the advice: "KEEP CALM AND DRINK FRISTI" ... let's try fristi:
data:image/s3,"s3://crabby-images/49487/494873b5539c820a886ffefa9184bcd36ca42d79" alt=""
3 - EXPLOITATION
- Viewing the source of the web page it seems that there is a user called eezeepz:
data:image/s3,"s3://crabby-images/34685/34685f05f3db01ed91ecd133047002964bbbeb90" alt=""
- After the image reference there is a text encoded into Base64 format:
data:image/s3,"s3://crabby-images/4452d/4452dba5801a7516e2343b0cf11e52a20501f11f" alt=""
- Decoding the text:
data:image/s3,"s3://crabby-images/d313d/d313da9d48ae8f76138af9390e834c8f914dfc23" alt=""
- The output is an image that could be a password:
data:image/s3,"s3://crabby-images/6cb30/6cb30ea42d6113ac8eb37deb63a79dc02f6767b9" alt=""
data:image/s3,"s3://crabby-images/35f4f/35f4f6692b14b76234c05bf7fabe113aa40efd0e" alt=""
- Using that series of letters as password for the user eezeepz:
data:image/s3,"s3://crabby-images/709f7/709f7e154e4585ecdb55dbd3ef564c7391eb8b85" alt=""
- The login is successful, and we are invited to upload a file:
data:image/s3,"s3://crabby-images/b7743/b774323ea1f1b21ea02df7cebd07e49103bfb98c" alt=""
data:image/s3,"s3://crabby-images/e97b4/e97b4e4f9abe615f7d5c95393258c56ab996a54e" alt=""
- Let's try a webshell, for instance this provided by Kali:
data:image/s3,"s3://crabby-images/49411/49411a80c4ff2907d8db3556e76117db268e2326" alt=""
- Copying into a working directory to keep untouched the original version:
data:image/s3,"s3://crabby-images/dc479/dc47921c18634d894286b60cba51edb03b410352" alt=""
- The webshell must be modified to adapt to our needs:
data:image/s3,"s3://crabby-images/c7eed/c7eedc2cc4657db901c11487844bdbddd512693e" alt=""
data:image/s3,"s3://crabby-images/6ba13/6ba13d9d975ed73292969773fc5c4d925e47d2ea" alt=""
data:image/s3,"s3://crabby-images/96d03/96d0353977422b6fe611da7526e9ff8b90aec7e7" alt=""
- Now, it's time to upload the PHP file:
data:image/s3,"s3://crabby-images/ec7f9/ec7f9b518de281161e1b51e58dbea845cd5dbadb" alt=""
data:image/s3,"s3://crabby-images/b95ab/b95ab8bad57c2bbf7634a4171cb1133ed9d19b83" alt=""
- However the upload fails because an image format (png,jpg,gif) is required:
data:image/s3,"s3://crabby-images/74841/748413927ed55b514bf021a5f476630355c45967" alt=""
- To bypass this problem let's rename the PHP webshell just adding a png extension:
data:image/s3,"s3://crabby-images/02d51/02d51df12cc25f01428b278305ad1c516e130faa" alt=""
- The new file is uploaded successfully:
data:image/s3,"s3://crabby-images/74864/7486473d937874876b2918d1accc9113e14f8631" alt=""
data:image/s3,"s3://crabby-images/0ed78/0ed787ecc6a1f1ca2abcb0538470283b18657201" alt=""
- Now, starting a netcat listening session:
data:image/s3,"s3://crabby-images/419ea/419eaa1541107897f59101791117a014071ec268" alt=""
- Running the PHP reverse shell including it through the URL:
data:image/s3,"s3://crabby-images/41e2a/41e2aaf2c3e304e20de1b407d653a41792484587" alt=""
- The PHP reverse shell script is successful, achieving a limited shell:
data:image/s3,"s3://crabby-images/76a41/76a4105e3f70d8044b9253860f3d5a656c04f8b9" alt=""
4 - PRIVILEGE ESCALATION
- Browsing the /home directory, we detect 3 users:
data:image/s3,"s3://crabby-images/5abe0/5abe092c9b43a09dfccc755db6fe7983ace078cd" alt=""
- Access is denied to both /admin and /fristigod home folders:
data:image/s3,"s3://crabby-images/13977/1397708071d1e3e7e1c93e63fd10f1fe49925c1e" alt=""
data:image/s3,"s3://crabby-images/60695/6069509d2c6e80cd349eb56a965663d7c1ceb47b" alt=""
- However there is access to /eezeepz:
data:image/s3,"s3://crabby-images/d6896/d6896944c887425cddb43a1c8f9fdc451743487a" alt=""
- Listing the content of the home directory /eezeepz:
data:image/s3,"s3://crabby-images/96cdc/96cdc6ec804e338ca45a683bffcda975f1c33f28" alt=""
- Reading notes.txt:
data:image/s3,"s3://crabby-images/2b952/2b95209d549fc81f7e7aa202ed9295000b9f8bac" alt=""
- Giving access permisions to the folder /home/admin:
data:image/s3,"s3://crabby-images/8d927/8d927af3ad06af886311e9ffe173af374c2bb231" alt=""
- Waiting for a minute, and accessing to /tmp/runthis:
data:image/s3,"s3://crabby-images/5d46f/5d46f302b94eeb01d8f6a7e615f5e31700138049" alt=""
- Now, access to /home/admin is granted:
data:image/s3,"s3://crabby-images/65e10/65e108fc5dd65ac437c566645eb9d916afbf4e60" alt=""
data:image/s3,"s3://crabby-images/1f5dc/1f5dcb155da0132d0a8a2e9f1c69442e75df0eee" alt=""
- There are 2 text files whose contents seem encrypted text:
data:image/s3,"s3://crabby-images/3ddbb/3ddbb089d7a34568d729ef19f78a88a345917ce2" alt=""
data:image/s3,"s3://crabby-images/1df8b/1df8b46ff251ed3ce1ebe0c947d9ec6fe0311a9d" alt=""
- Also there is a Python script self explanatory about how to decrypt the texts:
data:image/s3,"s3://crabby-images/82c6d/82c6d6f1f4642099122775e0b8333f6f1f866d8a" alt=""
- Reversing the encrypting process we find 2 plaintext outputs with this Python script:
a) decoding with rot13
b) reversing the order
c) decoding with base64
data:image/s3,"s3://crabby-images/e94dd/e94dd59ef9fdfa534bfb58b54416acac9bb07376" alt=""
data:image/s3,"s3://crabby-images/fb172/fb172e5b537617d79f127ebf1c52834c6b4427bb" alt=""
- Now, trying to use su with fristigod we find that a new terminal is needed:
data:image/s3,"s3://crabby-images/b117e/b117eeabad0dde1d50df9e9d3290ec62cce9ffdf" alt=""
- Importing a new bash:
data:image/s3,"s3://crabby-images/c5300/c53001d8440205c53075af33883e7f7f59498293" alt=""
- su is successful for fristigod:
data:image/s3,"s3://crabby-images/499d0/499d024240f8c3149c391aa12b82900d0835be2e" alt=""
- Listing sudo powers for fristigod:
data:image/s3,"s3://crabby-images/ee61f/ee61f085e23d8358482e6fba1172d190e610f0b9" alt=""
- Going to /var/fristigod it seems that the user fristi is able to run some interesting commands for administration purposes:
data:image/s3,"s3://crabby-images/19dfe/19dfed08ca1c634998b38780ae67dc03e3a2e3f5" alt=""
- Reading .bash_history gives us interesting information about how to use doCom:
data:image/s3,"s3://crabby-images/638b3/638b3da53350fd630e202994297d86490d3c254f" alt=""
- Opening .secret_admin_stuff we find doCom:
data:image/s3,"s3://crabby-images/4c754/4c75487f3986131112d978cfe7400f29f0490732" alt=""
- Running ./doCom we need to provide a command:
data:image/s3,"s3://crabby-images/83f19/83f19790fea6c01342193ebb4791655f5f9321e7" alt=""
- Trying /bin/bash eventually we achieve a root shell:
data:image/s3,"s3://crabby-images/f5ad5/f5ad5e5be54cb76487a5af66d90c908e377135b9" alt=""
5 - CAPTURING THE FLAG
- Going to the /root folder:
data:image/s3,"s3://crabby-images/7e036/7e03608903d51d58a05c236556cf54bb2bd28a46" alt=""
data:image/s3,"s3://crabby-images/300f2/300f2f42d7ba5774adf76a11a1f4d84c1355dff9" alt=""