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

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

The 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.Map;

import org.apache.camel.support.service.ServiceSupport;
import org.apache.camel.util.StringHelper;

/**
 * An endpoint implements the
 * Message Endpoint pattern and represents an endpoint that
 * can send and receive message exchanges
 *
 * @see Exchange
 * @see Message
 */
public interface Endpoint extends IsSingleton, Service, ComponentAware {

    /**
     * Returns the string representation of the endpoint URI
     *
     * @return the endpoint URI
     */
    String getEndpointUri();

    /**
     * Returns the default exchange pattern to use when creating an exchange.
     */
    ExchangePattern getExchangePattern();

    /**
     * Returns the string representation of the base endpoint URI (without query parameters).
     */
    default String getEndpointBaseUri() {
        String value = getEndpointUri();
        return StringHelper.before(value, "?", value);
    }

    /**
     * Returns a string key of this endpoint.
     * 

* This key is used by {@link org.apache.camel.spi.LifecycleStrategy} when registering endpoint. This allows to * register different instances of endpoints with the same key. *

* For JMX mbeans this allows us to use the same JMX Mbean for all endpoints that are logical the same but have * different parameters. For instance the http endpoint. * * @return the endpoint key */ String getEndpointKey(); /** * Create a new exchange for communicating with this endpoint. *

* Important: Consumers should use {@link Consumer#createExchange(boolean)} to create an exchange for which * the consumer received a message. * * @return a new exchange */ Exchange createExchange(); /** * Create a new exchange for communicating with this endpoint with the specified {@link ExchangePattern} such as * whether its going to be an {@link ExchangePattern#InOnly} or {@link ExchangePattern#InOut} exchange *

* Important: Consumers should use {@link Consumer#createExchange(boolean)} to create an exchange for which * the consumer received a message. * * @param pattern the message exchange pattern for the exchange * @return a new exchange */ Exchange createExchange(ExchangePattern pattern); /** * Configures a newly created {@link Exchange}. * * @param exchange the new exchange */ void configureExchange(Exchange exchange); /** * Returns the context which created the endpoint * * @return the context which created the endpoint */ CamelContext getCamelContext(); /** * Creates a new producer which is used send messages into the endpoint. * * Important: Do not do any initialization in the constructor of the {@link Producer}. Instead use * {@link ServiceSupport#doInit()} or {@link ServiceSupport#doStart()}. * * @return a newly created producer * @throws Exception can be thrown */ Producer createProducer() throws Exception; /** * Whether this endpoint creates singleton producers */ default boolean isSingletonProducer() { return isSingleton(); } /** * Creates a new producer which is used send messages into the endpoint * * Important: Do not do any initialization in the constructor of the {@link Producer}. Instead use * {@link ServiceSupport#doInit()} or {@link ServiceSupport#doStart()}. * * @return a newly created producer * @throws Exception can be thrown */ AsyncProducer createAsyncProducer() throws Exception; /** * Creates a new Event Driven Consumer which * consumes messages from the endpoint using the given processor * * Important: Do not do any initialization in the constructor of the {@link Consumer}. Instead use * {@link ServiceSupport#doInit()} or {@link ServiceSupport#doStart()}. * * @param processor the given processor * @return a newly created consumer * @throws Exception can be thrown */ Consumer createConsumer(Processor processor) throws Exception; /** * Creates a new Polling Consumer so that the caller can * poll message exchanges from the consumer using {@link PollingConsumer#receive()}, * {@link PollingConsumer#receiveNoWait()} or {@link PollingConsumer#receive(long)} whenever it is ready to do so * rather than using the Event Based Consumer * returned by {@link #createConsumer(Processor)} * * Important: Do not do any initialization in the constructor of the {@link PollingConsumer}. Instead use * {@link ServiceSupport#doInit()} or {@link ServiceSupport#doStart()}. * * @return a newly created pull consumer * @throws Exception if the pull consumer could not be created */ PollingConsumer createPollingConsumer() throws Exception; /** * Configure properties on this endpoint. * * @param options the options (properties) */ void configureProperties(Map options); /** * Sets the camel context. * * @param context the camel context */ void setCamelContext(CamelContext context); /** * Should all properties be known or does the endpoint allow unknown options? *

* lenient = false means that the endpoint should validate that all given options is known and configured * properly. lenient = true means that the endpoint allows additional unknown options to be passed to it * but does not throw a ResolveEndpointFailedException when creating the endpoint. *

* This options is used by a few components for instance the HTTP based that can have dynamic URI options appended * that is targeted for an external system. *

* Most endpoints is configured to be not lenient. * * @return whether properties is lenient or not */ boolean isLenientProperties(); /** * Whether this endpoint can connect to remote system, such as cloud providers, messaging brokers, databases. A * local endpoint operates locally only, such as an internal message transformer, logger, or such as direct/seda * components. */ default boolean isRemote() { return true; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy