All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.camel.ExtendedCamelContext Maven / Gradle / Ivy

There is a newer version: 4.9.0
Show newest version
/*
 * 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;

import java.util.Collection;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.ScheduledExecutorService;

import org.apache.camel.catalog.RuntimeCamelCatalog;
import org.apache.camel.spi.AnnotationBasedProcessorFactory;
import org.apache.camel.spi.AsyncProcessorAwaitManager;
import org.apache.camel.spi.BeanIntrospection;
import org.apache.camel.spi.BeanProcessorFactory;
import org.apache.camel.spi.BeanProxyFactory;
import org.apache.camel.spi.CamelBeanPostProcessor;
import org.apache.camel.spi.ComponentNameResolver;
import org.apache.camel.spi.ComponentResolver;
import org.apache.camel.spi.ConfigurerResolver;
import org.apache.camel.spi.DataFormatResolver;
import org.apache.camel.spi.DeferServiceFactory;
import org.apache.camel.spi.EndpointStrategy;
import org.apache.camel.spi.FactoryFinder;
import org.apache.camel.spi.FactoryFinderResolver;
import org.apache.camel.spi.HeadersMapFactory;
import org.apache.camel.spi.InterceptStrategy;
import org.apache.camel.spi.LanguageResolver;
import org.apache.camel.spi.LifecycleStrategy;
import org.apache.camel.spi.LogListener;
import org.apache.camel.spi.ManagementMBeanAssembler;
import org.apache.camel.spi.ModelJAXBContextFactory;
import org.apache.camel.spi.ModelToXMLDumper;
import org.apache.camel.spi.NodeIdFactory;
import org.apache.camel.spi.NormalizedEndpointUri;
import org.apache.camel.spi.PackageScanClassResolver;
import org.apache.camel.spi.PackageScanResourceResolver;
import org.apache.camel.spi.ProcessorFactory;
import org.apache.camel.spi.ReactiveExecutor;
import org.apache.camel.spi.Registry;
import org.apache.camel.spi.RestBindingJaxbDataFormatFactory;
import org.apache.camel.spi.RouteController;
import org.apache.camel.spi.RouteStartupOrder;
import org.apache.camel.spi.SupervisingRouteController;
import org.apache.camel.spi.UnitOfWorkFactory;
import org.apache.camel.spi.XMLRoutesDefinitionLoader;

/**
 * Extended {@link CamelContext} which contains the methods and APIs that are not primary intended for Camel end users
 * but for SPI, custom components, or more advanced used-cases with Camel.
 */
public interface ExtendedCamelContext extends CamelContext {

