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:
- [email protected], [email protected]
-
-
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)
protected
SecurityServerTube(SecurityServerTube that, TubeCloner cloner)
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description protected void
addIncomingFaultPolicy(Policy effectivePolicy, SecurityPolicyHolder sph, WSDLFault fault)
protected SecurityPolicyHolder
addIncomingMP(WSDLBoundOperation operation, Policy policy, PolicyAlternativeHolder ph)
protected void
addIncomingProtocolPolicy(Policy effectivePolicy, String protocol, PolicyAlternativeHolder ph)
protected void
addOutgoingFaultPolicy(Policy effectivePolicy, SecurityPolicyHolder sph, WSDLFault fault)
protected SecurityPolicyHolder
addOutgoingMP(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 void
addOutgoingProtocolPolicy(Policy effectivePolicy, String protocol, PolicyAlternativeHolder ph)
AbstractTubeImpl
copy(TubeCloner cloner)
Creates an identical clone of thisTube
.protected String
getAction(WSDLOperation operation, boolean inComming)
protected MessagePolicy
getOutgoingFaultPolicy(Packet packet)
protected MessagePolicy
getOutgoingXWSSecurityPolicy(Packet packet, boolean isSCMessage)
protected ProcessingContext
initializeOutgoingProcessingContext(Packet packet, boolean isSCMessage)
protected ProcessingContext
initializeOutgoingProcessingContext(Packet packet, boolean isSCMessage, boolean isTrustMessage)
static URL
loadFromClasspath(String configFileName)
void
preDestroy()
Invoked before the last copy of the pipeline is about to be discarded, to giveTube
s a chance to clean up any resources.NextAction
processException(Throwable t)
Default no-op implementation.InputStreamMessage
processInputStream(Message msg)
InputStreamMessage
processInputStream(Packet packet)
InputStreamMessage
processInputStream(XMLStreamReaderMessage msg)
Packet
processMessage(XMLStreamReaderMessage msg)
NextAction
processRequest(Packet packet)
Default no-op implementation.NextAction
processResponse(Packet retPacket)
Default no-op implementation.protected jakarta.xml.soap.SOAPMessage
verifyInboundMessage(jakarta.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:Tube
Creates 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 otherTube
references you have, or else there's a risk of infinite recursion.For most
Tube
implementations that delegate to anotherTube
, this method requires that you also copy theTube
that you delegate to.For limited number of
Tube
s that do not maintain any thread unsafe resource, it is allowed to simply returnthis
from this method (notice that even if you are stateless, if you got a delegatingTube
and 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:
copy
in interfaceTube
- Specified by:
copy
in classAbstractTubeImpl
- Parameters:
cloner
- Use this object (in particular itsTubeCloner.copy(Tube)
method to clone other pipe references you have in your pipe. SeeTubeCloner
for more discussion about why.- Returns:
- always non-null
Tube
.
-
processRequest
public NextAction processRequest(Packet packet)
Description copied from class:AbstractFilterTubeImpl
Default no-op implementation.- Specified by:
processRequest
in interfaceTube
- Overrides:
processRequest
in 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
NextAction
object that represents the next action to be taken by the JAX-WS runtime.
-
processResponse
public NextAction processResponse(Packet retPacket)
Description copied from class:AbstractFilterTubeImpl
Default no-op implementation.- Specified by:
processResponse
in interfaceTube
- Overrides:
processResponse
in 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
NextAction
object that represents the next action to be taken by the JAX-WS runtime.
-
processException
public NextAction processException(Throwable t)
Description copied from class:AbstractFilterTubeImpl
Default no-op implementation.- Specified by:
processException
in interfaceTube
- Overrides:
processException
in classAbstractFilterTubeImpl
- Returns:
- A
NextAction
object that represents the next action to be taken by the JAX-WS runtime.
-
preDestroy
public void preDestroy()
Description copied from interface:Tube
Invoked before the last copy of the pipeline is about to be discarded, to giveTube
s a chance to clean up any resources.This can be used to invoke
PreDestroy
lifecycle 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:
preDestroy
in interfacePipe
- Specified by:
preDestroy
in interfaceTube
- Overrides:
preDestroy
in 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:
initializeOutgoingProcessingContext
in classSecurityTubeBase
-
getOutgoingXWSSecurityPolicy
protected MessagePolicy getOutgoingXWSSecurityPolicy(Packet packet, boolean isSCMessage)
- Overrides:
getOutgoingXWSSecurityPolicy
in classSecurityTubeBase
-
getOutgoingFaultPolicy
protected MessagePolicy getOutgoingFaultPolicy(Packet packet)
-
verifyInboundMessage
protected jakarta.xml.soap.SOAPMessage verifyInboundMessage(jakarta.xml.soap.SOAPMessage message, ProcessingContext ctx) throws WssSoapFaultException, XWSSecurityException
- Overrides:
verifyInboundMessage
in classSecurityTubeBase
- Throws:
WssSoapFaultException
XWSSecurityException
-
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:
addOutgoingMP
in classSecurityTubeBase
- Throws:
PolicyException
-
addIncomingMP
protected SecurityPolicyHolder addIncomingMP(WSDLBoundOperation operation, Policy policy, PolicyAlternativeHolder ph) throws PolicyException
- Specified by:
addIncomingMP
in classSecurityTubeBase
- Throws:
PolicyException
-
addIncomingProtocolPolicy
protected void addIncomingProtocolPolicy(Policy effectivePolicy, String protocol, PolicyAlternativeHolder ph) throws PolicyException
- Specified by:
addIncomingProtocolPolicy
in classSecurityTubeBase
- Throws:
PolicyException
-
addOutgoingProtocolPolicy
protected void addOutgoingProtocolPolicy(Policy effectivePolicy, String protocol, PolicyAlternativeHolder ph) throws PolicyException
- Specified by:
addOutgoingProtocolPolicy
in classSecurityTubeBase
- Throws:
PolicyException
-
addIncomingFaultPolicy
protected void addIncomingFaultPolicy(Policy effectivePolicy, SecurityPolicyHolder sph, WSDLFault fault) throws PolicyException
- Specified by:
addIncomingFaultPolicy
in classSecurityTubeBase
- Throws:
PolicyException
-
addOutgoingFaultPolicy
protected void addOutgoingFaultPolicy(Policy effectivePolicy, SecurityPolicyHolder sph, WSDLFault fault) throws PolicyException
- Specified by:
addOutgoingFaultPolicy
in classSecurityTubeBase
- Throws:
PolicyException
-
getAction
protected String getAction(WSDLOperation operation, boolean inComming)
- Specified by:
getAction
in classSecurityTubeBase
-
-