Deprecate OpenSamlRelyingPartyRegistration

Closes gh-15343
This commit is contained in:
Josh Cummings 2024-07-01 18:53:03 -06:00
parent 7b39800606
commit 6bd2f1ca97
No known key found for this signature in database
GPG Key ID: A306A51F43B8E5A5
3 changed files with 48 additions and 37 deletions

View File

@ -65,6 +65,20 @@ public final class OpenSamlAssertingPartyDetails extends RelyingPartyRegistratio
return new OpenSamlAssertingPartyDetails.Builder(entity); return new OpenSamlAssertingPartyDetails.Builder(entity);
} }
@Override
public OpenSamlAssertingPartyDetails.Builder mutate() {
return new OpenSamlAssertingPartyDetails.Builder(this.descriptor).entityId(getEntityId())
.wantAuthnRequestsSigned(getWantAuthnRequestsSigned())
.signingAlgorithms((algorithms) -> algorithms.addAll(getSigningAlgorithms()))
.verificationX509Credentials((c) -> c.addAll(getVerificationX509Credentials()))
.encryptionX509Credentials((c) -> c.addAll(getEncryptionX509Credentials()))
.singleSignOnServiceLocation(getSingleSignOnServiceLocation())
.singleSignOnServiceBinding(getSingleSignOnServiceBinding())
.singleLogoutServiceLocation(getSingleLogoutServiceLocation())
.singleLogoutServiceResponseLocation(getSingleLogoutServiceResponseLocation())
.singleLogoutServiceBinding(getSingleLogoutServiceBinding());
}
/** /**
* An OpenSAML version of * An OpenSAML version of
* {@link org.springframework.security.saml2.provider.service.registration.RelyingPartyRegistration.AssertingPartyDetails.Builder} * {@link org.springframework.security.saml2.provider.service.registration.RelyingPartyRegistration.AssertingPartyDetails.Builder}

View File

@ -29,7 +29,19 @@ import org.springframework.security.saml2.core.Saml2X509Credential;
* *
* @author Josh Cummings * @author Josh Cummings
* @since 6.1 * @since 6.1
* @deprecated This class no longer is needed in order to transmit the
* {@link EntityDescriptor} to {@link OpenSamlAssertingPartyDetails}. Instead of doing:
* <pre>
* if (registration instanceof OpenSamlRelyingPartyRegistration openSamlRegistration) {
* EntityDescriptor descriptor = openSamlRegistration.getAssertingPartyDetails.getEntityDescriptor();
* }
* </pre> do instead: <pre>
* if (registration.getAssertingPartyDetails() instanceof openSamlAssertingPartyDetails) {
* EntityDescriptor descriptor = openSamlAssertingPartyDetails.getEntityDescriptor();
* }
* </pre>
*/ */
@Deprecated
public final class OpenSamlRelyingPartyRegistration extends RelyingPartyRegistration { public final class OpenSamlRelyingPartyRegistration extends RelyingPartyRegistration {
OpenSamlRelyingPartyRegistration(RelyingPartyRegistration registration) { OpenSamlRelyingPartyRegistration(RelyingPartyRegistration registration) {
@ -47,7 +59,7 @@ public final class OpenSamlRelyingPartyRegistration extends RelyingPartyRegistra
@Override @Override
public OpenSamlRelyingPartyRegistration.Builder mutate() { public OpenSamlRelyingPartyRegistration.Builder mutate() {
OpenSamlAssertingPartyDetails party = getAssertingPartyDetails(); OpenSamlAssertingPartyDetails party = getAssertingPartyDetails();
return withAssertingPartyEntityDescriptor(party.getEntityDescriptor()).registrationId(getRegistrationId()) return new Builder(party).registrationId(getRegistrationId())
.entityId(getEntityId()) .entityId(getEntityId())
.signingX509Credentials((c) -> c.addAll(getSigningX509Credentials())) .signingX509Credentials((c) -> c.addAll(getSigningX509Credentials()))
.decryptionX509Credentials((c) -> c.addAll(getDecryptionX509Credentials())) .decryptionX509Credentials((c) -> c.addAll(getDecryptionX509Credentials()))
@ -57,18 +69,7 @@ public final class OpenSamlRelyingPartyRegistration extends RelyingPartyRegistra
.singleLogoutServiceResponseLocation(getSingleLogoutServiceResponseLocation()) .singleLogoutServiceResponseLocation(getSingleLogoutServiceResponseLocation())
.singleLogoutServiceBindings((c) -> c.addAll(getSingleLogoutServiceBindings())) .singleLogoutServiceBindings((c) -> c.addAll(getSingleLogoutServiceBindings()))
.nameIdFormat(getNameIdFormat()) .nameIdFormat(getNameIdFormat())
.authnRequestsSigned(isAuthnRequestsSigned()) .authnRequestsSigned(isAuthnRequestsSigned());
.assertingPartyDetails((assertingParty) -> ((OpenSamlAssertingPartyDetails.Builder) assertingParty)
.entityId(party.getEntityId())
.wantAuthnRequestsSigned(party.getWantAuthnRequestsSigned())
.signingAlgorithms((algorithms) -> algorithms.addAll(party.getSigningAlgorithms()))
.verificationX509Credentials((c) -> c.addAll(party.getVerificationX509Credentials()))
.encryptionX509Credentials((c) -> c.addAll(party.getEncryptionX509Credentials()))
.singleSignOnServiceLocation(party.getSingleSignOnServiceLocation())
.singleSignOnServiceBinding(party.getSingleSignOnServiceBinding())
.singleLogoutServiceLocation(party.getSingleLogoutServiceLocation())
.singleLogoutServiceResponseLocation(party.getSingleLogoutServiceResponseLocation())
.singleLogoutServiceBinding(party.getSingleLogoutServiceBinding()));
} }
/** /**
@ -100,6 +101,10 @@ public final class OpenSamlRelyingPartyRegistration extends RelyingPartyRegistra
super(entityDescriptor.getEntityID(), OpenSamlAssertingPartyDetails.withEntityDescriptor(entityDescriptor)); super(entityDescriptor.getEntityID(), OpenSamlAssertingPartyDetails.withEntityDescriptor(entityDescriptor));
} }
Builder(OpenSamlAssertingPartyDetails details) {
super(details.getEntityDescriptor().getEntityID(), details.mutate());
}
@Override @Override
public Builder registrationId(String id) { public Builder registrationId(String id) {
return (Builder) super.registrationId(id); return (Builder) super.registrationId(id);

View File

@ -139,8 +139,7 @@ public class RelyingPartyRegistration {
* @since 6.1 * @since 6.1
*/ */
public Builder mutate() { public Builder mutate() {
AssertingPartyDetails party = this.assertingPartyDetails; return new Builder(this.registrationId, this.assertingPartyDetails.mutate()).entityId(this.entityId)
return withRegistrationId(this.registrationId).entityId(this.entityId)
.signingX509Credentials((c) -> c.addAll(this.signingX509Credentials)) .signingX509Credentials((c) -> c.addAll(this.signingX509Credentials))
.decryptionX509Credentials((c) -> c.addAll(this.decryptionX509Credentials)) .decryptionX509Credentials((c) -> c.addAll(this.decryptionX509Credentials))
.assertionConsumerServiceLocation(this.assertionConsumerServiceLocation) .assertionConsumerServiceLocation(this.assertionConsumerServiceLocation)
@ -149,17 +148,7 @@ public class RelyingPartyRegistration {
.singleLogoutServiceResponseLocation(this.singleLogoutServiceResponseLocation) .singleLogoutServiceResponseLocation(this.singleLogoutServiceResponseLocation)
.singleLogoutServiceBindings((c) -> c.addAll(this.singleLogoutServiceBindings)) .singleLogoutServiceBindings((c) -> c.addAll(this.singleLogoutServiceBindings))
.nameIdFormat(this.nameIdFormat) .nameIdFormat(this.nameIdFormat)
.authnRequestsSigned(this.authnRequestsSigned) .authnRequestsSigned(this.authnRequestsSigned);
.assertingPartyDetails((assertingParty) -> assertingParty.entityId(party.getEntityId())
.wantAuthnRequestsSigned(party.getWantAuthnRequestsSigned())
.signingAlgorithms((algorithms) -> algorithms.addAll(party.getSigningAlgorithms()))
.verificationX509Credentials((c) -> c.addAll(party.getVerificationX509Credentials()))
.encryptionX509Credentials((c) -> c.addAll(party.getEncryptionX509Credentials()))
.singleSignOnServiceLocation(party.getSingleSignOnServiceLocation())
.singleSignOnServiceBinding(party.getSingleSignOnServiceBinding())
.singleLogoutServiceLocation(party.getSingleLogoutServiceLocation())
.singleLogoutServiceResponseLocation(party.getSingleLogoutServiceResponseLocation())
.singleLogoutServiceBinding(party.getSingleLogoutServiceBinding()));
} }
/** /**
@ -346,17 +335,7 @@ public class RelyingPartyRegistration {
public static Builder withAssertingPartyDetails(AssertingPartyDetails assertingPartyDetails) { public static Builder withAssertingPartyDetails(AssertingPartyDetails assertingPartyDetails) {
Assert.notNull(assertingPartyDetails, "assertingPartyDetails cannot be null"); Assert.notNull(assertingPartyDetails, "assertingPartyDetails cannot be null");
return withRegistrationId(assertingPartyDetails.getEntityId()) return new Builder(assertingPartyDetails.getEntityId(), assertingPartyDetails.mutate());
.assertingPartyDetails((party) -> party.entityId(assertingPartyDetails.getEntityId())
.wantAuthnRequestsSigned(assertingPartyDetails.getWantAuthnRequestsSigned())
.signingAlgorithms((algorithms) -> algorithms.addAll(assertingPartyDetails.getSigningAlgorithms()))
.verificationX509Credentials((c) -> c.addAll(assertingPartyDetails.getVerificationX509Credentials()))
.encryptionX509Credentials((c) -> c.addAll(assertingPartyDetails.getEncryptionX509Credentials()))
.singleSignOnServiceLocation(assertingPartyDetails.getSingleSignOnServiceLocation())
.singleSignOnServiceBinding(assertingPartyDetails.getSingleSignOnServiceBinding())
.singleLogoutServiceLocation(assertingPartyDetails.getSingleLogoutServiceLocation())
.singleLogoutServiceResponseLocation(assertingPartyDetails.getSingleLogoutServiceResponseLocation())
.singleLogoutServiceBinding(assertingPartyDetails.getSingleLogoutServiceBinding()));
} }
/** /**
@ -592,6 +571,19 @@ public class RelyingPartyRegistration {
return this.singleLogoutServiceBinding; return this.singleLogoutServiceBinding;
} }
public AssertingPartyDetails.Builder mutate() {
return new AssertingPartyDetails.Builder().entityId(this.entityId)
.wantAuthnRequestsSigned(this.wantAuthnRequestsSigned)
.signingAlgorithms((algorithms) -> algorithms.addAll(this.signingAlgorithms))
.verificationX509Credentials((c) -> c.addAll(this.verificationX509Credentials))
.encryptionX509Credentials((c) -> c.addAll(this.encryptionX509Credentials))
.singleSignOnServiceLocation(this.singleSignOnServiceLocation)
.singleSignOnServiceBinding(this.singleSignOnServiceBinding)
.singleLogoutServiceLocation(this.singleLogoutServiceLocation)
.singleLogoutServiceResponseLocation(this.singleLogoutServiceResponseLocation)
.singleLogoutServiceBinding(this.singleLogoutServiceBinding);
}
public static class Builder { public static class Builder {
private String entityId; private String entityId;