Class MemberSubmissionWsaClientTube
- Author:
- Rama Pulavarthi
-
Field Summary
Modifier and TypeFieldDescriptionprotected final AddressingVersion
protected final WSBinding
protected final SOAPVersion
protected final WSDLPort
Port that we are processing.Fields inherited from class com.sun.xml.ws.addressing.WsaClientTube
expectReply
Fields inherited from class com.sun.xml.ws.api.pipe.helper.AbstractFilterTubeImpl
next
-
Constructor Summary
ConstructorDescriptionMemberSubmissionWsaClientTube
(WSDLPort wsdlPort, WSBinding binding, Tube next) -
Method Summary
Modifier and TypeMethodDescriptionprotected void
checkCardinality
(Packet packet) Checks the cardinality of WS-Addressing headers on an inboundPacket
.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.protected void
This method checks all the WS-Addressing headers are valid and as per the spec definded rules.copy
(TubeCloner cloner) Creates an identical clone of thisTube
.protected WsaTubeHelper
protected final WSDLBoundOperation
getWSDLBoundOperation
(Packet packet) Default no-op implementation.protected Packet
validateInboundHeaders
(Packet packet) Validates the inbound message.protected void
validateSOAPAction
(Packet packet) Methods inherited from class com.sun.xml.ws.addressing.WsaClientTube
processRequest, processResponse, validateAction
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 Details
-
wsdlPort
Port that we are processing. -
binding
-
addressingVersion
-
soapVersion
-
-
Constructor Details
-
MemberSubmissionWsaClientTube
-
MemberSubmissionWsaClientTube
-
-
Method Details
-
copy
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
- Overrides:
copy
in classWsaClientTube
- 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
.
-
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. -
processException
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.
-
getTubeHelper
-
validateInboundHeaders
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. -
checkMessageAddressingProperties
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- Parameters:
packet
-
-
checkCardinality
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:
javax.xml.ws.WebServiceException
- if:
-
getWSDLBoundOperation
-
validateSOAPAction
-