Class AssertionValidator
- java.lang.Object
-
- se.litsec.opensaml.common.validation.AbstractObjectValidator<T>
-
- se.litsec.opensaml.common.validation.AbstractSignableObjectValidator<Assertion>
-
- se.litsec.opensaml.saml2.common.assertion.AssertionValidator
-
- All Implemented Interfaces:
ObjectValidator<Assertion>
public class AssertionValidator extends AbstractSignableObjectValidator<Assertion>
A validator forAssertion
objects.Supports the following
ValidationContext
static parameters:- The static parameters defined for
AbstractSignableObjectValidator
. CoreValidatorParameters.STRICT_VALIDATION
: Optional. If not supplied, defaults to 'false'. Tells whether strict validation should be performed.SAML2AssertionValidationParameters.CLOCK_SKEW
: Optional. Gives the number of milliseconds that is the maximum allowed clock skew. If not givenSAML20AssertionValidator.DEFAULT_CLOCK_SKEW
is used.CoreValidatorParameters.MAX_AGE_MESSAGE
: Optional. Gives the maximum age (difference between issuance time and the validation time). If not given, theAbstractObjectValidator.DEFAULT_MAX_AGE_RECEIVED_MESSAGE
is used.CoreValidatorParameters.RECEIVE_INSTANT
: Optional. Gives the timestamp (Instant) for when the response message was received. If not given the current time is used.CoreValidatorParameters.AUTHN_REQUEST
: Optional. If supplied will be used in a number of validations when information from the correspondingAuthnRequest
is needed. If not supplied, other, more detailed parameters must be given.CoreValidatorParameters.AUTHN_REQUEST_ID
: Required if theCoreValidatorParameters.AUTHN_REQUEST
is not assigned. Is used when validating theInResponseTo
attribute of the response.CoreValidatorParameters.RECEIVE_URL
: Required. A String holding the URL on which we received the response message. Is used when theDestination
attribute is validated.CoreValidatorParameters.EXPECTED_ISSUER
: Optional. If set, is used when the issuer of the response is validated. If not set, the issuer from theCoreValidatorParameters.AUTHN_REQUEST
is used (if available).RESPONSE_ISSUE_INSTANT
: Optional. If set, the IssueInstant of the Assertion being validated is compared with the corresponding response issue instant.
Supports the following
ValidationContext
dynamic parameters:SAML2AssertionValidationParameters.CONFIRMED_SUBJECT_CONFIRMATION
: Optional. Will be present after validation if subject confirmation was successfully performed.
Note: Also check the validation context parameters defined by the
SubjectConfirmationValidator
andConditionValidator
instances that are installed.- Author:
- Martin Lindström (martin.lindstrom@litsec.se)
-
-
Field Summary
Fields Modifier and Type Field Description protected Map<QName,ConditionValidator>
conditionValidators
RegisteredCondition
validators.static String
RESPONSE_ISSUE_INSTANT
Carries aInstant
holding the issue instant of the Response that contained the assertion being validated.protected Map<String,SubjectConfirmationValidator>
subjectConfirmationValidators
RegisteredSubjectConfirmation
validators.-
Fields inherited from class se.litsec.opensaml.common.validation.AbstractSignableObjectValidator
signaturePrevalidator, trustEngine
-
Fields inherited from class se.litsec.opensaml.common.validation.AbstractObjectValidator
DEFAULT_MAX_AGE_RECEIVED_MESSAGE
-
-
Constructor Summary
Constructors Constructor Description AssertionValidator(SignatureTrustEngine trustEngine, SignaturePrevalidator signaturePrevalidator, Collection<SubjectConfirmationValidator> confirmationValidators, Collection<ConditionValidator> conditionValidators, Collection<StatementValidator> statementValidators)
Constructor.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description protected String
getID(Assertion signableObject)
Returns the Assertion ID.protected String
getIssuer(Assertion signableObject)
Returns the Assertion issuer.protected String
getObjectName()
Returns the name of the object being validated, e.g.protected Instant
getResponseIssueInstant(ValidationContext context)
Gets theRESPONSE_ISSUE_INSTANT
setting.ValidationResult
validate(Assertion assertion, ValidationContext context)
Validates the assertion.protected ValidationResult
validateConditions(Assertion assertion, ValidationContext context)
Validates theConditions
elements of the assertion.protected ValidationResult
validateConditionsTimeBounds(Assertion assertion, ValidationContext context)
Validates the NotBefore and NotOnOrAfter Conditions constraints on the assertion.protected ValidationResult
validateID(Assertion assertion, ValidationContext context)
Validates that theAssertion
object has an ID attribute.protected ValidationResult
validateIssueInstant(Assertion assertion, ValidationContext context)
Validates that theAssertion
object has a IssueInstant attribute and checks that its value is OK.protected ValidationResult
validateIssuer(Assertion assertion, ValidationContext context)
Ensures that theIssuer
element is present and matches the expected issuer (if set in the context under theCoreValidatorParameters.EXPECTED_ISSUER
key).protected ValidationResult
validateStatements(Assertion assertion, ValidationContext context)
Validates the statements of the assertion using the registeredStatementValidator
instance.protected ValidationResult
validateSubject(Assertion assertion, ValidationContext context)
Validates theSubject
element of the assertion.protected ValidationResult
validateSubjectConfirmations(Assertion assertion, List<SubjectConfirmation> subjectConfirmations, ValidationContext context)
Validates the subject confirmations and for the one that is confirmed, it is saved in the validation context under theSAML2AssertionValidationParameters.CONFIRMED_SUBJECT_CONFIRMATION
key.protected ValidationResult
validateVersion(Assertion assertion, ValidationContext context)
Validates that theResponse
object has a valid Version attribute.-
Methods inherited from class se.litsec.opensaml.common.validation.AbstractSignableObjectValidator
getSignatureValidationCriteriaSet, performSignatureValidation, validateSignature
-
Methods inherited from class se.litsec.opensaml.common.validation.AbstractObjectValidator
getAllowedClockSkew, getMaxAgeReceivedMessage, getReceiveInstant, isStrictValidation
-
-
-
-
Field Detail
-
RESPONSE_ISSUE_INSTANT
public static final String RESPONSE_ISSUE_INSTANT
Carries aInstant
holding the issue instant of the Response that contained the assertion being validated.- See Also:
- Constant Field Values
-
subjectConfirmationValidators
protected Map<String,SubjectConfirmationValidator> subjectConfirmationValidators
RegisteredSubjectConfirmation
validators.
-
conditionValidators
protected Map<QName,ConditionValidator> conditionValidators
RegisteredCondition
validators.
-
-
Constructor Detail
-
AssertionValidator
public AssertionValidator(SignatureTrustEngine trustEngine, SignaturePrevalidator signaturePrevalidator, Collection<SubjectConfirmationValidator> confirmationValidators, Collection<ConditionValidator> conditionValidators, Collection<StatementValidator> statementValidators)
Constructor.- Parameters:
trustEngine
- the trust used to validate the object's signaturesignaturePrevalidator
- the signature pre-validator used to pre-validate the object's signatureconfirmationValidators
- validators used to validateSubjectConfirmation
methods within the assertionconditionValidators
- validators used to validate theCondition
elements within the assertionstatementValidators
- validators used to validateStatement
s within the assertion
-
-
Method Detail
-
validate
public ValidationResult validate(Assertion assertion, ValidationContext context)
Validates the assertion.- Parameters:
assertion
- object to be evaluatedcontext
- current validation context- Returns:
- the result of the evaluation
-
validateID
protected ValidationResult validateID(Assertion assertion, ValidationContext context)
Validates that theAssertion
object has an ID attribute.- Parameters:
assertion
- the assertioncontext
- the validation context- Returns:
- a validation result
-
validateVersion
protected ValidationResult validateVersion(Assertion assertion, ValidationContext context)
Validates that theResponse
object has a valid Version attribute.- Parameters:
assertion
- the assertioncontext
- the validation context- Returns:
- a validation result
-
validateIssueInstant
protected ValidationResult validateIssueInstant(Assertion assertion, ValidationContext context)
Validates that theAssertion
object has a IssueInstant attribute and checks that its value is OK. If the response that contained the assertion was previously validated the static context parameterRESPONSE_ISSUE_INSTANT
should be passed. If so, the method checks that the assertion issue instant is not after the response issue instant. Otherwise the method checks that the IssueInstant is not too old given theCoreValidatorParameters.MAX_AGE_MESSAGE
andCoreValidatorParameters.RECEIVE_INSTANT
context parameters.- Parameters:
assertion
- the responsecontext
- the validation context- Returns:
- a validation result
-
getResponseIssueInstant
protected Instant getResponseIssueInstant(ValidationContext context)
Gets theRESPONSE_ISSUE_INSTANT
setting.- Parameters:
context
- the context- Returns:
- the response issue instant, or null if it is not set
-
validateIssuer
protected ValidationResult validateIssuer(Assertion assertion, ValidationContext context)
Ensures that theIssuer
element is present and matches the expected issuer (if set in the context under theCoreValidatorParameters.EXPECTED_ISSUER
key).- Parameters:
assertion
- the assertioncontext
- the validation context- Returns:
- a validation result
-
validateSubject
protected ValidationResult validateSubject(Assertion assertion, ValidationContext context)
Validates theSubject
element of the assertion. The default implementation returnsValidationResult.VALID
if there is noSubject
element since it is optional according to the SAML 2.0 Core specifications.- Parameters:
assertion
- the assertioncontext
- the validation context- Returns:
- a validation result
-
validateSubjectConfirmations
protected ValidationResult validateSubjectConfirmations(Assertion assertion, List<SubjectConfirmation> subjectConfirmations, ValidationContext context)
Validates the subject confirmations and for the one that is confirmed, it is saved in the validation context under theSAML2AssertionValidationParameters.CONFIRMED_SUBJECT_CONFIRMATION
key.- Parameters:
assertion
- the assertionsubjectConfirmations
- the subject confirmationscontext
- the validation context- Returns:
- a validation result
-
validateConditions
protected ValidationResult validateConditions(Assertion assertion, ValidationContext context)
Validates theConditions
elements of the assertion.- Parameters:
assertion
- the assertioncontext
- the validation context- Returns:
- the validation result
-
validateConditionsTimeBounds
protected ValidationResult validateConditionsTimeBounds(Assertion assertion, ValidationContext context)
Validates the NotBefore and NotOnOrAfter Conditions constraints on the assertion.- Parameters:
assertion
- the assertion whose conditions will be validatedcontext
- current validation context- Returns:
- the result of the validation evaluation
-
validateStatements
protected ValidationResult validateStatements(Assertion assertion, ValidationContext context)
Validates the statements of the assertion using the registeredStatementValidator
instance.- Parameters:
assertion
- the assertion to validatecontext
- the validation context- Returns:
- validation result
-
getIssuer
protected String getIssuer(Assertion signableObject)
Returns the Assertion issuer.- Specified by:
getIssuer
in classAbstractSignableObjectValidator<Assertion>
- Parameters:
signableObject
- the object being verified- Returns:
- the issuer
-
getID
protected String getID(Assertion signableObject)
Returns the Assertion ID.- Specified by:
getID
in classAbstractSignableObjectValidator<Assertion>
- Parameters:
signableObject
- the object being verified- Returns:
- the ID
-
getObjectName
protected String getObjectName()
Returns the name of the object being validated, e.g. "Assertion". Used for logging.- Specified by:
getObjectName
in classAbstractSignableObjectValidator<Assertion>
- Returns:
- the object name
-
-