Package org.mule.transport.soap.axis.extensions

Source Code of org.mule.transport.soap.axis.extensions.MuleSoapHeadersHandler

/*
* $Id: MuleSoapHeadersHandler.java 19191 2010-08-25 21:05:23Z tcarlson $
* --------------------------------------------------------------------------------------
* Copyright (c) MuleSoft, Inc.  All rights reserved.  http://www.mulesoft.com
*
* The software in this package is published under the terms of the CPAL v1.0
* license, a copy of which has been included with this distribution in the
* LICENSE.txt file.
*/

package org.mule.transport.soap.axis.extensions;

import org.mule.api.MuleEvent;
import org.mule.api.config.MuleProperties;
import org.mule.module.cxf.MuleSoapHeaders;

import javax.xml.soap.SOAPEnvelope;
import javax.xml.soap.SOAPMessage;

import org.apache.axis.AxisFault;
import org.apache.axis.MessageContext;
import org.apache.axis.handlers.BasicHandler;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

/**
* <code>MuleSoapHeadersHandler</code> is an Axis handler that can read and write
* Mule header properties to a SOAP message.
*/
public class MuleSoapHeadersHandler extends BasicHandler
{
    /**
     * Serial version
     */
    private static final long serialVersionUID = 1813393257662701953L;

    /**
     * logger used by this class
     */
    protected static final Log logger = LogFactory.getLog(MuleSoapHeadersHandler.class);

    public void invoke(MessageContext msgContext) throws AxisFault
    {
        boolean setMustUnderstand = msgContext.isPropertyTrue("MULE_HEADER_MUST_UNDERSTAND");

        try
        {
            if (msgContext.isClient())
            {
                if (!msgContext.getPastPivot())
                {
                    processClientRequest(msgContext, setMustUnderstand);
                    if (logger.isDebugEnabled())
                    {
                        logger.debug("After Client Request, Message is:\n"
                                        + msgContext.getRequestMessage().getSOAPPartAsString());
                    }
                }
                else
                {
                    processClientResponse(msgContext);
                    if (logger.isDebugEnabled())
                    {
                        logger.debug("After Client Response, Message is:\n"
                                        + msgContext.getRequestMessage().getSOAPPartAsString());
                    }
                }
            }
            else
            {
                if (!msgContext.getPastPivot())
                {
                    processServerRequest(msgContext);
                    if (logger.isDebugEnabled())
                    {
                        logger.debug("After Server Request, Message is:\n"
                                        + msgContext.getRequestMessage().getSOAPPartAsString());
                    }
                }
                else
                {
                    processServerResponse(msgContext, setMustUnderstand);
                    if (logger.isDebugEnabled())
                    {
                        logger.debug("After Server Response, Message is:\n"
                                        + msgContext.getRequestMessage().getSOAPPartAsString());
                    }
                }
            }
        }
        catch (Exception e)
        {
            throw AxisFault.makeFault(e);
        }
    }

    /**
     * Method processClientRequest
     *
     * @param msgContext
     */
    protected synchronized void processClientRequest(MessageContext msgContext, boolean setMustUnderstand)
        throws Exception
    {
        SOAPMessage msg = msgContext.getMessage();
        if (msg == null)
        {
            return;
        }
        MuleEvent event = (MuleEvent)msgContext.getProperty(MuleProperties.MULE_EVENT_PROPERTY);

        if (event == null)
        {
            return;
        }
        else
        {
            synchronized (msgContext)
            {
                MuleSoapHeaders headers = new MuleSoapHeaders(event);
                headers.addHeaders(msgContext.getMessage().getSOAPPart().getEnvelope());
            }
        }
    }

    /**
     * Method processClientResponse
     *
     * @param msgContext
     */
    protected void processClientResponse(MessageContext msgContext) throws Exception
    {
        SOAPMessage msg = msgContext.getMessage();
        if (msg == null)
        {
            return;
        }
        SOAPEnvelope env = msg.getSOAPPart().getEnvelope();
        MuleSoapHeaders headers = new MuleSoapHeaders(env.getHeader());

        if (headers.getCorrelationId() != null)
        {
            msgContext.setProperty(MuleProperties.MULE_CORRELATION_ID_PROPERTY, headers.getCorrelationId());
        }
        if (headers.getCorrelationGroup() != null)
        {
            msgContext.setProperty(MuleProperties.MULE_CORRELATION_GROUP_SIZE_PROPERTY, headers
                .getCorrelationGroup());
        }
        if (headers.getCorrelationSequence() != null)
        {
            msgContext.setProperty(MuleProperties.MULE_CORRELATION_SEQUENCE_PROPERTY, headers
                .getCorrelationSequence());
        }

        if (headers.getReplyTo() != null)
        {
            msgContext.setProperty(MuleProperties.MULE_REPLY_TO_PROPERTY, headers.getReplyTo());
        }
    }

    /**
     * Method processServerRequest
     *
     * @param msgContext
     * @throws Exception
     */
    protected void processServerRequest(MessageContext msgContext) throws Exception
    {
        SOAPMessage msg = msgContext.getMessage();
        if (msg == null)
        {
            return;
        }
        MuleSoapHeaders headers = new MuleSoapHeaders(msg.getSOAPPart().getEnvelope().getHeader());
        msgContext.setProperty(MuleSoapHeaders.ENV_REQUEST_HEADERS, headers);
    }

    /**
     * Method processServerResponse
     *
     * @param msgContext
     */
    protected void processServerResponse(MessageContext msgContext, boolean setMustUnderstand)
        throws Exception
    {
        SOAPMessage msg = msgContext.getMessage();
        if (msg == null)
        {
            return;
        }
        MuleSoapHeaders headers = (MuleSoapHeaders)msgContext
            .getProperty(MuleSoapHeaders.ENV_REQUEST_HEADERS);

        if (headers == null)
        {
            return;
        }
        else
        {
            headers.addHeaders(msgContext.getMessage().getSOAPPart().getEnvelope());
        }
    }

}
TOP

Related Classes of org.mule.transport.soap.axis.extensions.MuleSoapHeadersHandler

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.