Search in sources :

Example 1 with FilterProcessor

use of org.apache.camel.processor.FilterProcessor in project camel by apache.

the class ChoiceDefinition method createProcessor.

@Override
public Processor createProcessor(RouteContext routeContext) throws Exception {
    List<FilterProcessor> filters = new ArrayList<FilterProcessor>();
    for (WhenDefinition whenClause : whenClauses) {
        FilterProcessor filter = (FilterProcessor) createProcessor(routeContext, whenClause);
        filters.add(filter);
    }
    Processor otherwiseProcessor = null;
    if (otherwise != null) {
        otherwiseProcessor = createProcessor(routeContext, otherwise);
    }
    return new ChoiceProcessor(filters, otherwiseProcessor);
}
Also used : Processor(org.apache.camel.Processor) FilterProcessor(org.apache.camel.processor.FilterProcessor) ChoiceProcessor(org.apache.camel.processor.ChoiceProcessor) FilterProcessor(org.apache.camel.processor.FilterProcessor) ArrayList(java.util.ArrayList) ChoiceProcessor(org.apache.camel.processor.ChoiceProcessor)

Example 2 with FilterProcessor

use of org.apache.camel.processor.FilterProcessor in project camel by apache.

the class RouteBuilderTest method testSimpleRouteWithChoice.

public void testSimpleRouteWithChoice() throws Exception {
    List<Route> routes = buildSimpleRouteWithChoice();
    log.debug("Created routes: " + routes);
    assertEquals("Number routes created", 1, routes.size());
    for (Route route : routes) {
        Endpoint key = route.getEndpoint();
        assertEquals("From endpoint", "direct://a", key.getEndpointUri());
        EventDrivenConsumerRoute consumer = assertIsInstanceOf(EventDrivenConsumerRoute.class, route);
        Channel channel = unwrapChannel(consumer.getProcessor());
        ChoiceProcessor choiceProcessor = assertIsInstanceOf(ChoiceProcessor.class, channel.getNextProcessor());
        List<FilterProcessor> filters = choiceProcessor.getFilters();
        assertEquals("Should be two when clauses", 2, filters.size());
        Processor filter1 = filters.get(0);
        assertSendTo(unwrapChannel(((FilterProcessor) filter1).getProcessor()).getNextProcessor(), "direct://b");
        Processor filter2 = filters.get(1);
        assertSendTo(unwrapChannel(((FilterProcessor) filter2).getProcessor()).getNextProcessor(), "direct://c");
        assertSendTo(unwrapChannel(choiceProcessor.getOtherwise()).getNextProcessor(), "direct://d");
    }
}
Also used : DelegateProcessor(org.apache.camel.DelegateProcessor) Processor(org.apache.camel.Processor) MulticastProcessor(org.apache.camel.processor.MulticastProcessor) FilterProcessor(org.apache.camel.processor.FilterProcessor) EvaluateExpressionProcessor(org.apache.camel.processor.EvaluateExpressionProcessor) ThreadsProcessor(org.apache.camel.processor.ThreadsProcessor) SendProcessor(org.apache.camel.processor.SendProcessor) ChoiceProcessor(org.apache.camel.processor.ChoiceProcessor) Endpoint(org.apache.camel.Endpoint) FilterProcessor(org.apache.camel.processor.FilterProcessor) Channel(org.apache.camel.Channel) DeadLetterChannel(org.apache.camel.processor.DeadLetterChannel) EventDrivenConsumerRoute(org.apache.camel.impl.EventDrivenConsumerRoute) Route(org.apache.camel.Route) EventDrivenConsumerRoute(org.apache.camel.impl.EventDrivenConsumerRoute) ChoiceProcessor(org.apache.camel.processor.ChoiceProcessor)

Example 3 with FilterProcessor

use of org.apache.camel.processor.FilterProcessor in project camel by apache.

the class DefaultManagementObjectStrategy method getManagedObjectForProcessor.

