/*
* $Id: InboundLoggingMessageProcessor.java 20221 2010-11-17 17:49:45Z aperepel $
* --------------------------------------------------------------------------------------
* 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.endpoint.inbound;
import org.mule.api.MuleEvent;
import org.mule.api.MuleException;
import org.mule.api.MuleMessage;
import org.mule.api.endpoint.InboundEndpoint;
import org.mule.api.processor.MessageProcessor;
import org.mule.util.ObjectUtils;
import org.mule.util.StringMessageUtils;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
public class InboundLoggingMessageProcessor implements MessageProcessor
{
protected final transient Log logger = LogFactory.getLog(getClass());
protected InboundEndpoint endpoint;
public InboundLoggingMessageProcessor(InboundEndpoint endpoint)
{
this.endpoint = endpoint;
}
public MuleEvent process(MuleEvent event) throws MuleException
{
MuleMessage message = event.getMessage();
if (logger.isDebugEnabled())
{
logger.debug("Message Received on: " + endpoint.getEndpointURI());
}
if (logger.isTraceEnabled())
{
try
{
logger.trace("Message Payload: \n"
+ StringMessageUtils.truncate(StringMessageUtils.toString(message.getPayload()),
200, false));
logger.trace("Message detail: \n" + StringMessageUtils.headersToString(message));
}
catch (Exception e)
{
// ignore
}
}
return event;
}
@Override
public String toString()
{
return ObjectUtils.toString(this);
}
}