Class ResponseProcessorImpl

  • All Implemented Interfaces:
    ResponseProcessor

    public class ResponseProcessorImpl
    extends Object
    implements ResponseProcessor
    Response processor for SAML Response messages.

    Note that initialize() must be invoked before the bean can be used.

    Author:
    Martin Lindström (martin.lindstrom@litsec.se)
    • Field Detail

      • metadataCredentialResolver

        protected MetadataCredentialResolver metadataCredentialResolver
        Used to locate certificates from the IdP metadata.
      • signatureTrustEngine

        protected SignatureTrustEngine signatureTrustEngine
        The signature trust engine to be used when validating signatures.
      • signatureProfileValidator

        protected SignaturePrevalidator signatureProfileValidator
        Validator for checking the a Signature is correct with respect to the standards.
      • responseValidator

        protected ResponseValidator responseValidator
        The response validator.
      • assertionValidator

        protected AssertionValidator assertionValidator
        The assertion validator.
      • responseValidationSettings

        protected ResponseValidationSettings responseValidationSettings
        Static response validation settings.
      • requireEncryptedAssertions

        protected boolean requireEncryptedAssertions
        Do we require assertions to be encrypted? The default is true.
    • Constructor Detail

      • ResponseProcessorImpl

        public ResponseProcessorImpl()
    • Method Detail

      • initialize

        public void initialize()
                        throws Exception
        Initializes the component.
        Throws:
        Exception - for initialization errors
      • createResponseValidator

        protected ResponseValidator createResponseValidator​(SignatureTrustEngine signatureTrustEngine,
                                                            SignaturePrevalidator signatureProfileValidator)
        Sets up the response validator.

        The default implementation creates a ResponseValidator instance. For use within the Swedish eID framework subclasses should create a SwedishEidResponseValidator instance, see the swedish-eid-opensaml library (https://github.com/litsec/swedish-eid-opensaml).

        Parameters:
        signatureTrustEngine - the signature trust engine to be used when validating signatures
        signatureProfileValidator - validator for checking the a Signature is correct with respect to the standards
        Returns:
        the created response validator
      • createAssertionValidator

        protected AssertionValidator createAssertionValidator​(SignatureTrustEngine signatureTrustEngine,
                                                              SignaturePrevalidator signatureProfileValidator)
        Sets up the assertion validator.

        The default implementation creates a AssertionValidator instance. For use within the Swedish eID framework subclasses should create a SwedishEidAssertionValidator instance, see the swedish-eid-opensaml library (https://github.com/litsec/swedish-eid-opensaml).

        Parameters:
        signatureTrustEngine - the signature trust engine to be used when validating signatures
        signatureProfileValidator - validator for checking the a Signature is correct with respect to the standards
        Returns:
        the created assertion validator
      • setDecrypter

        public void setDecrypter​(SAMLObjectDecrypter decrypter)
        Assigns the decrypter instance.
        Parameters:
        decrypter - the decrypter
      • setMessageReplayChecker

        public void setMessageReplayChecker​(MessageReplayChecker messageReplayChecker)
        Assigns the message replay checker to use.
        Parameters:
        messageReplayChecker - message replay checker
      • setResponseValidationSettings

        public void setResponseValidationSettings​(ResponseValidationSettings responseValidationSettings)
        Assigns the response validation settings.
        Parameters:
        responseValidationSettings - validation settings
      • setRequireEncryptedAssertions

        public void setRequireEncryptedAssertions​(boolean requireEncryptedAssertions)
        Assigns whether require assertions to be encrypted? The default is true.
        Parameters:
        requireEncryptedAssertions - boolean