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

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

/*
 * 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 java.util.concurrent.Future;
import java.util.function.Supplier;

import org.apache.camel.util.ObjectHelper;

/**
 * Template for working with Camel and sending {@link Message} instances in an {@link Exchange} to an {@link Endpoint}
 * using a fluent build style. 
*

* Important: Read the javadoc of each method carefully to ensure the behavior of the method is understood. Some * methods is for InOnly, others for InOut MEP. And some methods throws * {@link org.apache.camel.CamelExecutionException} while others stores any thrown exception on the returned * {@link Exchange}.
*

* The {@link FluentProducerTemplate} is thread safe with the assumption that its the same (single) thread that * builds the message (via the fluent methods) that also sends the message.
*

* When using the fluent template its required to chain the methods such as: * *

 *     FluentProducerTemplate fluent = ...
 *     fluent.withHeader("foo", 123).withHeader("bar", 456).withBody("Hello World").to("kafka:cheese").send();
 * 
* * The following code is wrong (do not do this) * *
 *     FluentProducerTemplate fluent = ...
 *     fluent.withHeader("foo", 123);
 *     fluent.withHeader("bar", 456);
 *     fluent.withBody("Hello World");
 *     fluent.to("kafka:cheese");
 *     fluent.send();
 * 
* * If you do not want to chain fluent methods you can do as follows: * *
 *     FluentProducerTemplate fluent = ...
 *     fluent = fluent.withHeader("foo", 123);
 *     fluent = fluent.withHeader("bar", 456);
 *     fluent = fluent.withBody("Hello World");
 *     fluent = fluent.to("kafka:cheese")
 *     fluent.send();
 * 
*

* You can either only use either withExchange, or withProcessor or a combination of withBody/withHeaders to construct * the message to be sent.
*

* All the methods which sends a message may throw {@link FailedToCreateProducerException} in case the {@link Producer} * could not be created. Or a {@link NoSuchEndpointException} if the endpoint could not be resolved. There may be other * related exceptions being thrown which occurs before the {@link Producer} has started sending the message.
*

* All the send or request methods will return the content according to this strategy: *

    *
  • throws {@link org.apache.camel.CamelExecutionException} if processing failed during routing with the * caused exception wrapped
  • *
  • The fault.body if there is a fault message set and its not null
  • *
  • Either IN or OUT body according to the message exchange pattern. If the pattern is Out capable * then the OUT body is returned, otherwise IN. *
*
*

* Before using the template it must be started. And when you are done using the template, make sure to {@link #stop()} * the template.
*

* Important note on usage: See this * FAQ entry before * using. * * @see ProducerTemplate * @see ConsumerTemplate */ public interface FluentProducerTemplate extends Service { /** * Get the {@link CamelContext} * * @return camelContext the Camel context */ CamelContext getCamelContext(); // Configuration methods // ----------------------------------------------------------------------- /** * Gets the maximum cache size used in the backing cache pools. * * @return the maximum cache size */ int getMaximumCacheSize(); /** * Sets a custom maximum cache size to use in the backing cache pools. * * @param maximumCacheSize the custom maximum cache size */ void setMaximumCacheSize(int maximumCacheSize); /** * Gets an approximated size of the current cached resources in the backing cache pools. * * @return the size of current cached resources */ int getCurrentCacheSize(); /** * Get the default endpoint to use if none is specified * * @return the default endpoint instance */ Endpoint getDefaultEndpoint(); /** * Sets the default endpoint to use if none is specified * * @param defaultEndpoint the default endpoint instance */ void setDefaultEndpoint(Endpoint defaultEndpoint); /** * Sets the default endpoint uri to use if none is specified * * @param endpointUri the default endpoint uri */ void setDefaultEndpointUri(String endpointUri); /** * Sets whether the {@link org.apache.camel.spi.EventNotifier} should be used by this {@link ProducerTemplate} to * send events about the {@link Exchange} being sent. *

* By default this is enabled. * * @param enabled true to enable, false to disable. */ void setEventNotifierEnabled(boolean enabled); /** * Whether the {@link org.apache.camel.spi.EventNotifier} should be used by this {@link ProducerTemplate} to send * events about the {@link Exchange} being sent. * * @return true if enabled, false otherwise */ boolean isEventNotifierEnabled(); /** * Cleanup the cache (purging stale entries) */ void cleanUp(); // Fluent methods // ----------------------------------------------------------------------- /** * Set the headers * * Important: You can either only use either withExchange, or withProcessor or a combination of * withBody/withHeaders to construct the message to be sent. * * @param headers the headers */ FluentProducerTemplate withHeaders(Map headers); /** * Set the header * * Important: You can either only use either withExchange, or withProcessor or a combination of * withBody/withHeaders to construct the message to be sent. * * @param key the key of the header * @param value the value of the header */ FluentProducerTemplate withHeader(String key, Object value); /** * Set the message body * * Important: You can either only use either withExchange, or withProcessor or a combination of * withBody/withHeaders to construct the message to be sent. * * @param body the body */ FluentProducerTemplate withBody(Object body); /** * Set the message body after converting it to the given type * * Important: You can either only use either withExchange, or withProcessor or a combination of * withBody/withHeaders to construct the message to be sent. * * @param body the body * @param type the type which the body should be converted to */ FluentProducerTemplate withBodyAs(Object body, Class type); /** * To customize the producer template for advanced usage like to set the executor service to use. * *

     * {@code
     * FluentProducerTemplate fluent = context.createFluentProducerTemplate();
     * fluent.withTemplateCustomizer(
     *         t -> {
     *             t.setExecutorService(myExecutor);
     *             t.setMaximumCacheSize(10);
     *         }
     *      )
     *     .withBody("the body")
     *     .to("direct:start")
     *     .send()}
     * 
* * Note that it is invoked only once. * * @param templateCustomizer the customizer */ FluentProducerTemplate withTemplateCustomizer(java.util.function.Consumer templateCustomizer); /** * Set the exchange to use for send. * * When using withExchange then you must use the send method (request is not supported). * * Important: You can either only use either withExchange, or withProcessor or a combination of * withBody/withHeaders to construct the message to be sent. * * @param exchange the exchange */ FluentProducerTemplate withExchange(Exchange exchange); /** * Set the exchangeSupplier which will be invoke to get the exchange to be used for send. * * When using withExchange then you must use the send method (request is not supported). * * Important: You can either only use either withExchange, or withProcessor or a combination of * withBody/withHeaders to construct the message to be sent. * * @param exchangeSupplier the supplier */ FluentProducerTemplate withExchange(Supplier exchangeSupplier); /** * Set the processor to use for send/request. * *
     * {@code
     * FluentProducerTemplate.on(context)
     *         .withProcessor(
     *                 exchange -> {
     *                     exchange.getIn().setHeader("Key1", "Val1");
     *                     exchange.getIn().setHeader("Key2", "Val2");
     *                     exchange.getIn().setBody("the body");
     *                 })
     *         .to("direct:start")
     *         .request()
     * }
     * 
* * Important: You can either only use either withExchange, or withProcessor or a combination of * withBody/withHeaders to construct the message to be sent. * * @param processor the processor */ FluentProducerTemplate withProcessor(Processor processor); /** * Set the processorSupplier which will be invoke to get the processor to be used for send/request. * * Important: You can either only use either withExchange, or withProcessor or a combination of * withBody/withHeaders to construct the message to be sent. * * @param processorSupplier the supplier */ FluentProducerTemplate withProcessor(Supplier processorSupplier); /** * Sets the default endpoint * * @param endpointUri the endpoint URI to send to */ FluentProducerTemplate withDefaultEndpoint(String endpointUri); /** * Sets the default endpoint * * @param resolver the {@link EndpointProducerResolver} that supply the endpoint to send to. */ FluentProducerTemplate withDefaultEndpoint(EndpointProducerResolver resolver); /** * Sets the default endpoint * * @param endpoint the endpoint to send to */ FluentProducerTemplate withDefaultEndpoint(Endpoint endpoint); /** * Endpoint to send to * * @param endpointUri the endpoint URI to send to */ default FluentProducerTemplate to(String endpointUri) { final CamelContext context = ObjectHelper.notNull(getCamelContext(), "camel context"); return to(context.getEndpoint(endpointUri)); } /** * Endpoint to send to. * * @param uri the String formatted endpoint uri to send to * @param args arguments for the string formatting of the uri */ default FluentProducerTemplate toF(String uri, Object... args) { return to(String.format(uri, args)); } /** * Endpoint to send to * * @param resolver the {@link EndpointProducerResolver} that supply the endpoint to send to. */ default FluentProducerTemplate to(EndpointProducerResolver resolver) { final CamelContext context = ObjectHelper.notNull(getCamelContext(), "camel context"); final Endpoint endpoint = resolver.resolve(context); return to(endpoint); } /** * Endpoint to send to * * @param endpoint the endpoint to send to */ FluentProducerTemplate to(Endpoint endpoint); /** * Send to an endpoint (InOut) returning any result output body. * * @return the result * @throws CamelExecutionException is thrown if error occurred */ Object request() throws CamelExecutionException; /** * Send to an endpoint (InOut). * * @param type the expected response type * @return the result * @throws CamelExecutionException is thrown if error occurred */ T request(Class type) throws CamelExecutionException; /** * Sends asynchronously to the given endpoint (InOut). * * @return a handle to be used to get the response in the future */ Future asyncRequest(); /** * Sends asynchronously to the given endpoint (InOut). * * @param type the expected response type * @return a handle to be used to get the response in the future */ Future asyncRequest(Class type); /** * Send to an endpoint (InOnly) * * @throws CamelExecutionException is thrown if error occurred */ Exchange send() throws CamelExecutionException; /** * Sends asynchronously to the given endpoint (InOnly). * * @return a handle to be used to get the response in the future */ Future asyncSend(); }