🕸️IDOR en APIs Inseguras
Última actualización
Última actualización
Hasta ahora, solo hemos utilizado vulnerabilidades de IDOR para acceder a archivos y recursos que están fuera del alcance de nuestros usuarios. Sin embargo, las vulnerabilidades de IDOR también pueden existir en llamadas de funciones y API, y explotarlas nos permitiría realizar diversas acciones como otros usuarios.
Si bien las IDOR Information Disclosure Vulnerabilities
nos permiten leer varios tipos de recursos, IDOR Insecure Function Calls
nos permiten llamar a API o ejecutar funciones como otro usuario. Dichas funciones y API se pueden utilizar para cambiar la información privada de otro usuario, restablecer la contraseña de otro usuario o incluso comprar artículos utilizando la información de pago de otro usuario. En muchos casos, podemos estar obteniendo cierta información a través de una vulnerabilidad de divulgación de información de IDOR y luego usar esta información con vulnerabilidades de llamada de función insegura de IDOR, como veremos más adelante en el módulo.
Volviendo a nuestra aplicación Employee Manager
, podemos comenzar a probar la página Edit Profile
en busca de vulnerabilidades de IDOR:
Al hacer clic en el botón Edit Profile
, se nos lleva a una página para editar información de nuestro perfil de usuario, es decir Full Name
, Email
, y About Me
, que es una característica común en muchas aplicaciones web:
Podemos cambiar cualquiera de los detalles de nuestro perfil y hacer clic en Update profile
, y veremos que se actualizan y persisten a través de las actualizaciones, lo que significa que se actualizan en una base de datos en algún lugar. Interceptemos la solicitud Update
en Burp y veámosla:
Vemos que la página está enviando una solicitud PUT
al punto final de la API /profile/api.php/profile/1
. Las solicitudes PUT
se utilizan normalmente en las API para actualizar los detalles de los elementos, mientras que POST
se utilizan para crear nuevos elementos, DELETE
eliminar elementos y GET
recuperar detalles de los elementos. Por lo tanto, se espera una solicitud PUT
para la función Update profile
. La parte interesante son los parámetros JSON que está enviando:
Vemos que la solicitud PUT
incluye algunos parámetros ocultos, como uid
, uuid
y lo más interesante role
, que está configurado en employee
. La aplicación web también parece estar configurando los privilegios de acceso del usuario (por ejemplo, role
) en el lado del cliente, en forma de nuestra Cookie: role=employee
, que parece reflejar lo especificado para nuestro role
de usuario. Este es un problema de seguridad común. Los privilegios de control de acceso se envían como parte de la solicitud HTTP del cliente, ya sea como una cookie o como parte de la solicitud JSON, dejándola bajo el control del cliente, que podría manipularse para obtener más privilegios.
Entonces, a menos que la aplicación web tenga un sistema de control de acceso sólido en el back-end, deberíamos poder establecer un rol arbitrario para nuestro usuario, lo que puede otorgarnos más privilegios. Sin embargo, ¿cómo sabríamos qué otros roles existen?
Sabemos que podemos cambiar los parámetros full_name
, email
y about
, ya que son los que están bajo nuestro control en el formulario HTML de la página /profile
. Por lo tanto, intentemos manipular los demás parámetros.
Hay algunas cosas que podríamos intentar en este caso:
Cambiar nuestra cuenta uid
por la de otro usuario uid
, de modo que podamos hacernos cargo de sus cuentas.
Cambiar los datos de otro usuario, lo que nos puede permitir realizar varios ataques web
Crear nuevos usuarios con detalles arbitrarios o eliminar usuarios existentes
Cambiar nuestro rol a un rol más privilegiado (por ejemplo admin
) para poder realizar más acciones
Comencemos por cambiar nuestro uid
por el de otro usuario (por ejemplo, "uid": 2
). Sin embargo, cualquier número que establezcamos que no sea nuestro uid
nos dará como respuesta uid mismatch
:
La aplicación web parece comparar la solicitud uid
con el punto final de la API ( /1
). Esto significa que una forma de control de acceso en el back-end nos impide cambiar arbitrariamente algunos parámetros JSON, lo que podría ser necesario para evitar que la aplicación web se bloquee o devuelva errores.
Quizás podamos intentar cambiar los datos de otro usuario. Cambiaremos el punto final de la API a /profile/api.php/profile/2
y cambiaremos "uid": 2
para evitar el error anterior uid mismatch
:
Como podemos ver, esta vez recibimos un mensaje de error que dice uuid mismatch
. La aplicación web parece estar verificando si el valor uuid
que estamos enviando coincide con el del usuario uuid
. Como estamos enviando nuestro propio uuid
, nuestra solicitud está fallando. Esto parece ser otra forma de control de acceso para evitar que los usuarios cambien los detalles de otro usuario.
A continuación, veamos si podemos crear un nuevo usuario con una solicitud POST
al punto final de la API. Podemos cambiar el método de solicitud a POST
, cambiar el uid
a uno nuevo y enviar la solicitud al punto final de la API del nuevo uid
:
Recibimos un mensaje de error que dice Creating new employees is for admins only
. Lo mismo sucede cuando enviamos una solicitud Delete
, ya que recibimos Deleting employees is for admins only
. La aplicación web podría estar verificando nuestra autorización a través de la cookie role=employee
porque esta parece ser la única forma de autorización en la solicitud HTTP.
Por último, intentemos cambiar nuestro role
a admin
/ administrator
para obtener mayores privilegios. Desafortunadamente, sin conocer un role
válido, obtenemos la respuesta Invalid role
y nuestro role
no se actualiza:
Por lo tanto todos nuestros intentos parecen haber fracasado, no podemos crear ni eliminar usuarios, ya que no podemos cambiar nuestro role
. No podemos cambiar nuestros uid
, ya que existen medidas preventivas en el back-end que no podemos controlar, ni tampoco podemos cambiar los datos de otro usuario por la misma razón. Entonces, ¿la aplicación web es segura contra ataques IDOR?
.
Hasta ahora, solo hemos estado probando IDOR Insecure Function Calls
. Sin embargo, no hemos probado la solicitud de la API GET
para IDOR Information Disclosure Vulnerabilities
. Si no hubiera un sistema de control de acceso sólido, podríamos leer los detalles de otros usuarios, lo que podría ayudarnos con los ataques anteriores que intentamos.
Intente leer los detalles del usuario con 'uid=5
'. ¿Cuál es su valor 'uuid
'?
Cuando editamos un perfil y capturamos la petición nos da muchos más detalles del uid y uuid del usuario:
Al intentar cambiar el uid al 5 por ejemplo nos da el error uuid mismatch
:
Cambiamos a POST y nos da otro error, que nos dice solo los admins pueden crear empleados:
Sin embargo, en este punto si cambiamos a GET podemos extraer la información sin problema: