EUROPA
- Layout for this exercise:
data:image/s3,"s3://crabby-images/5177a/5177a5b69c6a128cb820fa0103d24cc1f38f0c33" alt=""
1 - INTRODUCTION
- The goal of this exercise is to develop a hacking process for the vulnerable machine Europa, what is a retired machine from the Hack The Box pentesting platform:
https://www.hackthebox.eu
2 - ENUMERATION
- Europa's IP is 10.10.10.22:
data:image/s3,"s3://crabby-images/ac441/ac4410eea0e07e6f12276fa8f5fd1005abdbde7b" alt=""
- Scanning with Nmap:
data:image/s3,"s3://crabby-images/6360a/6360a86a02e582b443a691afbf65d0c26ad11c96" alt=""
- Going deeper with the scanning:
data:image/s3,"s3://crabby-images/b5ac7/b5ac7a984f7760a3e1339b0b06b47acdabc6e902" alt=""
- So there are two domains that should be added to the /etc/hosts file:
data:image/s3,"s3://crabby-images/58857/58857e3d76c8e9032d6756d2cfb2b013fb3b226a" alt=""
- sslyze is also able to find both domains:
data:image/s3,"s3://crabby-images/b4853/b4853783d23171c96802bffdca9e1bea6ac7e586" alt=""
data:image/s3,"s3://crabby-images/335b9/335b9e04d958bc340f0b5fd010eefcd1d64afc64" alt=""
data:image/s3,"s3://crabby-images/5f216/5f216cdf39a193d14d69485386552adc80705439" alt=""
- Connecting to admin.portal we have a Login form:
data:image/s3,"s3://crabby-images/77b43/77b43fc97a75bc2fb3f2015e1644998a1043bac0" alt=""
3 - EXPLOITATION
- The exploitation process consists of two steps:
3.1 - Database exploitation
- Let's start by exploiting with sqlmap any potential database at Europa:
- sqlmap has different options to be used, for instance:
data:image/s3,"s3://crabby-images/df06e/df06ece66f1777a817a915c756737e96364e0fd3" alt=""
data:image/s3,"s3://crabby-images/15cfe/15cfe8ce403931cd3f577a847de823e6977f6cbf" alt=""
data:image/s3,"s3://crabby-images/859a9/859a9d29399f7ba336d788b47aa03571dbdfb25e" alt=""
data:image/s3,"s3://crabby-images/37c7f/37c7f3894e49462d3e4fe53f6ece28b6283b9b45" alt=""
- Launching sqlmap against Europa's administrator portal we find two databases:
data:image/s3,"s3://crabby-images/5ebe2/5ebe2aa67e6a8f7c3c05b7d9b5f5a6e0a3180c7f" alt=""
data:image/s3,"s3://crabby-images/3ec83/3ec8300fca50523aa976a20e567e439f04bfe04b" alt=""
- Going deeper with database admin and dumping all available information:
data:image/s3,"s3://crabby-images/cad3b/cad3b8debe9f8a279d18ac8dd0dea53d0980c65e" alt=""
data:image/s3,"s3://crabby-images/44fe2/44fe2a7da3c7e796b9fac44de7b0564ebdff6c4a" alt=""
- Decrypting the password, what is common for both users:
data:image/s3,"s3://crabby-images/54880/548803315ad8805a54bcd376f08351f818d73452" alt=""
- Now we can login successfully to the admin-portal console with admin's email and his password SuperSecretPassword!
data:image/s3,"s3://crabby-images/7a43a/7a43a1c314a8b491189e47f956355b439417027d" alt=""
3.2 - PHP code exploitation
- Once logged in, the Dashboard has got a Tools tab:
data:image/s3,"s3://crabby-images/c85e8/c85e83b49a71814a0dae8ed7ed6a1414591386a5" alt=""
- Going to Tools we find a VPN generator script:
data:image/s3,"s3://crabby-images/1ed96/1ed963bdc1f1f7b55a3c6aba245023456c1a7e40" alt=""
- Intercepting the VPN generation with Burp:
data:image/s3,"s3://crabby-images/b88b3/b88b3cec1eeb68747bdf32b7dbe866c07a2dc874" alt=""
data:image/s3,"s3://crabby-images/9e4de/9e4dee33ded04d5d995ee8153afadb00eb4b241d" alt=""
- So there is a parameter called pattern, what is used by the preg_place PHP function in this way:
data:image/s3,"s3://crabby-images/80225/80225ec421e1df49e8fda752c04bbb065f6f8782" alt=""
- One of the modifiers is the /e feature, what has been deprecated in later versions of PHP because of its associated vulnerabilities:
data:image/s3,"s3://crabby-images/0f0f8/0f0f829a420888ecf1e7ae452ae67a3dd3ef1f7d" alt=""
data:image/s3,"s3://crabby-images/7111d/7111dee0c3eab10fef23e7a09d8afe9ca61d62d1" alt=""
- As said before, the modifier e is the origin of this vulnerability:
data:image/s3,"s3://crabby-images/d06a5/d06a50004ba7e755fe160e3428bf4a07f695ac40" alt=""
- Here is another interesting explanation about this vulnerability:
http://www.madirish.net/402
- So basically what modifier e does is to evaluate the subsequent string as PHP code.
- We can take advantage of this circumstance to handle the user input by adding the e modifier to the pattern parameter:
data:image/s3,"s3://crabby-images/660f6/660f6121e0e33df0a485dcc7763bf1a3bd5bc6e6" alt=""
- Going to Burp and sending the input to the Repeater let's try to read /etc/passwd:
data:image/s3,"s3://crabby-images/8b8be/8b8be9751df0c152b73b989ce06ed05eeca026e1" alt=""
data:image/s3,"s3://crabby-images/62856/628566824e22878b6212aca11486e1699ac133b2" alt=""
data:image/s3,"s3://crabby-images/a4138/a413888387d7cab13b9f715d6c43cd64e2f35923" alt=""
- Now, creating a shellcode with Msfvenom:
data:image/s3,"s3://crabby-images/9ee3f/9ee3fad4ab3eb85cf8b19beed913b8a780e1af1b" alt=""
- Encoding as URL format:
data:image/s3,"s3://crabby-images/721ee/721ee03cbfc74f2083c718d25a1771b2f4c24778" alt=""
- Adding to Burp request:
data:image/s3,"s3://crabby-images/b7d72/b7d723c765177de460ccddc965c74edf153ceb11" alt=""
- Setting a listener session:
data:image/s3,"s3://crabby-images/b44c6/b44c6d8d4ff446a15edfec8e8cff5a97fba87a5d" alt=""
- Finally, launching the Burp Repeater we achieve a shell reverse connection:
data:image/s3,"s3://crabby-images/3a8d1/3a8d1c72eaa395f72b0cf8319e1d8449e59a40fc" alt=""
data:image/s3,"s3://crabby-images/63acb/63acbe3d7b694690e5531b0c30c85abcb6bcdc6a" alt=""
- Improving the shell:
data:image/s3,"s3://crabby-images/6ddc5/6ddc5b2f3b6d0484c1d0e6f2ddac46d4ac466d74" alt=""
- The current user is www-data:
data:image/s3,"s3://crabby-images/d1cf5/d1cf5cfc3fb4acd43e42116789524f58d2a50474" alt=""
4 - CAPTURING THE 1st FLAG
- Reading user.txt:
data:image/s3,"s3://crabby-images/b2806/b2806fc7d72c7ecc2990d754b24e0b99458efbc2" alt=""
5 - PRIVILEGE ESCALATION
- Looking at the crontab jobs, there is one task called clearlog running every minute by the user root, what can be interested to be exploited:
data:image/s3,"s3://crabby-images/67911/67911a98edc15b87af7e7fbeff545e0f3c78496b" alt=""
- Reading clearlogs:
data:image/s3,"s3://crabby-images/39666/396662da3b25ac9b1c828c5c15e2c5cf3d586f75" alt=""
- So what we need to do is to replace content of logcleared.sh with an exploitation code of our interest.
- By the way, logcleared.sh does not even exist at the moment, so it must be created from the scratch:
data:image/s3,"s3://crabby-images/1c860/1c86083077e4af635e12cb298a57d9c9b7479550" alt=""
- Msfvenom comes again to our help, now using a different port than before:
data:image/s3,"s3://crabby-images/953f9/953f951ce96635b52c6e5e492b464cdc940501ab" alt=""
- Setting a listener session at port 6666:
data:image/s3,"s3://crabby-images/09230/0923027ff8be4d45bd9b43bb12bccbea8ead67b9" alt=""
- Echoing the exploit to logcleared.sh:
data:image/s3,"s3://crabby-images/0d77c/0d77c1aec5456233a5e3c239a411b3afc95301e6" alt=""
- The script is successfully created:
data:image/s3,"s3://crabby-images/bfa24/bfa24b30732cd3a3a1f82d83bf6d746b615c8b66" alt=""
- Giving running privileges:
data:image/s3,"s3://crabby-images/5fc66/5fc66d8b1fcc69730d49801ed4afa45fdb55f0cb" alt=""
- Now, if we don't wait the crontab time period and execute the script by ourselves it happens that the shell is run by www-data (not by root) so we have a low privilege shell:
data:image/s3,"s3://crabby-images/2d4fe/2d4fecf1bb0d9dd987a023a1cf78bfef590c5f86" alt=""
data:image/s3,"s3://crabby-images/70242/70242bb2738df05212bde58fd6ddfadfb6128808" alt=""
- However, stopping the last session, launching a new one, and waiting the crontab task until logcleared.sh is run by root we finally achieve a reverse root shell:
data:image/s3,"s3://crabby-images/dad48/dad48c0af128a0e707374ba35c79548df16b5ce3" alt=""
6 - READING THE 2nd FLAG
- Reading root.txt:
data:image/s3,"s3://crabby-images/1f32b/1f32b6a43cc212d972e6c36614241e2555498787" alt=""