Class WsaServerTube
- java.lang.Object
-
- com.sun.xml.ws.api.pipe.helper.AbstractTubeImpl
-
- com.sun.xml.ws.api.pipe.helper.AbstractFilterTubeImpl
-
- com.sun.xml.ws.addressing.WsaServerTube
-
- Direct Known Subclasses:
MemberSubmissionWsaServerTube,W3CWsaServerTube
public class WsaServerTube extends AbstractFilterTubeImpl
Handles WS-Addressing for the server.- Author:
- Rama Pulavarthi, Kohsuke Kawaguchi, Arun Gupta
-
-
Field Summary
Fields Modifier and Type Field Description protected AddressingVersionaddressingVersionprotected WSBindingbindingprotected booleanisEarlyBackchannelCloseAllowedstatic StringREQUEST_MESSAGE_IDDeprecated.protected SOAPVersionsoapVersionprotected WSDLPortwsdlPortPort that we are processing.-
Fields inherited from class com.sun.xml.ws.api.pipe.helper.AbstractFilterTubeImpl
next
-
-
Constructor Summary
Constructors Constructor Description WsaServerTube(WsaServerTube that, TubeCloner cloner)WsaServerTube(WSEndpoint endpoint, WSDLPort wsdlPort, WSBinding binding, Tube next)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description protected voidcheckAnonymousSemantics(WSDLBoundOperation wbo, WSEndpointReference replyTo, WSEndpointReference faultTo)protected voidcheckCardinality(Packet packet)Checks the cardinality of WS-Addressing headers on an inboundPacket.protected voidcheckMandatoryHeaders(Packet packet, boolean foundAction, boolean foundTo, boolean foundReplyTo, boolean foundFaultTo, boolean foundMessageId, boolean foundRelatesTo)This should be called only when Addressing is engaged.protected voidcheckMessageAddressingProperties(Packet packet)This method checks all the WS-Addressing headers are valid and as per the spec definded rules.WsaServerTubecopy(TubeCloner cloner)Creates an identical clone of thisTube.protected WsaTubeHelpergetTubeHelper()protected WSDLBoundOperationgetWSDLBoundOperation(Packet packet)protected booleanisAnonymousRequired(WSDLBoundOperation wbo)NextActionprocessException(Throwable t)Default no-op implementation.NextActionprocessRequest(Packet request)Default no-op implementation.NextActionprocessResponse(Packet response)Default no-op implementation.protected voidvalidateAction(Packet packet)protected PacketvalidateInboundHeaders(Packet packet)Validates the inbound message.protected voidvalidateSOAPAction(Packet packet)-
Methods inherited from class com.sun.xml.ws.api.pipe.helper.AbstractFilterTubeImpl
preDestroy
-
Methods inherited from class com.sun.xml.ws.api.pipe.helper.AbstractTubeImpl
copy, doInvoke, doInvokeAndForget, doReturnWith, doSuspend, doSuspend, doSuspend, doSuspend, doThrow, doThrow, process
-
-
-
-
Field Detail
-
isEarlyBackchannelCloseAllowed
protected boolean isEarlyBackchannelCloseAllowed
-
REQUEST_MESSAGE_ID
public static final String REQUEST_MESSAGE_ID
Deprecated.- See Also:
- Constant Field Values
-
binding
protected final WSBinding binding
-
addressingVersion
@NotNull protected final AddressingVersion addressingVersion
-
soapVersion
protected final SOAPVersion soapVersion
-
-
Constructor Detail
-
WsaServerTube
public WsaServerTube(WSEndpoint endpoint, @NotNull WSDLPort wsdlPort, WSBinding binding, Tube next)
-
WsaServerTube
public WsaServerTube(WsaServerTube that, TubeCloner cloner)
-
-
Method Detail
-
copy
public WsaServerTube 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
@NotNull public NextAction processRequest(Packet request)
Description copied from class:AbstractFilterTubeImplDefault no-op implementation.- Specified by:
processRequestin interfaceTube- Overrides:
processRequestin classAbstractFilterTubeImpl- Parameters:
request- 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.
-
isAnonymousRequired
protected boolean isAnonymousRequired(@Nullable WSDLBoundOperation wbo)
-
checkAnonymousSemantics
protected void checkAnonymousSemantics(WSDLBoundOperation wbo, WSEndpointReference replyTo, WSEndpointReference faultTo)
-
processException
@NotNull public NextAction processException(Throwable t)
Description copied from class:AbstractFilterTubeImplDefault no-op implementation.- Specified by:
processExceptionin interfaceTube- Returns:
- A
NextActionobject that represents the next action to be taken by the JAX-WS runtime.
-
processResponse
@NotNull public NextAction processResponse(Packet response)
Description copied from class:AbstractFilterTubeImplDefault no-op implementation.- Specified by:
processResponsein interfaceTube- Overrides:
processResponsein classAbstractFilterTubeImpl- Parameters:
response- 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.
-
validateAction
protected void validateAction(Packet packet)
-
checkMessageAddressingProperties
protected void checkMessageAddressingProperties(Packet packet)
This method checks all the WS-Addressing headers are valid and as per the spec definded rules. Mainly it checks the cardinality of the WSA headers and checks that mandatory headers exist. It also checks if the SOAPAction is equal to wsa:Action value when non-empty. Override this method if you need to additional checking of headers other than just existence of the headers. For ex: On server-side, check Anonymous and Non-Anonymous semantics in addition to checking cardinality. Override checkMandatoryHeaders(Packet p) to have different validation rules for different versions
-
getTubeHelper
protected WsaTubeHelper getTubeHelper()
-
validateInboundHeaders
protected Packet validateInboundHeaders(Packet packet)
Validates the inbound message. If an error is found, create a fault message and returns that. Otherwise it will pass through the parameter 'packet' object to the return value.
-
checkCardinality
protected void checkCardinality(Packet packet)
Checks the cardinality of WS-Addressing headers on an inboundPacket. This method checks for the cardinality if WS-Addressing is engaged (detected by the presence of wsa:Action header) or wsdl:required=true.- Parameters:
packet- The inbound packet.- Throws:
jakarta.xml.ws.WebServiceException- if:
-
getWSDLBoundOperation
protected final WSDLBoundOperation getWSDLBoundOperation(Packet packet)
-
validateSOAPAction
protected void validateSOAPAction(Packet packet)
-
checkMandatoryHeaders
protected void checkMandatoryHeaders(Packet packet, boolean foundAction, boolean foundTo, boolean foundReplyTo, boolean foundFaultTo, boolean foundMessageId, boolean foundRelatesTo)
This should be called only when Addressing is engaged. Checks only for presence of wsa:Action and validates that wsa:Action equals SOAPAction header when non-empty Should be overridden if other wsa headers need to be checked based on version.- Parameters:
packet-foundAction-foundTo-foundReplyTo-foundFaultTo-foundMessageId-foundRelatesTo-
-
-