MERCY
- Layout for this exercise:
data:image/s3,"s3://crabby-images/b153e/b153e36d3b8dbbb617d69e096b5669ab71d32ccf" alt=""
1 - INTRODUCTION
- The goal of this exercise is to develop a hacking process for the vulnerable machine MERCY.
- MERCY can be found here:
https://www.vulnhub.com/entry/digitalworldlocal-mercy,263/
- Once downloaded and extracted with VirtualBox:
data:image/s3,"s3://crabby-images/813d6/813d673911666e2f8523ffc5e8bf3522b3a7cbbf" alt=""
2 - ENUMERATION
- Discovering MERCY's IP:
data:image/s3,"s3://crabby-images/676eb/676ebc4be1e28a2412e557f3cf7cac7b584a11df" alt=""
data:image/s3,"s3://crabby-images/ddc7e/ddc7e05668fb457158c78cc039c97d626e315d2c" alt=""
- Scanning with Nmap:
data:image/s3,"s3://crabby-images/53842/538422857ddf3efc9c23df234e9dcb40bf39aed1" alt=""
- Going deeper within port 8080 HTTP, it seems that Apache Tomcat/Coyote engine JSP 1.1 is being run:
data:image/s3,"s3://crabby-images/589b8/589b87051977e5120166bfe8166118f35a0ac706" alt=""
- Dirbusting the web server at port 8080:
data:image/s3,"s3://crabby-images/b5c77/b5c77228f0275e5c3d9072d0da02af34fd0af912" alt=""
- So we have some interesting folders to explore, like robots.txt, /tryharder/tryharder and /manager.
- Connecting with the browser:
data:image/s3,"s3://crabby-images/909af/909af6ac10c443ceb7c1772f2b9699f3d1e16d0b" alt=""
- Reading robots.txt:
data:image/s3,"s3://crabby-images/1ccfd/1ccfdc43310b536c9f7a77df81027d5a2acb58dc" alt=""
- Checking folder /tryharder/tryharder we find a string encoded with Base64:
data:image/s3,"s3://crabby-images/60c16/60c16a3d5a5f3769f894dab57e5e500615af2f32" alt=""
- Decoding:
data:image/s3,"s3://crabby-images/18290/1829014e4fecd06ec3d498635437c912ab764b29" alt=""
- From the message we can write down that it might be a use with password password.
- Going to /manager:
data:image/s3,"s3://crabby-images/4e194/4e1946c499238d9c79512fad21b9381df7cea4eb" alt=""
- Also, port 445 is open, so why not enumerating with enum4linux taking advantage of the Samba server?
data:image/s3,"s3://crabby-images/28e41/28e4155ca2550dbe299a1673db7284bce1df5cdd" alt=""
data:image/s3,"s3://crabby-images/072e5/072e56d59a62268f63e646fa23a8cb32a300f356" alt=""
data:image/s3,"s3://crabby-images/08ffb/08ffb9672a04f3afbf8477368956472f7098f4f6" alt=""
- So there are 4 Local Users: pleadformercy, qiu, thisisasuperduperlonguser, fluffy.
- Launching Hydra over the Samba server with the text file usernames and the wordlist rockyou.txt:
data:image/s3,"s3://crabby-images/b7205/b7205d461a7636690228be99c980068ade73be5d" alt=""
data:image/s3,"s3://crabby-images/f1362/f1362ba30602dbafd2d847e15daa6efbacac5f23" alt=""
- Connecting to the Samba server with credentials qiu:password" (remembering the Base64 decoded string):
data:image/s3,"s3://crabby-images/427b7/427b7ff8ae5900e0c2dfa7c226f715f2ab30d1b3" alt=""
- Listing contents:
data:image/s3,"s3://crabby-images/39d7e/39d7e363423034f9340186bb738059cccca23d8b" alt=""
- Getting .bash_history:
data:image/s3,"s3://crabby-images/9e53a/9e53a19f083fe63e04c45bb410ade066d3e28214" alt=""
- Goint to folder .private:
data:image/s3,"s3://crabby-images/21025/2102501b5bdd969c7640e863792dfcad38839f43" alt=""
- Getting readme.txt:
data:image/s3,"s3://crabby-images/c83e9/c83e9101c11b340bff7c44c9dcbdd8b7a1d0678f" alt=""
- Going to secrets there is nothing inside:
data:image/s3,"s3://crabby-images/17006/17006b211f673a2f4b0ac0ba11315c01e8aad49d" alt=""
- Going to folder opensesame and getting configprint and config:
data:image/s3,"s3://crabby-images/968f8/968f8775c3969a3b5018206d656c1b638099f128" alt=""
- Reading .bash_history:
data:image/s3,"s3://crabby-images/ff7ec/ff7ec835e3a7268937913afe26de2ff80be92011" alt=""
- Reading readme.txt:
data:image/s3,"s3://crabby-images/173e6/173e6fa0a2b0b78c1f712058da71e1ba3a331421" alt=""
- Reading configprint, there are a lot of references to config:
data:image/s3,"s3://crabby-images/980bb/980bb930248f447cd476005d72b2d69c5cd7d7fa" alt=""
- Reading config we find information about filtered services HTTP at port 80 and SSH port 22:
data:image/s3,"s3://crabby-images/cdfb1/cdfb1559477d9f3ed4c35fd986b7ddec6d3a0559" alt=""
- Actually both ports 22, 80 are filtered:
data:image/s3,"s3://crabby-images/cbf3b/cbf3bffd2157c78aa59cbda0cc6f9ca10d732c94" alt=""
- Because several sequences are quoted we can imagine that knock command must be used to open filtered services, for instance HTTP port 80:
data:image/s3,"s3://crabby-images/1d0f9/1d0f95159bf5e64d82d135ee0f8cddf9017232a4" alt=""
- Same thing for SSH port 22:
data:image/s3,"s3://crabby-images/1622c/1622ce735feb0b487d1d1d0f639b4b61ef41d758" alt=""
- Now, connection with the browser is available:
data:image/s3,"s3://crabby-images/07870/0787092c772670bfb118c68b635b787d433c84b6" alt=""
- Dirbusting port 80:
data:image/s3,"s3://crabby-images/e56e6/e56e6114576f596855c15630efb2a1cf9f64893e" alt=""
- Reading robots.txt we discover two additional folders: /mercy and /nomercy:
data:image/s3,"s3://crabby-images/74099/7409987c366d428a362e2a299c0927322e0dc229" alt=""
- Going to /mercy:
data:image/s3,"s3://crabby-images/c6f0a/c6f0a41bd99031b84d8229d7299331d226e1674d" alt=""
data:image/s3,"s3://crabby-images/df391/df391fd275b90aaa319903dc0a2491e338b0ca81" alt=""
- Going to /nomercy the RIPS 0.53 application is running:
data:image/s3,"s3://crabby-images/9eb42/9eb420c18ca5caa1534312965b134a1414fcf31c" alt=""
3 - EXPLOITATION
- Searching for RIPS exploits we find a Multiple LFI exploit:
data:image/s3,"s3://crabby-images/190f4/190f402108437fdf1ec39d4898fe3fad17d3dfbd" alt=""
data:image/s3,"s3://crabby-images/40db1/40db1759f2a8388e78a0328571b10c1e3a14f0e8" alt=""
- Reading 18660.txt:
data:image/s3,"s3://crabby-images/25db2/25db2d0c5a6d0240a6b51b260080d60be98c0efc" alt=""
- Applying the LFI to /etc/passwd:
data:image/s3,"s3://crabby-images/68af6/68af6f47c2b97da09823244ab87daceaaf839de7" alt=""
- However it doesn't work with /etc/shadow:
data:image/s3,"s3://crabby-images/3785b/3785b179c2abc749a88ac2dbbf9d948ed78b7ae3" alt=""
- Remembering the existence of a tomcat-users.xml file:
data:image/s3,"s3://crabby-images/33bfb/33bfbbfb711427bb137242645589f9105b52eb00" alt=""
- Extracting tomcat-users.xml:
data:image/s3,"s3://crabby-images/61eda/61edaf8576a2bb45a2a29fe64b4aaa551097bbf1" alt=""
- Last lines give unvaluable information about 2 users and correspondent usernames:
data:image/s3,"s3://crabby-images/93668/93668cd3dd0e87dedd439f575418dc5daf63ed3e" alt=""
4 - GETTING A SHELL WITH METASPLOIT
- Launching Metasploit:
data:image/s3,"s3://crabby-images/4257a/4257a409f5352c88d2606047c27ea725dcb2f4d9" alt=""
- Using this exploit for Tomcat:
data:image/s3,"s3://crabby-images/174e8/174e86082b356e23176eba3340a3a1ab89004f10" alt=""
- Setting options and running the exploit we get a Meterpreter session:
data:image/s3,"s3://crabby-images/9e5bb/9e5bb99b8f7f59ed87a3ac68ee8965e8e716b401" alt=""
- Spawning and improving a shell:
data:image/s3,"s3://crabby-images/e87a0/e87a09c594dfab3039bb30812e14428a384e756a" alt=""
5 - PRIVILEGE ESCALATION
- Using credentials fluffy:freakishfluffybunny:
data:image/s3,"s3://crabby-images/12f47/12f4766ad27f1c8b0807e0d0ce227cc4ea99ec8c" alt=""
- Unfortunately fluffy is not a sudoer:
data:image/s3,"s3://crabby-images/1bb7a/1bb7a80d9aefb26e457ab35e8b5cf3f5846eb26c" alt=""
- Improving the shell for fluffy:
data:image/s3,"s3://crabby-images/709f4/709f4377120941040fcd78212c61b84c1a7ad4d7" alt=""
- Walking around into home folders and files until finding something useful:
data:image/s3,"s3://crabby-images/536ef/536efb0e4cd886813924bd1feac0e670b456538c" alt=""
data:image/s3,"s3://crabby-images/2c1a4/2c1a4302f27780f18f0e347913bf2113a4edc4af" alt=""
data:image/s3,"s3://crabby-images/3e0bb/3e0bb37d94ca41da216cda5fdeefda53e07e2b47" alt=""
data:image/s3,"s3://crabby-images/ff904/ff9041a55c9113bf4ed2ca5f7b51df38124950f5" alt=""
- Finally it seems that timeclok could be interesting, because it is a root owned script:
data:image/s3,"s3://crabby-images/b8ff8/b8ff8646331f926edbdbf714d7cfae3f485d6d57" alt=""
- Creating an exploit with Msfvenom:
data:image/s3,"s3://crabby-images/d2b77/d2b77749a3711b9294f623d4c2bcd329b839a0c6" alt=""
- Setting a Netcat listener:
data:image/s3,"s3://crabby-images/2cde2/2cde29d32278298e5510b7a54f12b0f4c6b05300" alt=""
- Appending the exploit to timeclock:
data:image/s3,"s3://crabby-images/1c58a/1c58ade51a8b847d16899e0360d7cf6e0a9ec75d" alt=""
data:image/s3,"s3://crabby-images/dd873/dd8731a58fed444dba42486e5bc273a375fa5379" alt=""
- After some minutes we've got a root shell:
data:image/s3,"s3://crabby-images/b02e5/b02e53e159132ada9a3900294781c60997ceef79" alt=""
data:image/s3,"s3://crabby-images/632a5/632a596dc70148e2af23a366897167a386d8ddfb" alt=""
data:image/s3,"s3://crabby-images/e0615/e06154991e6bfafa722fb0d29b4963b716156c6f" alt=""
6 - CAPTURING THE FLAG
- Reading proof.txt:
data:image/s3,"s3://crabby-images/8c9a5/8c9a5110a083950d1c6c35c1d1ea1f736295890f" alt=""