@SuppressWarnings({ "deprecation", "unchecked" })
public Object getManagedObjectForProcessor(CamelContext context, Processor processor, ProcessorDefinition<?> definition, Route route) {
    ManagedProcessor answer = null;
    if (definition instanceof RecipientListDefinition) {
        // special for RecipientListDefinition, as the processor is wrapped in a pipeline as last
        Pipeline pipeline = (Pipeline) processor;
        Iterator<Processor> it = pipeline.getProcessors().iterator();
        while (it.hasNext()) {
            processor = it.next();
        }
    } else if (definition instanceof ThreadsDefinition) {
        // special for ThreadsDefinition, as the processor is wrapped in a pipeline as first
        Pipeline pipeline = (Pipeline) processor;
        Iterator<Processor> it = pipeline.getProcessors().iterator();
        processor = it.next();
    }
    // unwrap delegates as we want the real target processor
    Processor target = processor;
    while (target != null) {
        // skip error handlers
        if (target instanceof ErrorHandler) {
            return false;
        }
        if (target instanceof ConvertBodyProcessor) {
            answer = new ManagedConvertBody(context, (ConvertBodyProcessor) target, definition);
        } else if (target instanceof ChoiceProcessor) {
            answer = new ManagedChoice(context, (ChoiceProcessor) target, definition);
        } else if (target instanceof Delayer) {
            answer = new ManagedDelayer(context, (Delayer) target, definition);
        } else if (target instanceof Throttler) {
            answer = new ManagedThrottler(context, (Throttler) target, definition);
        } else if (target instanceof DynamicRouter) {
            answer = new ManagedDynamicRouter(context, (DynamicRouter) target, (org.apache.camel.model.DynamicRouterDefinition) definition);
        } else if (target instanceof RoutingSlip) {
            answer = new ManagedRoutingSlip(context, (RoutingSlip) target, (org.apache.camel.model.RoutingSlipDefinition) definition);
        } else if (target instanceof FilterProcessor) {
            answer = new ManagedFilter(context, (FilterProcessor) target, (ExpressionNode) definition);
        } else if (target instanceof LogProcessor) {
            answer = new ManagedLog(context, (LogProcessor) target, definition);
        } else if (target instanceof LoopProcessor) {
            answer = new ManagedLoop(context, (LoopProcessor) target, (org.apache.camel.model.LoopDefinition) definition);
        } else if (target instanceof MarshalProcessor) {
            answer = new ManagedMarshal(context, (MarshalProcessor) target, (org.apache.camel.model.MarshalDefinition) definition);
        } else if (target instanceof UnmarshalProcessor) {
            answer = new ManagedUnmarshal(context, (UnmarshalProcessor) target, (org.apache.camel.model.UnmarshalDefinition) definition);
        } else if (target instanceof CircuitBreakerLoadBalancer) {
            answer = new ManagedCircuitBreakerLoadBalancer(context, (CircuitBreakerLoadBalancer) target, (org.apache.camel.model.LoadBalanceDefinition) definition);
        } else if (target instanceof FailOverLoadBalancer) {
            answer = new ManagedFailoverLoadBalancer(context, (FailOverLoadBalancer) target, (org.apache.camel.model.LoadBalanceDefinition) definition);
        } else if (target instanceof RandomLoadBalancer) {
            answer = new ManagedRandomLoadBalancer(context, (RandomLoadBalancer) target, (org.apache.camel.model.LoadBalanceDefinition) definition);
        } else if (target instanceof RoundRobinLoadBalancer) {
            answer = new ManagedRoundRobinLoadBalancer(context, (RoundRobinLoadBalancer) target, (org.apache.camel.model.LoadBalanceDefinition) definition);
        } else if (target instanceof StickyLoadBalancer) {
            answer = new ManagedStickyLoadBalancer(context, (StickyLoadBalancer) target, (org.apache.camel.model.LoadBalanceDefinition) definition);
        } else if (target instanceof TopicLoadBalancer) {
            answer = new ManagedTopicLoadBalancer(context, (TopicLoadBalancer) target, (org.apache.camel.model.LoadBalanceDefinition) definition);
        } else if (target instanceof WeightedLoadBalancer) {
            answer = new ManagedWeightedLoadBalancer(context, (WeightedLoadBalancer) target, (org.apache.camel.model.LoadBalanceDefinition) definition);
        } else if (target instanceof RecipientList) {
            answer = new ManagedRecipientList(context, (RecipientList) target, (RecipientListDefinition) definition);
        } else if (target instanceof Splitter) {
            answer = new ManagedSplitter(context, (Splitter) target, (org.apache.camel.model.SplitDefinition) definition);
        } else if (target instanceof MulticastProcessor) {
            answer = new ManagedMulticast(context, (MulticastProcessor) target, definition);
        } else if (target instanceof SamplingThrottler) {
            answer = new ManagedSamplingThrottler(context, (SamplingThrottler) target, definition);
        } else if (target instanceof Resequencer) {
            answer = new ManagedResequencer(context, (Resequencer) target, definition);
        } else if (target instanceof RollbackProcessor) {
            answer = new ManagedRollback(context, (RollbackProcessor) target, definition);
        } else if (target instanceof StreamResequencer) {
            answer = new ManagedResequencer(context, (StreamResequencer) target, definition);
        } else if (target instanceof SetBodyProcessor) {
            answer = new ManagedSetBody(context, (SetBodyProcessor) target, (org.apache.camel.model.SetBodyDefinition) definition);
        } else if (target instanceof RemoveHeaderProcessor) {
            answer = new ManagedRemoveHeader(context, (RemoveHeaderProcessor) target, definition);
        } else if (target instanceof RemoveHeadersProcessor) {
            answer = new ManagedRemoveHeaders(context, (RemoveHeadersProcessor) target, definition);
        } else if (target instanceof SetHeaderProcessor) {
            answer = new ManagedSetHeader(context, (SetHeaderProcessor) target, (org.apache.camel.model.SetHeaderDefinition) definition);
        } else if (target instanceof RemovePropertyProcessor) {
            answer = new ManagedRemoveProperty(context, (RemovePropertyProcessor) target, definition);
        } else if (target instanceof RemovePropertiesProcessor) {
            answer = new ManagedRemoveProperties(context, (RemovePropertiesProcessor) target, definition);
        } else if (target instanceof SetPropertyProcessor) {
            answer = new ManagedSetProperty(context, (SetPropertyProcessor) target, (org.apache.camel.model.SetPropertyDefinition) definition);
        } else if (target instanceof ExchangePatternProcessor) {
            answer = new ManagedSetExchangePattern(context, (ExchangePatternProcessor) target, definition);
        } else if (target instanceof ScriptProcessor) {
            answer = new ManagedScript(context, (ScriptProcessor) target, (org.apache.camel.model.ScriptDefinition) definition);
        } else if (target instanceof StopProcessor) {
            answer = new ManagedStop(context, (StopProcessor) target, definition);
        } else if (target instanceof ThreadsProcessor) {
            answer = new ManagedThreads(context, (ThreadsProcessor) target, definition);
        } else if (target instanceof ThrowExceptionProcessor) {
            answer = new ManagedThrowException(context, (ThrowExceptionProcessor) target, definition);
        } else if (target instanceof TransformProcessor) {
            answer = new ManagedTransformer(context, (TransformProcessor) target, (org.apache.camel.model.TransformDefinition) definition);
        } else if (target instanceof PredicateValidatingProcessor) {
            answer = new ManagedValidate(context, (PredicateValidatingProcessor) target, (org.apache.camel.model.ValidateDefinition) definition);
        } else if (target instanceof WireTapProcessor) {
            answer = new ManagedWireTapProcessor(context, (WireTapProcessor) target, definition);
        } else if (target instanceof SendDynamicProcessor) {
            answer = new ManagedSendDynamicProcessor(context, (SendDynamicProcessor) target, definition);
        } else if (target instanceof SendProcessor) {
            SendProcessor sp = (SendProcessor) target;
            // special for sending to throughput logger
            if (sp.getDestination() instanceof LogEndpoint) {
                LogEndpoint le = (LogEndpoint) sp.getDestination();
                if (le.getLogger() instanceof ThroughputLogger) {
                    ThroughputLogger tl = (ThroughputLogger) le.getLogger();
                    answer = new ManagedThroughputLogger(context, tl, definition);
                }
            }
            // regular send processor
            if (answer == null) {
                answer = new ManagedSendProcessor(context, (SendProcessor) target, definition);
            }
        } else if (target instanceof BeanProcessor) {
            answer = new ManagedBeanProcessor(context, (BeanProcessor) target, definition);
        } else if (target instanceof IdempotentConsumer) {
            answer = new ManagedIdempotentConsumer(context, (IdempotentConsumer) target, (org.apache.camel.model.IdempotentConsumerDefinition) definition);
        } else if (target instanceof AggregateProcessor) {
            answer = new ManagedAggregateProcessor(context, (AggregateProcessor) target, (org.apache.camel.model.AggregateDefinition) definition);
        } else if (target instanceof Enricher) {
            answer = new ManagedEnricher(context, (Enricher) target, (org.apache.camel.model.EnrichDefinition) definition);
        } else if (target instanceof PollEnricher) {
            answer = new ManagedPollEnricher(context, (PollEnricher) target, (org.apache.camel.model.PollEnrichDefinition) definition);
        } else if (target instanceof org.apache.camel.spi.ManagementAware) {
            return ((org.apache.camel.spi.ManagementAware<Processor>) target).getManagedObject(processor);
        }
        // special for custom load balancer
        if (definition instanceof LoadBalanceDefinition) {
            LoadBalanceDefinition lb = (LoadBalanceDefinition) definition;
            if (lb.getLoadBalancerType() instanceof CustomLoadBalancerDefinition) {
                answer = new ManagedCustomLoadBalancer(context, (LoadBalancer) target, (LoadBalanceDefinition) definition);
            }
        }
        if (answer != null) {
            // break out as we found an answer
            break;
        }
        // no answer yet, so unwrap any delegates and try again
        if (target instanceof DelegateProcessor) {
            target = ((DelegateProcessor) target).getProcessor();
        } else {
            // no delegate so we dont have any target to try next
            break;
        }
    }
    if (answer == null && definition instanceof ProcessDefinition) {
        answer = new ManagedProcess(context, target, (ProcessDefinition) definition);
    } else if (answer == null) {
        // fallback to a generic processor
        answer = new ManagedProcessor(context, target, definition);
    }
    answer.setRoute(route);
    answer.init(context.getManagementStrategy());
    return answer;
}
Also used : ManagedMarshal(org.apache.camel.management.mbean.ManagedMarshal) ManagedSplitter(org.apache.camel.management.mbean.ManagedSplitter) FilterProcessor(org.apache.camel.processor.FilterProcessor) UnmarshalProcessor(org.apache.camel.processor.UnmarshalProcessor) ManagedResequencer(org.apache.camel.management.mbean.ManagedResequencer) Resequencer(org.apache.camel.processor.Resequencer) StreamResequencer(org.apache.camel.processor.StreamResequencer) ManagedSetExchangePattern(org.apache.camel.management.mbean.ManagedSetExchangePattern) ManagedWeightedLoadBalancer(org.apache.camel.management.mbean.ManagedWeightedLoadBalancer) ManagedPollEnricher(org.apache.camel.management.mbean.ManagedPollEnricher) MarshalProcessor(org.apache.camel.processor.MarshalProcessor) ManagedThrottler(org.apache.camel.management.mbean.ManagedThrottler) ManagedThroughputLogger(org.apache.camel.management.mbean.ManagedThroughputLogger) ChoiceProcessor(org.apache.camel.processor.ChoiceProcessor) ManagedThrottler(org.apache.camel.management.mbean.ManagedThrottler) SamplingThrottler(org.apache.camel.processor.SamplingThrottler) Throttler(org.apache.camel.processor.Throttler) ManagedSamplingThrottler(org.apache.camel.management.mbean.ManagedSamplingThrottler) ManagedTopicLoadBalancer(org.apache.camel.management.mbean.ManagedTopicLoadBalancer) SetHeaderProcessor(org.apache.camel.processor.SetHeaderProcessor) ManagedRemoveProperties(org.apache.camel.management.mbean.ManagedRemoveProperties) ManagedRecipientList(org.apache.camel.management.mbean.ManagedRecipientList) ManagedIdempotentConsumer(org.apache.camel.management.mbean.ManagedIdempotentConsumer) ManagedValidate(org.apache.camel.management.mbean.ManagedValidate) ConvertBodyProcessor(org.apache.camel.processor.ConvertBodyProcessor) ManagedLoop(org.apache.camel.management.mbean.ManagedLoop) MulticastProcessor(org.apache.camel.processor.MulticastProcessor) ManagedRollback(org.apache.camel.management.mbean.ManagedRollback) LogEndpoint(org.apache.camel.component.log.LogEndpoint) WireTapProcessor(org.apache.camel.processor.WireTapProcessor) ManagedWireTapProcessor(org.apache.camel.management.mbean.ManagedWireTapProcessor) ManagedScript(org.apache.camel.management.mbean.ManagedScript) ScriptProcessor(org.apache.camel.processor.ScriptProcessor) ManagedSendDynamicProcessor(org.apache.camel.management.mbean.ManagedSendDynamicProcessor) PredicateValidatingProcessor(org.apache.camel.processor.validation.PredicateValidatingProcessor) WireTapProcessor(org.apache.camel.processor.WireTapProcessor) LogProcessor(org.apache.camel.processor.LogProcessor) ManagedBeanProcessor(org.apache.camel.management.mbean.ManagedBeanProcessor) StopProcessor(org.apache.camel.processor.StopProcessor) TransformProcessor(org.apache.camel.processor.TransformProcessor) BeanProcessor(org.apache.camel.component.bean.BeanProcessor) ThrowExceptionProcessor(org.apache.camel.processor.ThrowExceptionProcessor) RemoveHeadersProcessor(org.apache.camel.processor.RemoveHeadersProcessor) SendProcessor(org.apache.camel.processor.SendProcessor) MarshalProcessor(org.apache.camel.processor.MarshalProcessor) LoopProcessor(org.apache.camel.processor.LoopProcessor) SetHeaderProcessor(org.apache.camel.processor.SetHeaderProcessor) UnmarshalProcessor(org.apache.camel.processor.UnmarshalProcessor) RemoveHeaderProcessor(org.apache.camel.processor.RemoveHeaderProcessor) RemovePropertiesProcessor(org.apache.camel.processor.RemovePropertiesProcessor) MulticastProcessor(org.apache.camel.processor.MulticastProcessor) FilterProcessor(org.apache.camel.processor.FilterProcessor) SetPropertyProcessor(org.apache.camel.processor.SetPropertyProcessor) ThreadsProcessor(org.apache.camel.processor.ThreadsProcessor) ExchangePatternProcessor(org.apache.camel.processor.ExchangePatternProcessor) SetBodyProcessor(org.apache.camel.processor.SetBodyProcessor) SendDynamicProcessor(org.apache.camel.processor.SendDynamicProcessor) ManagedProcessor(org.apache.camel.management.mbean.ManagedProcessor) ChoiceProcessor(org.apache.camel.processor.ChoiceProcessor) RollbackProcessor(org.apache.camel.processor.RollbackProcessor) DelegateProcessor(org.apache.camel.DelegateProcessor) ManagedAggregateProcessor(org.apache.camel.management.mbean.ManagedAggregateProcessor) ManagedWireTapProcessor(org.apache.camel.management.mbean.ManagedWireTapProcessor) RemovePropertyProcessor(org.apache.camel.processor.RemovePropertyProcessor) Processor(org.apache.camel.Processor) ScriptProcessor(org.apache.camel.processor.ScriptProcessor) ConvertBodyProcessor(org.apache.camel.processor.ConvertBodyProcessor) ManagedSendProcessor(org.apache.camel.management.mbean.ManagedSendProcessor) AggregateProcessor(org.apache.camel.processor.aggregate.AggregateProcessor) ThreadsProcessor(org.apache.camel.processor.ThreadsProcessor) LoopProcessor(org.apache.camel.processor.LoopProcessor) SetPropertyProcessor(org.apache.camel.processor.SetPropertyProcessor) ExchangePatternProcessor(org.apache.camel.processor.ExchangePatternProcessor) ManagedRandomLoadBalancer(org.apache.camel.management.mbean.ManagedRandomLoadBalancer) ManagedSendProcessor(org.apache.camel.management.mbean.ManagedSendProcessor) ManagedCustomLoadBalancer(org.apache.camel.management.mbean.ManagedCustomLoadBalancer) RemoveHeadersProcessor(org.apache.camel.processor.RemoveHeadersProcessor) ManagedRemoveHeaders(org.apache.camel.management.mbean.ManagedRemoveHeaders) ManagedRoutingSlip(org.apache.camel.management.mbean.ManagedRoutingSlip) RoutingSlip(org.apache.camel.processor.RoutingSlip) ManagedProcessor(org.apache.camel.management.mbean.ManagedProcessor) ThrowExceptionProcessor(org.apache.camel.processor.ThrowExceptionProcessor) ManagedFilter(org.apache.camel.management.mbean.ManagedFilter) ManagedAggregateProcessor(org.apache.camel.management.mbean.ManagedAggregateProcessor) ManagedRemoveHeader(org.apache.camel.management.mbean.ManagedRemoveHeader) CustomLoadBalancerDefinition(org.apache.camel.model.loadbalancer.CustomLoadBalancerDefinition) ManagedChoice(org.apache.camel.management.mbean.ManagedChoice) RemovePropertiesProcessor(org.apache.camel.processor.RemovePropertiesProcessor) LogProcessor(org.apache.camel.processor.LogProcessor) ManagedEnricher(org.apache.camel.management.mbean.ManagedEnricher) RemovePropertyProcessor(org.apache.camel.processor.RemovePropertyProcessor) ManagedSendDynamicProcessor(org.apache.camel.management.mbean.ManagedSendDynamicProcessor) Pipeline(org.apache.camel.processor.Pipeline) ManagedProcess(org.apache.camel.management.mbean.ManagedProcess) ManagedSetProperty(org.apache.camel.management.mbean.ManagedSetProperty) ExpressionNode(org.apache.camel.model.ExpressionNode) SamplingThrottler(org.apache.camel.processor.SamplingThrottler) ManagedSamplingThrottler(org.apache.camel.management.mbean.ManagedSamplingThrottler) RollbackProcessor(org.apache.camel.processor.RollbackProcessor) ManagedThreads(org.apache.camel.management.mbean.ManagedThreads) SendProcessor(org.apache.camel.processor.SendProcessor) ManagedSendProcessor(org.apache.camel.management.mbean.ManagedSendProcessor) ManagedIdempotentConsumer(org.apache.camel.management.mbean.ManagedIdempotentConsumer) IdempotentConsumer(org.apache.camel.processor.idempotent.IdempotentConsumer) ManagedTransformer(org.apache.camel.management.mbean.ManagedTransformer) LoadBalanceDefinition(org.apache.camel.model.LoadBalanceDefinition) SetBodyProcessor(org.apache.camel.processor.SetBodyProcessor) FailOverLoadBalancer(org.apache.camel.processor.loadbalancer.FailOverLoadBalancer) ProcessDefinition(org.apache.camel.model.ProcessDefinition) ManagedDelayer(org.apache.camel.management.mbean.ManagedDelayer) CircuitBreakerLoadBalancer(org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer) ManagedCircuitBreakerLoadBalancer(org.apache.camel.management.mbean.ManagedCircuitBreakerLoadBalancer) Enricher(org.apache.camel.processor.Enricher) PollEnricher(org.apache.camel.processor.PollEnricher) ManagedPollEnricher(org.apache.camel.management.mbean.ManagedPollEnricher) ManagedEnricher(org.apache.camel.management.mbean.ManagedEnricher) ManagedWireTapProcessor(org.apache.camel.management.mbean.ManagedWireTapProcessor) ManagedRoutingSlip(org.apache.camel.management.mbean.ManagedRoutingSlip) ManagedRandomLoadBalancer(org.apache.camel.management.mbean.ManagedRandomLoadBalancer) RandomLoadBalancer(org.apache.camel.processor.loadbalancer.RandomLoadBalancer) ManagedSamplingThrottler(org.apache.camel.management.mbean.ManagedSamplingThrottler) ManagedSetHeader(org.apache.camel.management.mbean.ManagedSetHeader) TransformProcessor(org.apache.camel.processor.TransformProcessor) RemoveHeaderProcessor(org.apache.camel.processor.RemoveHeaderProcessor) ErrorHandler(org.apache.camel.processor.ErrorHandler) ManagedErrorHandler(org.apache.camel.management.mbean.ManagedErrorHandler) ManagedCircuitBreakerLoadBalancer(org.apache.camel.management.mbean.ManagedCircuitBreakerLoadBalancer) ManagedTopicLoadBalancer(org.apache.camel.management.mbean.ManagedTopicLoadBalancer) ManagedWeightedLoadBalancer(org.apache.camel.management.mbean.ManagedWeightedLoadBalancer) CircuitBreakerLoadBalancer(org.apache.camel.processor.loadbalancer.CircuitBreakerLoadBalancer) StickyLoadBalancer(org.apache.camel.processor.loadbalancer.StickyLoadBalancer) WeightedLoadBalancer(org.apache.camel.processor.loadbalancer.WeightedLoadBalancer) ManagedRandomLoadBalancer(org.apache.camel.management.mbean.ManagedRandomLoadBalancer) ManagedCustomLoadBalancer(org.apache.camel.management.mbean.ManagedCustomLoadBalancer) RoundRobinLoadBalancer(org.apache.camel.processor.loadbalancer.RoundRobinLoadBalancer) TopicLoadBalancer(org.apache.camel.processor.loadbalancer.TopicLoadBalancer) ManagedFailoverLoadBalancer(org.apache.camel.management.mbean.ManagedFailoverLoadBalancer) FailOverLoadBalancer(org.apache.camel.processor.loadbalancer.FailOverLoadBalancer) LoadBalancer(org.apache.camel.processor.loadbalancer.LoadBalancer) ManagedStickyLoadBalancer(org.apache.camel.management.mbean.ManagedStickyLoadBalancer) ManagedCircuitBreakerLoadBalancer(org.apache.camel.management.mbean.ManagedCircuitBreakerLoadBalancer) RandomLoadBalancer(org.apache.camel.processor.loadbalancer.RandomLoadBalancer) ManagedRoundRobinLoadBalancer(org.apache.camel.management.mbean.ManagedRoundRobinLoadBalancer) ManagedWeightedLoadBalancer(org.apache.camel.management.mbean.ManagedWeightedLoadBalancer) WeightedLoadBalancer(org.apache.camel.processor.loadbalancer.WeightedLoadBalancer) ManagedRemoveProperty(org.apache.camel.management.mbean.ManagedRemoveProperty) ManagedAggregateProcessor(org.apache.camel.management.mbean.ManagedAggregateProcessor) AggregateProcessor(org.apache.camel.processor.aggregate.AggregateProcessor) ManagedStickyLoadBalancer(org.apache.camel.management.mbean.ManagedStickyLoadBalancer) StreamResequencer(org.apache.camel.processor.StreamResequencer) ManagedThroughputLogger(org.apache.camel.management.mbean.ManagedThroughputLogger) ThroughputLogger(org.apache.camel.processor.ThroughputLogger) PredicateValidatingProcessor(org.apache.camel.processor.validation.PredicateValidatingProcessor) ManagedResequencer(org.apache.camel.management.mbean.ManagedResequencer) ManagedLog(org.apache.camel.management.mbean.ManagedLog) RoundRobinLoadBalancer(org.apache.camel.processor.loadbalancer.RoundRobinLoadBalancer) ManagedRoundRobinLoadBalancer(org.apache.camel.management.mbean.ManagedRoundRobinLoadBalancer) ManagedRecipientList(org.apache.camel.management.mbean.ManagedRecipientList) RecipientList(org.apache.camel.processor.RecipientList) ManagedConvertBody(org.apache.camel.management.mbean.ManagedConvertBody) PollEnricher(org.apache.camel.processor.PollEnricher) ManagedPollEnricher(org.apache.camel.management.mbean.ManagedPollEnricher) Iterator(java.util.Iterator) ManagedMulticast(org.apache.camel.management.mbean.ManagedMulticast) ManagedStop(org.apache.camel.management.mbean.ManagedStop) RecipientListDefinition(org.apache.camel.model.RecipientListDefinition) ManagedSplitter(org.apache.camel.management.mbean.ManagedSplitter) Splitter(org.apache.camel.processor.Splitter) StopProcessor(org.apache.camel.processor.StopProcessor) ManagedFailoverLoadBalancer(org.apache.camel.management.mbean.ManagedFailoverLoadBalancer) ManagedBeanProcessor(org.apache.camel.management.mbean.ManagedBeanProcessor) BeanProcessor(org.apache.camel.component.bean.BeanProcessor) ThreadsDefinition(org.apache.camel.model.ThreadsDefinition) StickyLoadBalancer(org.apache.camel.processor.loadbalancer.StickyLoadBalancer) ManagedStickyLoadBalancer(org.apache.camel.management.mbean.ManagedStickyLoadBalancer) ManagedDynamicRouter(org.apache.camel.management.mbean.ManagedDynamicRouter) DynamicRouter(org.apache.camel.processor.DynamicRouter) ManagedDelayer(org.apache.camel.management.mbean.ManagedDelayer) Delayer(org.apache.camel.processor.Delayer) ManagedSendDynamicProcessor(org.apache.camel.management.mbean.ManagedSendDynamicProcessor) SendDynamicProcessor(org.apache.camel.processor.SendDynamicProcessor) ManagedBeanProcessor(org.apache.camel.management.mbean.ManagedBeanProcessor) ManagedTopicLoadBalancer(org.apache.camel.management.mbean.ManagedTopicLoadBalancer) TopicLoadBalancer(org.apache.camel.processor.loadbalancer.TopicLoadBalancer) ManagedDynamicRouter(org.apache.camel.management.mbean.ManagedDynamicRouter) ManagedUnmarshal(org.apache.camel.management.mbean.ManagedUnmarshal) DelegateProcessor(org.apache.camel.DelegateProcessor) ManagedThrowException(org.apache.camel.management.mbean.ManagedThrowException) ManagedRoundRobinLoadBalancer(org.apache.camel.management.mbean.ManagedRoundRobinLoadBalancer) ManagedSetBody(org.apache.camel.management.mbean.ManagedSetBody)

