First published: Tue Oct 08 2024(Updated: )
Keycloak versions 26 and earlier are vulnerable to a denial-of-service (DoS) attack through improper handling of proxy headers. When Keycloak is configured to accept incoming proxy headers, it may accept non-IP values, such as obfuscated identifiers, without proper validation. This can lead to costly DNS resolution operations, which an attacker could exploit to tie up IO threads and potentially cause a denial of service. The attacker must have access to send requests to a Keycloak instance that is configured to accept proxy headers, specifically when reverse proxies do not overwrite incoming headers, and Keycloak is configured to trust these headers. For Keycloak version 26, for successful exploitation includes: the realm must have SslRequired=EXTERNAL (the default), HTTP must be enabled, the instance must not be using a full hostname URL, access must come from behind a proxy (assuming the proxy overwrites the X-Forwarded-For header), and trusted proxies must not be set or must incorrectly trust the client from which the request is originating.
Affected Software | Affected Version | How to fix |
---|---|---|
Keycloak | <26 |
Sign up to SecAlerts for real-time vulnerability data matched to your software, aggregated from hundreds of sources.
The severity of REDHAT-BUG-2317440 is classified as high due to the potential for a denial-of-service attack.
To fix REDHAT-BUG-2317440, upgrade your Keycloak installation to version 27 or later, which includes proper handling of proxy headers.
Keycloak versions 26 and earlier are affected by REDHAT-BUG-2317440.
REDHAT-BUG-2317440 is associated with a denial-of-service (DoS) attack.
Improper handling of proxy headers in REDHAT-BUG-2317440 can lead to costly service disruptions.