Bug 2339115 (CVE-2025-0752)
Summary: | CVE-2025-0752 envoyproxy: OpenShift Service Mesh Envoy HTTP Header Sanitization Bypass Leading to DoS and Unauthorized Access | ||
---|---|---|---|
Product: | [Other] Security Response | Reporter: | OSIDB Bzimport <bzimport> |
Component: | vulnerability | Assignee: | Product Security DevOps Team <prodsec-dev> |
Status: | NEW --- | QA Contact: | |
Severity: | medium | Docs Contact: | |
Priority: | medium | ||
Version: | unspecified | CC: | dcillera, jwendell, rcernich, sburke, security-response-team, twalsh |
Target Milestone: | --- | Keywords: | Security |
Target Release: | --- | ||
Hardware: | All | ||
OS: | Linux | ||
Whiteboard: | |||
Fixed In Version: | Doc Type: | If docs needed, set a value | |
Doc Text: |
A flaw was found in OpenShift Service Mesh 2.6.3 and 2.5.6. Rate-limiter avoidance, access-control bypass, CPU and memory exhaustion, and replay attacks may be possible due to improper HTTP header sanitization in Envoy.
|
Story Points: | --- |
Clone Of: | Environment: | ||
Last Closed: | Type: | --- | |
Regression: | --- | Mount Type: | --- |
Documentation: | --- | CRM: | |
Verified Versions: | Category: | --- | |
oVirt Team: | --- | RHEL 7.3 requirements from Atomic Host: | |
Cloudforms Team: | --- | Target Upstream Version: | |
Embargoed: |
Description
OSIDB Bzimport
2025-01-21 12:26:01 UTC
The following configurations are advised to tackle the attack, simulated with curl, in the description above. 1. Filter possibly malicious headers Any HTTP header can be stripped from a request by using the key "request_headers_to_remove" in the Envoy configuration file (for envoy-openssl 2.6 see: https://www.envoyproxy.io/docs/envoy/v1.8.0/api-v2/api/v2/route/route.proto#envoy-api-field-route-route-request-headers-to-remove ). request_headers_to_remove (string) Specifies a list of HTTP headers that should be removed from each request handled by this virtual host. Example: request_headers_to_remove: ["x-forwarded-for"] will remove the "x-forward-for http" header. This is the resulting log entry: {"start_time":"2025-03-19T12:00:40.213Z", "x_forwarded_for":null} Instead of: {"start_time":"2025-03-19T12:04:50.573Z", "x_forwarded_for":"\u003cscript\u003ealert()\u003c/script\u003e"} 2. Do not trust addresses in the x-forwarded-for header but use Downstream IP address. This is possible with the following configuration (see Example 1: "XFF is ignored" case in https://www.envoyproxy.io/docs/envoy/v1.28.7/configuration/http/http_conn_man/headers#x-forwarded-for:~:text=Example%201%3A%20Envoy%20as%20edge%20proxy%2C%20without%20a%20trusted%20proxy%20in%20front%20of%20it ) xff_num_trusted_hops = 0 (no trusted addresses in XFF) use_remote_address=true (untrusted environments: do not use the x-forwarded-for HTTP header but use downstream real address instead) That is, the existing XFF content (IP addresses) will be preserved, but not taken into account, and the downstream real address is added to the XFF header as a trusted address. |