Class SecurityServerTube
- java.lang.Object
-
- com.sun.xml.ws.api.pipe.helper.AbstractTubeImpl
-
- com.sun.xml.ws.api.pipe.helper.AbstractFilterTubeImpl
-
- com.sun.xml.wss.jaxws.impl.SecurityTubeBase
-
- com.sun.xml.wss.jaxws.impl.SecurityServerTube
-
public class SecurityServerTube extends SecurityTubeBase
- Author:
- shyam.rao@sun.com, Vbkumar.Jayanti@Sun.COM
-
-
Field Summary
-
Fields inherited from class com.sun.xml.wss.jaxws.impl.SecurityTubeBase
allowMissingTimestamp, bindingLevelAlgSuite, bpMSP, bsp10, cachedOperation, debug, disableIncPrefix, disablePayloadBuffer, EMPTY_LIST, encHeaderContent, encRMLifecycleMsg, isCertValid, isCertValidityVerified, isEPREnabled, isSOAP12, issuedTokenContextMap, iterationsForPDK, jaxbContext, log, marshaller, mcVer, optimized, policyAlternatives, rmVer, secEnv, securityMUValue, securityPolicyNamespaces, serverCert, soapFactory, soapVersion, spVersion, timestampTimeOut, transportOptimization, tubeConfig, unmarshaller, WSDLPORT, WSENDPOINT, wsitConfig, wsPolicyMap, wsscVer, wsTrustVer
-
Fields inherited from class com.sun.xml.ws.api.pipe.helper.AbstractFilterTubeImpl
next
-
-
Constructor Summary
Constructors Modifier Constructor Description SecurityServerTube(ServerTubelineAssemblyContext context, Tube nextTube)protectedSecurityServerTube(SecurityServerTube that, TubeCloner cloner)
-
Method Summary
All Methods Static 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)private Packet addAddressingHeaders(Packet packet, String relatesTo, String action){ AddressingBuilder builder = AddressingBuilder.newInstance(); AddressingProperties ap = builder.newAddressingProperties(); try{ // Action ap.setAction(builder.newURI(new URI(action))); // RelatesTo Relationship[] rs = new Relationship[]{builder.newRelationship(new URI(relatesTo))}; ap.setRelatesTo(rs); // To ap.setTo(builder.newURI(new URI(builder.newAddressingConstants().getAnonymousURI()))); } catch (URISyntaxException e) { throw new RuntimeException("Exception when adding Addressing Headers"); } WsaRuntimeFactory fac = WsaRuntimeFactory.newInstance(ap.getNamespaceURI(), pipeConfig.getWSDLModel(), pipeConfig.getBinding()); fac.writeHeaders(packet, ap); packet.invocationProperties .put(JAXWSAConstants.SERVER_ADDRESSING_PROPERTIES_OUTBOUND, ap); return packet; }protected voidaddOutgoingProtocolPolicy(Policy effectivePolicy, String protocol, PolicyAlternativeHolder ph)AbstractTubeImplcopy(TubeCloner cloner)Creates an identical clone of thisTube.protected StringgetAction(WSDLOperation operation, boolean inComming)protected MessagePolicygetOutgoingFaultPolicy(Packet packet)protected MessagePolicygetOutgoingXWSSecurityPolicy(Packet packet, boolean isSCMessage)protected ProcessingContextinitializeOutgoingProcessingContext(Packet packet, boolean isSCMessage)protected ProcessingContextinitializeOutgoingProcessingContext(Packet packet, boolean isSCMessage, boolean isTrustMessage)static URLloadFromClasspath(String configFileName)voidpreDestroy()Invoked before the last copy of the pipeline is about to be discarded, to giveTubes a chance to clean up any resources.NextActionprocessException(Throwable t)Default no-op implementation.InputStreamMessageprocessInputStream(Message msg)InputStreamMessageprocessInputStream(Packet packet)InputStreamMessageprocessInputStream(XMLStreamReaderMessage msg)PacketprocessMessage(XMLStreamReaderMessage msg)NextActionprocessRequest(Packet packet)Default no-op implementation.NextActionprocessResponse(Packet retPacket)Default no-op implementation.protected javax.xml.soap.SOAPMessageverifyInboundMessage(javax.xml.soap.SOAPMessage message, ProcessingContext ctx)-
Methods inherited from class com.sun.xml.wss.jaxws.impl.SecurityTubeBase
bindingHasIssuedTokenPolicy, bindingHasRMPolicy, bindingHasSecureConversationPolicy, buildProtocolPolicy, cacheMessage, cacheOperation, collectPolicies, constructPolicyHolder, constructPolicyHolder, generateInternalError, getAction, getAlgoSuite, getBindingAlgorithmSuite, getEffectiveBootstrapPolicy, getInBoundSCP, getInboundXWSBootstrapPolicy, getIssuedTokenPoliciesFromBootstrapPolicy, getKerberosTokenPoliciesFromBootstrapPolicy, getOperation, getOperationKey, getOutBoundKTP, getOutBoundSCP, getOutgoingXWSBootstrapPolicy, getSecureConversationPolicies, getSOAPFault, getSOAPFaultException, getSOAPFaultException, getTokens, getWSDLOpFromAction, getWSDLOpFromAction, getWssAssertion, hasKerberosTokenPolicy, initializeInboundProcessingContext, isAddressingEnabled, isMakeConnectionMessage, isRMMessage, isSCCancel, isSCMessage, isSCRenew, isTrustMessage, loadClass, populateConfigProperties, resetCachedOperation, resolveAlternative, secureOutboundMessage, secureOutboundMessage, unmarshalPolicy, verifyInboundMessage
-
Methods inherited from class com.sun.xml.ws.api.pipe.helper.AbstractTubeImpl
copy, doInvoke, doInvokeAndForget, doReturnWith, doSuspend, doSuspend, doSuspend, doSuspend, doThrow, doThrow, process
-
-
-
-
Constructor Detail
-
SecurityServerTube
public SecurityServerTube(ServerTubelineAssemblyContext context, Tube nextTube)
-
SecurityServerTube
protected SecurityServerTube(SecurityServerTube that, TubeCloner cloner)
-
-
Method Detail
-
copy
public AbstractTubeImpl copy(TubeCloner cloner)
Description copied from interface:TubeCreates an identical clone of thisTube.This method creates an identical pipeline that can be used concurrently with this pipeline. When the caller of a pipeline is multi-threaded and need concurrent use of the same pipeline, it can do so by creating copies through this method.
Implementation Note
It is the implementation's responsibility to call
TubeCloner.add(Tube,Tube)to register the copied pipe with the original. This is required before you start copying the otherTubereferences you have, or else there's a risk of infinite recursion.For most
Tubeimplementations that delegate to anotherTube, this method requires that you also copy theTubethat you delegate to.For limited number of
Tubes that do not maintain any thread unsafe resource, it is allowed to simply returnthisfrom this method (notice that even if you are stateless, if you got a delegatingTubeand that one isn't stateless, you still have to copy yourself.)Note that this method might be invoked by one thread while another thread is executing the other process method. See the
Codec.copy()for more discussion about this.- Specified by:
copyin interfaceTube- Specified by:
copyin classAbstractTubeImpl- Parameters:
cloner- Use this object (in particular itsTubeCloner.copy(Tube)method to clone other pipe references you have in your pipe. SeeTubeClonerfor more discussion about why.- Returns:
- always non-null
Tube.
-
processRequest
public NextAction processRequest(Packet packet)
Description copied from class:AbstractFilterTubeImplDefault no-op implementation.- Specified by:
processRequestin interfaceTube- Overrides:
processRequestin classAbstractFilterTubeImpl- Parameters:
packet- The packet that represents a request message. If the packet has a non-null message, it must be a valid unconsumedMessage. This message represents the SOAP message to be sent as a request.The packet is also allowed to carry no message, which indicates that this is an output-only request. (that's called "solicit", right? - KK)
- Returns:
- A
NextActionobject that represents the next action to be taken by the JAX-WS runtime.
-
processResponse
public NextAction processResponse(Packet retPacket)
Description copied from class:AbstractFilterTubeImplDefault no-op implementation.- Specified by:
processResponsein interfaceTube- Overrides:
processResponsein classAbstractFilterTubeImpl- Parameters:
retPacket- If the packet has a non-null message, it must be a valid unconsumedMessage. This message represents a response to the request message passed toTube.processRequest(Packet)earlier.The packet is also allowed to carry no message, which indicates that there was no response. This is used for things like one-way message and/or one-way transports. TODO: exception handling semantics need more discussion
- Returns:
- A
NextActionobject that represents the next action to be taken by the JAX-WS runtime.
-
processException
public NextAction processException(Throwable t)
Description copied from class:AbstractFilterTubeImplDefault no-op implementation.- Specified by:
processExceptionin interfaceTube- Overrides:
processExceptionin classAbstractFilterTubeImpl- Returns:
- A
NextActionobject that represents the next action to be taken by the JAX-WS runtime.
-
preDestroy
public void preDestroy()
Description copied from interface:TubeInvoked before the last copy of the pipeline is about to be discarded, to giveTubes a chance to clean up any resources.This can be used to invoke
PreDestroylifecycle methods on user handler. The invocation of it is optional on the client side, but mandatory on the server side.When multiple copies of pipelines are created, this method is called only on one of them.
- Specified by:
preDestroyin interfacePipe- Specified by:
preDestroyin interfaceTube- Overrides:
preDestroyin classAbstractFilterTubeImpl
-
processMessage
public Packet processMessage(XMLStreamReaderMessage msg)
-
processInputStream
public InputStreamMessage processInputStream(XMLStreamReaderMessage msg)
-
processInputStream
public InputStreamMessage processInputStream(Message msg)
-
initializeOutgoingProcessingContext
protected ProcessingContext initializeOutgoingProcessingContext(Packet packet, boolean isSCMessage, boolean isTrustMessage)
-
initializeOutgoingProcessingContext
protected ProcessingContext initializeOutgoingProcessingContext(Packet packet, boolean isSCMessage)
- Overrides:
initializeOutgoingProcessingContextin classSecurityTubeBase
-
getOutgoingXWSSecurityPolicy
protected MessagePolicy getOutgoingXWSSecurityPolicy(Packet packet, boolean isSCMessage)
- Overrides:
getOutgoingXWSSecurityPolicyin classSecurityTubeBase
-
getOutgoingFaultPolicy
protected MessagePolicy getOutgoingFaultPolicy(Packet packet)
-
verifyInboundMessage
protected javax.xml.soap.SOAPMessage verifyInboundMessage(javax.xml.soap.SOAPMessage message, ProcessingContext ctx) throws WssSoapFaultException, XWSSecurityException- Overrides:
verifyInboundMessagein classSecurityTubeBase- Throws:
WssSoapFaultExceptionXWSSecurityException
-
processInputStream
public InputStreamMessage processInputStream(Packet packet)
-
addOutgoingMP
protected SecurityPolicyHolder addOutgoingMP(WSDLBoundOperation operation, Policy policy, PolicyAlternativeHolder ph) throws PolicyException
private Packet addAddressingHeaders(Packet packet, String relatesTo, String action){ AddressingBuilder builder = AddressingBuilder.newInstance(); AddressingProperties ap = builder.newAddressingProperties(); try{ // Action ap.setAction(builder.newURI(new URI(action))); // RelatesTo Relationship[] rs = new Relationship[]{builder.newRelationship(new URI(relatesTo))}; ap.setRelatesTo(rs); // To ap.setTo(builder.newURI(new URI(builder.newAddressingConstants().getAnonymousURI()))); } catch (URISyntaxException e) { throw new RuntimeException("Exception when adding Addressing Headers"); } WsaRuntimeFactory fac = WsaRuntimeFactory.newInstance(ap.getNamespaceURI(), pipeConfig.getWSDLModel(), pipeConfig.getBinding()); fac.writeHeaders(packet, ap); packet.invocationProperties .put(JAXWSAConstants.SERVER_ADDRESSING_PROPERTIES_OUTBOUND, ap); return packet; }- Specified by:
addOutgoingMPin classSecurityTubeBase- Throws:
PolicyException
-
addIncomingMP
protected SecurityPolicyHolder addIncomingMP(WSDLBoundOperation operation, Policy policy, PolicyAlternativeHolder ph) throws PolicyException
- Specified by:
addIncomingMPin classSecurityTubeBase- Throws:
PolicyException
-
addIncomingProtocolPolicy
protected void addIncomingProtocolPolicy(Policy effectivePolicy, String protocol, PolicyAlternativeHolder ph) throws PolicyException
- Specified by:
addIncomingProtocolPolicyin classSecurityTubeBase- Throws:
PolicyException
-
addOutgoingProtocolPolicy
protected void addOutgoingProtocolPolicy(Policy effectivePolicy, String protocol, PolicyAlternativeHolder ph) throws PolicyException
- Specified by:
addOutgoingProtocolPolicyin classSecurityTubeBase- Throws:
PolicyException
-
addIncomingFaultPolicy
protected void addIncomingFaultPolicy(Policy effectivePolicy, SecurityPolicyHolder sph, WSDLFault fault) throws PolicyException
- Specified by:
addIncomingFaultPolicyin classSecurityTubeBase- Throws:
PolicyException
-
addOutgoingFaultPolicy
protected void addOutgoingFaultPolicy(Policy effectivePolicy, SecurityPolicyHolder sph, WSDLFault fault) throws PolicyException
- Specified by:
addOutgoingFaultPolicyin classSecurityTubeBase- Throws:
PolicyException
-
getAction
protected String getAction(WSDLOperation operation, boolean inComming)
- Specified by:
getActionin classSecurityTubeBase
-
-