org.mule.exception.DefaultServiceExceptionStrategy Maven / Gradle / Ivy
/*
* $Id: DefaultServiceExceptionStrategy.java 21336 2011-02-22 19:11:43Z dzapata $
* --------------------------------------------------------------------------------------
* 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.exception;
import org.mule.api.MuleContext;
import org.mule.api.MuleEvent;
import org.mule.api.construct.FlowConstruct;
import org.mule.api.processor.MessageProcessor;
import org.mule.config.DefaultMuleConfiguration;
import org.mule.config.ExceptionHelper;
import org.mule.management.stats.FlowConstructStatistics;
import org.mule.management.stats.ServiceStatistics;
import org.mule.util.CollectionUtils;
import java.util.List;
/**
* DefaultServiceExceptionStrategy
is the default exception handler
* for components. The handler logs errors and will forward the message and exception
* to an exception endpointUri if one is set on this Exception strategy
*/
public class DefaultServiceExceptionStrategy extends AbstractMessagingExceptionStrategy
{
/**
* For IoC only
* @deprecated Use DefaultServiceExceptionStrategy(MuleContext muleContext) instead
*/
public DefaultServiceExceptionStrategy()
{
super();
}
public DefaultServiceExceptionStrategy(MuleContext muleContext)
{
super();
setMuleContext(muleContext);
}
@Override
protected void doHandleException(Exception e, MuleEvent event)
{
FlowConstructStatistics statistics = getFlowConstructStatistics(event.getFlowConstruct());
if (statistics != null && statistics.isEnabled())
{
statistics.incExecutionError();
}
super.doHandleException(DefaultMuleConfiguration.fullStackTraces ? e : (Exception) ExceptionHelper.sanitize(e), event);
}
@Override
protected void logFatal(MuleEvent event, Throwable t)
{
FlowConstructStatistics statistics = getFlowConstructStatistics(event.getFlowConstruct());
if (statistics != null && statistics.isEnabled())
{
statistics.incFatalError();
}
super.logFatal(event, t);
}
@Override
protected void routeException(MuleEvent event, MessageProcessor target, Throwable t)
{
super.routeException(event, target, t);
List processors = getMessageProcessors();
if (CollectionUtils.isNotEmpty(processors) && getFlowConstructStatistics(event.getFlowConstruct()) instanceof ServiceStatistics)
{
ServiceStatistics statistics = getServiceStatistics(event.getFlowConstruct());
if (statistics.isEnabled())
{
for (MessageProcessor endpoint : processors)
{
statistics.getOutboundRouterStat().incrementRoutedMessage(endpoint);
}
}
}
}
protected FlowConstructStatistics getFlowConstructStatistics(FlowConstruct flowConstruct)
{
if (flowConstruct != null )
{
return flowConstruct.getStatistics();
}
else
{
//this can happen, e.g. with event constructed to handle exceptions
// logger.fatal("The Default Service Exception Strategy has been invoked but there is no current flow construct on the context. Please report this to [email protected]");
return null;
}
}
protected ServiceStatistics getServiceStatistics(FlowConstruct flowConstruct)
{
FlowConstructStatistics stats = getFlowConstructStatistics(flowConstruct);
if (!(stats instanceof ServiceStatistics))
{
//this should never happen, but JIC
logger.fatal("The Default Service Exception Strategy has been invoked but there is no current service on the context. Please report this to [email protected]");
return null;
}
return (ServiceStatistics) stats;
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy