Skip to content

Netdata Streaming Alert Command Injection

High
ralphm published GHSA-xg38-3vmw-2978 Dec 1, 2022

Package

netdata

Affected versions

Stable < 1.37, Nightlies < 1.36.0-409

Patched versions

1.36.0-409, 1.37

Description

Impact

An attacker with the ability to establish a streaming connection can execute arbitrary commands on the targeted Netdata agent.

When an alert is triggered, the function health_alarm_execute is called. This function performs different checks and then enqueues a command by calling spawn_enq_cmd. This command is populated with several arguments that are not sanitized. One of them is the registry_hostname of the node for which the alert is raised. By providing a specially crafted registry_hostname as part of the health data that is streamed to a Netdata (parent) agent, an attacker can execute arbitrary commands at the remote host as a side-effect of the raised alert.

Note that the commands are executed as the user running the Netdata Agent. This user is usually named netdata. The ability to run arbitrary commands may allow an attacker to escalate privileges by escalating other vulnerabilities in the system, as that user.

Patches

The problem has been fixed in:

Netdata agent v1.37 (stable)
Netdata agent v1.36.0-409 (nightly)

Workarounds

Streaming is not enabled by default. If you have previously enabled this, it can be disabled by modifying stream.conf:

[stream]
    enabled = no

Limiting access to the port on the recipient Agent to trusted child connections may mitigate the impact of this vulnerability.

References

For more information

If you have any questions or comments about this advisory:

Severity

High
8.1
/ 10

CVSS base metrics

Attack vector
Network
Attack complexity
High
Privileges required
None
User interaction
None
Scope
Unchanged
Confidentiality
High
Integrity
High
Availability
High
CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:H

CVE ID

CVE-2023-22496