Description
If an OpenID Connect provider supports the "none" algorithm (i.e., tokens with no signature), pac4j v5.3.0 (and prior) does not refuse it without an explicit configuration on its side or for the "idtoken" response type which is not secure and violates the OpenID Core Specification. The "none" algorithm does not require any signature verification when validating the ID tokens, which allows the attacker to bypass the token validation by injecting a malformed ID token using "none" as the value of "alg" key in the header with an empty signature value.
Remediation
References
https://github.com/pac4j/pac4j/commit/22b82ffd702a132d9f09da60362fc6264fc281ae
https://openid.net/specs/openid-connect-core-1_0.html#IDToken
https://www.pac4j.org/blog/cve_2021_44878_is_this_serious.html
Related Vulnerabilities
CVE-2020-36379 Vulnerability in npm package aaptjs
CVE-2021-46361 Vulnerability in maven package info.magnolia:magnolia-core
CVE-2022-29249 Vulnerability in maven package io.github.javaezlib:javaez
CVE-2007-5614 Vulnerability in maven package org.mortbay.jetty:jetty
CVE-2016-10707 Vulnerability in maven package org.webjars.npm:jquery