KEYCLOAK-4250 Include certificates without name for validation
Nameless certificates are now included for signature validation in the SAML adapter when the certificate is downloaded from metadataUrl.
This commit is contained in:
parent
91a51c2dbe
commit
acfea8ecd2
1 changed files with 13 additions and 4 deletions
|
@ -37,6 +37,8 @@ import org.keycloak.dom.saml.v2.metadata.KeyTypes;
|
||||||
import org.keycloak.rotation.KeyLocator;
|
import org.keycloak.rotation.KeyLocator;
|
||||||
import org.keycloak.saml.processing.api.util.KeyInfoTools;
|
import org.keycloak.saml.processing.api.util.KeyInfoTools;
|
||||||
import java.security.cert.CertificateException;
|
import java.security.cert.CertificateException;
|
||||||
|
import java.util.UUID;
|
||||||
|
import javax.security.auth.x500.X500Principal;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This class defines a {@link KeyLocator} that looks up public keys and certificates in IdP's
|
* This class defines a {@link KeyLocator} that looks up public keys and certificates in IdP's
|
||||||
|
@ -148,18 +150,25 @@ public class SamlDescriptorPublicKeyLocator implements KeyLocator, Iterable<Publ
|
||||||
for (KeyInfo ki : signingCerts) {
|
for (KeyInfo ki : signingCerts) {
|
||||||
KeyName keyName = KeyInfoTools.getKeyName(ki);
|
KeyName keyName = KeyInfoTools.getKeyName(ki);
|
||||||
X509Certificate x509certificate = KeyInfoTools.getX509Certificate(ki);
|
X509Certificate x509certificate = KeyInfoTools.getX509Certificate(ki);
|
||||||
|
if (x509certificate == null) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
try {
|
try {
|
||||||
x509certificate.checkValidity();
|
x509certificate.checkValidity();
|
||||||
} catch (CertificateException ex) {
|
} catch (CertificateException ex) {
|
||||||
x509certificate = null;
|
continue;
|
||||||
}
|
}
|
||||||
if (x509certificate != null && keyName != null) {
|
|
||||||
|
if (keyName != null) {
|
||||||
LOG.tracef("Registering signing certificate %s", keyName.getName());
|
LOG.tracef("Registering signing certificate %s", keyName.getName());
|
||||||
this.publicKeyCache.put(keyName.getName(), x509certificate.getPublicKey());
|
this.publicKeyCache.put(keyName.getName(), x509certificate.getPublicKey());
|
||||||
} else {
|
} else {
|
||||||
LOG.tracef("Ignoring certificate %s: %s", keyName, x509certificate);
|
final X500Principal principal = x509certificate.getSubjectX500Principal();
|
||||||
|
String name = (principal == null ? "unnamed" : principal.getName())
|
||||||
|
+ "@" + x509certificate.getSerialNumber() + "$" + UUID.randomUUID();
|
||||||
|
this.publicKeyCache.put(name, x509certificate.getPublicKey());
|
||||||
|
LOG.tracef("Adding certificate %s without a specific key name: %s", name, x509certificate);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return (kid == null ? null : this.publicKeyCache.get(kid));
|
return (kid == null ? null : this.publicKeyCache.get(kid));
|
||||||
|
|
Loading…
Reference in a new issue