Example 4 with FilterProcessor

use of org.apache.camel.processor.FilterProcessor in project camel by apache.

the class ManagedChoice method choiceStatistics.

@Override
public TabularData choiceStatistics() {
    try {
        TabularData answer = new TabularDataSupport(CamelOpenMBeanTypes.choiceTabularType());
        List<WhenDefinition> whens = getDefinition().getWhenClauses();
        List<FilterProcessor> filters = processor.getFilters();
        for (int i = 0; i < filters.size(); i++) {
            WhenDefinition when = whens.get(i);
            FilterProcessor filter = filters.get(i);
            CompositeType ct = CamelOpenMBeanTypes.choiceCompositeType();
            String predicate = when.getExpression().getExpression();
            String language = when.getExpression().getLanguage();
            Long matches = filter.getFilteredCount();
            CompositeData data = new CompositeDataSupport(ct, new String[] { "predicate", "language", "matches" }, new Object[] { predicate, language, matches });
            answer.put(data);
        }
        if (getDefinition().getOtherwise() != null) {
            CompositeType ct = CamelOpenMBeanTypes.choiceCompositeType();
            String predicate = "otherwise";
            String language = "";
            Long matches = processor.getNotFilteredCount();
            CompositeData data = new CompositeDataSupport(ct, new String[] { "predicate", "language", "matches" }, new Object[] { predicate, language, matches });
            answer.put(data);
        }
        return answer;
    } catch (Exception e) {
        throw ObjectHelper.wrapRuntimeCamelException(e);
    }
}
Also used : FilterProcessor(org.apache.camel.processor.FilterProcessor) CompositeData(javax.management.openmbean.CompositeData) CompositeDataSupport(javax.management.openmbean.CompositeDataSupport) TabularData(javax.management.openmbean.TabularData) TabularDataSupport(javax.management.openmbean.TabularDataSupport) WhenDefinition(org.apache.camel.model.WhenDefinition) CompositeType(javax.management.openmbean.CompositeType)

