GHSA-5rv5-6h4r-h22v

Suggest an improvement
Source
https://github.com/advisories/GHSA-5rv5-6h4r-h22v
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2023/10/GHSA-5rv5-6h4r-h22v/GHSA-5rv5-6h4r-h22v.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-5rv5-6h4r-h22v
Aliases
Related
Published
2023-10-02T23:29:42Z
Modified
2024-02-16T08:18:26.543161Z
Severity
  • 7.5 (High) CVSS_V3 - CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H CVSS Calculator
Summary
opentelemetry-instrumentation Denial of Service vulnerability due to unbound cardinality metrics
Details

Summary

Autoinstrumentation out of the box adds the label http_method that has unbound cardinality. It leads to the server's potential memory exhaustion when many malicious requests are sent.

Details

HTTP method for requests can be easily set by an attacker to be random and long.

PoC

Send many requests with long randomly generated HTTP methods and observe how memory consumption increases during it. The app can be like this example from the official docs.

Impact

In order to be affected program has to be instrumented for HTTP handlers and does not filter any unknown HTTP methods on the level of CDN, LB, previous middleware, etc.

Proposed solution

For convenience and safe usage of this library, it should by default mark with the label UNKNOWN non-standard HTTP methods to show that such requests were made (and this way does not increase cardinality). In case someone wants to stay with the current behavior, library API should allow it. The mechanism with environment variables can be reused - introduce the variable OTEL_INSTRUMENTATION_HTTP_CAPTURE_ALL_METHODS that will allow enabling current behavior when someone really wants it.

Database specific
{
    "nvd_published_at": "2023-10-06T14:15:12Z",
    "cwe_ids": [
        "CWE-400"
    ],
    "severity": "HIGH",
    "github_reviewed": true,
    "github_reviewed_at": "2023-10-02T23:29:42Z"
}
References

Affected packages

PyPI / opentelemetry-instrumentation

Package

Name
opentelemetry-instrumentation
View open source insights on deps.dev
Purl
pkg:pypi/opentelemetry-instrumentation

Affected ranges

Type
ECOSYSTEM
Events
Introduced
0Unknown introduced version / All previous versions are affected
Fixed
0.41b0

Affected versions

0.*

0.9b0
0.10b0
0.11b0
0.12b0
0.13b0
0.14b0
0.15b0
0.16b0
0.16b1
0.17b0
0.18b0
0.19b0
0.20b0
0.21b0
0.22b0
0.23b0
0.23b1
0.23b2
0.24b0
0.25b0
0.25b1
0.25b2
0.26b1
0.27b0
0.28b0
0.28b1
0.29b0
0.30b0
0.30b1
0.31b0
0.32b0
0.33b0
0.34b0
0.35b0
0.36b0
0.37b0
0.38b0
0.39b0
0.40b0