Class WSITClientAuthContext
- java.lang.Object
-
- com.sun.xml.wss.provider.wsit.WSITAuthContextBase
-
- com.sun.xml.wss.provider.wsit.WSITClientAuthContext
-
- All Implemented Interfaces:
ClientAuth,ClientAuthContext
public class WSITClientAuthContext extends WSITAuthContextBase implements ClientAuthContext
- Author:
- kumar jayanti
-
-
Field Summary
Fields Modifier and Type Field Description protected WeakReference<WSITClientAuthConfig>authConfigprotected inttubeOrPipeHashCode-
Fields inherited from class com.sun.xml.wss.provider.wsit.WSITAuthContextBase
allowMissingTimestamp, bindingLevelAlgSuite, bpMSP, debug, DEFAULT_JMAC_HANDLER, disableIncPrefix, EMPTY_LIST, encHeaderContent, encRMLifecycleMsg, isCertValid, isCertValidityVerified, isEPREnabled, isSOAP12, issuedTokenContextMap, iterationsForPDK, jaxbContext, log, marshaller, mcVer, nextPipe, nextTube, optimized, pipeConfig, policyAlternatives, REQ_PACKET, RES_PACKET, rmVer, secEnv, securityMUValue, securityPolicyNamespaces, serverCert, soapFactory, soapVersion, spVersion, timestampTimeOut, unmarshaller, WSDLPORT, WSENDPOINT, wsscVer, wsTrustVer
-
-
Constructor Summary
Constructors Constructor Description WSITClientAuthContext(String operation, Subject subject, Map<Object,Object> map, CallbackHandler callbackHandler)Creates a new instance of WSITClientAuthContext
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description protected voidaddIncomingFaultPolicy(Policy effectivePolicy, SecurityPolicyHolder sph, WSDLFault fault)protected SecurityPolicyHolderaddIncomingMP(WSDLBoundOperation operation, Policy policy, PolicyAlternativeHolder ph)protected voidaddIncomingProtocolPolicy(Policy effectivePolicy, String protocol, PolicyAlternativeHolder ph)protected voidaddOutgoingFaultPolicy(Policy effectivePolicy, SecurityPolicyHolder sph, WSDLFault fault)protected SecurityPolicyHolderaddOutgoingMP(WSDLBoundOperation operation, Policy policy, PolicyAlternativeHolder ph)protected voidaddOutgoingProtocolPolicy(Policy effectivePolicy, String protocol, PolicyAlternativeHolder ph)voidcleanSubject(MessageInfo messageInfo, Subject subject)Remove implementation specific principals and credentials from the subject.protected StringgetAction(WSDLOperation operation, boolean inComming)protected List<PolicyAssertion>getIssuedTokenPolicies(Packet packet, String scope)protected voidpopulateKerberosContext(Packet packet, ProcessingContextImpl ctx, boolean isSCMessage)protected MessagesecureOutboundMessage(Message message, ProcessingContext ctx)protected jakarta.xml.soap.SOAPMessagesecureOutboundMessage(jakarta.xml.soap.SOAPMessage message, ProcessingContext ctx)PacketsecureRequest(Packet packet, Subject clientSubject, boolean isSCMessage)AuthStatussecureRequest(MessageInfo messageInfo, Subject clientSubject)Secure a service request message before sending it to the service.PacketvalidateResponse(Packet req, Subject clientSubject, Subject serviceSubject)AuthStatusvalidateResponse(MessageInfo messageInfo, Subject clientSubject, Subject serviceSubject)Validate a received service response.protected MessageverifyInboundMessage(Message message, ProcessingContext ctx)protected jakarta.xml.soap.SOAPMessageverifyInboundMessage(jakarta.xml.soap.SOAPMessage message, ProcessingContext ctx)-
Methods inherited from class com.sun.xml.wss.provider.wsit.WSITAuthContextBase
bindingHasIssuedTokenPolicy, bindingHasRMPolicy, bindingHasSecureConversationPolicy, buildProtocolPolicy, cachedOperation, cacheMessage, cacheOperation, cacheOperation, collectPolicies, constructPolicyHolder, constructPolicyHolder, generateInternalError, getAction, getAlgoSuite, getBindingAlgorithmSuite, getEffectiveBootstrapPolicy, getInBoundSCP, getIssuedTokenPoliciesFromBootstrapPolicy, getKerberosTokenPoliciesFromBootstrapPolicy, getOperation, getOperationKey, getOutBoundKTP, getOutBoundSCP, getOutgoingXWSBootstrapPolicy, getOutgoingXWSSecurityPolicy, getRequestPacket, getResponsePacket, getSecureConversationPolicies, getSOAPFault, getSOAPFaultException, getSOAPFaultException, getTokens, getWSDLOpFromAction, getWssAssertion, hasKerberosTokenPolicy, initializeInboundProcessingContext, initializeOutgoingProcessingContext, isAddressingEnabled, isMakeConnectionMessage, isRMMessage, isSCCancel, isSCMessage, isSCRenew, isTrustMessage, loadClass, loadGFHandler, populateConfigProperties, resetCachedOperation, resolveAlternative, setRequestPacket, setResponsePacket, unmarshalPolicy
-
-
-
-
Field Detail
-
authConfig
protected WeakReference<WSITClientAuthConfig> authConfig
-
tubeOrPipeHashCode
protected int tubeOrPipeHashCode
-
-
Method Detail
-
secureRequest
public AuthStatus secureRequest(MessageInfo messageInfo, Subject clientSubject) throws AuthException
Description copied from interface:ClientAuthSecure a service request message before sending it to the service.This method is called to transform the request message acquired by calling getRequestMessage (on messageInfo) into the mechanism-specific form to be sent by the runtime.
This method conveys the outcome of its message processing either by returning an AuthStatus value or by throwing an AuthException.
- Specified by:
secureRequestin interfaceClientAuth- Parameters:
messageInfo- A contextual object that encapsulates the client request and server response objects, and that may be used to save state across a sequence of calls made to the methods of this interface for the purpose of completing a secure message exchange.clientSubject- A Subject that represents the source of the service request, or null. It may be used by the method implementation as the source of Principals or credentials to be used to secure the request. If the Subject is not null, the method implementation may add additional Principals or credentials (pertaining to the source of the service request) to the Subject.- Returns:
- An AuthStatus object representing the completion status of the processing performed by the method. The
AuthStatus values that may be returned by this method are defined as follows:
- AuthStatus.SUCCESS when the application request message was successfully secured. The secured request message may be obtained by calling getRequestMessage on messageInfo.
- AuthStatus.SEND_CONTINUE to indicate that the application request message (within messageInfo) was replaced with
a security message that should elicit a security-specific response from the peer security system. This status value
also indicates that the application message has not yet been secured.
This status value serves to inform the calling runtime that (to successfully complete the message exchange) it will
need to be capable of continuing the message dialog by conducting at least one additional request/response exchange
after having received the security-specific response elicited by sending the security message.
When this status value is returned, the corresponding invocation of
validateResponsemust be able to obtain the original application request message. - AuthStatus.FAILURE to indicate that a failure occured while securing the request message, and that an appropriate failure response message is available by calling getResponseMessage on messageInfo.
- Throws:
AuthException- When the message processing failed without establishing a failure response message (in messageInfo).
-
secureRequest
public Packet secureRequest(Packet packet, Subject clientSubject, boolean isSCMessage) throws XWSSecurityException
- Throws:
XWSSecurityException
-
validateResponse
public AuthStatus validateResponse(MessageInfo messageInfo, Subject clientSubject, Subject serviceSubject) throws AuthException
Description copied from interface:ClientAuthValidate a received service response.This method is called to transform the mechanism-specific response message acquired by calling getResponseMessage (on messageInfo) into the validated application message to be returned to the message processing runtime. If the response message is a (mechanism-specific) meta-message, the method implementation must attempt to transform the meta-message into the next mechanism-specific request message to be sent by the runtime.
This method conveys the outcome of its message processing either by returning an AuthStatus value or by throwing an AuthException.
- Specified by:
validateResponsein interfaceClientAuth- Parameters:
messageInfo- A contextual object that encapsulates the client request and server response objects, and that may be used to save state across a sequence of calls made to the methods of this interface for the purpose of completing a secure message exchange.clientSubject- A Subject that represents the recipient of the service response, or null. It may be used by the method implementation as the source of Principals or credentials to be used to validate the response. If the Subject is not null, the method implementation may add additional Principals or credentials (pertaining to the recipient of the service request) to the Subject.serviceSubject- A Subject that represents the source of the service response, or null. If the Subject is not null, the method implementation may add additional Principals or credentials (pertaining to the source of the service response) to the Subject.- Returns:
- An AuthStatus object representing the completion status of the processing performed by the method. The
AuthStatus values that may be returned by this method are defined as follows:
- AuthStatus.SUCCESS when the application response message was successfully validated. The validated message is available by calling getResponseMessage on messageInfo.
- AuthStatus.SEND_CONTINUE to indicate that response validation is incomplete, and that a continuation request was returned as the request message within messageInfo. This status value serves to inform the calling runtime that (to successfully complete the message exchange) it will need to be capable of continuing the message dialog by conducting at least one additional request/response exchange.
- AuthStatus.FAILURE to indicate that validation of the response failed, and that a failure response message has been established in messageInfo.
- Throws:
AuthException- When the message processing failed without establishing a failure response message (in messageInfo).
-
cleanSubject
public void cleanSubject(MessageInfo messageInfo, Subject subject) throws AuthException
Description copied from interface:ClientAuthRemove implementation specific principals and credentials from the subject.- Specified by:
cleanSubjectin interfaceClientAuth- Parameters:
messageInfo- A contextual object that encapsulates the client request and server response objects, and that may be used to save state across a sequence of calls made to the methods of this interface for the purpose of completing a secure message exchange.subject- The Subject instance from which the Principals and credentials are to be removed.- Throws:
AuthException- If an error occurs during the Subject processing.
-
validateResponse
public Packet validateResponse(Packet req, Subject clientSubject, Subject serviceSubject) throws XWSSecurityException
- Throws:
XWSSecurityException
-
secureOutboundMessage
protected jakarta.xml.soap.SOAPMessage secureOutboundMessage(jakarta.xml.soap.SOAPMessage message, ProcessingContext ctx)- Overrides:
secureOutboundMessagein classWSITAuthContextBase
-
secureOutboundMessage
protected Message secureOutboundMessage(Message message, ProcessingContext ctx)
- Overrides:
secureOutboundMessagein classWSITAuthContextBase
-
verifyInboundMessage
protected jakarta.xml.soap.SOAPMessage verifyInboundMessage(jakarta.xml.soap.SOAPMessage message, ProcessingContext ctx) throws WssSoapFaultException, XWSSecurityException
-
verifyInboundMessage
protected Message verifyInboundMessage(Message message, ProcessingContext ctx) throws XWSSecurityException
- Throws:
XWSSecurityException
-
addOutgoingMP
protected SecurityPolicyHolder addOutgoingMP(WSDLBoundOperation operation, Policy policy, PolicyAlternativeHolder ph) throws PolicyException
- Specified by:
addOutgoingMPin classWSITAuthContextBase- Throws:
PolicyException
-
addIncomingMP
protected SecurityPolicyHolder addIncomingMP(WSDLBoundOperation operation, Policy policy, PolicyAlternativeHolder ph) throws PolicyException
- Specified by:
addIncomingMPin classWSITAuthContextBase- Throws:
PolicyException
-
addIncomingProtocolPolicy
protected void addIncomingProtocolPolicy(Policy effectivePolicy, String protocol, PolicyAlternativeHolder ph) throws PolicyException
- Specified by:
addIncomingProtocolPolicyin classWSITAuthContextBase- Throws:
PolicyException
-
addOutgoingProtocolPolicy
protected void addOutgoingProtocolPolicy(Policy effectivePolicy, String protocol, PolicyAlternativeHolder ph) throws PolicyException
- Specified by:
addOutgoingProtocolPolicyin classWSITAuthContextBase- Throws:
PolicyException
-
addIncomingFaultPolicy
protected void addIncomingFaultPolicy(Policy effectivePolicy, SecurityPolicyHolder sph, WSDLFault fault) throws PolicyException
- Specified by:
addIncomingFaultPolicyin classWSITAuthContextBase- Throws:
PolicyException
-
addOutgoingFaultPolicy
protected void addOutgoingFaultPolicy(Policy effectivePolicy, SecurityPolicyHolder sph, WSDLFault fault) throws PolicyException
- Specified by:
addOutgoingFaultPolicyin classWSITAuthContextBase- Throws:
PolicyException
-
getAction
protected String getAction(WSDLOperation operation, boolean inComming)
- Specified by:
getActionin classWSITAuthContextBase
-
getIssuedTokenPolicies
protected List<PolicyAssertion> getIssuedTokenPolicies(Packet packet, String scope)
-
populateKerberosContext
protected void populateKerberosContext(Packet packet, ProcessingContextImpl ctx, boolean isSCMessage) throws XWSSecurityException
- Throws:
XWSSecurityException
-
-