LAZY
- Layout for this exercise:
data:image/s3,"s3://crabby-images/71d7b/71d7b2e98c4a6e23223656d0334bb03930a4a362" alt=""
1 - INTRODUCTION
- The goal for this exercise is to develop a hacking process for the vulnerable machine Lazy from the Hack The Box pentesting platform:
https://www.hackthebox.eu/
2 - ENUMERATION
- Lazy's IP is 10.10.10.18:
data:image/s3,"s3://crabby-images/094de/094de0b5b410da6ba697a6037b4e0223feb68283" alt=""
- Scanning with Nmap:
data:image/s3,"s3://crabby-images/6c582/6c58269254825ea84b9cd276a8c6f06286001508" alt=""
data:image/s3,"s3://crabby-images/9594f/9594f4cb1ace9b5ed3d22aff1ed907d03b81a898" alt=""
- Dirbusting:
data:image/s3,"s3://crabby-images/b2a8c/b2a8cd9256c960b693b80c1659ca7378f4af4db7" alt=""
data:image/s3,"s3://crabby-images/d5973/d597397b453249635d57acf10882e063fc1adaf1" alt=""
- Going to /classes/auth.php we discover a potential user called admin:
data:image/s3,"s3://crabby-images/af0ce/af0ce1e361c2323a3f7b85a3cf0ad36e0d3aa6e6" alt=""
data:image/s3,"s3://crabby-images/80132/801322658fb232bea74adca692be1ae14d36397a" alt=""
- Connecting to the web server we confirm the existence of user admin because when trying to register admin the answer is that the user already exists:
data:image/s3,"s3://crabby-images/33c38/33c388599c602541f7ce220c34439617f7994922" alt=""
data:image/s3,"s3://crabby-images/27270/27270b8955f3ba91cfd26cde3621ad013bd701ba" alt=""
data:image/s3,"s3://crabby-images/83a8a/83a8aad09dc655e4a5c3b306d391ad551c9f4ba5" alt=""
3 - EXPLOITATION
3.1 - Intercepting with Burp
data:image/s3,"s3://crabby-images/e3d05/e3d059d2ce859bed2ff69103c8dadb94da96be0e" alt=""
data:image/s3,"s3://crabby-images/f4d30/f4d30f148e72f9e5b4482d559896e4cf019faeb7" alt=""
- Let's intercept the login of user whitelist:12345 with Burp:
data:image/s3,"s3://crabby-images/12e32/12e32213bece2b6e3ae10bf9ba3e46b44ac2d9da" alt=""
data:image/s3,"s3://crabby-images/2a6d3/2a6d38187caa0e5eb350091861df49760818f8a0" alt=""
- Clicking Forward the authentication cookie is displayed:
data:image/s3,"s3://crabby-images/ffa5c/ffa5c221d75d7abfed4b361886e1188daf59a998" alt=""
- Sending to Repeater, removing the caracter % and finally clicking Go the Response is Invalid padding:
data:image/s3,"s3://crabby-images/f86cb/f86cb4957841eb1dec9a71732a607ff7900de0f2" alt=""
3.2 - Oracle padding attack
- The Invalid padding response leads to think on a possible padding oracle attack.
- A padding oracle attack is an attack which uses the padding validation of a cryptographic message to decrypt the ciphertext.
- For further explanation:
https://en.wikipedia.org/wiki/Padding_oracle_attack
- padbuster is an automated script for performing this type of attacks:
https://github.com/GDSSecurity/PadBuster
https://tools.kali.org/web-applications/padbuster
data:image/s3,"s3://crabby-images/de47a/de47ab0b135565a51c09a5f7553393c171a1ebe4" alt=""
- Providing ID# equals to 2:
data:image/s3,"s3://crabby-images/a7df5/a7df5ddb1059aa0f6fc314012af03c3512f4a09d" alt=""
data:image/s3,"s3://crabby-images/1b115/1b1155bc06bc441236029379f86e5556bf1c106d" alt=""
- Launching again padbuster but entering user=admin as option:
data:image/s3,"s3://crabby-images/022ec/022ecfa8317852cae31d0cd5138fe6634dce2853" alt=""
data:image/s3,"s3://crabby-images/dc82d/dc82d1a89ba5333d262babb269ee5ca46830b5c2" alt=""
- Finally we get the authentication cookie for user admin:
data:image/s3,"s3://crabby-images/9ad71/9ad71ccc0570283d54b2c263e1fd6df7658eb945" alt=""
- Replacing the original authentication cookie and clicking Forward:
data:image/s3,"s3://crabby-images/570aa/570aa188f96a4a0bcb26f1bb6286119fa38015c2" alt=""
- Clicking Forward again finally the admin authentication is successful:
data:image/s3,"s3://crabby-images/e7c46/e7c46dddbf11e66547230e3c472cff8d5e7c538a" alt=""
- There is a message about an SSH key, and just clicking My Key we get an RSA Private Key:
data:image/s3,"s3://crabby-images/5da1c/5da1c3f3352783f89a9a9a7e726c1e397c2e7fee" alt=""
data:image/s3,"s3://crabby-images/d3a11/d3a117bb8c179ba92b6211cfd64fe9a048e915c6" alt=""
- The URL shows that the SSH key belongs to user with name mitsos:
data:image/s3,"s3://crabby-images/2df71/2df7146afa71869b71bf7d2a632172e8fa3d83e0" alt=""
- Storing locally the SSH key:
data:image/s3,"s3://crabby-images/9ad97/9ad9769f3b37dd51e38022d2808fb19b1e9c6320" alt=""
- Using that key the SSH connection fails, due to bad permissions:
data:image/s3,"s3://crabby-images/17332/17332ad67d31fe48aceb15eab40038f3f845dd06" alt=""
- Changing permissions so that owner can read and write:
data:image/s3,"s3://crabby-images/2aac5/2aac55e72f1f50ab4ccbf21e63c1c5e7e89a6614" alt=""
- Now connection with SSH is successful and we get a remote shell:
data:image/s3,"s3://crabby-images/0a985/0a9853d78059ac0ffa34c4d4953320e4935b209b" alt=""
data:image/s3,"s3://crabby-images/922fb/922fb83938122c88d0c657911b00e3fe0a87fff3" alt=""
4 - CAPTURING THE 1st FLAG
- Finding the 1st flag is easy:
data:image/s3,"s3://crabby-images/99396/993961007f0012350bcd17336ae1a5e4e04e9459" alt=""
- Reading user.txt:
data:image/s3,"s3://crabby-images/b5dce/b5dce2db399b6a4dd0c0f260d7ae9b4c2d79d730" alt=""
5 - PRIVILEGE ESCALATION
- The file backup is owned by user root and has got SUID and SGID bits set:
data:image/s3,"s3://crabby-images/1f3fd/1f3fdb8493f8e18118cf7084a3319908f54868b8" alt=""
data:image/s3,"s3://crabby-images/2610a/2610a484c0c5417ef92e7dd1661cf30a7ee58659" alt=""
- When running backup the file /etc/shadow is displayed:
data:image/s3,"s3://crabby-images/83123/83123bb08357b2246ecc94a4149b3113dc23781e" alt=""
- Also /etc/passwd is available:
data:image/s3,"s3://crabby-images/6302e/6302e72af911be810126d2c9fe6bd18ccc23c581" alt=""
- So it seems that using John The Ripper could be a good solution, however we will follow an alternative Privilege Escalation path.
- Applying command strings over backup we learn that the command cat /etc/shadow is executed every time file backup is run:
data:image/s3,"s3://crabby-images/53b05/53b054d4ae62646714bbae884198d5a7ecbafe8b" alt=""
- The path to the command cat is not fully specified (/bin/cat), what means that it is vulnerable to the attack of modifying the PATH system variable to the local or working directory.
- Redefining the command cat so that it spawns a shell (with root privileges because backup is run as root), giving execution privileges, and finally setting the path to the working directory (/tmp in this case):
data:image/s3,"s3://crabby-images/63a9c/63a9c025a48429b8af6270b81f84a8fccfaa873a" alt=""
- Now running again backup we get a remote root shell:
data:image/s3,"s3://crabby-images/7a684/7a684916d10bd71f6662bbbe3dfa5a5d1a9bd7c8" alt=""
6 - CAPTURING THE 2nd FLAG
- Reading root.txt (look that the full path /bin/cat is now specified):
data:image/s3,"s3://crabby-images/252bf/252bf42199879964e55af65d07f54b2a859fe51d" alt=""