Описание
io.micronaut.security:micronaut-security-oauth2 has invalid IdTokenClaimsValidator logic on aud
Summary
IdTokenClaimsValidator skips aud claim validation if token is issued by same identity issuer/provider.
Details
This logic violates point 3 of https://openid.net/specs/openid-connect-core-1_0.html#IDTokenValidation.
Workaround exists by setting micronaut.security.token.jwt.claims-validators.audience with valid values.
micronaut.security.token.jwt.claims-validators.openid-idtoken can be kept as default on.
PoC
Should probably be:
Impact
Any OIDC setup using Micronaut where multiple OIDC applications exists for the same issuer but token auth are not meant to be shared.
Mitigation
Please upgrade to a patched micronaut-security-oauth2 release as soon as possible.
If you cannot upgrade, for example, if you are still using Micronaut Framework 2, you can patch your application by creating a replacement of IdTokenClaimsValidatorReplacement
Ссылки
- https://github.com/micronaut-projects/micronaut-security/security/advisories/GHSA-qw22-8w9r-864h
- https://nvd.nist.gov/vuln/detail/CVE-2023-36820
- https://github.com/micronaut-projects/micronaut-security/commit/9728b925221a0d87798ccf250657a3c214b7e980
- https://github.com/micronaut-projects/micronaut-security/blob/master/security-oauth2/src/main/java/io/micronaut/security/oauth2/client/IdTokenClaimsValidator.java#L202
Пакеты
io.micronaut.security:micronaut-security-oauth2
>= 3.11.0, < 3.11.1
3.11.1
io.micronaut.security:micronaut-security-oauth2
>= 3.10.0, < 3.10.2
3.10.2
io.micronaut.security:micronaut-security-oauth2
>= 3.9.0, < 3.9.6
3.9.6
io.micronaut.security:micronaut-security-oauth2
>= 3.8.0, < 3.8.4
3.8.4
io.micronaut.security:micronaut-security-oauth2
>= 3.7.0, < 3.7.4
3.7.4
io.micronaut.security:micronaut-security-oauth2
>= 3.6.0, < 3.6.6
3.6.6
io.micronaut.security:micronaut-security-oauth2
>= 3.5.0, < 3.5.3
3.5.3
io.micronaut.security:micronaut-security-oauth2
>= 3.4.0, < 3.4.3
3.4.3
io.micronaut.security:micronaut-security-oauth2
>= 3.3.0, < 3.3.2
3.3.2
io.micronaut.security:micronaut-security-oauth2
>= 3.2.0, < 3.2.4
3.2.4
io.micronaut.security:micronaut-security-oauth2
>= 3.1.0, < 3.1.2
3.1.2
Связанные уязвимости
Micronaut Security is a security solution for applications. Prior to versions 3.1.2, 3.2.4, 3.3.2, 3.4.3, 3.5.3, 3.6.6, 3.7.4, 3.8.4, 3.9.6, 3.10.2, and 3.11.1, IdTokenClaimsValidator skips `aud` claim validation if token is issued by same identity issuer/provider. Any OIDC setup using Micronaut where multiple OIDC applications exists for the same issuer but token auth are not meant to be shared. This issue has been patched in versions 3.1.2, 3.2.4, 3.3.2, 3.4.3, 3.5.3, 3.6.6, 3.7.4, 3.8.4, 3.9.6, 3.10.2, and 3.11.1.