Vulnerability Details CVE-2021-29492
Envoy is a cloud-native edge/middle/service proxy. Envoy does not decode escaped slash sequences `%2F` and `%5C` in HTTP URL paths in versions 1.18.2 and before. A remote attacker may craft a path with escaped slashes, e.g. `/something%2F..%2Fadmin`, to bypass access control, e.g. a block on `/admin`. A backend server could then decode slash sequences and normalize path and provide an attacker access beyond the scope provided for by the access control policy. ### Impact Escalation of Privileges when using RBAC or JWT filters with enforcement based on URL path. Users with back end servers that interpret `%2F` and `/` and `%5C` and `\` interchangeably are impacted. ### Attack Vector URL paths containing escaped slash characters delivered by untrusted client. Patches in versions 1.18.3, 1.17.3, 1.16.4, 1.15.5 contain new path normalization option to decode escaped slash characters. As a workaround, if back end servers treat `%2F` and `/` and `%5C` and `\` interchangeably and a URL path based access control is configured, one may reconfigure the back end server to not treat `%2F` and `/` and `%5C` and `\` interchangeably.
Exploit prediction scoring system (EPSS) score
EPSS Score 0.074
EPSS Ranking 91.3%
CVSS Severity
CVSS v3 Score 8.1
CVSS v2 Score 7.5
Products affected by CVE-2021-29492
-
cpe:2.3:a:envoyproxy:envoy:-
-
cpe:2.3:a:envoyproxy:envoy:1.0.0
-
cpe:2.3:a:envoyproxy:envoy:1.1.0
-
cpe:2.3:a:envoyproxy:envoy:1.10.0
-
cpe:2.3:a:envoyproxy:envoy:1.11.0
-
cpe:2.3:a:envoyproxy:envoy:1.11.1
-
cpe:2.3:a:envoyproxy:envoy:1.11.2
-
cpe:2.3:a:envoyproxy:envoy:1.12.0
-
cpe:2.3:a:envoyproxy:envoy:1.12.1
-
cpe:2.3:a:envoyproxy:envoy:1.12.2
-
cpe:2.3:a:envoyproxy:envoy:1.12.3
-
cpe:2.3:a:envoyproxy:envoy:1.12.4
-
cpe:2.3:a:envoyproxy:envoy:1.12.5
-
cpe:2.3:a:envoyproxy:envoy:1.12.6
-
cpe:2.3:a:envoyproxy:envoy:1.12.7
-
cpe:2.3:a:envoyproxy:envoy:1.13.0
-
cpe:2.3:a:envoyproxy:envoy:1.13.1
-
cpe:2.3:a:envoyproxy:envoy:1.13.2
-
cpe:2.3:a:envoyproxy:envoy:1.13.3
-
cpe:2.3:a:envoyproxy:envoy:1.13.4
-
cpe:2.3:a:envoyproxy:envoy:1.13.5
-
cpe:2.3:a:envoyproxy:envoy:1.13.6
-
cpe:2.3:a:envoyproxy:envoy:1.13.7
-
cpe:2.3:a:envoyproxy:envoy:1.13.8
-
cpe:2.3:a:envoyproxy:envoy:1.14.0
-
cpe:2.3:a:envoyproxy:envoy:1.14.1
-
cpe:2.3:a:envoyproxy:envoy:1.14.2
-
cpe:2.3:a:envoyproxy:envoy:1.14.3
-
cpe:2.3:a:envoyproxy:envoy:1.14.4
-
cpe:2.3:a:envoyproxy:envoy:1.14.5
-
cpe:2.3:a:envoyproxy:envoy:1.14.6
-
cpe:2.3:a:envoyproxy:envoy:1.14.7
-
cpe:2.3:a:envoyproxy:envoy:1.15.0
-
cpe:2.3:a:envoyproxy:envoy:1.15.1
-
cpe:2.3:a:envoyproxy:envoy:1.15.2
-
cpe:2.3:a:envoyproxy:envoy:1.15.3
-
cpe:2.3:a:envoyproxy:envoy:1.15.4
-
cpe:2.3:a:envoyproxy:envoy:1.16.0
-
cpe:2.3:a:envoyproxy:envoy:1.16.1
-
cpe:2.3:a:envoyproxy:envoy:1.16.2
-
cpe:2.3:a:envoyproxy:envoy:1.16.3
-
cpe:2.3:a:envoyproxy:envoy:1.17.0
-
cpe:2.3:a:envoyproxy:envoy:1.17.1
-
cpe:2.3:a:envoyproxy:envoy:1.17.2
-
cpe:2.3:a:envoyproxy:envoy:1.18.0
-
cpe:2.3:a:envoyproxy:envoy:1.18.1
-
cpe:2.3:a:envoyproxy:envoy:1.18.2
-
cpe:2.3:a:envoyproxy:envoy:1.2.0
-
cpe:2.3:a:envoyproxy:envoy:1.3.0
-
cpe:2.3:a:envoyproxy:envoy:1.4.0
-
cpe:2.3:a:envoyproxy:envoy:1.5.0
-
cpe:2.3:a:envoyproxy:envoy:1.6.0
-
cpe:2.3:a:envoyproxy:envoy:1.7.0
-
cpe:2.3:a:envoyproxy:envoy:1.7.1
-
cpe:2.3:a:envoyproxy:envoy:1.8.0
-
cpe:2.3:a:envoyproxy:envoy:1.9.0
-
cpe:2.3:a:envoyproxy:envoy:1.9.1