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

org.apache.camel.FluentProducerTemplate 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.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.
*

* 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 // ----------------------------------------------------------------------- /** * Remove the body and headers. * * @deprecated the template automatic clears when sending */ @Deprecated FluentProducerTemplate clearAll(); /** * Set the header * * @param key the key of the header * @param value the value of the header */ FluentProducerTemplate withHeader(String key, Object value); /** * Remove the headers. * * @deprecated the template automatic clears when sending */ @Deprecated FluentProducerTemplate clearHeaders(); /** * Set the message body * * @param body the body */ FluentProducerTemplate withBody(Object body); /** * Set the message body after converting it to the given type * * @param body the body * @param type the type which the body should be converted to */ FluentProducerTemplate withBodyAs(Object body, Class type); /** * Remove the body. * * @deprecated the template automatic clears when sending */ @Deprecated FluentProducerTemplate clearBody(); /** * 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). * * @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). * * @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()}
     * 
* * @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. * * @param processorSupplier the supplier */ FluentProducerTemplate withProcessor(Supplier processorSupplier); /** * 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 EndpointConsumerResolver} 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(); }