    /**
     * Sets the name (id) of the this context.
     * 

* This operation is mostly only used by different Camel runtimes such as camel-spring, camel-cdi, camel-spring-boot etc. * Important: Setting the name should only be set before CamelContext is started. * * @param name the name */ void setName(String name); /** * Sets the registry Camel should use for looking up beans by name or type. *

* This operation is mostly only used by different Camel runtimes such as camel-spring, camel-cdi, camel-spring-boot etc. * Important: Setting the registry should only be set before CamelContext is started. * * @param registry the registry such as DefaultRegistry or */ void setRegistry(Registry registry); /** * Method to signal to {@link CamelContext} that the process to initialize setup routes is in progress. * * @param done false to start the process, call again with true to signal its done. * @see #isSetupRoutes() */ void setupRoutes(boolean done); /** * Indicates whether current thread is setting up route(s) as part of starting Camel from spring/blueprint. *

* This can be useful to know by {@link LifecycleStrategy} or the likes, in case * they need to react differently. *

* As the startup procedure of {@link CamelContext} is slightly different when using plain Java versus * Spring or Blueprint, then we need to know when Spring/Blueprint is setting up the routes, which * can happen after the {@link CamelContext} itself is in started state, due the asynchronous event nature * of especially Blueprint. * * @return true if current thread is setting up route(s), or false if not. */ boolean isSetupRoutes(); /** * Registers a {@link org.apache.camel.spi.EndpointStrategy callback} to allow you to do custom * logic when an {@link Endpoint} is about to be registered to the {@link org.apache.camel.spi.EndpointRegistry}. *

* When a callback is registered it will be executed on the already registered endpoints allowing you to catch-up * * @param strategy callback to be invoked */ void registerEndpointCallback(EndpointStrategy strategy); /** * Resolves the given name to an {@link Endpoint} of the specified type (scope is prototype). * If the name has a singleton endpoint registered, then the singleton is returned. * Otherwise, a new {@link Endpoint} is created. * * The endpoint is NOT registered in the {@link org.apache.camel.spi.EndpointRegistry} as its prototype scoped, * and therefore expected to be short lived and discarded after use (you must stop and shutdown the * endpoint when no longer in use). * * @param uri the URI of the endpoint * @return the endpoint * * @see #getEndpoint(String) */ Endpoint getPrototypeEndpoint(String uri); /** * Resolves the given name to an {@link Endpoint} of the specified type (scope is prototype). * If the name has a singleton endpoint registered, then the singleton is returned. * Otherwise, a new {@link Endpoint} is created. * * The endpoint is NOT registered in the {@link org.apache.camel.spi.EndpointRegistry} as its prototype scoped, * and therefore expected to be short lived and discarded after use (you must stop and shutdown the * endpoint when no longer in use). * * @param uri the URI of the endpoint * @return the endpoint * * @see #getEndpoint(String) */ Endpoint getPrototypeEndpoint(NormalizedEndpointUri uri); /** * Is the given endpoint already registered in the {@link org.apache.camel.spi.EndpointRegistry} * * @param uri the URI of the endpoint * @return the registered endpoint or null if not registered */ Endpoint hasEndpoint(NormalizedEndpointUri uri); /** * Resolves the given name to an {@link Endpoint} of the specified type. * If the name has a singleton endpoint registered, then the singleton is returned. * Otherwise, a new {@link Endpoint} is created and registered in the {@link org.apache.camel.spi.EndpointRegistry}. * * @param uri the URI of the endpoint * @return the endpoint * * @see #getPrototypeEndpoint(String) */ Endpoint getEndpoint(NormalizedEndpointUri uri); /** * Resolves the given name to an {@link Endpoint} of the specified type. * If the name has a singleton endpoint registered, then the singleton is returned. * Otherwise, a new {@link Endpoint} is created and registered in the {@link org.apache.camel.spi.EndpointRegistry}. * * @param uri the URI of the endpoint * @param parameters the parameters to customize the endpoint * @return the endpoint * * @see #getPrototypeEndpoint(String) */ Endpoint getEndpoint(NormalizedEndpointUri uri, Map parameters); /** * Normalizes the given uri. * * @param uri the uri * @return a normalized uri */ NormalizedEndpointUri normalizeUri(String uri); /** * Returns the order in which the route inputs was started. *

* The order may not be according to the startupOrder defined on the route. * For example a route could be started manually later, or new routes added at runtime. * * @return a list in the order how routes was started */ List getRouteStartupOrder(); /** * Returns the bean post processor used to do any bean customization. * * @return the bean post processor. */ CamelBeanPostProcessor getBeanPostProcessor(); /** * Returns the management mbean assembler * * @return the mbean assembler */ ManagementMBeanAssembler getManagementMBeanAssembler(); /** * Creates a new multicast processor which sends an exchange to all the processors. * * @param processors the list of processors to send to * @param executor the executor to use * @return a multicasting processor */ AsyncProcessor createMulticast(Collection processors, ExecutorService executor, boolean shutdownExecutorService); /** * Gets the default error handler builder which is inherited by the routes * * @return the builder */ ErrorHandlerFactory getErrorHandlerFactory(); /** * Sets the default error handler builder which is inherited by the routes * * @param errorHandlerFactory the builder */ void setErrorHandlerFactory(ErrorHandlerFactory errorHandlerFactory); /** * Uses a custom node id factory when generating auto assigned ids to the nodes in the route definitions * * @param factory custom factory to use */ void setNodeIdFactory(NodeIdFactory factory); /** * Gets the node id factory * * @return the node id factory */ NodeIdFactory getNodeIdFactory(); /** * Gets the {@link ComponentResolver} to use. */ ComponentResolver getComponentResolver(); /** * Sets a custom {@link ComponentResolver} to use. */ void setComponentResolver(ComponentResolver componentResolver); /** * Gets the {@link ComponentNameResolver} to use. */ ComponentNameResolver getComponentNameResolver(); /** * Sets a custom {@link ComponentNameResolver} to use. */ void setComponentNameResolver(ComponentNameResolver componentNameResolver); /** * Gets the {@link LanguageResolver} to use. */ LanguageResolver getLanguageResolver(); /** * Sets a custom {@link LanguageResolver} to use. */ void setLanguageResolver(LanguageResolver languageResolver); /** * Gets the current data format resolver * * @return the resolver */ DataFormatResolver getDataFormatResolver(); /** * Sets a custom data format resolver * * @param dataFormatResolver the resolver */ void setDataFormatResolver(DataFormatResolver dataFormatResolver); /** * Returns the package scanning class resolver * * @return the resolver */ PackageScanClassResolver getPackageScanClassResolver(); /** * Sets the package scanning class resolver to use * * @param resolver the resolver */ void setPackageScanClassResolver(PackageScanClassResolver resolver); /** * Returns the package scanning resource resolver * * @return the resolver */ PackageScanResourceResolver getPackageScanResourceResolver(); /** * Sets the package scanning resource resolver to use * * @param resolver the resolver */ void setPackageScanResourceResolver(PackageScanResourceResolver resolver); /** * Gets the default FactoryFinder which will be used for the loading the factory class from META-INF * * @return the default factory finder */ FactoryFinder getDefaultFactoryFinder(); /** * Gets the FactoryFinder which will be used for the loading the factory class from META-INF in the given path * * @param path the META-INF path * @return the factory finder */ FactoryFinder getFactoryFinder(String path); /** * Sets the factory finder resolver to use. * * @param resolver the factory finder resolver */ void setFactoryFinderResolver(FactoryFinderResolver resolver); /** * Gets the factory finder resolver to use * * @return the factory finder resolver */ FactoryFinderResolver getFactoryFinderResolver(); /** * Gets the current {@link org.apache.camel.spi.ProcessorFactory} * * @return the factory, can be null if no custom factory has been set */ ProcessorFactory getProcessorFactory(); /** * Sets a custom {@link org.apache.camel.spi.ProcessorFactory} * * @param processorFactory the custom factory */ void setProcessorFactory(ProcessorFactory processorFactory); /** * Returns the JAXB Context factory used to create Models. * * @return the JAXB Context factory used to create Models. */ ModelJAXBContextFactory getModelJAXBContextFactory(); /** * Sets a custom JAXB Context factory to be used * * @param modelJAXBContextFactory a JAXB Context factory */ void setModelJAXBContextFactory(ModelJAXBContextFactory modelJAXBContextFactory); /** * Gets the {@link DeferServiceFactory} to use. */ DeferServiceFactory getDeferServiceFactory(); /** * Gets the {@link UnitOfWorkFactory} to use. */ UnitOfWorkFactory getUnitOfWorkFactory(); /** * Sets a custom {@link UnitOfWorkFactory} to use. */ void setUnitOfWorkFactory(UnitOfWorkFactory unitOfWorkFactory); /** * Gets the {@link AnnotationBasedProcessorFactory} to use. */ AnnotationBasedProcessorFactory getAnnotationBasedProcessorFactory(); /** * Gets the {@link BeanProxyFactory} to use. */ BeanProxyFactory getBeanProxyFactory(); /** * Gets the {@link BeanProcessorFactory} to use. */ BeanProcessorFactory getBeanProcessorFactory(); /** * Gets the default shared thread pool for error handlers which * leverages this for asynchronous redelivery tasks. */ ScheduledExecutorService getErrorHandlerExecutorService(); /** * Adds the given interceptor strategy * * @param interceptStrategy the strategy */ void addInterceptStrategy(InterceptStrategy interceptStrategy); /** * Gets the interceptor strategies * * @return the list of current interceptor strategies */ List getInterceptStrategies(); /** * Setup management according to whether JMX is enabled or disabled. * * @param options optional parameters to configure {@link org.apache.camel.spi.ManagementAgent}. */ void setupManagement(Map options); /** * Gets a list of {@link LogListener}. */ Set getLogListeners(); /** * Adds a {@link LogListener}. */ void addLogListener(LogListener listener); /** * Gets the {@link org.apache.camel.AsyncProcessor} await manager. * * @return the manager */ AsyncProcessorAwaitManager getAsyncProcessorAwaitManager(); /** * Sets a custom {@link org.apache.camel.AsyncProcessor} await manager. * * @param manager the manager */ void setAsyncProcessorAwaitManager(AsyncProcessorAwaitManager manager); /** * Gets the {@link BeanIntrospection} */ BeanIntrospection getBeanIntrospection(); /** * Sets a custom {@link BeanIntrospection}. */ void setBeanIntrospection(BeanIntrospection beanIntrospection); /** * Gets the {@link HeadersMapFactory} to use. */ HeadersMapFactory getHeadersMapFactory(); /** * Sets a custom {@link HeadersMapFactory} to be used. */ void setHeadersMapFactory(HeadersMapFactory factory); /** * Gets the {@link ReactiveExecutor} to use. */ ReactiveExecutor getReactiveExecutor(); /** * Sets a custom {@link ReactiveExecutor} to be used. */ void setReactiveExecutor(ReactiveExecutor reactiveExecutor); /** * Whether event notification is applicable (possible). * This API is used internally in Camel as optimization. */ boolean isEventNotificationApplicable(); /** * Used as internal optimization in Camel to flag whether event notification is applicable or not. */ void setEventNotificationApplicable(boolean eventNotificationApplicable); /** * Sets a custom {@link XMLRoutesDefinitionLoader} to be used. */ void setXMLRoutesDefinitionLoader(XMLRoutesDefinitionLoader xmlRoutesDefinitionLoader); /** * Gets the {@link XMLRoutesDefinitionLoader} to be used. */ XMLRoutesDefinitionLoader getXMLRoutesDefinitionLoader(); /** * Sets a custom {@link ModelToXMLDumper} to be used. */ void setModelToXMLDumper(ModelToXMLDumper modelToXMLDumper); /** * Gets the {@link ModelToXMLDumper} to be used. */ ModelToXMLDumper getModelToXMLDumper(); /** * Sets a custom {@link RestBindingJaxbDataFormatFactory} to be used. */ void setRestBindingJaxbDataFormatFactory(RestBindingJaxbDataFormatFactory restBindingJaxbDataFormatFactory); /** * Gets the {@link RestBindingJaxbDataFormatFactory} to be used. */ RestBindingJaxbDataFormatFactory getRestBindingJaxbDataFormatFactory(); /** * Gets the {@link RuntimeCamelCatalog} if available on the classpath. */ RuntimeCamelCatalog getRuntimeCamelCatalog(); /** * Sets the {@link RuntimeCamelCatalog} to use. */ void setRuntimeCamelCatalog(RuntimeCamelCatalog runtimeCamelCatalog); /** * Gets the {@link ConfigurerResolver} to use. */ ConfigurerResolver getConfigurerResolver(); /** * Sets the {@link ConfigurerResolver} to use. */ void setConfigurerResolver(ConfigurerResolver configurerResolver); /** * Gets the {@link SupervisingRouteController} to use. */ SupervisingRouteController getSupervisingRouteController(); /** * Sets the {@link SupervisingRouteController} to use. */ void setSupervisingRouteController(SupervisingRouteController supervisingRouteController); /** * Internal {@link RouteController} that are only used internally by Camel to * perform basic route operations. Do not use this as end user. */ RouteController getInternalRouteController(); /** * Internal API for adding routes. Do not use this as end user. */ void addRoute(Route route); /** * Internal API for removing routes. Do not use this as end user. */ void removeRoute(Route route); /** * Internal API for creating error handler. Do not use this as end user. */ Processor createErrorHandler(Route route, Processor processor) throws Exception; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy