001/*
002 * Licensed to the Apache Software Foundation (ASF) under one or more
003 * contributor license agreements.  See the NOTICE file distributed with
004 * this work for additional information regarding copyright ownership.
005 * The ASF licenses this file to You under the Apache License, Version 2.0
006 * (the "License"); you may not use this file except in compliance with
007 * the License.  You may obtain a copy of the License at
008 *
009 *      http://www.apache.org/licenses/LICENSE-2.0
010 *
011 * Unless required by applicable law or agreed to in writing, software
012 * distributed under the License is distributed on an "AS IS" BASIS,
013 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
014 * See the License for the specific language governing permissions and
015 * limitations under the License.
016 */
017package org.apache.camel.management;
018
019import java.util.concurrent.ThreadPoolExecutor;
020
021import org.apache.camel.CamelContext;
022import org.apache.camel.Component;
023import org.apache.camel.Consumer;
024import org.apache.camel.DelegateProcessor;
025import org.apache.camel.Endpoint;
026import org.apache.camel.NamedNode;
027import org.apache.camel.Processor;
028import org.apache.camel.Producer;
029import org.apache.camel.Route;
030import org.apache.camel.Service;
031import org.apache.camel.cluster.CamelClusterService;
032import org.apache.camel.component.bean.BeanProcessor;
033import org.apache.camel.component.log.LogEndpoint;
034import org.apache.camel.health.HealthCheckRegistry;
035import org.apache.camel.management.mbean.ManagedAggregateProcessor;
036import org.apache.camel.management.mbean.ManagedBeanProcessor;
037import org.apache.camel.management.mbean.ManagedBrowsableEndpoint;
038import org.apache.camel.management.mbean.ManagedCamelContext;
039import org.apache.camel.management.mbean.ManagedCamelHealth;
040import org.apache.camel.management.mbean.ManagedChoice;
041import org.apache.camel.management.mbean.ManagedClaimCheck;
042import org.apache.camel.management.mbean.ManagedClusterService;
043import org.apache.camel.management.mbean.ManagedComponent;
044import org.apache.camel.management.mbean.ManagedConsumer;
045import org.apache.camel.management.mbean.ManagedConvertBody;
046import org.apache.camel.management.mbean.ManagedConvertHeader;
047import org.apache.camel.management.mbean.ManagedConvertVariable;
048import org.apache.camel.management.mbean.ManagedCustomLoadBalancer;
049import org.apache.camel.management.mbean.ManagedDataFormat;
050import org.apache.camel.management.mbean.ManagedDelayer;
051import org.apache.camel.management.mbean.ManagedDisabled;
052import org.apache.camel.management.mbean.ManagedDoCatch;
053import org.apache.camel.management.mbean.ManagedDoFinally;
054import org.apache.camel.management.mbean.ManagedDoTry;
055import org.apache.camel.management.mbean.ManagedDynamicRouter;
056import org.apache.camel.management.mbean.ManagedEndpoint;
057import org.apache.camel.management.mbean.ManagedEnricher;
058import org.apache.camel.management.mbean.ManagedEventNotifier;
059import org.apache.camel.management.mbean.ManagedFailoverLoadBalancer;
060import org.apache.camel.management.mbean.ManagedFilter;
061import org.apache.camel.management.mbean.ManagedIdempotentConsumer;
062import org.apache.camel.management.mbean.ManagedLog;
063import org.apache.camel.management.mbean.ManagedLoop;
064import org.apache.camel.management.mbean.ManagedMarshal;
065import org.apache.camel.management.mbean.ManagedMulticast;
066import org.apache.camel.management.mbean.ManagedPoll;
067import org.apache.camel.management.mbean.ManagedPollEnricher;
068import org.apache.camel.management.mbean.ManagedProcess;
069import org.apache.camel.management.mbean.ManagedProcessor;
070import org.apache.camel.management.mbean.ManagedProducer;
071import org.apache.camel.management.mbean.ManagedRandomLoadBalancer;
072import org.apache.camel.management.mbean.ManagedRecipientList;
073import org.apache.camel.management.mbean.ManagedRemoveHeader;
074import org.apache.camel.management.mbean.ManagedRemoveHeaders;
075import org.apache.camel.management.mbean.ManagedRemoveProperties;
076import org.apache.camel.management.mbean.ManagedRemoveProperty;
077import org.apache.camel.management.mbean.ManagedRemoveVariable;
078import org.apache.camel.management.mbean.ManagedResequencer;
079import org.apache.camel.management.mbean.ManagedRollback;
080import org.apache.camel.management.mbean.ManagedRoundRobinLoadBalancer;
081import org.apache.camel.management.mbean.ManagedRoute;
082import org.apache.camel.management.mbean.ManagedRouteController;
083import org.apache.camel.management.mbean.ManagedRouteGroup;
084import org.apache.camel.management.mbean.ManagedRoutingSlip;
085import org.apache.camel.management.mbean.ManagedSamplingThrottler;
086import org.apache.camel.management.mbean.ManagedScheduledPollConsumer;
087import org.apache.camel.management.mbean.ManagedScript;
088import org.apache.camel.management.mbean.ManagedSendDynamicProcessor;
089import org.apache.camel.management.mbean.ManagedSendProcessor;
090import org.apache.camel.management.mbean.ManagedService;
091import org.apache.camel.management.mbean.ManagedSetBody;
092import org.apache.camel.management.mbean.ManagedSetExchangePattern;
093import org.apache.camel.management.mbean.ManagedSetHeader;
094import org.apache.camel.management.mbean.ManagedSetHeaders;
095import org.apache.camel.management.mbean.ManagedSetProperty;
096import org.apache.camel.management.mbean.ManagedSetVariable;
097import org.apache.camel.management.mbean.ManagedSetVariables;
098import org.apache.camel.management.mbean.ManagedSplitter;
099import org.apache.camel.management.mbean.ManagedStep;
100import org.apache.camel.management.mbean.ManagedStickyLoadBalancer;
101import org.apache.camel.management.mbean.ManagedStop;
102import org.apache.camel.management.mbean.ManagedSupervisingRouteController;
103import org.apache.camel.management.mbean.ManagedSuspendableRoute;
104import org.apache.camel.management.mbean.ManagedThreadPool;
105import org.apache.camel.management.mbean.ManagedThreads;
106import org.apache.camel.management.mbean.ManagedThrottler;
107import org.apache.camel.management.mbean.ManagedThroughputLogger;
108import org.apache.camel.management.mbean.ManagedThrowException;
109import org.apache.camel.management.mbean.ManagedTopicLoadBalancer;
110import org.apache.camel.management.mbean.ManagedTransformer;
111import org.apache.camel.management.mbean.ManagedUnmarshal;
112import org.apache.camel.management.mbean.ManagedValidate;
113import org.apache.camel.management.mbean.ManagedWeightedLoadBalancer;
114import org.apache.camel.management.mbean.ManagedWireTapProcessor;
115import org.apache.camel.model.ExpressionNode;
116import org.apache.camel.model.LoadBalanceDefinition;
117import org.apache.camel.model.ProcessDefinition;
118import org.apache.camel.model.ProcessorDefinition;
119import org.apache.camel.model.RecipientListDefinition;
120import org.apache.camel.model.TransformDefinition;
121import org.apache.camel.model.loadbalancer.CustomLoadBalancerDefinition;
122import org.apache.camel.processor.CatchProcessor;
123import org.apache.camel.processor.ChoiceProcessor;
124import org.apache.camel.processor.ClaimCheckProcessor;
125import org.apache.camel.processor.Delayer;
126import org.apache.camel.processor.DisabledProcessor;
127import org.apache.camel.processor.DynamicRouter;
128import org.apache.camel.processor.Enricher;
129import org.apache.camel.processor.ExchangePatternProcessor;
130import org.apache.camel.processor.FilterProcessor;
131import org.apache.camel.processor.FinallyProcessor;
132import org.apache.camel.processor.LogProcessor;
133import org.apache.camel.processor.LoopProcessor;
134import org.apache.camel.processor.MulticastProcessor;
135import org.apache.camel.processor.Pipeline;
136import org.apache.camel.processor.PollEnricher;
137import org.apache.camel.processor.PollProcessor;
138import org.apache.camel.processor.RecipientList;
139import org.apache.camel.processor.RemoveHeaderProcessor;
140import org.apache.camel.processor.RemoveHeadersProcessor;
141import org.apache.camel.processor.RemovePropertiesProcessor;
142import org.apache.camel.processor.RemovePropertyProcessor;
143import org.apache.camel.processor.RemoveVariableProcessor;
144import org.apache.camel.processor.Resequencer;
145import org.apache.camel.processor.RollbackProcessor;
146import org.apache.camel.processor.RoutingSlip;
147import org.apache.camel.processor.SamplingThrottler;
148import org.apache.camel.processor.ScriptProcessor;
149import org.apache.camel.processor.SendDynamicProcessor;
150import org.apache.camel.processor.SendProcessor;
151import org.apache.camel.processor.SetBodyProcessor;
152import org.apache.camel.processor.SetHeaderProcessor;
153import org.apache.camel.processor.SetHeadersProcessor;
154import org.apache.camel.processor.SetPropertyProcessor;
155import org.apache.camel.processor.SetVariableProcessor;
156import org.apache.camel.processor.SetVariablesProcessor;
157import org.apache.camel.processor.Splitter;
158import org.apache.camel.processor.StepProcessor;
159import org.apache.camel.processor.StopProcessor;
160import org.apache.camel.processor.StreamResequencer;
161import org.apache.camel.processor.ThreadsProcessor;
162import org.apache.camel.processor.Throttler;
163import org.apache.camel.processor.ThrowExceptionProcessor;
164import org.apache.camel.processor.TransformProcessor;
165import org.apache.camel.processor.TryProcessor;
166import org.apache.camel.processor.WireTapProcessor;
167import org.apache.camel.processor.aggregate.AggregateProcessor;
168import org.apache.camel.processor.idempotent.IdempotentConsumer;
169import org.apache.camel.processor.loadbalancer.FailOverLoadBalancer;
170import org.apache.camel.processor.loadbalancer.LoadBalancer;
171import org.apache.camel.processor.loadbalancer.RandomLoadBalancer;
172import org.apache.camel.processor.loadbalancer.RoundRobinLoadBalancer;
173import org.apache.camel.processor.loadbalancer.StickyLoadBalancer;
174import org.apache.camel.processor.loadbalancer.TopicLoadBalancer;
175import org.apache.camel.processor.loadbalancer.WeightedLoadBalancer;
176import org.apache.camel.processor.transformer.DataTypeProcessor;
177import org.apache.camel.spi.BrowsableEndpoint;
178import org.apache.camel.spi.DataFormat;
179import org.apache.camel.spi.ErrorHandler;
180import org.apache.camel.spi.EventNotifier;
181import org.apache.camel.spi.ManagementObjectStrategy;
182import org.apache.camel.spi.RouteController;
183import org.apache.camel.spi.SupervisingRouteController;
184import org.apache.camel.support.ScheduledPollConsumer;
185import org.apache.camel.support.processor.ConvertBodyProcessor;
186import org.apache.camel.support.processor.ConvertHeaderProcessor;
187import org.apache.camel.support.processor.ConvertVariableProcessor;
188import org.apache.camel.support.processor.MarshalProcessor;
189import org.apache.camel.support.processor.PredicateValidatingProcessor;
190import org.apache.camel.support.processor.ThroughputLogger;
191import org.apache.camel.support.processor.UnmarshalProcessor;
192
193/**
194 * Default {@link org.apache.camel.spi.ManagementObjectStrategy}.
195 */
196public class DefaultManagementObjectStrategy implements ManagementObjectStrategy {
197
198    @Override
199    public Object getManagedObjectForCamelContext(CamelContext context) {
200        ManagedCamelContext mc = new ManagedCamelContext(context);
201        mc.init(context.getManagementStrategy());
202        return mc;
203    }
204
205    @Override
206    public Object getManagedObjectForCamelHealth(CamelContext context, HealthCheckRegistry healthCheckRegistry) {
207        ManagedCamelHealth mch = new ManagedCamelHealth(context, healthCheckRegistry);
208        mch.init(context.getManagementStrategy());
209        return mch;
210    }
211
212    @Override
213    public Object getManagedObjectForComponent(CamelContext context, Component component, String name) {
214        ManagedComponent mc = new ManagedComponent(name, component);
215        mc.init(context.getManagementStrategy());
216        return mc;
217    }
218
219    @Override
220    public Object getManagedObjectForDataFormat(CamelContext context, DataFormat dataFormat) {
221        ManagedDataFormat md = new ManagedDataFormat(context, dataFormat);
222        md.init(context.getManagementStrategy());
223        return md;
224    }
225
226    @Override
227    public Object getManagedObjectForEndpoint(CamelContext context, Endpoint endpoint) {
228        // we only want to manage singleton endpoints
229        if (!endpoint.isSingleton()) {
230            return null;
231        }
232
233        if (endpoint instanceof BrowsableEndpoint browsableEndpoint) {
234            ManagedBrowsableEndpoint me = new ManagedBrowsableEndpoint(browsableEndpoint);
235            me.init(context.getManagementStrategy());
236            return me;
237        } else {
238            ManagedEndpoint me = new ManagedEndpoint(endpoint);
239            me.init(context.getManagementStrategy());
240            return me;
241        }
242    }
243
244    @Override
245    public Object getManagedObjectForRouteController(CamelContext context, RouteController routeController) {
246        ManagedService mrc;
247        if (routeController instanceof SupervisingRouteController supervisingRouteController) {
248            mrc = new ManagedSupervisingRouteController(context, supervisingRouteController);
249        } else {
250            mrc = new ManagedRouteController(context, routeController);
251        }
252        mrc.init(context.getManagementStrategy());
253        return mrc;
254    }
255
256    @Override
257    public Object getManagedObjectForRoute(CamelContext context, Route route) {
258        ManagedRoute mr;
259        if (route.supportsSuspension()) {
260            mr = new ManagedSuspendableRoute(context, route);
261        } else {
262            mr = new ManagedRoute(context, route);
263        }
264        mr.init(context.getManagementStrategy());
265        return mr;
266    }
267
268    @Override
269    public Object getManagedObjectForRouteGroup(CamelContext context, String group) {
270        if (group == null) {
271            return null;
272        }
273        ManagedRouteGroup mr = new ManagedRouteGroup(context, group);
274        mr.init(context.getManagementStrategy());
275        return mr;
276    }
277
278    @Override
279    public Object getManagedObjectForThreadPool(
280            CamelContext context, ThreadPoolExecutor threadPool,
281            String id, String sourceId, String routeId, String threadPoolProfileId) {
282        ManagedThreadPool mtp = new ManagedThreadPool(context, threadPool, id, sourceId, routeId, threadPoolProfileId);
283        mtp.init(context.getManagementStrategy());
284        return mtp;
285    }
286
287    @Override
288    public Object getManagedObjectForEventNotifier(CamelContext context, EventNotifier eventNotifier) {
289        ManagedEventNotifier men = new ManagedEventNotifier(context, eventNotifier);
290        men.init(context.getManagementStrategy());
291        return men;
292    }
293
294    @Override
295    public Object getManagedObjectForConsumer(CamelContext context, Consumer consumer) {
296        ManagedConsumer mc;
297        if (consumer instanceof ScheduledPollConsumer scheduledPollConsumer) {
298            mc = new ManagedScheduledPollConsumer(context, scheduledPollConsumer);
299        } else {
300            mc = new ManagedConsumer(context, consumer);
301        }
302        mc.init(context.getManagementStrategy());
303        return mc;
304    }
305
306    @Override
307    public Object getManagedObjectForProducer(CamelContext context, Producer producer) {
308        ManagedProducer mp = new ManagedProducer(context, producer);
309        mp.init(context.getManagementStrategy());
310        return mp;
311    }
312
313    @Override
314    public Object getManagedObjectForService(CamelContext context, Service service) {
315        ManagedService mc = new ManagedService(context, service);
316        mc.init(context.getManagementStrategy());
317        return mc;
318    }
319
320    @Override
321    public Object getManagedObjectForClusterService(CamelContext context, CamelClusterService service) {
322        ManagedClusterService mcs = new ManagedClusterService(context, service);
323        mcs.init(context.getManagementStrategy());
324        return mcs;
325    }
326
327    @Override
328    public Object getManagedObjectForProcessor(
329            CamelContext context, Processor processor,
330            NamedNode node, Route route) {
331        ManagedProcessor answer = null;
332
333        ProcessorDefinition<?> definition = (ProcessorDefinition<?>) node;
334
335        if (definition instanceof RecipientListDefinition) {
336            // special for RecipientListDefinition, as the processor is wrapped in a pipeline as last
337            Pipeline pipeline = (Pipeline) processor;
338            for (Processor value : pipeline.next()) {
339                processor = value;
340            }
341        }
342
343        // unwrap delegates as we want the real target processor
344        Processor target = processor;
345        while (target != null) {
346
347            // skip error handlers
348            if (target instanceof ErrorHandler) {
349                return false;
350            }
351
352            if (target instanceof ConvertBodyProcessor) {
353                answer = new ManagedConvertBody(context, (ConvertBodyProcessor) target, definition);
354            } else if (target instanceof ConvertHeaderProcessor) {
355                answer = new ManagedConvertHeader(context, (ConvertHeaderProcessor) target, definition);
356            } else if (target instanceof ConvertVariableProcessor) {
357                answer = new ManagedConvertVariable(context, (ConvertVariableProcessor) target, definition);
358            } else if (target instanceof ChoiceProcessor) {
359                answer = new ManagedChoice(context, (ChoiceProcessor) target, definition);
360            } else if (target instanceof ClaimCheckProcessor) {
361                answer = new ManagedClaimCheck(context, (ClaimCheckProcessor) target, definition);
362            } else if (target instanceof Delayer) {
363                answer = new ManagedDelayer(context, (Delayer) target, definition);
364            } else if (target instanceof DisabledProcessor) {
365                answer = new ManagedDisabled(context, (DisabledProcessor) target, definition);
366            } else if (target instanceof TryProcessor tryProc) {
367                answer = new ManagedDoTry(context, tryProc, cast(definition));
368            } else if (target instanceof CatchProcessor) {
369                answer = new ManagedDoCatch(context, (CatchProcessor) target, cast(definition));
370            } else if (target instanceof FinallyProcessor) {
371                answer = new ManagedDoFinally(context, (FinallyProcessor) target, cast(definition));
372            } else if (target instanceof Throttler) {
373                answer = new ManagedThrottler(context, (Throttler) target, definition);
374            } else if (target instanceof DynamicRouter) {
375                answer = new ManagedDynamicRouter(context, (DynamicRouter) target, cast(definition));
376            } else if (target instanceof RoutingSlip) {
377                answer = new ManagedRoutingSlip(context, (RoutingSlip) target, cast(definition));
378            } else if (target instanceof FilterProcessor) {
379                answer = new ManagedFilter(context, (FilterProcessor) target, (ExpressionNode) definition);
380            } else if (target instanceof LogProcessor) {
381                answer = new ManagedLog(context, (LogProcessor) target, definition);
382            } else if (target instanceof LoopProcessor) {
383                answer = new ManagedLoop(context, (LoopProcessor) target, cast(definition));
384            } else if (target instanceof MarshalProcessor) {
385                answer = new ManagedMarshal(context, (MarshalProcessor) target, cast(definition));
386            } else if (target instanceof UnmarshalProcessor) {
387                answer = new ManagedUnmarshal(context, (UnmarshalProcessor) target, cast(definition));
388            } else if (target instanceof FailOverLoadBalancer) {
389                answer = new ManagedFailoverLoadBalancer(
390                        context, (FailOverLoadBalancer) target, cast(definition));
391            } else if (target instanceof RandomLoadBalancer) {
392                answer = new ManagedRandomLoadBalancer(
393                        context, (RandomLoadBalancer) target, cast(definition));
394            } else if (target instanceof RoundRobinLoadBalancer) {
395                answer = new ManagedRoundRobinLoadBalancer(
396                        context, (RoundRobinLoadBalancer) target, cast(definition));
397            } else if (target instanceof StickyLoadBalancer) {
398                answer = new ManagedStickyLoadBalancer(
399                        context, (StickyLoadBalancer) target, cast(definition));
400            } else if (target instanceof TopicLoadBalancer) {
401                answer = new ManagedTopicLoadBalancer(context, (TopicLoadBalancer) target, cast(definition));
402            } else if (target instanceof WeightedLoadBalancer) {
403                answer = new ManagedWeightedLoadBalancer(
404                        context, (WeightedLoadBalancer) target, cast(definition));
405            } else if (target instanceof RecipientList) {
406                answer = new ManagedRecipientList(context, (RecipientList) target, cast(definition));
407            } else if (target instanceof Splitter) {
408                answer = new ManagedSplitter(context, (Splitter) target, cast(definition));
409            } else if (target instanceof MulticastProcessor) {
410                answer = new ManagedMulticast(context, (MulticastProcessor) target, definition);
411            } else if (target instanceof SamplingThrottler) {
412                answer = new ManagedSamplingThrottler(context, (SamplingThrottler) target, definition);
413            } else if (target instanceof Resequencer) {
414                answer = new ManagedResequencer(context, (Resequencer) target, definition);
415            } else if (target instanceof RollbackProcessor) {
416                answer = new ManagedRollback(context, (RollbackProcessor) target, definition);
417            } else if (target instanceof StreamResequencer) {
418                answer = new ManagedResequencer(context, (StreamResequencer) target, definition);
419            } else if (target instanceof SetBodyProcessor) {
420                answer = new ManagedSetBody(context, (SetBodyProcessor) target, cast(definition));
421            } else if (target instanceof RemoveHeaderProcessor) {
422                answer = new ManagedRemoveHeader(context, (RemoveHeaderProcessor) target, definition);
423            } else if (target instanceof RemoveHeadersProcessor) {
424                answer = new ManagedRemoveHeaders(context, (RemoveHeadersProcessor) target, definition);
425            } else if (target instanceof SetHeaderProcessor) {
426                answer = new ManagedSetHeader(context, (SetHeaderProcessor) target, cast(definition));
427            } else if (target instanceof SetHeadersProcessor) {
428                answer = new ManagedSetHeaders(context, (SetHeadersProcessor) target, cast(definition));
429            } else if (target instanceof SetVariableProcessor) {
430                answer = new ManagedSetVariable(context, (SetVariableProcessor) target, cast(definition));
431            } else if (target instanceof SetVariablesProcessor) {
432                answer = new ManagedSetVariables(context, (SetVariablesProcessor) target, cast(definition));
433            } else if (target instanceof RemovePropertyProcessor) {
434                answer = new ManagedRemoveProperty(context, (RemovePropertyProcessor) target, definition);
435            } else if (target instanceof RemovePropertiesProcessor) {
436                answer = new ManagedRemoveProperties(context, (RemovePropertiesProcessor) target, definition);
437            } else if (target instanceof RemoveVariableProcessor) {
438                answer = new ManagedRemoveVariable(context, (RemoveVariableProcessor) target, definition);
439            } else if (target instanceof SetPropertyProcessor) {
440                answer = new ManagedSetProperty(context, (SetPropertyProcessor) target, cast(definition));
441            } else if (target instanceof ExchangePatternProcessor) {
442                answer = new ManagedSetExchangePattern(context, (ExchangePatternProcessor) target, definition);
443            } else if (target instanceof ScriptProcessor) {
444                answer = new ManagedScript(context, (ScriptProcessor) target, cast(definition));
445            } else if (target instanceof StepProcessor) {
446                answer = new ManagedStep(context, (StepProcessor) target, definition);
447            } else if (target instanceof StopProcessor) {
448                answer = new ManagedStop(context, (StopProcessor) target, definition);
449            } else if (target instanceof ThreadsProcessor) {
450                answer = new ManagedThreads(context, (ThreadsProcessor) target, definition);
451            } else if (target instanceof ThrowExceptionProcessor) {
452                answer = new ManagedThrowException(context, (ThrowExceptionProcessor) target, definition);
453            } else if (target instanceof TransformProcessor) {
454                answer = new ManagedTransformer(context, target, cast(definition));
455            } else if (target instanceof DataTypeProcessor && definition instanceof TransformDefinition) {
456                answer = new ManagedTransformer(context, target, (TransformDefinition) definition);
457            } else if (target instanceof PredicateValidatingProcessor) {
458                answer = new ManagedValidate(context, (PredicateValidatingProcessor) target, cast(definition));
459            } else if (target instanceof WireTapProcessor) {
460                answer = new ManagedWireTapProcessor(context, (WireTapProcessor) target, definition);
461            } else if (target instanceof SendDynamicProcessor) {
462                answer = new ManagedSendDynamicProcessor(context, (SendDynamicProcessor) target, definition);
463            } else if (target instanceof SendProcessor sp) {
464                // special for sending to throughput logger
465                if (sp.getDestination() instanceof LogEndpoint le && le.getLogger() instanceof ThroughputLogger tl) {
466                    answer = new ManagedThroughputLogger(context, tl, definition);
467                }
468                // regular send processor
469                if (answer == null) {
470                    answer = new ManagedSendProcessor(context, (SendProcessor) target, definition);
471                }
472            } else if (target instanceof BeanProcessor) {
473                answer = new ManagedBeanProcessor(context, (BeanProcessor) target, definition);
474            } else if (target instanceof IdempotentConsumer) {
475                answer = new ManagedIdempotentConsumer(
476                        context, (IdempotentConsumer) target, cast(definition));
477            } else if (target instanceof AggregateProcessor) {
478                answer = new ManagedAggregateProcessor(context, (AggregateProcessor) target, cast(definition));
479            } else if (target instanceof Enricher) {
480                answer = new ManagedEnricher(context, (Enricher) target, cast(definition));
481            } else if (target instanceof PollProcessor) {
482                answer = new ManagedPoll(context, (PollProcessor) target, cast(definition));
483            } else if (target instanceof PollEnricher) {
484                answer = new ManagedPollEnricher(context, (PollEnricher) target, cast(definition));
485            }
486
487            // special for custom load balancer
488            if (definition instanceof LoadBalanceDefinition lb) {
489                if (lb.getLoadBalancerType() instanceof CustomLoadBalancerDefinition) {
490                    answer = new ManagedCustomLoadBalancer(context, (LoadBalancer) target, (LoadBalanceDefinition) definition);
491                }
492            }
493
494            if (answer != null) {
495                // break out as we found an answer
496                break;
497            }
498
499            // no answer yet, so unwrap any delegates and try again
500            if (target instanceof DelegateProcessor) {
501                target = ((DelegateProcessor) target).getProcessor();
502            } else {
503                // no delegate so we dont have any target to try next
504                break;
505            }
506        }
507
508        if (answer == null && definition instanceof ProcessDefinition) {
509            answer = new ManagedProcess(context, target, (ProcessDefinition) definition);
510        } else if (answer == null) {
511            // fallback to a generic processor
512            answer = new ManagedProcessor(context, target, definition);
513        }
514
515        answer.setRoute(route);
516        answer.init(context.getManagementStrategy());
517        return answer;
518    }
519
520    @SuppressWarnings("unchecked")
521    private <T extends ProcessorDefinition<?>> T cast(ProcessorDefinition<?> definition) {
522        return (T) definition;
523    }
524
525}