Package org.apache.wss4j.dom.saml
Class WSSecSignatureSAML
java.lang.Object
org.apache.wss4j.dom.message.WSSecBase
org.apache.wss4j.dom.message.WSSecSignatureBase
org.apache.wss4j.dom.message.WSSecSignature
org.apache.wss4j.dom.saml.WSSecSignatureSAML
-
Field Summary
Fields inherited from class org.apache.wss4j.dom.message.WSSecSignature
bstToken, c14nMethod, certUri, keyInfo, keyInfoUri, secretKey, sig, signatureFactory, signatureValue, strUriFields inherited from class org.apache.wss4j.dom.message.WSSecBase
addWSUNamespace, attachmentCallbackHandler, callbackLookup, expandXopInclude, keyIdentifierType, password, storeBytesInAttachment, user -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionbuild(Crypto uCrypto, SamlAssertionWrapper samlAssertion, Crypto iCrypto, String iKeyName, String iKeyPW) Builds a signed soap envelope with SAML token.voidcomputeSignature(List<Reference> referenceList, Element siblingElement) Compute the Signature over the references.booleanReturn whether a Direct Reference is to be used to reference the assertion.voidprepare(Crypto uCrypto, SamlAssertionWrapper samlAssertion, Crypto iCrypto, String iKeyName, String iKeyPW) Initialize a WSSec SAML Signature.voidPrepend the SAML elements to the elements already in the Security header.voidsetUseDirectReferenceToAssertion(boolean useDirectReferenceToAssertion) Set whether a Direct Reference is to be used to reference the assertion.Methods inherited from class org.apache.wss4j.dom.message.WSSecSignature
addReferencesToSign, appendBSTElementToHeader, build, computeSignature, computeSignature, getBinarySecurityTokenElement, getBSTTokenId, getCustomKeyInfoElement, getCustomTokenId, getDigestAlgo, getId, getKeyInfoUri, getSecurityTokenReference, getSecurityTokenReferenceURI, getSigCanonicalization, getSignatureAlgorithm, getSignatureElement, getSignatureProvider, getSignatureValue, isAddInclusivePrefixes, isIncludeSignatureToken, isUseSingleCertificate, marshalKeyInfo, prepare, prependBSTElementToHeader, setAddInclusivePrefixes, setCustomKeyInfoElement, setCustomTokenId, setCustomTokenValueType, setDigestAlgo, setEncrKeySha1value, setIncludeSignatureToken, setSecretKey, setSecurityTokenReference, setSigCanonicalization, setSignatureAlgorithm, setSignatureProvider, setUseSingleCertificate, setX509CertificateMethods inherited from class org.apache.wss4j.dom.message.WSSecSignatureBase
addReferencesToSign, cleanup, createSTRParameter, getInclusivePrefixes, getInclusivePrefixesMethods inherited from class org.apache.wss4j.dom.message.WSSecBase
clean, getDocument, getIdAllocator, getKeyIdentifierType, getParts, getSecurityHeader, getWsDocInfo, isExpandXopInclude, setAttachmentCallbackHandler, setBodyID, setCallbackLookup, setExpandXopInclude, setIdAllocator, setKeyIdentifierType, setStoreBytesInAttachment, setUserInfo, setWsDocInfo, setWsuId
-
Constructor Details
-
WSSecSignatureSAML
Constructor. -
WSSecSignatureSAML
-
-
Method Details
-
build
public Document build(Crypto uCrypto, SamlAssertionWrapper samlAssertion, Crypto iCrypto, String iKeyName, String iKeyPW) throws WSSecurityException Builds a signed soap envelope with SAML token. The method first gets an appropriate security header. According to the defined parameters for certificate handling the signature elements are constructed and inserted into thewsse:Signature- Parameters:
uCrypto- The user's Crypto instancesamlAssertion- the complete SAML assertioniCrypto- An instance of the Crypto API to handle keystore SAML token issuer and to generate certificatesiKeyName- Private key to use in case of "sender-Vouches"iKeyPW- Password for issuer private key- Returns:
- A signed SOAP envelope as
Document - Throws:
WSSecurityException
-
prepare
public void prepare(Crypto uCrypto, SamlAssertionWrapper samlAssertion, Crypto iCrypto, String iKeyName, String iKeyPW) throws WSSecurityException Initialize a WSSec SAML Signature. The method sets up and initializes a WSSec SAML Signature structure after the relevant information was set. After setup of the references to elements to sign may be added. After all references are added they can be signed. This method does not add the Signature element to the security header. SeeprependSignatureElementToHeader()method.- Parameters:
uCrypto- The user's Crypto instancesamlAssertion- the complete SAML assertioniCrypto- An instance of the Crypto API to handle keystore SAML token issuer and to generate certificatesiKeyName- Private key to use in case of "sender-Vouches"iKeyPW- Password for issuer private key- Throws:
WSSecurityException
-
prependSAMLElementsToHeader
public void prependSAMLElementsToHeader()Prepend the SAML elements to the elements already in the Security header. The method can be called any time afterprepare(). This allows to insert the SAML elements at any position in the Security header. This methods first prepends the SAML security reference if mode issenderVouches, then the SAML token itself, -
computeSignature
public void computeSignature(List<Reference> referenceList, Element siblingElement) throws WSSecurityException Compute the Signature over the references. After references are set this method computes the Signature for them. This method can be called any time after the references were set. SeeaddReferencesToSign().- Throws:
WSSecurityException
-
isUseDirectReferenceToAssertion
public boolean isUseDirectReferenceToAssertion()Return whether a Direct Reference is to be used to reference the assertion. The default is false.- Returns:
- whether a Direct Reference is to be used to reference the assertion
-
setUseDirectReferenceToAssertion
public void setUseDirectReferenceToAssertion(boolean useDirectReferenceToAssertion) Set whether a Direct Reference is to be used to reference the assertion. The default is false.- Parameters:
useDirectReferenceToAssertion- whether a Direct Reference is to be used to reference the assertion
-