SOLIDSTATE
- Layout for this exercise:
data:image/s3,"s3://crabby-images/c4ba9/c4ba924759a51c664a09de2030dbc6143b9c1579" alt=""
1 - INTRODUCTION
- The goal of this exercise is to develop a hacking process for the vulnerable machine SolidState, what is a retired machine from the Hack The Box pentesting platform:
https://www.hackthebox.eu
2 - ENUMERATION
- SolidState's IP is 10.10.10.51:
data:image/s3,"s3://crabby-images/ccabc/ccabc4bc8fa01701ba7b1086de1ae0ae94a9a282" alt=""
- Scanning all ports with Nmap there are 6 open ports:
data:image/s3,"s3://crabby-images/4ceec/4ceec6657ef30271e47a26d1ddd4e886b6b4fc04" alt=""
- Connecting with the browser:
data:image/s3,"s3://crabby-images/3df80/3df80932a7f9bed7848fa1ceadec72aa62b95461" alt=""
- Scanning deeply those 6 open ports:
data:image/s3,"s3://crabby-images/1b1df/1b1dfba45e49a8ae1b5cca88d05115ec53079419" alt=""
- So the James Remote Admin 2.3.2 application is running on port 4555, what is vulnerable to this exploit:
https://www.exploit-db.com/exploits/35513
data:image/s3,"s3://crabby-images/7937f/7937f5418f073ff88015998d8ccea673a8f7bf10" alt=""
- Reading the content we discover default credentials root:root :
data:image/s3,"s3://crabby-images/5de23/5de234bd86d2ad23acbbff910ee24016e88755a3" alt=""
3 - EXPLOITATION
- The connection to port 4555 using credentials root:root is successful:
data:image/s3,"s3://crabby-images/36088/36088da0d6a7f7e246ed34ed98d70f49ff11eced" alt=""
- HELP lists available commands:
data:image/s3,"s3://crabby-images/8246d/8246decdf7f297092b25d6a03b8f6eda23d99f8c" alt=""
- Listing users:
data:image/s3,"s3://crabby-images/1fe5d/1fe5d6aedc8cbeea7f17dffc151309dd1b458f79" alt=""
- Resetting passwords:
data:image/s3,"s3://crabby-images/b1d9a/b1d9a7bb89ff605723ec11d6241330479c59edcb" alt=""
- Now, using these new passwords let's connect to the POP3 service running on port 110:
data:image/s3,"s3://crabby-images/e970a/e970aab92779701ace452f8397f61b73559e4fd8" alt=""
- users james, thomas and mailadmin don't have messages to be retrieved:
data:image/s3,"s3://crabby-images/5d208/5d20861b2270eed9058aaa788bb4b04c02308e69" alt=""
data:image/s3,"s3://crabby-images/918dc/918dcb0778ba42ae706faadcb3642eb5b025673c" alt=""
data:image/s3,"s3://crabby-images/b77dc/b77dc31fd936ab55faf6aa91f278fbdb3a5c3b39" alt=""
- user john has and interesting message from james, where they talk about user mindy's credentials:
data:image/s3,"s3://crabby-images/d94ce/d94ce1663f32023defadae685ef52e89540ee41b" alt=""
- However, the most interesting task is to retrieve user mindy's two messages:
data:image/s3,"s3://crabby-images/ea690/ea69090fcb856ae82328f639266976c92e2f4d6b" alt=""
data:image/s3,"s3://crabby-images/47079/4707921ecc79c8bce0565371f951bb31ec6f9b2d" alt=""
data:image/s3,"s3://crabby-images/69b4d/69b4d7258e7505a85af4a451f0bd58cfcda113cb" alt=""
- At the second message we can read the password P@55W0rd1!2@
- Using this password to try an SSH connection for mindy:
data:image/s3,"s3://crabby-images/89ab2/89ab2961d4a7968f78b34ce5ec31f6504b4efc9f" alt=""
4 - READING THE 1st FLAG
- Reading user.txt:
data:image/s3,"s3://crabby-images/d250e/d250ec8221f9d50f6fbd13dc809676354e7ffd6a" alt=""
5 - PRIVILEGE ESCALATION
- However this shell is no very powerful because a lot of essential commands are restricted:
data:image/s3,"s3://crabby-images/68286/6828674a29e43907d3fbfc473e3177b99532c654" alt=""
- To start a Privilege Escalation process let's copy locally the script of the 35513 exploit, where the payload can be modified according to our own interest:
data:image/s3,"s3://crabby-images/b3b19/b3b19be71b41489ba81c0166d98ac8dd2ddd9cf3" alt=""
- Giving execution permissions:
data:image/s3,"s3://crabby-images/98aea/98aea55bf132bc8500801c721066891f5f5411d1" alt=""
- Setting a Netcat listening session after the modified payload:
data:image/s3,"s3://crabby-images/1ac28/1ac286ae4ae755dd8831af15b4352c5c8b96ca16" alt=""
- Running 35513.py against SolidState's IP:
data:image/s3,"s3://crabby-images/b98a3/b98a3a834b4e2a4be54eb817cdd62d31a223ae9d" alt=""
- So to get the payload executed we need that somebody logs in, for instance user mindy:
data:image/s3,"s3://crabby-images/b23e7/b23e72141e61bbff3230ec1c6e9a2f2303bd4d0a" alt=""
- As a consequence there is a reverse shell that can be improved successfully:
data:image/s3,"s3://crabby-images/e252d/e252d233d8f10b84c44929f4e4dd3aa15e6b32c6" alt=""
- This shell allows more commands than the previous one:
data:image/s3,"s3://crabby-images/9e381/9e3813d32ca840299e59f7237c9e0ee0fa0c2bdf" alt=""
data:image/s3,"s3://crabby-images/65d1a/65d1ad54f6c78ef8fbcc1b0450f8459f61b3331c" alt=""
- At this point let's look for any process being run by users either mindy, james, ...:
data:image/s3,"s3://crabby-images/160ed/160eda325bf72c8715f69617b4c603297cf250b9" alt=""
data:image/s3,"s3://crabby-images/60a4c/60a4c895e746b51b80474f3341a2e59f445fe671" alt=""
- It seems that a process inside folder /opt is being run with root privileges, and going there we discover that tmp.py is owned by root and sldo it is world writable:
data:image/s3,"s3://crabby-images/02e5b/02e5b8728fe2441fa003b0c6ca617802a1ca30d4" alt=""
- Reading tmp.py:
data:image/s3,"s3://crabby-images/a5f79/a5f79567272b010e2a718f55a6c9ca69a3872518" alt=""
- Modifying tmp.py so that a shell is remotely spawn:
data:image/s3,"s3://crabby-images/85ed0/85ed06ca70066a50717af62c9f2bffb88c2a391e" alt=""
data:image/s3,"s3://crabby-images/9f1e5/9f1e57056a9f6b35b86b0f22891bf8d43da4cfa8" alt=""
- After 3 minutes a root shell is spwan:
data:image/s3,"s3://crabby-images/0b6ca/0b6caf4dd7fa40ce9e777989e3c32b98fd65105b" alt=""
- Checking that tmp.py is scheduled as a crontab job every 3 minutes:
data:image/s3,"s3://crabby-images/ad1f7/ad1f7a586dd9216e405b5b76c7180949a4ae4c5f" alt=""
6 - CAPTURING THE 2nd FLAG
- Reading root.txt:
data:image/s3,"s3://crabby-images/2ab53/2ab537797cd37076ba02a87c814f5cb5a0c923ad" alt=""