VALENTINE
- Layout for this exercise:
data:image/s3,"s3://crabby-images/464ad/464adb757d1b7e15c3ebf3f0b6b2d130490e90dd" alt=""
1 - INTRODUCTION
- The goal of this exercise is to develop a hacking process for the vulnerable machine Valentine, what is a retired machine from the Hack the Box pentesting platform:
https://www.hackthebox.eu
2 - ENUMERATION
- Valentine's IP is 10.10.10.79:
data:image/s3,"s3://crabby-images/75af5/75af53bd9317a73cea0f5e61d0078a3e52fc55cf" alt=""
- Scanning with Nmap:
data:image/s3,"s3://crabby-images/2c38c/2c38cea38ff3a273c84823c8b224219dfb3c5e5f" alt=""
data:image/s3,"s3://crabby-images/ba0d8/ba0d8213e62c0f54c310ef1b5f10f5616120a0aa" alt=""
- Connecting with the browser at port 80 the image is very reminiscent of the Heartbleed vulnerability icon:
data:image/s3,"s3://crabby-images/58749/58749473587d9ea3079856dfb906adff410a7afe" alt=""
- Same thing with HTTPS at port 443:
data:image/s3,"s3://crabby-images/1815b/1815b711a0e2c6591a9c4efa32ab4b97251b9444" alt=""
- There is a lot of information available about Heartbleed vulnerability:
http://heartbleed.com/
https://en.wikipedia.org/wiki/Heartbleed
- Nmap script confirms the Heartbleed vulnerability:
data:image/s3,"s3://crabby-images/95200/95200c00f6df85038ec9df60ca04c3d13f218539" alt=""
- Dirbusting Valentine's web server:
data:image/s3,"s3://crabby-images/8e2ee/8e2eef00ea3f502ca16a74635540ac37df4f539e" alt=""
- Checking folder /encode:
data:image/s3,"s3://crabby-images/015a2/015a2b61ad4865ca366d4045d96972dadccd9490" alt=""
- Checking folder /decode:
data:image/s3,"s3://crabby-images/60392/60392564cc6d70dc0e5acbcdcd740caf7a87344d" alt=""
- Going to /dev:
data:image/s3,"s3://crabby-images/909a2/909a2f714e898a79335f0025515c5fe22117905f" alt=""
- Reading notes.txt:
data:image/s3,"s3://crabby-images/f4f22/f4f22d98f71db84e1445a4ffe55166518c4f6c9c" alt=""
- Reading hype_key:
data:image/s3,"s3://crabby-images/9c0d5/9c0d534c50907af550ef0d089f4af815d0f64b7f" alt=""
- Copying hype_key locally:
data:image/s3,"s3://crabby-images/1f611/1f611e850a770223caf0b77256937ebe1016dd21" alt=""
- Because hype_key is written with hexadecimal numbers let's decode it:
data:image/s3,"s3://crabby-images/7cffc/7cffc04600e04c667059b60a5a55793ad28cd2f5" alt=""
- It seems that we are dealing with an RSA Private key. Copying it locally:
data:image/s3,"s3://crabby-images/461b3/461b3d58dc64eb3b5d859c718e81ff936b6a3481" alt=""
3 - EXPLOITATION
- Looking for an exploit related to Heartbleed vulnerability:
data:image/s3,"s3://crabby-images/90748/9074804213b0588ad34d1645ba98d10c4c0dfe86" alt=""
data:image/s3,"s3://crabby-images/18518/18518be57b1c434481c5a14ce643795cac9fce73" alt=""
- Copying the Python script 32764.py to the working folder:
data:image/s3,"s3://crabby-images/7b1b6/7b1b6879804c77f8efdc1ce6d13bf739273c8a2b" alt=""
- Now, launching the script against Valentine's IP:
data:image/s3,"s3://crabby-images/cb7b2/cb7b2d87be709df53069d89249d2e0885bf982af" alt=""
..................................
data:image/s3,"s3://crabby-images/6c247/6c247cae9193f0c144f74e3b8fda310e8015ba32" alt=""
- The answer includes a reference to a string encoded with Base64:
data:image/s3,"s3://crabby-images/5f280/5f2808f36323f69988071c5c5f761fcf7fc5a870" alt=""
data:image/s3,"s3://crabby-images/7968a/7968ad311213e02e776ee1e67698aad114c4add0" alt=""
- Decoding the string we get a plaint text string: heartbleedbelievethehype
data:image/s3,"s3://crabby-images/65aa9/65aa99baac0dcd4449d5d47a277c3fb1aa02bf28" alt=""
- Going back to the encrypted key, let's see whether openssl help to decrypt it by providing as password the string heartbleedbelievethehype:
data:image/s3,"s3://crabby-images/bbcf8/bbcf8d7b7ca1ab3718d356c20735ed8ce2c8eb36" alt=""
- The new decrypted ssh_key:
data:image/s3,"s3://crabby-images/09411/0941105d607832bdc84f8c4695fcaf3da4e7df2e" alt=""
- SSH-ing valentine with user hype's credentials:
data:image/s3,"s3://crabby-images/c88ba/c88ba0eb9d8d5b98c6bb89f504dfa1afdd9c7a2f" alt=""
- The remote shell is low privileged:
data:image/s3,"s3://crabby-images/f53b0/f53b00896ad348bb3be22f554230c0b55e15a340" alt=""
4 - CAPTURING THE 1st FLAG
- Reading user.txt:
data:image/s3,"s3://crabby-images/a4b1d/a4b1da4a1036aebf78569cb5a39c899bbcc429ef" alt=""
5 - PRIVILEGE ESCALATION
- Let's try two ways for Privilege Escalation:
5.1 - Kernel exploitation
- First, checking Operating System version and Kernel number:
data:image/s3,"s3://crabby-images/a3d6c/a3d6c2d4aaf1e35d7bd1cab168b65f9a4aec8c3e" alt=""
data:image/s3,"s3://crabby-images/446ed/446edc7f1f8d92ef77e1b5c957ea312f4b9afcb9" alt=""
- There are some exploits for Linux 3.2 kernel version, for instance this one:
data:image/s3,"s3://crabby-images/39469/3946994a8c9255585a4f897f2f8776b98177f8f7" alt=""
- Downloading to Kali and transferring to Valentine:
data:image/s3,"s3://crabby-images/06376/06376f866b530ee0dc9aefd0b0c61abe3912ede8" alt=""
data:image/s3,"s3://crabby-images/8b5b8/8b5b84280d8aa9303286645e64336b011223fd84" alt=""
- Compiling according to the instructions:
data:image/s3,"s3://crabby-images/cacd1/cacd1e7e8529db962bd8252918d7eaa91b0c3f43" alt=""
data:image/s3,"s3://crabby-images/182f9/182f95e892e44e37b9a3a2254fa1ce989b3e459f" alt=""
- Now, a new password must be entered, for instance hello:
data:image/s3,"s3://crabby-images/08831/08831f5bdcb75514e3b772ba2d745149f1874069" alt=""
data:image/s3,"s3://crabby-images/82cf7/82cf772be1f05abdc9d26709bd828711497c4ce1" alt=""
- Switching to the user firefart with the new password hello we get a root shell:
data:image/s3,"s3://crabby-images/9ec38/9ec38bc3f809c75b48b26b95e6de8621a8459751" alt=""
5.2 - Tmux
- Reading the hidden file .bash_history there is a reference to a tmux command:
data:image/s3,"s3://crabby-images/add8d/add8dd1aa73654c3ccf01374d2040c8a84aa7f20" alt=""
data:image/s3,"s3://crabby-images/e24fc/e24fc34a2492aac367ec5387700283d91f2e70cb" alt=""
- Also, ps aux confirms that there is a tmux session running as root:
data:image/s3,"s3://crabby-images/a4408/a4408ec05441160201b10eddd6e69dcf6c7f9493" alt=""
- Finally, just running the tmux command found at .bash_history we get a remote root shell:
data:image/s3,"s3://crabby-images/35fdf/35fdf32ca83c0be7fbb6222e3c5a6a125b2ea840" alt=""
data:image/s3,"s3://crabby-images/4c558/4c558052edc9e2e069551184b4fa0ae1415afca9" alt=""
6 - CAPTURING THE 2nd FLAG
- Reading root.txt:
data:image/s3,"s3://crabby-images/de1a1/de1a111e820461f8c84d7287664e4428d0cbf87d" alt=""