KEVIntel
9.8
CVSS
Critical

CVE-2022-46169

PUBLISHED

Unauthenticated Command Injection

Exploited in the wild Remote Low complexity No user interaction
Vendor
Cacti
Product
cacti
Published
Dec 05, 2022
EPSS

Description

Cacti is an open source platform which provides a robust and extensible operational monitoring and fault management framework for users. In affected versions a command injection vulnerability allows an unauthenticated user to execute arbitrary code on a server running Cacti, if a specific data source was selected for any monitored device. The vulnerability resides in the `remote_agent.php` file. This file can be accessed without authentication. This function retrieves the IP address of the client via `get_client_addr` and resolves this IP address to the corresponding hostname via `gethostbyaddr`. After this, it is verified that an entry within the `poller` table exists, where the hostname corresponds to the resolved hostname. If such an entry was found, the function returns `true` and the client is authorized. This authorization can be bypassed due to the implementation of the `get_client_addr` function. The function is defined in the file `lib/functions.php` and checks serval `$_SERVER` variables to determine the IP address of the client. The variables beginning with `HTTP_` can be arbitrarily set by an attacker. Since there is a default entry in the `poller` table with the hostname of the server running Cacti, an attacker can bypass the authentication e.g. by providing the header `Forwarded-For: `. This way the function `get_client_addr` returns the IP address of the server running Cacti. The following call to `gethostbyaddr` will resolve this IP address to the hostname of the server, which will pass the `poller` hostname check because of the default entry. After the authorization of the `remote_agent.php` file is bypassed, an attacker can trigger different actions. One of these actions is called `polldata`. The called function `poll_for_data` retrieves a few request parameters and loads the corresponding `poller_item` entries from the database. If the `action` of a `poller_item` equals `POLLER_ACTION_SCRIPT_PHP`, the function `proc_open` is used to execute a PHP script. The attacker-controlled parameter `$poller_id` is retrieved via the function `get_nfilter_request_var`, which allows arbitrary strings. This variable is later inserted into the string passed to `proc_open`, which leads to a command injection vulnerability. By e.g. providing the `poller_id=;id` the `id` command is executed. In order to reach the vulnerable call, the attacker must provide a `host_id` and `local_data_id`, where the `action` of the corresponding `poller_item` is set to `POLLER_ACTION_SCRIPT_PHP`. Both of these ids (`host_id` and `local_data_id`) can easily be bruteforced. The only requirement is that a `poller_item` with an `POLLER_ACTION_SCRIPT_PHP` action exists. This is very likely on a productive instance because this action is added by some predefined templates like `Device - Uptime` or `Device - Polling Time`. This command injection vulnerability allows an unauthenticated user to execute arbitrary commands if a `poller_item` with the `action` type `POLLER_ACTION_SCRIPT_PHP` (`2`) is configured. The authorization bypass should be prevented by not allowing an attacker to make `get_client_addr` (file `lib/functions.php`) return an arbitrary IP address. This could be done by not honoring the `HTTP_...` `$_SERVER` variables. If these should be kept for compatibility reasons it should at least be prevented to fake the IP address of the server running Cacti. This vulnerability has been addressed in both the 1.2.x and 1.3.x release branches with `1.2.23` being the first release containing the patch.

php windows cisa nuclei_scanner metasploit

CVSS scores

CVSS v3.1 9.8 Critical

CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H

Exploitation status

Exploited in the wild

Recorded 2023-02-16 00:00:00 UTC · Source

SSVC decision points

Exploitation
active
Automatable
No
Technical impact
total

Known exploited vulnerability sources

Catalogues that list this CVE as a known exploited vulnerability.

Source Added
CISA Feb 16, 2023

Potential proof of concepts

These PoCs are unverified and could contain malware. Use at your own risk.

cacti_unauthenticated_cmd_injection

metasploit · Created Unknown

Metasploit module for CVE-2022-46169

FredBrave/CVE-2022-46169-CACTI-1.2.22

github · Created 2023-05-01 20:00:23 UTC · 41 stars

This is a exploit of CVE-2022-46169 to cacti 1.2.22. This exploit allows through an RCE to obtain a reverse shell on your computer.

ruycr4ft/CVE-2022-46169

github · Created 2023-05-01 14:29:28 UTC · 2 stars

Exploit for cacti version 1.2.22

icebreack/CVE-2022-46169

github · Created 2023-04-13 08:55:08 UTC · 3 stars

Fixed exploit for CVE-2022-46169 (originally from https://www.exploit-db.com/exploits/51166)

JacobEbben/CVE-2022-46169_unauth_remote_code_execution

github · Created 2023-04-07 23:40:53 UTC · 2 stars

Unauthenticated Remote Code Execution through authentication bypass and command injection in Cacti < 1.2.23 and < 1.3.0

N1arut/CVE-2022-46169_POC

github · Created 2023-01-16 10:21:26 UTC · 3 stars

RCE POC for CVE-2022-46169

Habib0x0/CVE-2022-46169

github · Created 2023-01-15 22:46:52 UTC · 2 stars

Cacti: Unauthenticated Remote Code Execution Exploit in Ruby

c3rrberu5/CVE-2022-46169

github · Created 2023-01-13 05:37:56 UTC · 10 stars

Exploit to CVE-2022-46169 vulnerability

sAsPeCt488/CVE-2022-46169

github · Created 2023-01-05 16:56:06 UTC · 30 stars

PoC for CVE-2022-46169 - Unauthenticated RCE on Cacti <= 1.2.22

Inplex-sys/CVE-2022-46169

github · Created 2023-01-02 18:03:26 UTC · 3 stars

Cacti Unauthenticated Command Injection

taythebot/CVE-2022-46169

github · Created 2022-12-16 16:16:35 UTC · 1 stars

CVE-2022-46169 - Cacti Blind Remote Code Execution (Pre-Auth)

0xf4n9x/CVE-2022-46169

github · Created 2022-12-08 01:52:13 UTC · 48 stars

CVE-2022-46169 Cacti remote_agent.php Unauthenticated Command Injection.

Timeline

  • CVE ID Reserved

  • CVE Published to Public

  • Added to KEVIntel

  • Detected by Nuclei

  • Detected by Metasploit