// The contents of this file are subject to the Mozilla Public License // Version 1.1 (the "License"); you may not use this file except in // compliance with the License. You may obtain a copy of the License // at http://www.mozilla.org/MPL/ // // Software distributed under the License is distributed on an "AS IS" // basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See // the License for the specific language governing rights and // limitations under the License. // // The Original Code is RabbitMQ. // // The Initial Developer of the Original Code is VMware, Inc. // Copyright (c) 2007-2011 VMware, Inc. All rights reserved. // package com.rabbitmq.client.impl; import java.io.IOException; import com.rabbitmq.client.AMQP; import com.rabbitmq.client.Channel; import com.rabbitmq.client.Connection; import com.rabbitmq.client.Consumer; public class DefaultExceptionHandler implements ExceptionHandler { public void handleUnexpectedConnectionDriverException(Connection conn, Throwable exception) { // TODO: Log this somewhere, just in case we have a bug like // 16272 where exceptions aren't being propagated properly // again. //System.err.println("DefaultExceptionHandler:"); //exception.printStackTrace(); } public void handleReturnListenerException(Channel channel, Throwable exception) { handleChannelKiller(channel, exception, "ReturnListener.handleReturn"); } public void handleFlowListenerException(Channel channel, Throwable exception) { handleChannelKiller(channel, exception, "FlowListener.handleFlow"); } public void handleConfirmListenerException(Channel channel, Throwable exception) { handleChannelKiller(channel, exception, "ConfirmListener.handle{N,A}ck"); } public void handleConsumerException(Channel channel, Throwable exception, Consumer consumer, String consumerTag, String methodName) { handleChannelKiller(channel, exception, "Consumer " + consumer + " (" + consumerTag + ")" + " method " + methodName + " for channel " + channel); } protected void handleChannelKiller(Channel channel, Throwable exception, String what) { // TODO: Convert to logging framework System.err.println(what + " threw an exception for channel " + channel + ":"); exception.printStackTrace(); try { ((AMQConnection) channel.getConnection()).close(AMQP.INTERNAL_ERROR, "Internal error in " + what, false, exception); } catch (IOException ioe) { // Man, this clearly isn't our day. // Ignore the exception? TODO: Log the nested failure } } }