Example 5 with FilterProcessor

use of org.apache.camel.processor.FilterProcessor in project camel by apache.

the class RouteBuilderTest method testSimpleRouteWithHeaderPredicate.

public void testSimpleRouteWithHeaderPredicate() throws Exception {
    List<Route> routes = buildSimpleRouteWithHeaderPredicate();
    log.debug("Created routes: " + routes);
    assertEquals("Number routes created", 1, routes.size());
    for (Route route : routes) {
        Endpoint key = route.getEndpoint();
        assertEquals("From endpoint", "direct://a", key.getEndpointUri());
        EventDrivenConsumerRoute consumer = assertIsInstanceOf(EventDrivenConsumerRoute.class, route);
        Channel channel = unwrapChannel(consumer.getProcessor());
        FilterProcessor filterProcessor = assertIsInstanceOf(FilterProcessor.class, channel.getNextProcessor());
        SendProcessor sendProcessor = assertIsInstanceOf(SendProcessor.class, unwrapChannel(filterProcessor).getNextProcessor());
        assertEquals("Endpoint URI", "direct://b", sendProcessor.getDestination().getEndpointUri());
    }
}
Also used : Endpoint(org.apache.camel.Endpoint) FilterProcessor(org.apache.camel.processor.FilterProcessor) Channel(org.apache.camel.Channel) DeadLetterChannel(org.apache.camel.processor.DeadLetterChannel) EventDrivenConsumerRoute(org.apache.camel.impl.EventDrivenConsumerRoute) SendProcessor(org.apache.camel.processor.SendProcessor) Route(org.apache.camel.Route) EventDrivenConsumerRoute(org.apache.camel.impl.EventDrivenConsumerRoute)

