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

org.apache.camel.Message 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 java.util.function.Supplier;

import org.apache.camel.spi.HeadersMapFactory;
import org.apache.camel.trait.message.MessageTrait;

/**
 * Implements the Message pattern and represents an inbound or
 * outbound message as part of an {@link Exchange}.
 * 

* Headers are represented in Camel using a {@link org.apache.camel.util.CaseInsensitiveMap CaseInsensitiveMap}. The * implementation of the map can be configured by the {@link HeadersMapFactory} which can be set on the * {@link CamelContext}. The default implementation uses the {@link org.apache.camel.util.CaseInsensitiveMap * CaseInsensitiveMap}. */ public interface Message { /** * Clears the message from user data, so the message can be reused. *

* Important: This API is NOT intended for Camel end users, but used internally by Camel itself. */ void reset(); /** * Returns the id of the message. *

* By default, the message uses the same id as {@link Exchange#getExchangeId()} as messages are associated with the * exchange and using different IDs does not offer much value. Another reason is to optimize for performance to * avoid generating new IDs. *

* A few Camel components do provide their own message IDs such as the JMS components. * * @return the message id */ String getMessageId(); /** * Returns the timestamp that this messages originates from. *

* Some systems like JMS, Kafka, AWS have a timestamp on the event/message, that Camel received. This method returns * the timestamp, if a timestamp exists. *

* The message timestamp and exchange created are not the same. An exchange always have a created timestamp which is * the local timestamp when Camel created the exchange. The message timestamp is only available in some Camel * components when the consumer is able to extract the timestamp from the source event. * * @return the timestamp, or 0 if the message has no source timestamp. * @see Exchange#getClock() */ long getMessageTimestamp(); /** * Sets the id of the message * * @param messageId id of the message */ void setMessageId(String messageId); /** * Whether the message has any message ID assigned. */ boolean hasMessageId(); /** * Returns the exchange this message is related to * * @return the exchange */ Exchange getExchange(); /** * Accesses a specific header * * @param name name of header * @return the value of the given header or null if there is no header for the given name */ Object getHeader(String name); /** * Accesses a specific header * * @param name name of header * @param defaultValue the default value to return if header was absent * @return the value of the given header or defaultValue if there is no header for the given * name */ Object getHeader(String name, Object defaultValue); /** * Accesses a specific header * * @param name name of header * @param defaultValueSupplier the default value supplier used to generate the value to return if header was absent * @return the value of the given header or the value generated by the * defaultValueSupplier if there is no header for the given name */ Object getHeader(String name, Supplier defaultValueSupplier); /** * Returns a header associated with this message by name and specifying the type required * * @param name the name of the header * @param type the type of the header * @return the value of the given header or null if there is no header for the * given name * @throws TypeConversionException is thrown if error during type conversion */ T getHeader(String name, Class type); /** * Returns a header associated with this message by name and specifying the type required * * @param name the name of the header * @param defaultValue the default value to return if header was absent * @param type the type of the header * @return the value of the given header or defaultValue if there is no header for the given * name or null if it cannot be converted to the given type */ T getHeader(String name, Object defaultValue, Class type); /** * Returns a header associated with this message by name and specifying the type required * * @param name the name of the header * @param defaultValueSupplier the default value supplier used to generate the value to return if header was absent * @param type the type of the header * @return the value of the given header or the value generated by the * defaultValueSupplier if there is no header for the given name or * null if it cannot be converted to the given type */ T getHeader(String name, Supplier defaultValueSupplier, Class type); /** * Sets a header on the message * * @param name of the header * @param value to associate with the name */ void setHeader(String name, Object value); /** * Removes the named header from this message * * @param name name of the header * @return the old value of the header */ Object removeHeader(String name); /** * Removes the headers from this message * * @param pattern pattern of names * @return boolean whether any headers matched */ boolean removeHeaders(String pattern); /** * Removes the headers from this message that match the given pattern, except for the ones matching one or * more excludePatterns * * @param pattern pattern of names that should be removed * @param excludePatterns one or more pattern of header names that should be excluded (= preserved) * @return boolean whether any headers matched */ boolean removeHeaders(String pattern, String... excludePatterns); /** * Returns all the headers associated with the message. *

* Headers are represented in Camel using a {@link org.apache.camel.util.CaseInsensitiveMap CaseInsensitiveMap}. The * implementation of the map can be configured by the {@link HeadersMapFactory} which can be set on the * {@link CamelContext}. The default implementation uses the {@link org.apache.camel.util.CaseInsensitiveMap * CaseInsensitiveMap}. *

* Important: If you want to walk the returned {@link Map} and fetch all the keys and values, you should use * the {@link java.util.Map#entrySet()} method, which ensure you get the keys in the original case. * * @return all the headers in a Map */ Map getHeaders(); /** * Set all the headers associated with this message *

* Important: If you want to copy headers from another {@link Message} to this {@link Message}, then use * getHeaders().putAll(other) to copy the headers, where other is the other headers. * * @param headers headers to set */ void setHeaders(Map headers); /** * Returns whether any headers have been set. * * @return true if any headers has been set */ boolean hasHeaders(); /** * Returns the body of the message as a POJO *

* The body can be null if body has not been set. *

* Notice if the message body is stream based then calling this method multiple times may lead to the stream not * being able to be re-read again. You can enable stream caching and call the {@link StreamCache#reset()} method to * reset the stream to be able to re-read again (if possible). See more details about * stream caching. * * @return the body, can be null */ Object getBody(); /** * Returns the body of the message as a POJO *

* Notice if the message body is stream based then calling this method multiple times may lead to the stream not * being able to be re-read again. See more details about * stream caching. * * @return the body, is never null * @throws InvalidPayloadException Is thrown if the body being null or wrong class type */ Object getMandatoryBody() throws InvalidPayloadException; /** * Returns the body as the specified type *

* Notice if the message body is stream based then calling this method multiple times may lead to the stream not * being able to be re-read again. You can enable stream caching and call the {@link StreamCache#reset()} method to * reset the stream to be able to re-read again (if possible). See more details about * stream caching. *

* The helper method {@link org.apache.camel.support.ExchangeHelper#getBodyAndResetStreamCache(Exchange, Class)} can * be used instead that gets the body, convert to the given type, and ensures to reset the body if its stream based. * * @param type the type that the body * @return the body of the message as the specified type, or null if body does not * exist * @throws TypeConversionException is thrown if error during type conversion * @see org.apache.camel.support.ExchangeHelper#getBodyAndResetStreamCache(Exchange, * Class) */ T getBody(Class type); /** * Returns the mandatory body as the specified type *

* Notice if the message body is stream based then calling this method multiple times may lead to the stream not * being able to be re-read again. You can enable stream caching and call the {@link StreamCache#reset()} method to * reset the stream to be able to re-read again (if possible). See more details about * stream caching. *

* The helper method {@link org.apache.camel.support.ExchangeHelper#getBodyAndResetStreamCache(Exchange, Class)} can * be used instead that gets the body, convert to the given type, and ensures to reset the body if its stream based. * * @param type the type that the body * @return the body of the message as the specified type, is never null. * @throws InvalidPayloadException Is thrown if the body being null or wrong class type * @see org.apache.camel.support.ExchangeHelper#getBodyAndResetStreamCache(Exchange, * Class) */ T getMandatoryBody(Class type) throws InvalidPayloadException; /** * Sets the body of the message * * @param body the body */ void setBody(Object body); /** * Sets the body of the message as a specific type * * @param body the body * @param type the type of the body */ void setBody(Object body, Class type); /** * Creates a copy of this message so that it can be used and possibly modified further in another exchange. *

* The returned {@link Message} copy will have its {@link Exchange} set to the same {@link Exchange} instance as * from the source. * * @return a new message instance copied from this message */ Message copy(); /** * Copies the contents of the other message into this message *

* If you need to do a copy and then set a new body, then use {@link #copyFromWithNewBody(Message, Object)} method * instead. *

* The returned {@link Message} copy will have its {@link Exchange} set to the same {@link Exchange} instance as * from the source. * * @param message the other message * @see #copyFromWithNewBody(Message, Object) */ void copyFrom(Message message); /** * Copies the contents (except the body) of the other message into this message and uses the provided new body * instead *

* The returned {@link Message} copy will have its {@link Exchange} set to the same {@link Exchange} instance as * from the source. * * @param message the other message * @param newBody the new body to use */ void copyFromWithNewBody(Message message, Object newBody); /** * Checks whether the message has a given {@link MessageTrait} * * @param trait the {@link MessageTrait} to check * @return true if the message instance has the trait or false otherwise */ boolean hasTrait(MessageTrait trait); /** * Gets the payload for the {@link MessageTrait} * * @param trait the {@link MessageTrait} to obtain the payload * @return The trait payload or null if not available */ Object getPayloadForTrait(MessageTrait trait); /** * Sets the payload for the {@link MessageTrait} * * @param trait the {@link MessageTrait} to set the payload * @param object the payload */ void setPayloadForTrait(MessageTrait trait, Object object); }