Class MemberSubmissionWsaServerTube

  • All Implemented Interfaces:
    Pipe, Tube

    public class MemberSubmissionWsaServerTube
    extends WsaServerTube
    Author:
    Rama Pulavarthi
    • Field Detail

      • wsdlPort

        @NotNull
        protected final WSDLPort wsdlPort
        Port that we are processing.
    • Method Detail

      • copy

        public MemberSubmissionWsaServerTube copy​(TubeCloner cloner)
        Description copied from interface: Tube
        Creates an identical clone of this Tube.

        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 other Tube references you have, or else there's a risk of infinite recursion.

        For most Tube implementations that delegate to another Tube, this method requires that you also copy the Tube that you delegate to.

        For limited number of Tubes that do not maintain any thread unsafe resource, it is allowed to simply return this from this method (notice that even if you are stateless, if you got a delegating Tube 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 interface Tube
        Overrides:
        copy in class WsaServerTube
        Parameters:
        cloner - Use this object (in particular its TubeCloner.copy(Tube) method to clone other pipe references you have in your pipe. See TubeCloner 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.
      • 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 inbound Packet. 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:
        • there is an error reading ReplyTo or FaultTo
        • WS-Addressing is required and Message within packet is null
        • WS-Addressing is required and no headers are found in the Message
        • an uknown WS-Addressing header is present
      • validateSOAPAction

        protected void validateSOAPAction​(Packet packet)