CVE-2024-56331 Information

Description

Uptime Kuma is an open source self-hosted monitoring tool. An Improper URL Handling Vulnerability allows an attacker to access sensitive local files on the server by exploiting the file:/// protocol. This vulnerability is triggered via the eal-browser\ request type which takes a screenshot of the URL provided by the attacker. By supplying local file paths such as file:///etc/passwd an attacker can read sensitive data from the server. This vulnerability arises because the system does not properly validate or sanitize the user input for the URL field. Specifically: 1. The URL input (<input data-v-5f5c86d7=\ id=rl\ type=rl\ class= orm-control\ pattern=\https?://.+\ required=\>) allows users to input arbitrary file paths including those using the file:/// protocol without server-side validation. 2. The server then uses the user-provided URL to make a request passing it to a browser instance that performs the eal-browser\ request which takes a screenshot of the content at the given URL. If a local file path is entered (e.g. file:///etc/passwd) the browser fetches and captures the file’s content. Since the user input is not validated an attacker can manipulate the URL to request local files (e.g. file:///etc/passwd) and the system will capture a screenshot of the file’s content potentially exposing sensitive data. Any authenticated user who can submit a URL in eal-browser\ mode is at risk of exposing sensitive data through screenshots of these files. This issue has been addressed in version 1.23.16 and all users are advised to upgrade. There are no known workarounds for this vulnerability.

Reference

https://github.com/louislam/uptime-kuma/commit/6cfae01a0d3727c517afe512fc8fec1d99acf875 https://github.com/louislam/uptime-kuma/security/advisories/GHSA-2qgm-m29m-cj2h Uptime Kuma is an open source self-hosted monitoring tool. An Improper URL Handling Vulnerability allows an attacker to access sensitive local files on the server by exploiting the file:/// protocol. This vulnerability is triggered via the ** eal-browser** request type which takes a screenshot of the URL provided by the attacker. By supplying local file paths such as file:///etc/passwd an attacker can read sensitive data from the server. This vulnerability arises because the system does not properly validate or sanitize the user input for the URL field. Specifically: 1. The URL input (<input data-v-5f5c86d7=\ id=rl\ type=rl\ class= orm-control\ pattern=\[***https?://.+\***](https?://.+\) required=\>) allows users to input arbitrary file paths including those using the file:/// protocol without server-side validation. 2. The server then uses the user-provided URL to make a request passing it to a browser instance that performs the eal-browser
request which takes a screenshot of the content at the given URL. If a local file path is entered (e.g. file:///etc/passwd) the browser fetches and captures the file’s content. Since the user input is not validated an attacker can manipulate the URL to request local files (e.g. file:///etc/passwd) and the system will capture a screenshot of the file’s content potentially exposing sensitive data. Any authenticated user who can submit a URL in eal-browser
mode is at risk of exposing sensitive data through screenshots of these files. This issue has been addressed in version 1.23.16 and all users are advised to upgrade. There are no known workarounds for this vulnerability.

Share on: