TR0LL 1
- Layout for this exercise:
data:image/s3,"s3://crabby-images/3378d/3378df0fa971366ed7f0078dc73b15c8d2cfcf64" alt=""
1 - INTRODUCTION
- The goal of this exercise is the study of the hacking process for the vulnerable machine Tr0ll 1.
- According to the author's description there is a Proof.txt file at the /root directory.
- Tr0ll 1 can be downloaded from here:
- Once downloaded and extracted with VMware:
data:image/s3,"s3://crabby-images/a5d07/a5d07b719954889ffe489f9a4082131f29b3c6fe" alt=""
2 - ENUMERATION
- Using netdiscover to find the IP corresponding to Tr0ll 1:
data:image/s3,"s3://crabby-images/8f391/8f39160067ec4fd349baa0dc0690119a2fc6afcc" alt=""
data:image/s3,"s3://crabby-images/b749e/b749ee1d3777171305f94a74839d749e2c1b58f8" alt=""
- Scanning with Nmap there are 3 available services at port 21 (FTP), 22 (SH) and 80 (HTTP):
data:image/s3,"s3://crabby-images/32a90/32a9061d71dac2e1e28068922c6f220153b8bdb4" alt=""
2.1 - Web service
- Starting with the web service, we detect the presence of the folder /secret and the file robots.txt:
data:image/s3,"s3://crabby-images/942b9/942b92b9cd1e7af409bfd032a9b547b22318c71e" alt=""
- Same information with nikto:
data:image/s3,"s3://crabby-images/534c5/534c50fd94e4683317b5fc2ca02125eb8b3b09f0" alt=""
- Going directly to the website, there is nothing interesting:
data:image/s3,"s3://crabby-images/c19fe/c19fe67a7654aee3984741a7d2e7d6976eb2c513" alt=""
data:image/s3,"s3://crabby-images/d578b/d578b994091d76110ecde48c4650f4ea7f968504" alt=""
- Similar results when checking robots.txt and /secret:
data:image/s3,"s3://crabby-images/28653/2865302e7ea37146a2121c740c62fb451cb93aac" alt=""
data:image/s3,"s3://crabby-images/7a647/7a6475e054d6532df9e04f700a588553174cfc3c" alt=""
data:image/s3,"s3://crabby-images/0a5f3/0a5f3c420b90c14e6442e24509821a7e1250ae23" alt=""
2.2 - FTP Service
- Scanning specifically the port 21 for FTP service, we discover that the anonymous login is allowed:
data:image/s3,"s3://crabby-images/03f01/03f01abfaee0f98aa01849ba4aa06c97782cf1b5" alt=""
- Login with anonymous:
data:image/s3,"s3://crabby-images/37841/378410d98608f6c944b3c6e828442ffccecf27c4" alt=""
- There is a very promising file called lol.pcap:
data:image/s3,"s3://crabby-images/9a298/9a2985eee132eeb2c619fc5b338a601a39e18ed8" alt=""
3 - EXPLOITATION
- Getting the file lol.pcap:
data:image/s3,"s3://crabby-images/c3bbd/c3bbdac74cd81b4fde641f26331e7bbd7b49395a" alt=""
data:image/s3,"s3://crabby-images/bf2e5/bf2e58f1f4887d6f85dfce1172eaae15eb144b2b" alt=""
- lol.cap can be also downloaded by using the browser with FTP protocol:
data:image/s3,"s3://crabby-images/5b7c9/5b7c93e57e9640b809c91f0173676c6e57d9f327" alt=""
data:image/s3,"s3://crabby-images/6d2e7/6d2e7bdffba40721af6a7e6d13e24a39443bb296" alt=""
- Opening lol.pcap with Wireshark:
data:image/s3,"s3://crabby-images/14693/1469354ebe3b2d59f640d574304dc6373d8367a9" alt=""
data:image/s3,"s3://crabby-images/c3b32/c3b3222ad21fb688dbb7ed6f1de0d471b08dd6b1" alt=""
- There is a line about a file called secret_stuff.txt:
data:image/s3,"s3://crabby-images/50f6b/50f6ba9278c4ad8c7cdf07d28a841a4695bd73c9" alt=""
- Following the TCP Stream number 0:
data:image/s3,"s3://crabby-images/30d56/30d56aabfe2caf3fc92bf27883bfec582132e7ae" alt=""
- Following the TCP Stream number 2:
data:image/s3,"s3://crabby-images/7ce57/7ce57dfaf79acde5d6904ec4e51f3a85d0cb0ca8" alt=""
- So, we learn that there is an additional directory called sup3rs3cr3tdirlol
- Let's see if we can access it via the browser:
data:image/s3,"s3://crabby-images/ea51f/ea51fdb6e3a2d05bfdd9255c3f17b312fcd0f449" alt=""
- A file called roflmao is contained, let's download it and see what we can learn about it
- It seems to be a BIN file:
data:image/s3,"s3://crabby-images/0efb9/0efb9a96bcdba6f27303de00b92a8db302ba33fe" alt=""
data:image/s3,"s3://crabby-images/6d21e/6d21ea10a386b5b0ca6479ce016783bcc510f520" alt=""
- At this moment there are no execution permissions:
data:image/s3,"s3://crabby-images/5e6e4/5e6e44ff9d96271efa94a678996ebccc2bbdfe18" alt=""
- Giving execution permissions:
data:image/s3,"s3://crabby-images/7354c/7354c0bfa0a05737cad755132473dab206d8b233" alt=""
data:image/s3,"s3://crabby-images/94e1d/94e1d4807d7a17c776a6672d99137b005d5d5534" alt=""
- Running the file we find more information:
data:image/s3,"s3://crabby-images/679bd/679bd96b657fe501f94d4d35b7bfd18b78f7b789" alt=""
- Trying 0x0856BF as a web directory, we discover 2 new folders:
data:image/s3,"s3://crabby-images/66271/662715e27b22d995e1168b4486e2bbee24ad15ee" alt=""
- The folder good_luck contains a list of potential usernames:
data:image/s3,"s3://crabby-images/eeb49/eeb49c4ba83fd1d4f2387e51436c877364265c73" alt=""
data:image/s3,"s3://crabby-images/94670/9467021e07c4817d31a33497d04827be12e98c24" alt=""
- About the folder this_folder_contains_the_password there are 2 strings that could be passwords: Pass.txt and Good_job:)
data:image/s3,"s3://crabby-images/60c82/60c82061f22abe2bab285e2a51484fb86308a11c" alt=""
data:image/s3,"s3://crabby-images/1c65b/1c65b618acd3d60d182d632ddaee96d106cede2d" alt=""
- Let's create a text file for potential usernames:
data:image/s3,"s3://crabby-images/a7d07/a7d074ea5ee1679b2a7b3e412fc857eb0024f4d1" alt=""
- Same thing for potential passwords:
data:image/s3,"s3://crabby-images/2f733/2f733aa655602bc2c889be9f14b214428a613087" alt=""
- Launching Hydra over SSH service using both wordlists:
data:image/s3,"s3://crabby-images/49823/4982351ede3a6e8deec47adb37a87afaca174cf2" alt=""
- The result is successful for overflow:Pass.txt
data:image/s3,"s3://crabby-images/a7f11/a7f1179599c9970ac3771021062cf8c24c055de1" alt=""
- Using overflow:Pass.txt as SSH credentials we get a remote shell:
data:image/s3,"s3://crabby-images/11305/11305ef5f0388a6ccb72f4249f8ea05d939a4577" alt=""
data:image/s3,"s3://crabby-images/a57f8/a57f8c81913519367ac5b96f0595756abab689f7" alt=""
data:image/s3,"s3://crabby-images/21637/216371d3b79e9b6bde49df2c7e3ea04f1afacefa" alt=""
- However this shell is of low privilege, so we need privilege escalation to complete the attack:
data:image/s3,"s3://crabby-images/ff055/ff0551de2753bee359924ea80bb0a582315313e5" alt=""
4 - PRIVILEGE ESCALATION
- Let's try two alternative ways to perform privilege escalation:
4.1 - Exploiting the Operating System
- From previous step we know that Tr0ll 1 is an Ubuntu 14.04 machine with kernel 3.13:
data:image/s3,"s3://crabby-images/cd36e/cd36efacdfd515eb5dfee2fb5bb062d5eb9510b0" alt=""
- Googling for an exploit for this version of machine:
data:image/s3,"s3://crabby-images/f9fac/f9fac56f3209ef18725287a206d9a05f63713be7" alt=""
- searchsploit helps us to find the privilege escalation exploit:
data:image/s3,"s3://crabby-images/66e58/66e5893ee496b1c508a05a5ffe397ce012f2d0dd" alt=""
data:image/s3,"s3://crabby-images/ddb29/ddb2952d2c948e032c7fae5dfc3b2c4dd9021778" alt=""
- The path to find the exploit is:
data:image/s3,"s3://crabby-images/b6485/b6485589e719a011e221149c97202409c5efd6d6" alt=""
data:image/s3,"s3://crabby-images/e2b50/e2b5009fd85e70163ee3e3862876ae4cfc54723a" alt=""
- Looking for 37292.c:
data:image/s3,"s3://crabby-images/f59e3/f59e36ff29b43b7a21a4c73b273aaa4112ad3cc2" alt=""
- Setting a SimpleHTTPServer at port 8000 of the attacker Kali:
data:image/s3,"s3://crabby-images/2dfb7/2dfb71332b2e6eb229c3db3b291170e9e21dffb0" alt=""
- Going to the remote shell at Tr0ll1, let's change to directory /tmp, what is usually writable:
data:image/s3,"s3://crabby-images/f2c57/f2c57e89dfb2dece9e5551a3fc309da10a968c28" alt=""
- Downloading 37292.c from Kali:
data:image/s3,"s3://crabby-images/77211/77211df82b32dac8678096956020b252d55c98b3" alt=""
- Compiling 37292.c:
data:image/s3,"s3://crabby-images/ec707/ec7076e28ea804b1369beb3d16b909889d7e313a" alt=""
- Running the executable 37292 we get finally a root shell:
data:image/s3,"s3://crabby-images/3ba99/3ba994f91a8d756b50456c5f307cbd26cef50960" alt=""
4.2 - Exploiting crontab bad configuration
- It is noticeable that every some minutes the SSH connection is closed by the remote host, sending back a laughing message:
data:image/s3,"s3://crabby-images/b6482/b6482139b0f1da70f52ae7e4ee4f5a1754a25a92" alt=""
- At the same time the content of /tmp is removed by the remote host:
data:image/s3,"s3://crabby-images/adc67/adc67ab768e83cafe00135f4466d604f81d728cb" alt=""
- These two circumstances make us think that probably a crontab job is working here.
- However, when searching for crontab permissions are denied:
data:image/s3,"s3://crabby-images/6c88b/6c88bcd1a1c63aad754ace357192434a58ba273b" alt=""
data:image/s3,"s3://crabby-images/581fe/581fefb44b814f686758c00a9c993b8fd95e0a9b" alt=""
- Looking for writable areas:
data:image/s3,"s3://crabby-images/0202d/0202d0c34cccd00048791c1ab7fe368db5d80694" alt=""
data:image/s3,"s3://crabby-images/cd7dd/cd7ddf0d0fd99d8795e778d3d917a14d8cb3cd07" alt=""
data:image/s3,"s3://crabby-images/5628d/5628d66143a16f209f99869d37706226aecdbefb" alt=""
- Going to cronlog we detect the presence of a script called cleaner.py running every 2 minutes via crontab:
data:image/s3,"s3://crabby-images/23467/23467e7794d5a71022073b2386666cd7982ae229" alt=""
- Let.s find it:
data:image/s3,"s3://crabby-images/da698/da698eb7e2142436f33d13da809a91db4d68c326" alt=""
data:image/s3,"s3://crabby-images/819d0/819d00adf927a10be4120f8f1a243afc322631f2" alt=""
- Interestingly, cleaner.py has full root privileges:
data:image/s3,"s3://crabby-images/f982f/f982fa69ccb08885543f88c87473d04115c78dd9" alt=""
- Reading the content of cleaner.py we understand now why tr0ll1 is clearing all content of /tmp every 2 minutes:
data:image/s3,"s3://crabby-images/6f929/6f92918a807c6cbfce7056c9564d805daa9031f0" alt=""
data:image/s3,"s3://crabby-images/d685c/d685cafc449df3f2369bd56916ed024b4ff0ab44" alt=""
- Now, the idea that comes to our mind: why not change the content of the script on our own interest? For instance, providing the user overflow with sudo privileges to run a root shell.
- Let's check that at this moment the user overflow does not have any sudo privileges:
data:image/s3,"s3://crabby-images/bca58/bca587f2728a41a6deae11f321c852f43cca3bff" alt=""
- Editing cleaner.py to assign all sudo editing privileges to the user overflow:
data:image/s3,"s3://crabby-images/70814/70814706277556f0c2d969be1bfd53817ff4cdbe" alt=""
data:image/s3,"s3://crabby-images/eeadc/eeadce3bd5ef0920abba12558c05253a899c1fcb" alt=""
- Waiting until the period expires, tr0ll1 kicks me out of the SSH connection:
data:image/s3,"s3://crabby-images/210a6/210a621c5f28fc10f7687246322f4c24cdeea1b4" alt=""
- Reconnecting again with SSH:
data:image/s3,"s3://crabby-images/0e85f/0e85f5e5a77961a2807d672a17b23447f73ec251" alt=""
- Eventually user overflow gives us a root shell:
data:image/s3,"s3://crabby-images/423bb/423bbeba29964618a3f0f97ad90211413a570a9a" alt=""
- Being root we can look deeper into the crontab works to understand what was happening at tr0ll1:
data:image/s3,"s3://crabby-images/aa2d0/aa2d07b5fea5fd847327282f802b29e64c0ad662" alt=""
data:image/s3,"s3://crabby-images/0fbb8/0fbb887eb8a16a484e591a8c886706b616d96718" alt=""
data:image/s3,"s3://crabby-images/53c07/53c07ad30ccb52bca0612322e50419b666b32fc7" alt=""
data:image/s3,"s3://crabby-images/464a6/464a61df9e71985bcc6368901f263f8f664d2e16" alt=""
- Every 5 minutes the script lmao.py sends back a teasing message and also kills the session for the user overflow:
data:image/s3,"s3://crabby-images/19f19/19f190161de93f80da031b0ea1f1ec35411ec521" alt=""
5 - CAPTURING THE FLAG
- Going to the /root folder we finally read the flag proof.txt:
data:image/s3,"s3://crabby-images/4533e/4533eb157d0fc3dc31df2d887f9400795fa2200c" alt=""