SILO
- Layout for this exercise:
data:image/s3,"s3://crabby-images/65d2c/65d2c5dfb00259330f380ac0fc2713c9a0f86b50" alt=""
1 - INTRODUCTION
- The goal of this exercise is to develop a hacking process for the vulnerable machine Silo, what is a retired machine from the Hack the Box pentesting platform:
https://www.hackthebox.eu
2 - ENUMERATION
- Silo's IP is 10.10.10.82:
data:image/s3,"s3://crabby-images/2c1e2/2c1e2917383a7296368e22bca3434f673a5e61c1" alt=""
- Scanning with Nmap:
data:image/s3,"s3://crabby-images/553ff/553ff0dbbc7ae76f99b84b051956deff2fde0860" alt=""
- So we have a Windows machine running the database Oracle listening on ports 1521 and 49161, and also IIS at port 80.
- Metasploit helps with the module sid_brute to bruteforce the Oracle SID's to connect to the database:
data:image/s3,"s3://crabby-images/e41ef/e41efde844da4e6c296d3fa9c208f622d3839c5a" alt=""
- The ODAT (Oracle Database Attacking Tool) yields similar result when guessing the SID's:
https://github.com/quentinhardy/odat
- Along this exercise I will be using the standalone version for ODAT.
https://github.com/quentinhardy/odat/releases/
data:image/s3,"s3://crabby-images/9c13e/9c13eda4a1f451fa39df1c877b90f7d19358cb07" alt=""
- Also, we know that default credentials for Oracle are scott:tiger, as explained here:
http://www.orafaq.com/wiki/SCOTT
http://www.dba-oracle.com/t_oracle_scott_tiger_user.htm
data:image/s3,"s3://crabby-images/41197/4119769677bff418a0fb4d3cccfd579f6391282a" alt=""
3 - EXPLOITATION
- Msfvenom helps to create an .aspx backdoor:
data:image/s3,"s3://crabby-images/76d21/76d21438d010ef9f923d8243d132a6d960a1b4c0" alt=""
data:image/s3,"s3://crabby-images/e0084/e0084ddbeb1c3572b87aa09d21da2a8c38ddbad8" alt=""
- ODAT uploads backdoor.aspx at Silo's web root directory:
data:image/s3,"s3://crabby-images/ae268/ae26875e72ff5f04630a5538a653ac39ab608c9a" alt=""
- Starting a listening session:
data:image/s3,"s3://crabby-images/7fe70/7fe70b3bc0af6978f79eb82d7543d7dc79fed7f3" alt=""
- Running backdoor.aspx from the browser:
data:image/s3,"s3://crabby-images/d9d26/d9d266fce80e3ae82d1adc85c267d728c0e55c74" alt=""
- The consequence is a low privileged Meterpreter session:
data:image/s3,"s3://crabby-images/dec7d/dec7d19def817f635bccc47a59df7d6851477471" alt=""
- Also, we can spawn a shell:
data:image/s3,"s3://crabby-images/45a3e/45a3e8d79407abbaaf7b0f529e936a5328610781" alt=""
- Going to Phineas user's Desktop there are two interesting files: user.txt and Oracle issue.txt:
data:image/s3,"s3://crabby-images/b5995/b599535c04354bd084fb1164346e4e5e92e5782c" alt=""
4 - CAPTURING THE 1st FLAG
- Reading user.txt:
data:image/s3,"s3://crabby-images/56133/56133b7c3e3ca261a88ea65e8cf7d862112814b6" alt=""
5 - PRIVILEGE ESCALATION
- There are different ways of getting a remote root shell, let's see two of them.
5.1 - Uploading and running a backdoor with Odat
- Let's create now an executable backdoor.exe with Msfvenom:
data:image/s3,"s3://crabby-images/2dca9/2dca933d8099d19dac0dd0ba79ad5002aee72ce5" alt=""
data:image/s3,"s3://crabby-images/c2cfc/c2cfc93d41772f0aa9b90da2d70a175f7ab93d5e" alt=""
- Copying backdoor.exe to Odat's working directory:
data:image/s3,"s3://crabby-images/18560/18560858d4b3eca6831caed6c279ddd60fb4fefe" alt=""
- Odat's utlfile --putFile option uploads the executable to Silo's C:/
data:image/s3,"s3://crabby-images/ab5a8/ab5a8bfdefad5e8f96e85d04a3fad4e810b0b019" alt=""
- Setting a listening session:
data:image/s3,"s3://crabby-images/8fc2b/8fc2b180d4adc3759b97724593fdfda60af57c22" alt=""
- Running backdoor.exe with Odat's option externaltable --exec:
data:image/s3,"s3://crabby-images/8cbeb/8cbeb09a912e1868d486165e114a9ae596e9b31c" alt=""
- Once backdoor.exe is executed we get a root Meterpreter session:
data:image/s3,"s3://crabby-images/cde34/cde3479f45184583508d24b6583e758167e80190" alt=""
5.2 - Pass The Hash (PTH)
- First, we need to get the credential hashes with Volatility.
- Reading the text file Oracle issue.txt we find a link to Dropbox and an associated password:
data:image/s3,"s3://crabby-images/6d9d1/6d9d1b793f9c32ff28f8879ff9d268613f7f1c60" alt=""
- However the first character of the password needs to be found:
data:image/s3,"s3://crabby-images/e4861/e4861f51ed28233197d3645859c8492573196a20" alt=""
- Backgrounding the shell and going back to the Meterpreter session we can download the Oracle issue.txt text file to Kali:
data:image/s3,"s3://crabby-images/faa7d/faa7da59aa982cc58758e6851962288617c3578e" alt=""
data:image/s3,"s3://crabby-images/e53f3/e53f39c0737fe5a3d2132d0a289c15d4f4aac3fd" alt=""
data:image/s3,"s3://crabby-images/254b5/254b5bd520d9e6a5bd0a4fc069768e6b9dd3b5ae" alt=""
data:image/s3,"s3://crabby-images/680c2/680c29d13ea38ab6aad270c79675388f32f369bc" alt=""
data:image/s3,"s3://crabby-images/02e67/02e673748a3dcf8c5e33f6380c2b37b4871cad0c" alt=""
- Opening with gedit, now the 1st character of the password is clear:
data:image/s3,"s3://crabby-images/0dbf4/0dbf472c87178300350ca075657f404c1e3e6885" alt=""
data:image/s3,"s3://crabby-images/6b1fd/6b1fdad3cc4586286a7bab5757638a2fa649e56f" alt=""
- Using the password there is access to the Dropbox link:
data:image/s3,"s3://crabby-images/e9652/e9652573e894d128d75bde9db49c1f3f9cceb8a8" alt=""
data:image/s3,"s3://crabby-images/0c943/0c94319e29a50ed54344b01cab5a7bc86bdea406" alt=""
- We find a Memory Dump for Silo:
data:image/s3,"s3://crabby-images/49aba/49aba73f47c31ed6bf7ff303d228039f51b17318" alt=""
- Saving the file:
data:image/s3,"s3://crabby-images/59dc4/59dc4e9df81c5d23e245611a89e5e50c78af181d" alt=""
- Unzipping twice:
data:image/s3,"s3://crabby-images/06242/062426d6aa3a21643b310e79779bafa5c542067b" alt=""
data:image/s3,"s3://crabby-images/724df/724dfc05cca3e9e9b8a8eda93a0763f5188d386e" alt=""
- Finally we get a .dmp file:
data:image/s3,"s3://crabby-images/fdc61/fdc610f78bd8473eea062c000e3d990fb1990b22" alt=""
data:image/s3,"s3://crabby-images/70680/70680d4bf1473261a69049531af5086633c2102d" alt=""
- The forensics tool Volatility can help to read the dump content:
https://www.volatilityfoundation.org/
- Some options for Volatility:
data:image/s3,"s3://crabby-images/5190f/5190f48691e764973e652b5e2956816d3da679d5" alt=""
data:image/s3,"s3://crabby-images/fee6c/fee6cc22783e2bbc4d09fa65a57e4fdae2525231" alt=""
data:image/s3,"s3://crabby-images/f5412/f5412d478b462631ae5b433f6a476701f31bb418" alt=""
- Getting virtual addresses for some files:
data:image/s3,"s3://crabby-images/7cd9d/7cd9d1da4ba91ba5ffc2ab18ae5ba066d3e002fe" alt=""
- Actually, adresses of SYSTEM and SAM are of our greatest interest:
data:image/s3,"s3://crabby-images/e43b4/e43b4e00ea8b2116202ac30cc66acd4aa9b59c30" alt=""
data:image/s3,"s3://crabby-images/c1f68/c1f682d57c52c4ce283e9a5103c2010002aefa9b" alt=""
- Hashdumping to a text file:
data:image/s3,"s3://crabby-images/92d5c/92d5cb139d6cd3f114c4c036205160a5c12375c1" alt=""
- Finally, we can read the hashes for 3 of the users, Administrator, Guest, Phineas:
data:image/s3,"s3://crabby-images/f2007/f20073fa0c094a2895ec17a5d45cb450de22d7cf" alt=""
- Pass The Hash (PTH) is a hacking technique that allows an attacker to authenticate to a remote server or service by using the underlying NTLM or LM hash of a user's password, instead of requiring the associated plaintext password as is normally the case.
data:image/s3,"s3://crabby-images/1fe11/1fe11da7aa8ae2a233ac64480245067d38e52022" alt=""
- We will use Pass The Hash (PTH) in two ways , the first using the Metasploit module psexec, the second using pth-winexe:
5.2.1 - Pash the Hash (PTH) with Metasploit psexec
- The psexec module can be used to obtain access to a given system when credentials like username and password hash are known:
https://www.offensive-security.com/metasploit-unleashed/psexec-pass-hash/
data:image/s3,"s3://crabby-images/1981e/1981e57485c8d45c89c1ba999cebca058d9a5306" alt=""
5.2.2 - Pash the Hash (PTH) with pth-winexe
- pth-winexe is a patched version of winexe that can be used to get a remote shell by just providing the username and the hash of the password, so no cleartext password is needed:
https://www.whitelist1.com/2017/10/pass-hash-pth-attack-with-pth-winexe.html
data:image/s3,"s3://crabby-images/4cd43/4cd4376d2d5f65976443e626701745a7e39e891b" alt=""
- Also, passing the username and hashed password on the command-line:
data:image/s3,"s3://crabby-images/eab79/eab799fabc205d7597acf113814b59913617495b" alt=""
6 - CAPTURING THE 2nd FLAG
- Reading root.txt:
data:image/s3,"s3://crabby-images/2f0ef/2f0ef17726ed14e33158283f36eedbef8478ffcd" alt=""