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}