ARCTIC
- Layout for this exercise:
data:image/s3,"s3://crabby-images/ac79b/ac79b9e7b5ceb7d6e299cd78aaec5b9ed68bfc80" alt=""
1 - INTRODUCTION
- The goal of this exercise is to develop a hacking process for the vulnerable machine Arctic, what is a machine from the Hack the Box pentesting platform:
https://www.hackthebox.eu
2 - ENUMERATION
- The IP for Arctic is 10.10.10.11:
data:image/s3,"s3://crabby-images/55ad3/55ad3a5df34950abda6449e91d0592697a1200dc" alt=""
- Scanning we find 3 available open ports:
data:image/s3,"s3://crabby-images/f815c/f815c13fd597fd991d02a51d2fc5732f5e889745" alt=""
- The port 8500 is used by the built-in web server of ColdFusion web development platform:
data:image/s3,"s3://crabby-images/978fe/978fea7b04242ad011f09c8ef2d2742c24980449" alt=""
- Also it could be used by the protocol fmtp (Flight Message Transfer Protocol):
data:image/s3,"s3://crabby-images/ed336/ed3360e82766539d1d214743061ea01261009a09" alt=""
- Scanning deeper port 8500:
data:image/s3,"s3://crabby-images/4d412/4d4127c966b7439e9b4166d9686a36f5e88e9261" alt=""
- Connecting to port 8500 we confirm that there is a ColdFusion server running:
data:image/s3,"s3://crabby-images/fbd73/fbd7302811f54a9418dcb0e644d4db6af9143da7" alt=""
data:image/s3,"s3://crabby-images/b4ddd/b4dddb8eee772a50d8ef4f1ec3572abe49b6bc26" alt=""
data:image/s3,"s3://crabby-images/5db3a/5db3a15ddf191f8d04b853e3c6a57d2724a9fb74" alt=""
3 - EXPLOITATION
- There is a Directory Traversal exploit for ColdFusion:
data:image/s3,"s3://crabby-images/ceb32/ceb3219c84c4714f3c74267a1bf2d6db939b9392" alt=""
data:image/s3,"s3://crabby-images/522f2/522f26a88065e7e10a189c9730f9bfadb41b67d1" alt=""
- Following the instructions of the exploit we find a password hash:
data:image/s3,"s3://crabby-images/4d9c2/4d9c23c6adfc5af592d46002a74b258694149fb6" alt=""
data:image/s3,"s3://crabby-images/a5a11/a5a11a00ee32e4579f9e1be5091024040c9d7c9b" alt=""
- The hash type is SHA-1:
data:image/s3,"s3://crabby-images/ba1db/ba1db9ea2c02af4b550082e8dd5526ae6e8a7cc2" alt=""
- Decrypting online:
data:image/s3,"s3://crabby-images/6b291/6b291137b75ae0a0eccf92fb43af4b90e4126bc5" alt=""
- Now we can use credentials admin:happyday to login as the ColdFusion Administrator:
data:image/s3,"s3://crabby-images/1582b/1582b15c673e6b8f45c3de8b21a922db4f4a2744" alt=""
data:image/s3,"s3://crabby-images/22f41/22f41f21b2844139800d480d7fb397f055dced2b" alt=""
4 - GETTING A LOW PRIVILEGE REMOTE SHELL
- Under Debugging & Logging tab there is the option of Scheduled Task, what enables us to upload files or exploits to Arctic:
data:image/s3,"s3://crabby-images/1632b/1632b0444681c1ef9941febfb4c07bb1d0fc8b39" alt=""
- Msfvenom helps to create an exploit with .jsp extension because the exploit will be actually a Java Server page run at ColdFusion:
data:image/s3,"s3://crabby-images/9e90c/9e90c8b827fe635934f34633c54cbe8c3a2dbbf8" alt=""
- Now let's transfer myexploit.jsp to Arctic uploading it with option Schedule New Task.
- First, setting a local web server at Kali:
data:image/s3,"s3://crabby-images/4e0af/4e0af875093b9c0cddf6620485664bdc20d59adc" alt=""
- It is very important to notice the location of ColdFusion webroot folder:
data:image/s3,"s3://crabby-images/e5da9/e5da9f307322be705c765486b7864a040b889c88" alt=""
- So the destination folder for myexploit.jsp will be:
data:image/s3,"s3://crabby-images/54972/54972d5b973fbdf14e35413696e22bd7b7f87c9e" alt=""
- Adding the Task and submitting:
data:image/s3,"s3://crabby-images/c038f/c038f68824518649dbb124b15cbe3e5698e8c58e" alt=""
- The task is successfully added:
- To run the task there is two options. The first option works just by clicking the green tab:
data:image/s3,"s3://crabby-images/d4e69/d4e693f194f6af8c8663e5a200e410bb89701bcd" alt=""
- The second option works by clicking at the index page:
data:image/s3,"s3://crabby-images/f60a1/f60a15c6ad2a02562ccf100845378ff12d757a83" alt=""
data:image/s3,"s3://crabby-images/a6396/a63960085ba7be659718d4293d1589db7e233e5c" alt=""
- Anyway the exploit is successful and we get a remote low privilege shell:
data:image/s3,"s3://crabby-images/24bbe/24bbe5d3e4580c0232f25b22e28202eb9068cf06" alt=""
5 - CAPTURING THE 1st FLAG
- Reading user.txt:
data:image/s3,"s3://crabby-images/ba42a/ba42ac61349b4c4caeecb7e94b2ecd42f2f688dc" alt=""
6 - PRIVILEGE ESCALATION
- Access to Administrator's Desktop is not possible for user tolis, so we need Privilege Escalation:
data:image/s3,"s3://crabby-images/d0120/d0120b88d5393db4bf29c704ad687856cf4cfb4a" alt=""
data:image/s3,"s3://crabby-images/4250a/4250a936ca239004579d444ea9c1c3879da3d8d9" alt=""
- Let's notice that Arctic is using an x64 architecture:
data:image/s3,"s3://crabby-images/951b2/951b23a79d61c473661da55ebd2fc3d7701a2f80" alt=""
- Msfvenom creates an executable exploit for architecture x64:
data:image/s3,"s3://crabby-images/c1599/c159905f5bd2d5d424cf52a0faceb39aefe03412" alt=""
data:image/s3,"s3://crabby-images/b33c8/b33c8eee027d5b969f2b16845dc12e7db917aa00" alt=""
- Transferring exploit_system.exe to Arctic:
data:image/s3,"s3://crabby-images/6d6a5/6d6a51ea54df2e8956d3cb053dbb807118d94787" alt=""
- The transfer is successful:
data:image/s3,"s3://crabby-images/63114/631141028974b69fe7d80aa351fbbaa4b1a866ea" alt=""
- Setting a meterpreter listening session:
data:image/s3,"s3://crabby-images/2237f/2237fa4ab9ae4c82dbc1755fbe3663dcce5a730b" alt=""
- Executing exploit_system.exe:
data:image/s3,"s3://crabby-images/452fd/452fdab02d1626a6a9c440913f87fca462ea1d23" alt=""
- The consequence is a Meterpreter session with low privileges because the user is still tolis:
data:image/s3,"s3://crabby-images/84351/843518a4b0e86ba55c0bc8e56540681d3d39efc2" alt=""
data:image/s3,"s3://crabby-images/12d0f/12d0f618dfaab99315cabe873ba3c2aaed958a9f" alt=""
- Backgrounding the session:
data:image/s3,"s3://crabby-images/d8246/d8246f49b391c142de448786edb4c6f7c2368f2e" alt=""
- Searching for a Local Privilege Escalation exploit for Meterpreter Session 1:
data:image/s3,"s3://crabby-images/6fae5/6fae5730e263887dfced17a5d5c4ca19c58373dc" alt=""
- The exploit is completed but no session is created. Why? The reason is that Metasploit took the IP 192.168.1.19, instead of the VPN interface's IP:
data:image/s3,"s3://crabby-images/094d6/094d6f14bd2caec0803b632212424176a9d6d0e6" alt=""
- Setting as local host the IP corresponding to Artic's VPN interface the problem is solved:
data:image/s3,"s3://crabby-images/65e2b/65e2bb13310378f4fae069e733a2c44634e55fb6" alt=""
- Finally we've got a remote System shell with all the privileges:
data:image/s3,"s3://crabby-images/4dbe2/4dbe279c959a62b0337c5d3e37a78d3d5402d82f" alt=""
7 - CAPTURING THE 2nd FLAG
- Reading root.txt:
data:image/s3,"s3://crabby-images/7e1a3/7e1a3a78ee1a90b953f955931d8d3fd8d767e007" alt=""