6.5 KiB
HackTheBox-Laboratory
Rustscan
rustscan -a 10.10.10.216 -- -A -sC -sV
.----. .-. .-. .----..---. .----. .---. .--. .-. .-.
| {} }| { } |{ {__ {_ _}{ {__ / ___} / {} \ | `| |
| .-. \| {_} |.-._} } | | .-._} }\ }/ /\ \| |\ |
`-' `-'`-----'`----' `-' `----' `---' `-' `-'`-' `-'
The Modern Day Port Scanner.
________________________________________
: https://discord.gg/GFrQsGy :
: https://github.com/RustScan/RustScan :
--------------------------------------
Please contribute more quotes to our GitHub https://github.com/rustscan/rustscan
[~] The config file is expected to be at "/root/.rustscan.toml"
[!] File limit is lower than default batch size. Consider upping with --ulimit. May cause harm to sensitive servers
[!] Your file limit is very small, which negatively impacts RustScan's speed. Use the Docker image, or up the Ulimit with '--ulimit 5000'.
Open 10.10.10.216:22
Open 10.10.10.216:80
Open 10.10.10.216:443
PORT STATE SERVICE REASON VERSION
22/tcp open ssh syn-ack ttl 63 OpenSSH 8.2p1 Ubuntu 4ubuntu0.1 (Ubuntu Linux; protocol 2.0)
80/tcp open http syn-ack ttl 63 Apache httpd 2.4.41
| http-methods:
|_ Supported Methods: GET HEAD POST OPTIONS
|_http-server-header: Apache/2.4.41 (Ubuntu)
|_http-title: Did not follow redirect to https://laboratory.htb/
443/tcp open ssl/http syn-ack ttl 63 Apache httpd 2.4.41 ((Ubuntu))
| http-methods:
|_ Supported Methods: OPTIONS HEAD GET POST
|_http-server-header: Apache/2.4.41 (Ubuntu)
|_http-title: The Laboratory
| ssl-cert: Subject: commonName=laboratory.htb
| Subject Alternative Name: DNS:git.laboratory.htb
| Issuer: commonName=laboratory.htb
| Public Key type: rsa
| Public Key bits: 4096
| Signature Algorithm: sha256WithRSAEncryption
PORT 80/443 (HTTP/HTTPS)
On visting port 80 I was redirected to https with a domain laboratory.htb
data:image/s3,"s3://crabby-images/e3690/e369014bd85a3eeb7a1fbc65ad6557387010334b" alt=""
So let's add this to /etc/hosts
file
data:image/s3,"s3://crabby-images/fec85/fec85d536a52a47bab0cc2442783c607ba2f38c3" alt=""
data:image/s3,"s3://crabby-images/1f1b1/1f1b13c63e42f3b9ad85382059234f5ce59edd29" alt=""
Running dirsearch was pointless because couldn't find anything
data:image/s3,"s3://crabby-images/72743/72743f649d34b7d5473821317502c1cd1497edc4" alt=""
But I did saw a subdomain from the nmap scan git.laboratory.htb
on adding to /etc/hosts
data:image/s3,"s3://crabby-images/c5164/c5164ed9ea8469d7dc56aa20b97b76c0ca21d7b8" alt=""
data:image/s3,"s3://crabby-images/2afff/2afff9bbbcad3af92567c9d3adc96a41c01c4bdd" alt=""
We could not sign in since we have not found any users so I registered an account
data:image/s3,"s3://crabby-images/ad157/ad1570510dc79009a3526117fc25a759c3e11852" alt=""
On logging in we can't see anything useful
data:image/s3,"s3://crabby-images/0cb65/0cb653b9426bf7d5ceb6af4680a9e25f97bce6d2" alt=""
But going to help page we see the version number of gitlab which is 12.8.1
data:image/s3,"s3://crabby-images/15959/15959b037cc86a51eaa0bd501d6e31ab446d2afd" alt=""
Searching an exploit for this version I found one RCE
https://github.com/dotPY-hax/gitlab_RCE
Edited the email for the payload
data:image/s3,"s3://crabby-images/a3d81/a3d81edc3938644e7801b21030937d01fc4cbc3b" alt=""
data:image/s3,"s3://crabby-images/22695/226959af10e16f5d2c080cb576aa8681b2e00031" alt=""
data:image/s3,"s3://crabby-images/22acc/22acc80d781567916afad48dffa3a302cc2c4ed4" alt=""
But it was not stable
data:image/s3,"s3://crabby-images/25fe5/25fe57fbaedfecfc3cc6092364f4ca540c696c02" alt=""
I grabbed the secrets.yml
through unstablized shell also realized that this was a docker container
data:image/s3,"s3://crabby-images/556dc/556dc2992906e5a485e0dd73f20771c97fb4ac21" alt=""
It was unstable so I decide to go for metasploit
https://www.rapid7.com/db/modules/exploit/multi/http/gitlab_file_read_rce/
data:image/s3,"s3://crabby-images/3e361/3e361d8fe3556d722ad113b7eafa63dddfdc7c1b" alt=""
These are the options you would have to set
data:image/s3,"s3://crabby-images/ac7ba/ac7ba04b78d456c9a3c43b7ffe8effaca1ff70da" alt=""
And we get a bash prompt
data:image/s3,"s3://crabby-images/77ff8/77ff8ec5f0449a584a1d52cb60fa04f82b763820" alt=""
To get a more stablized shell
data:image/s3,"s3://crabby-images/a5cfd/a5cfddd54db34faf36aaa9ae5d232eea0c09c4a0" alt=""
data:image/s3,"s3://crabby-images/0d7e0/0d7e0f36979daa3f92dcca2d0f468dfd4e44b1f7" alt=""
I searched for pentesting gitlab
and found a website that had some juicy information about what to look for
data:image/s3,"s3://crabby-images/7e71b/7e71b3cfcaf244634c890b6f16e11a317146ff4f" alt=""
data:image/s3,"s3://crabby-images/631b4/631b46b1620fae4448f1dd99900b65a35808613d" alt=""
I saw a user dexter
that had a a repository
data:image/s3,"s3://crabby-images/bcc8b/bcc8bd90f1d2b42637b0fde374e00e27158f8287" alt=""
But there wasn't anything intersting there looking back at that directory I saw two files having secret
in them
data:image/s3,"s3://crabby-images/84790/84790e8d1c10efc68c1f27aac438c8214f0ca6f6" alt=""
Didn't found anything then I came across a report that was submitted on hackerone regarding gitlab
https://hackerone.com/reports/493324
data:image/s3,"s3://crabby-images/443e0/443e09ebf76b0a6272ef3f268932b3498f8c6f7e" alt=""
data:image/s3,"s3://crabby-images/c9785/c9785c944c4c61eb359c86cb9e3e40283c6000d4" alt=""
But this didn't worked so I searched for gitlab shell change user password
and found documentation
data:image/s3,"s3://crabby-images/7846a/7846aef581149366f7cf0a95cd8264b09670e8ba" alt=""
After going through this I came to know that we can reset a user's password on gitlab
data:image/s3,"s3://crabby-images/398a5/398a58b2aa9df7262e055e047ab5c39d5a4065bd" alt=""
And we logged in as dexter
data:image/s3,"s3://crabby-images/b48e6/b48e608f33360e6076dd3a623421aec69846b242" alt=""
data:image/s3,"s3://crabby-images/8beaf/8beaf12e849a50d188eb7327d51f35cc2ffa95f4" alt=""
data:image/s3,"s3://crabby-images/4d4d6/4d4d6ecdece414064454157c482a0070ea658871" alt=""
We see a ssh key so we can login as dexter
data:image/s3,"s3://crabby-images/8eac2/8eac2ad388e5ef440743513dac17ed3f5bbef075" alt=""
There was a cron job running
data:image/s3,"s3://crabby-images/75c03/75c037e034ee2bfa021fd7a26ded53b10daa0abd" alt=""
But I couldn't run docker
data:image/s3,"s3://crabby-images/d08f4/d08f49e002133a31ea4b63270cb66770f42aec70" alt=""
Because we don't have permissions to execute. So here I spend a lot of time running linpeas
, manual going through folders but found nothing then I looked for SUID
data:image/s3,"s3://crabby-images/800b7/800b745307e0bc0027418832fdc215358815718a" alt=""
data:image/s3,"s3://crabby-images/a0dbf/a0dbf4d5c013c710e986a8ab2bb0017919474aa0" alt=""
data:image/s3,"s3://crabby-images/ae22f/ae22f8d2d600b422718117d8a7f43d8f1b370f10" alt=""
We see that it's using chmod
so we can exploit PATH variable
#!/bin/bash
bash
data:image/s3,"s3://crabby-images/1f732/1f7329cda97a568da24aa317d7130d443652b45f" alt=""
data:image/s3,"s3://crabby-images/aa380/aa380bbdb74db39a5928372f1914084ce53e9a22" alt=""