org.mule.transport.soap.axis.extensions.MuleSoapHeadersHandler.java Source code

Java tutorial

Introduction

Here is the source code for org.mule.transport.soap.axis.extensions.MuleSoapHeadersHandler.java

Source

/*
 * $Id$
 * --------------------------------------------------------------------------------------
 * 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());
        }
    }

}