Aggregations

FilterProcessor (org.apache.camel.processor.FilterProcessor)6 Processor (org.apache.camel.Processor)3 ChoiceProcessor (org.apache.camel.processor.ChoiceProcessor)3 SendProcessor (org.apache.camel.processor.SendProcessor)3 Channel (org.apache.camel.Channel)2 DelegateProcessor (org.apache.camel.DelegateProcessor)2 Endpoint (org.apache.camel.Endpoint)2 Route (org.apache.camel.Route)2 EventDrivenConsumerRoute (org.apache.camel.impl.EventDrivenConsumerRoute)2 MulticastProcessor (org.apache.camel.processor.MulticastProcessor)2 ThreadsProcessor (org.apache.camel.processor.ThreadsProcessor)2 ArrayList (java.util.ArrayList)1 Iterator (java.util.Iterator)1 CompositeData (javax.management.openmbean.CompositeData)1 CompositeDataSupport (javax.management.openmbean.CompositeDataSupport)1 CompositeType (javax.management.openmbean.CompositeType)1 TabularData (javax.management.openmbean.TabularData)1 TabularDataSupport (javax.management.openmbean.TabularDataSupport)1 CamelContextAware (org.apache.camel.CamelContextAware)1 BeanProcessor (org.apache.camel.component.bean.BeanProcessor)1