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

org.apache.camel.spi.RouteContext 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.spi;

import java.util.List;
import java.util.Map;
import java.util.Set;

import org.apache.camel.CamelContext;
import org.apache.camel.Endpoint;
import org.apache.camel.EndpointAware;
import org.apache.camel.ErrorHandlerFactory;
import org.apache.camel.NamedNode;
import org.apache.camel.Processor;
import org.apache.camel.Route;
import org.apache.camel.RuntimeConfiguration;

/**
 * The context used to activate new routing rules
 */
public interface RouteContext extends RuntimeConfiguration, EndpointAware {

    /**
     * Gets the route id
     */
    String getRouteId();

    /**
     * Get the route type
     *
     * @return the route type
     */
    NamedNode getRoute();

    /**
     * Gets the camel context
     *
     * @return the camel context
     */
    CamelContext getCamelContext();

    /**
     * Resolves an endpoint from the URI
     *
     * @param uri the URI
     * @return the resolved endpoint
     */
    Endpoint resolveEndpoint(String uri);

    /**
     * Resolves an endpoint from either a URI or a named reference
     *
     * @param uri  the URI or
     * @param ref  the named reference
     * @return the resolved endpoint
     */
    Endpoint resolveEndpoint(String uri, String ref);

    /**
     * lookup an object by name and type
     *
     * @param name  the name to lookup
     * @param type  the expected type
     * @return the found object
     */
     T lookup(String name, Class type);

    /**
     * lookup an object by name and type or throws {@link org.apache.camel.NoSuchBeanException} if not found.
     *
     * @param name  the name to lookup
     * @param type  the expected type
     * @return the found object
     */
     T mandatoryLookup(String name, Class type);

    /**
     * lookup objects by type
     *
     * @param type the expected type
     * @return the found objects with the name as the key in the map. Returns an empty map if none found.
     */
     Map lookupByType(Class type);

    /**
     * For completing the route creation, creating a single event driven route
     * for the current from endpoint with any processors required
     */
    Route commit();

    /**
     * Adds an event driven processor
     *
     * @param processor the processor
     */
    void addEventDrivenProcessor(Processor processor);

    /**
     * This method retrieves the InterceptStrategy instances this route context.
     *
     * @return the strategy
     */
    List getInterceptStrategies();

    /**
     * This method sets the InterceptStrategy instances on this route context.
     *
     * @param interceptStrategies the strategies
     */
    void setInterceptStrategies(List interceptStrategies);

    /**
     * Adds a InterceptStrategy to this route context
     *
     * @param interceptStrategy the strategy
     */
    void addInterceptStrategy(InterceptStrategy interceptStrategy);

    /**
     * Sets a special intercept strategy for management.
     * 

* Is by default used to correlate managed performance counters with processors * when the runtime route is being constructed * * @param interceptStrategy the managed intercept strategy */ void setManagementInterceptStrategy(ManagementInterceptStrategy interceptStrategy); /** * Gets the special managed intercept strategy if any * * @return the managed intercept strategy, or null if not managed */ ManagementInterceptStrategy getManagementInterceptStrategy(); /** * If this flag is true, {@link org.apache.camel.reifier.ProcessorReifier#addRoutes(RouteContext)} * will not add processor to addEventDrivenProcessor to the RouteContext and it * will prevent from adding an EventDrivenRoute. * * @param value the flag */ void setIsRouteAdded(boolean value); void setEndpoint(Endpoint endpoint); /** * Returns the isRouteAdded flag * * @return the flag */ boolean isRouteAdded(); /** * Gets the route policy List * * @return the route policy list if any */ List getRoutePolicyList(); /** * Sets a custom route policy List * * @param routePolicyList the custom route policy list */ void setRoutePolicyList(List routePolicyList); /** * Sets whether the route should automatically start when Camel starts. *

* Default is true to always start up. * * @param autoStartup whether to start up automatically. */ @Override void setAutoStartup(Boolean autoStartup); /** * Gets whether the route should automatically start when Camel starts. *

* Default is true to always start up. * * @return true if route should automatically start */ @Override Boolean isAutoStartup(); void setStartupOrder(Integer startupOrder); Integer getStartupOrder(); void setErrorHandlerFactory(ErrorHandlerFactory errorHandlerFactory); ErrorHandlerFactory getErrorHandlerFactory(); void addAdvice(CamelInternalProcessorAdvice advice); void addProperty(String key, Object value); /** * Gets the last error. * * @return the error */ default RouteError getLastError() { return null; } /** * Sets the last error. * * @param error the error */ default void setLastError(RouteError error) { } /** * Gets the {@link RouteController} for this route. * * @return the route controller, */ RouteController getRouteController(); /** * Sets the {@link RouteController} for this route. * * @param controller the RouteController */ void setRouteController(RouteController controller); Processor getOnCompletion(String onCompletionId); void setOnCompletion(String onCompletionId, Processor processor); Processor getOnException(String onExceptionId); void setOnException(String onExceptionId, Processor processor); /** * Adds error handler for the given exception type * * @param factory the error handler factory * @param exception the exception to handle */ void addErrorHandler(ErrorHandlerFactory factory, NamedNode exception); /** * Gets the error handlers * * @param factory the error handler factory */ Set getErrorHandlers(ErrorHandlerFactory factory); /** * Link the error handlers from a factory to another * * @param source the source factory * @param target the target factory */ void addErrorHandlerFactoryReference(ErrorHandlerFactory source, ErrorHandlerFactory target); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy