| /** |
| * Licensed to the Apache Software Foundation (ASF) under one or more |
| * contributor license agreements. See the NOTICE file distributed with |
| * this work for additional information regarding copyright ownership. |
| * The ASF licenses this file to You under the Apache License, Version 2.0 |
| * (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.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| package org.apache.camel.processor; |
| |
| import org.apache.camel.CamelContext; |
| import org.apache.camel.Exchange; |
| import org.apache.camel.Predicate; |
| import org.apache.camel.Processor; |
| import org.apache.camel.builder.ExpressionBuilder; |
| import org.apache.camel.builder.PredicateBuilder; |
| import org.apache.camel.processor.exceptionpolicy.ExceptionPolicyStrategy; |
| |
| /** |
| * Implements a <a |
| * href="http://camel.apache.org/dead-letter-channel.html">Dead Letter |
| * Channel</a> after attempting to redeliver the message using the |
| * {@link RedeliveryPolicy} |
| * |
| * @version |
| */ |
| public class DeadLetterChannel extends RedeliveryErrorHandler { |
| |
| /** |
| * Creates the dead letter channel. |
| * |
| * @param camelContext the camel context |
| * @param output outer processor that should use this dead letter channel |
| * @param logger logger to use for logging failures and redelivery attempts |
| * @param redeliveryProcessor an optional processor to run before redelivery attempt |
| * @param redeliveryPolicy policy for redelivery |
| * @param exceptionPolicyStrategy strategy for onException handling |
| * @param deadLetter the failure processor to send failed exchanges to |
| * @param deadLetterUri an optional uri for logging purpose |
| * @param useOriginalBodyPolicy should the original IN body be moved to the dead letter queue or the current exchange IN body? |
| * @param retryWhile retry while |
| * @param executorServiceRef reference to a {@link java.util.concurrent.ScheduledExecutorService} to be used for redelivery thread pool. Can be <tt>null</tt>. |
| */ |
| public DeadLetterChannel(CamelContext camelContext, Processor output, CamelLogger logger, Processor redeliveryProcessor, RedeliveryPolicy redeliveryPolicy, |
| ExceptionPolicyStrategy exceptionPolicyStrategy, Processor deadLetter, String deadLetterUri, boolean useOriginalBodyPolicy, Predicate retryWhile, String executorServiceRef) { |
| |
| super(camelContext, output, logger, redeliveryProcessor, redeliveryPolicy, deadLetter, deadLetterUri, useOriginalBodyPolicy, retryWhile, executorServiceRef); |
| setExceptionPolicy(exceptionPolicyStrategy); |
| } |
| |
| public void process(Exchange exchange) throws Exception { |
| // just to let the stack trace reveal that this is a dead letter channel |
| super.process(exchange); |
| } |
| |
| @Override |
| public String toString() { |
| if (output == null) { |
| // if no output then don't do any description |
| return ""; |
| } |
| return "DeadLetterChannel[" + output + ", " + (deadLetterUri != null ? deadLetterUri : deadLetter) + "]"; |
| } |
| |
| @Override |
| protected Predicate getDefaultHandledPredicate() { |
| // DeadLetterChannel handles errors before sending to DLQ |
| return PredicateBuilder.toPredicate(ExpressionBuilder.constantExpression(true)); |
| } |
| } |