SUNDAY
- Layout for this exercise:
data:image/s3,"s3://crabby-images/df51e/df51ee986bb1a5c14d99e95c3f0fc6a96367e4f4" alt=""
1 - INTRODUCTION
- The goal of this exercise is to develop a hacking process for the vulnerable machine Sunday, what is a retired machine from the Hack the Box pentesting platform:
https://www.hackthebox.eu
2 - ENUMERATION
- Sunday's IP is 10.10.10.76:
data:image/s3,"s3://crabby-images/401f9/401f969928ad6bf4f6b9674bb3b32f37d90bdd35" alt=""
- Scanning all ports with Nmap:
data:image/s3,"s3://crabby-images/af517/af517eeac6d919a25e27cf74b160de01dc17b059" alt=""
- Scanning deeply open ports we discover that Sunday is a Sun Solaris machine:
data:image/s3,"s3://crabby-images/aea44/aea44e20b57947ade59501629d91ff12381455ae" alt=""
2.1 - Finger enumeration
- Let's focus our attention for now on port 79 where the service finger is running.
- There are a couple of ways of enumeration for finger usernames.
2.1.1 - finger-user-enum
- First, the Pearl script finger-user-enum:
data:image/s3,"s3://crabby-images/1b561/1b5611d4747e55ca967248e992f0841e74e83037" alt=""
- Once downloaded and extracted:
data:image/s3,"s3://crabby-images/80d89/80d89ebe76359925d3159076c46749124fc0dfd7" alt=""
data:image/s3,"s3://crabby-images/3d904/3d90436b5471707318e774a613570fb9ef052654" alt=""
- Options and parameters for finger-user-enum:
data:image/s3,"s3://crabby-images/89641/896410d1c2a8129e85cdf563b1e0737566be7262" alt=""
- Using as wordlist the seclists file names.txt the script discovers the two users sammy and sunny:
data:image/s3,"s3://crabby-images/e88ad/e88ad4612c82add5d8b56608d7670e923b568c70" alt=""
data:image/s3,"s3://crabby-images/eaaf3/eaaf3d44dba5e78ef412adc93ed97bb0fa22a00d" alt=""
data:image/s3,"s3://crabby-images/83384/8338431cb8d150d2cc17a2b5a6f41c71b3a5bbc6" alt=""
2.1.2 - finger_users
- Second, the Metasploit module finger_users yields the same result:
data:image/s3,"s3://crabby-images/de9dc/de9dc8d37255ff04c8d269f83db0fdea8ac743f1" alt=""
2.2 - SSH enumeration
- Medusa discovers SSH password sunday for user sunny:
data:image/s3,"s3://crabby-images/ff722/ff722eb613f1f8dd7739cb9c3aa441b70c89b8ca" alt=""
3 - EXPLOITATION
- Using credentials sunny:sunday to connect with SSH:
data:image/s3,"s3://crabby-images/a9d0e/a9d0ef5d1e3a1e70b09a86b886eb78589807470a" alt=""
- However the SSH conection is rejected, so we need to specify the algorithm diffie-hellman-group1-sha1 for being successful:
data:image/s3,"s3://crabby-images/af729/af7294d5715b0fe1354a7b42384e4b675fa1d422" alt=""
data:image/s3,"s3://crabby-images/068e8/068e8517755f7126a8d97750376e2167d8d1ce1a" alt=""
- It is interesting to notice that user sunny has got some sudoer privileges to run the file /root/troll:
data:image/s3,"s3://crabby-images/b439d/b439d46ec14908013fb028484b54ffae87b53973" alt=""
- Running /root/troll:
data:image/s3,"s3://crabby-images/8c6de/8c6de47c1a0f7923eeff0bc88e9459061e8a29c0" alt=""
- Searching and listing for anything of interest:
data:image/s3,"s3://crabby-images/71447/71447f3784329059bb0d335c824bfec9d3965fda" alt=""
- The directory /backup holds a backup of /etc/shadow:
data:image/s3,"s3://crabby-images/0eaf8/0eaf8001d92efdd758b7211e26dba5aaea5f8b28" alt=""
data:image/s3,"s3://crabby-images/18cda/18cdaafccccea02a72232161edb4f33560f7be79" alt=""
- Also, /etc/passwd is accessible:
data:image/s3,"s3://crabby-images/e7381/e738155406533baba501751ca164ec5d154b6eb7" alt=""
- Copying to Kali lines for user sammy and sunny:
data:image/s3,"s3://crabby-images/89a20/89a201ec83f952182b35bc6575c167b47a2c9725" alt=""
- Unshadowing:
data:image/s3,"s3://crabby-images/7d236/7d236576137ec62ce96528a8bb64ced610c2360c" alt=""
- Passing unshadowed file u to John The Ripper we discover password cooldude! for user sammy:
data:image/s3,"s3://crabby-images/e1df3/e1df31553ec0c76f40bc172e34a773e78d465210" alt=""
- Now, connecting to SSH with user sammy gives same problem than before, what can be solved in the previous way:
data:image/s3,"s3://crabby-images/ddc9a/ddc9a407db8d87ef48ff847e2f0b56f572ab2f10" alt=""
data:image/s3,"s3://crabby-images/c8407/c8407e2109b6a0c4bfc4d0a1c28de7da2569bd92" alt=""
- Again, we have a low privileged remote shell:
data:image/s3,"s3://crabby-images/77b92/77b923c30d41603bccb31909806605a80c2012a1" alt=""
- User sammy has got also some sudoer privileges:
data:image/s3,"s3://crabby-images/de284/de2846b74a3588ca57e9ddb978d30223f50bf4a6" alt=""
4 - PRIVILEGE ESCALATION
- There are different ways of privileges escalation, let's try 3 of them.
- First, finding binaries with the SUID bit enabled:
data:image/s3,"s3://crabby-images/5975a/5975a047d327a5ab28e23f20c3b12d657641ab7e" alt=""
- Let's pick up these two files:
data:image/s3,"s3://crabby-images/bf788/bf78824ad9eb02133895293d584ab1fc22553c82" alt=""
data:image/s3,"s3://crabby-images/2608a/2608a075cec00525edc278ad752a4d8591f39a6b" alt=""
4.1 - pfexec
- pfexec executes the command bash and the result is a root shell:
data:image/s3,"s3://crabby-images/dfe1e/dfe1e985d743dddaf0d4c4e07f674b3fba3f9863" alt=""
4.2 - Msfevnom
- Generating a payload:
data:image/s3,"s3://crabby-images/0f79b/0f79be0ad2860613307d870bf11334a9ac9eefba" alt=""
- Transferring exploit.elf from Kali to Sunday and outputting to /usr/bin/rsh:
data:image/s3,"s3://crabby-images/d952f/d952f50bb9a8a2512e509793dc25738f710afdc9" alt=""
data:image/s3,"s3://crabby-images/e7c9c/e7c9cd01be28856da2ce78353a746d5bbbae39be" alt=""
- Setting a Netcat listening session:
data:image/s3,"s3://crabby-images/be98a/be98a87e5b15a78de10a9702dc7a9f46164cbf89" alt=""
- Running /usr/bin/rsh a shell with euid=0(root) is achieved:
data:image/s3,"s3://crabby-images/afe72/afe727a52619e0c34373c4830b4ec7882ff452f6" alt=""
data:image/s3,"s3://crabby-images/249bc/249bc2452df53d5cdc837b032ca009753a53ac2f" alt=""
4.3 - wget --post-file
- The command wget allows the --post-file HTTP option, what sends the content of any file using the POST method:
data:image/s3,"s3://crabby-images/e665c/e665ccbecc26ee69c70a199d8403ac2c6f20ce5e" alt=""
data:image/s3,"s3://crabby-images/a1b86/a1b866d1db498e6cd0d8d6021bc6b4b6a42a5c91" alt=""
- Setting a Netcat session at port 80:
data:image/s3,"s3://crabby-images/75c2d/75c2d01854a9e08b4e2769ac580e2f995c070ec4" alt=""
- Sending /root/root.txt from Sunday to Kali:
data:image/s3,"s3://crabby-images/ea972/ea9728c2ce2ba227795dfb0773401317c5684ae3" alt=""
- The root.txt flag shows up at Kali:
data:image/s3,"s3://crabby-images/d5e58/d5e58651e00d0b6b39776ed7fccec08c9c1d7576" alt=""
5 - CAPTURING THE FLAG
- Also, reading root.txt:
data:image/s3,"s3://crabby-images/7cc70/7cc70e6e05fcdd8538ca09b2b58b12b2efa6e234" alt=""