Class DefaultXMLSignatureValidator
java.lang.Object
se.idsec.signservice.security.sign.xml.impl.DefaultXMLSignatureValidator
- All Implemented Interfaces:
- SignatureValidator<Document>,- XMLSignatureValidator
Default implementation of the 
XMLSignatureValidator interface.
 Note that this implementation only supports validation of signatures that covers the supplied document.
- Author:
- Martin Lindström (martin@idsec.se), Stefan Santesson (stefan@idsec.se)
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected booleanFlag that tells if the validator should handle XAdES signatures.
- 
Constructor SummaryConstructorsConstructorDescriptionConstructor setting up the validator so that no required certificates are configured and no certificate path validation is performed.DefaultXMLSignatureValidator(X509Certificate acceptedSignerCertificate) Constructor setting up the validator to require that the signature is signed using the supplied certificate.DefaultXMLSignatureValidator(List<X509Certificate> acceptedSignerCertificates) Constructor setting up the validator to require that the signature is signed using any of the supplied certificates.DefaultXMLSignatureValidator(CertificateValidator certificateValidator) Constructor setting up the validator to perform a certificate validation of the signer certificate using the supplied certificate validator instance.
- 
Method SummaryModifier and TypeMethodDescriptionprotected List<X509Certificate> getAdditionalCertificates(org.apache.xml.security.keys.KeyInfo keyInfo, X509Certificate signerCertificate) Extracts all certificates from the supplied KeyInfo except for the actual signer certificate.booleanprotected voidregisterXadesIdNodes(Document document) Looks for anyxades:SignedPropertieselements and registers an ID attribute for the elements that are found.voidsetXadesProcessing(boolean xadesProcessing) Sets flag that tells whether this validator should handle XAdES processing.protected List<SignatureValidationResult> Validates the supplied signatures.validate(Document document, XMLSignatureLocation signatureLocation) Validates the signature(s) of supplied document.protected DefaultXMLSignatureValidationResultvalidateSignature(Element signature, String signatureUriReference) Validates the signature value and checks that the signer certificate is accepted.
- 
Field Details- 
xadesProcessingprotected boolean xadesProcessingFlag that tells if the validator should handle XAdES signatures.
 
- 
- 
Constructor Details- 
DefaultXMLSignatureValidatorpublic DefaultXMLSignatureValidator()Constructor setting up the validator so that no required certificates are configured and no certificate path validation is performed. This means that no control of the signer certificate will be performed.
- 
DefaultXMLSignatureValidatorConstructor setting up the validator to require that the signature is signed using the supplied certificate.- Parameters:
- acceptedSignerCertificate- required signer certificate
 
- 
DefaultXMLSignatureValidatorConstructor setting up the validator to require that the signature is signed using any of the supplied certificates.- Parameters:
- acceptedSignerCertificates- required signer certificates
 
- 
DefaultXMLSignatureValidatorConstructor setting up the validator to perform a certificate validation of the signer certificate using the supplied certificate validator instance.- Parameters:
- certificateValidator- certificate validator instance
 
 
- 
- 
Method Details- 
validate- Specified by:
- validatein interface- SignatureValidator<Document>
- Throws:
- SignatureException
 
- 
validatepublic List<SignatureValidationResult> validate(Document document, XMLSignatureLocation signatureLocation) throws SignatureException Validates the signature(s) of supplied document.If the signatureLocationparameter is non null only that signature of the document will be validated, even if there are more signatures.- Specified by:
- validatein interface- XMLSignatureValidator
- Parameters:
- document- the document to validate
- signatureLocation- tells where the signature can be found
- Returns:
- a validation result containing the details from a signature validation
- Throws:
- SignatureException- for errors during the validation process (pure signature validation errors are reported in the returned result)
 
- 
validateValidates the supplied signatures.- Parameters:
- document- the document containing the signatures
- signatures- the signatures
- Returns:
- a list of result objects
 
- 
validateSignatureprotected DefaultXMLSignatureValidationResult validateSignature(Element signature, String signatureUriReference) Validates the signature value and checks that the signer certificate is accepted.- Parameters:
- signature- the signature element
- signatureUriReference- the signature URI reference
- Returns:
- a validation result
 
- 
getAdditionalCertificatesprotected List<X509Certificate> getAdditionalCertificates(org.apache.xml.security.keys.KeyInfo keyInfo, X509Certificate signerCertificate) Extracts all certificates from the supplied KeyInfo except for the actual signer certificate.- Parameters:
- keyInfo- the KeyInfo
- signerCertificate- the signer certificate
- Returns:
- a list of certificates
 
- 
isSigned- Specified by:
- isSignedin interface- SignatureValidator<Document>
- Throws:
- IllegalArgumentException
 
- 
getRequiredSignerCertificates- Specified by:
- getRequiredSignerCertificatesin interface- SignatureValidator<Document>
 
- 
getCertificateValidator- Specified by:
- getCertificateValidatorin interface- SignatureValidator<Document>
 
- 
setXadesProcessingpublic void setXadesProcessing(boolean xadesProcessing) Sets flag that tells whether this validator should handle XAdES processing. The default istrue- Parameters:
- xadesProcessing- whether to process XAdES
 
- 
registerXadesIdNodesLooks for anyxades:SignedPropertieselements and registers an ID attribute for the elements that are found.- Parameters:
- document- the document to manipulate
 
 
-