BASTION
- Layout for this exercise:
data:image/s3,"s3://crabby-images/aa8cc/aa8cc6db4f645dd4b2cd6c3ae48e9a0763e50f75" alt=""
1 - INTRODUCTION
- The goal for this exercise is to develop a hacking process for the vulnerable machine Bastion from Hack The Box pentesting platform:
https://www.hackthebox.eu/
2 - ENUMERATION
- Bastion's IP is 10.10.10.134:
data:image/s3,"s3://crabby-images/bedf0/bedf0cd691a891e8b670b372f478237573169ff1" alt=""
- Scanning with Nmap there are four open ports: 22, 135,139 and 445.
data:image/s3,"s3://crabby-images/10830/108309ebd68181c55c6fd9dc9263dcadc8174f1c" alt=""
- Scanning deeper those four ports it seems that we have an SMB service running on port 445:
data:image/s3,"s3://crabby-images/f844f/f844f11aa2032402ff88fd05c8b6ed96d91de1cd" alt=""
data:image/s3,"s3://crabby-images/9660c/9660c6646fe356697698a2b3a32deed807836e9e" alt=""
- This Nmap script enumerates the four shared folders:
data:image/s3,"s3://crabby-images/7257a/7257aa30ea28dbd2d7898de5e8de09f7dce2c63a" alt=""
- Connecting with smbclient:
data:image/s3,"s3://crabby-images/6bff4/6bff4fe9aff596677aa620204ad3611f603c421d" alt=""
- As expected, both ADMIN$ and C$ are not accessible:
data:image/s3,"s3://crabby-images/f2216/f22168aa202e5fee279b2a592897b9db5c5783c4" alt=""
- IPC$ seems accessible, but it does not yield any valuable information:
data:image/s3,"s3://crabby-images/dea24/dea241cf32376d553f91c58941bb3c8a3befcafb" alt=""
- However folder Backups gives us a lot of very important information about Bastion:
data:image/s3,"s3://crabby-images/212f0/212f07e36bffc07329690bcb5e8715ed220227d5" alt=""
- Getting and reading note.txt it gives us a hint about backup related problems:
data:image/s3,"s3://crabby-images/cba54/cba54f151f8d013c87969c8a142ba2784674df9a" alt=""
data:image/s3,"s3://crabby-images/017c7/017c7f185762a9c68ec3559f44e7149b64f45532" alt=""
- Getting and reading SDT65CB.tmp it seems that the file is empty:
data:image/s3,"s3://crabby-images/505ff/505ffa179e42f9e3ba49cf086975ebbe75da535c" alt=""
data:image/s3,"s3://crabby-images/23e7e/23e7e42b5eb3568aa575c1ae8c2f79d4d91b6515" alt=""
- Going into folder WindowsImageBackup\L4mpje-PC\Backup 2019-02-22 124351:
data:image/s3,"s3://crabby-images/45fe6/45fe68e32b4df070f4f8f27356b63a7056cbc25e" alt=""
- There are some .vhd and .xml files:
data:image/s3,"s3://crabby-images/b9757/b9757ae894ed0d2fd73a37d8433d7a2b705815fa" alt=""
- VHD (Virtual Hard Disk) is a file format representing a virtual hard disk drive (HDD).
- It may contain what is found on a physical HDD, such as disk partitions and a file system, which in turn can contain files and folders.
- It is typically used as the hard disk of a virtual machine.
https://en.wikipedia.org/wiki/VHD_(file_format)
- Getting the 1st .vhd file and applying command strings over it we find a lot of strings, but nothing that could lead to find any interesting hint for our purpose:
data:image/s3,"s3://crabby-images/a65a7/a65a762388326e42bbb4743224475331b7baec9d" alt=""
data:image/s3,"s3://crabby-images/c604b/c604ba1815fec5a87b91b1753c2d13ce251ffa1e" alt=""
............................
3 - EXPLOITATION
3.1 - Mounting the backup .vhd disk
- About the 2nd .vhd disk it is too large (5.4 GB) to check with strings, so it would be a better solution to mount it locally.
- Installing cifs-utils:
data:image/s3,"s3://crabby-images/beb3c/beb3cbc7269d17996be505d9ec92a4f48902cef9" alt=""
- Creating folder /Backups:
data:image/s3,"s3://crabby-images/47bb9/47bb92687c79f6a6ce4a993151d92d0afcaebcef" alt=""
- Mounting locally the shared folder /Backups:
data:image/s3,"s3://crabby-images/35e69/35e693e4d3b805c0f9f01f260d03dd8e480d9176" alt=""
- The mounting process is successful:
data:image/s3,"s3://crabby-images/a19ac/a19ac21804da1d62dd6d10e2e4de24bef22b15a8" alt=""
- Looking for the 2nd .vhd disk:
data:image/s3,"s3://crabby-images/03e41/03e41ffb6e9412f09217ebb9d691963ffab591b6" alt=""
- The guestmount program can be used to mount virtual machine filesystems and other disk images on the host.
- It uses libguestfs for access to the guest filesystem, and FUSE (the "filesystem in userspace") to make it appear as a mountable device.
http://libguestfs.org/guestmount.1.html
- Installing libguestfs-tools:
data:image/s3,"s3://crabby-images/d32bd/d32bdb59d1e448843aea0ae66d36f6132046536f" alt=""
- Creating folder /vhd2:
data:image/s3,"s3://crabby-images/08e7d/08e7df35e7933dca28d77dcfef639dbd66ee9b58" alt=""
- Using guestmount to mount the 2nd .vhd disk on local folder /mnt/vhd2:
data:image/s3,"s3://crabby-images/f5c32/f5c32d3504454d6e100dfd9bfc57cc42903fc3bf" alt=""
- The mounting process is successful, so now we have access to the whole backup disk .vhd2:
data:image/s3,"s3://crabby-images/0edf1/0edf1f5725c51440891db2a9473946b9ab5c7433" alt=""
data:image/s3,"s3://crabby-images/adb1a/adb1a6bc43adc76be1437f872604f1644da32d6d" alt=""
3.2 - Getting the Security Account Manager (SAM)
- The Security Account Manager (SAM) is the database where Windows systems store users's passwords.
- The user passwords are stored in a hashed format in a registry hive either as a LM hash or as a NTLM hash.
- Bastion is a Windows Server 2016 so it uses NTLM hashes for sure.
- This file can be found in %SystemRoot%/System32/config/SAM and is mounted on HKLM/SAM:
data:image/s3,"s3://crabby-images/71421/7142135fc131addc133faf795168cc4829cdb2ac" alt=""
- Using samdump2 to retrieve hashes from Bastion's users:
data:image/s3,"s3://crabby-images/6ebaa/6ebaa3b6411bcb4efb6f8863edeaacaa2488b886" alt=""
data:image/s3,"s3://crabby-images/75188/751887e0f00f3096433a8c66c0d126cb37bf9c73" alt=""
data:image/s3,"s3://crabby-images/d037b/d037b1325b78b9d90a3d916d9a55cc2f42582bf2" alt=""
- Accounts Administrator and Guest are disabled, so let's write down hash for user L4mpje:
26112010952d963c8dc4217daec986d9
3.3 - Cracking the NTLM hash
- Hashkiller works online to decrypt the NTLM hash found in previous point:
data:image/s3,"s3://crabby-images/c1cb1/c1cb1d6c6ee2a20fa117fde53780437181c5bc64" alt=""
data:image/s3,"s3://crabby-images/da564/da56498df4407564920e120b21585e5641957418" alt=""
3.4 - Getting a remote shell
- Now, using credentials L4mpje:bureaulampje we have an SSH connection and a remote shell:
data:image/s3,"s3://crabby-images/e866d/e866dd14e39b45b00ff573a860d38a3e6a5e4a3c" alt=""
data:image/s3,"s3://crabby-images/ea3d6/ea3d625fb26f896cdadb8ceda45ff8e6f4f5567b" alt=""
data:image/s3,"s3://crabby-images/9bd1f/9bd1f199b7e094a14c71ac24332c3a6212c52794" alt=""
4 - CAPTURING THE 1st FLAG
- Reading user.txt from user l4mpje's Desktop:
data:image/s3,"s3://crabby-images/a3c11/a3c117f55935c7cdf5178f270b93678de2e68d7b" alt=""
5 - PRIVILEGE ESCALATION
- As expected Administrator's Desktop is not accessible, so we need some type of Privilege Escalation:
data:image/s3,"s3://crabby-images/428a1/428a1c2b3266fb765661c63f1914536a94fbea76" alt=""
- Browsing around with the command line we check the presence of the .vhd and .xml files found before:
data:image/s3,"s3://crabby-images/3b725/3b7252a1f4743d49dc80c27a4d50f8ee91d83539" alt=""
- Going to L4mpje's home folder:
data:image/s3,"s3://crabby-images/058bc/058bce3ab647392db7ce1896089abfdc81f45c2f" alt=""
- However looking for hidden folders we discover a lot more available resources:
data:image/s3,"s3://crabby-images/01c80/01c80c8ca9acf685e1a0d0915ccf0d91c3b066d0" alt=""
- Going inside AppData\Roaming there is a very interesting folder named mRemoteNG:
data:image/s3,"s3://crabby-images/bb595/bb595e802bbedd57ebdf6ada4e3a7c7c54116faa" alt=""
data:image/s3,"s3://crabby-images/72b5b/72b5be45cbe60f5320814189707d8673e596a291" alt=""
- Actually mRemoteNG is an open source remote control and connections manager:
data:image/s3,"s3://crabby-images/fa301/fa301db3e2b3fd1bdd16d6dfd228fd5144cc59e9" alt=""
- Reading confCons.xml we find encrypted credentials for Administrator:
data:image/s3,"s3://crabby-images/15be3/15be38377684cde80aad4eaaacf3d89fe9b7f970" alt=""
- It happens that there are online available tools for dealing with mRemoteNG encrypted credentials, for instance the Python script named mremoteng_decrypt.py:
data:image/s3,"s3://crabby-images/935e6/935e63e18d68e466ab9071c16c282301e8961166" alt=""
- Launching the script without parameters to explore available optional arguments:
data:image/s3,"s3://crabby-images/e2637/e263798a2fe71b1709b60859bb0bff473df12c52" alt=""
- Applying the -s option, because the encrypted password seems to be encoded with base64 (see the final ==):
data:image/s3,"s3://crabby-images/f3ebd/f3ebdd03d7e859e2f2fc9ab808f1b5f000779a52" alt=""
- So finally we have the Administrator's password: thXLHM96BeKL0ER2
- Connecting with SSH as Administrator we have a privileged remote shell:
data:image/s3,"s3://crabby-images/84c7d/84c7d964e15d05383414aa886d6ccaaa47dfb7b8" alt=""
data:image/s3,"s3://crabby-images/83bf2/83bf2b29f03d0e9f508bdc87e9d8bbbf688ca90b" alt=""
data:image/s3,"s3://crabby-images/746ce/746ce24e25a169bb706b680603b2abd6b262dd61" alt=""
6 - CAPTURING THE 2nd FLAG
- Reading root.txt:
data:image/s3,"s3://crabby-images/43e58/43e5808128f6d6609bdad4d72b8ed6faa5881a84" alt=""