#ifndef QPID_MESSAGING_MESSAGE_H #define QPID_MESSAGING_MESSAGE_H /* * * 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. * */ #include "qpid/messaging/ImportExport.h" #include "qpid/messaging/Duration.h" #include "qpid/types/Exception.h" #include "qpid/types/Variant.h" #include namespace qpid { namespace messaging { class Address; class Codec; struct MessageImpl; /** \ingroup messaging * Representation of a message. */ class QPID_MESSAGING_CLASS_EXTERN Message { public: QPID_MESSAGING_EXTERN Message(const std::string& bytes = std::string()); QPID_MESSAGING_EXTERN Message(const char*, size_t); QPID_MESSAGING_EXTERN Message(const Message&); QPID_MESSAGING_EXTERN ~Message(); QPID_MESSAGING_EXTERN Message& operator=(const Message&); QPID_MESSAGING_EXTERN void setReplyTo(const Address&); QPID_MESSAGING_EXTERN const Address& getReplyTo() const; QPID_MESSAGING_EXTERN void setSubject(const std::string&); QPID_MESSAGING_EXTERN const std::string& getSubject() const; /** * Set the content type (i.e. the MIME type) for the message. This * should be set by the sending application and indicates to * recipients of message how to interpret or decode the content. */ QPID_MESSAGING_EXTERN void setContentType(const std::string&); /** * Returns the content type (i.e. the MIME type) for the * message. This can be used to determine how to decode the * message content. */ QPID_MESSAGING_EXTERN const std::string& getContentType() const; /** * Set an application defined identifier for the message. At * present this must be a stringfied UUID (support for less * restrictive IDs is anticipated however). */ QPID_MESSAGING_EXTERN void setMessageId(const std::string&); QPID_MESSAGING_EXTERN const std::string& getMessageId() const; /** * Sets the user id of the message. This should in general be the * user-id as which the sending connection authenticated itself as * the messaging infrastructure will verify this. See * Connection::getAuthenticatedUsername() */ QPID_MESSAGING_EXTERN void setUserId(const std::string&); QPID_MESSAGING_EXTERN const std::string& getUserId() const; /** * Can be used to set application specific correlation identifiers * as part of a protocol for message exchange patterns. E.g. a * request-reponse pattern might require the correlation-id of the * request and response to match, or might use the message-id of * the request as the correlation-id on the response etc. */ QPID_MESSAGING_EXTERN void setCorrelationId(const std::string&); QPID_MESSAGING_EXTERN const std::string& getCorrelationId() const; /** * Sets a priority level on the message. This may be used by the * messaging infrastructure to prioritise delivery of higher * priority messages. */ QPID_MESSAGING_EXTERN void setPriority(uint8_t); QPID_MESSAGING_EXTERN uint8_t getPriority() const; /** * Set the time to live for this message in milliseconds. This can * be used by the messaging infrastructure to discard messages * that are no longer of relevance. */ QPID_MESSAGING_EXTERN void setTtl(Duration ttl); /** *Get the time to live for this message in milliseconds. */ QPID_MESSAGING_EXTERN Duration getTtl() const; /** * Mark the message as durable. This is a hint to the messaging * infrastructure that the message should be persisted or * otherwise stored such that failoures or shutdown do not cause * it to be lost. */ QPID_MESSAGING_EXTERN void setDurable(bool durable); QPID_MESSAGING_EXTERN bool getDurable() const; /** * The redelivered flag if set implies that the message *may* have * been previously delivered and thus is a hint to the application * or messaging infrastructure that if de-duplication is required * this message should be examined to determine if it is a * duplicate. */ QPID_MESSAGING_EXTERN bool getRedelivered() const; /** * Can be used to provide a hint to the application or messaging * infrastructure that if de-duplication is required this message * should be examined to determine if it is a duplicate. */ QPID_MESSAGING_EXTERN void setRedelivered(bool); /** * In addition to a payload (i.e. the content), messages can * include annotations describing aspectf of the message. In * addition to the standard annotations such as TTL and content * type, application- or context- specific properties can also be * defined. Each message has a map of name values for such custom * properties. The value is specified as a Variant. */ QPID_MESSAGING_EXTERN const qpid::types::Variant::Map& getProperties() const; QPID_MESSAGING_EXTERN qpid::types::Variant::Map& getProperties(); /** * Set the content to the data held in the string parameter. Note: * this is treated as raw bytes and need not be text. Consider * setting the content-type to indicate how the data should be * interpreted by recipients. */ QPID_MESSAGING_EXTERN void setContent(const std::string&); /** * Copy count bytes from the region pointed to by chars as the * message content. */ QPID_MESSAGING_EXTERN void setContent(const char* chars, size_t count); /** Get the content as a std::string */ QPID_MESSAGING_EXTERN std::string getContent() const; /** * Get a const pointer to the start of the content data. The * memory pointed to is owned by the message. The getContentSize() * method indicates how much data there is (i.e. the extent of the * memory region pointed to by the return value of this method). */ QPID_MESSAGING_EXTERN const char* getContentPtr() const; /** Get the size of content in bytes. */ QPID_MESSAGING_EXTERN size_t getContentSize() const; QPID_MESSAGING_EXTERN void setProperty(const std::string&, const qpid::types::Variant&); private: MessageImpl* impl; friend struct MessageImplAccess; }; struct QPID_MESSAGING_CLASS_EXTERN EncodingException : qpid::types::Exception { QPID_MESSAGING_EXTERN EncodingException(const std::string& msg); }; /** * Decodes message content into a Variant::Map. * * @param message the message whose content should be decoded * @param map the map into which the message contents will be decoded * @param encoding if specified, the encoding to use - this overrides * any encoding specified by the content-type of the message * @exception EncodingException */ QPID_MESSAGING_EXTERN void decode(const Message& message, qpid::types::Variant::Map& map, const std::string& encoding = std::string()); /** * Decodes message content into a Variant::List. * * @param message the message whose content should be decoded * @param list the list into which the message contents will be decoded * @param encoding if specified, the encoding to use - this overrides * any encoding specified by the content-type of the message * @exception EncodingException */ QPID_MESSAGING_EXTERN void decode(const Message& message, qpid::types::Variant::List& list, const std::string& encoding = std::string()); /** * Encodes a Variant::Map into a message. * * @param map the map to be encoded * @param message the message whose content should be set to the encoded map * @param encoding if specified, the encoding to use - this overrides * any encoding specified by the content-type of the message * @exception EncodingException */ QPID_MESSAGING_EXTERN void encode(const qpid::types::Variant::Map& map, Message& message, const std::string& encoding = std::string()); /** * Encodes a Variant::List into a message. * * @param list the list to be encoded * @param message the message whose content should be set to the encoded list * @param encoding if specified, the encoding to use - this overrides * any encoding specified by the content-type of the message * @exception EncodingException */ QPID_MESSAGING_EXTERN void encode(const qpid::types::Variant::List& list, Message& message, const std::string& encoding = std::string()); }} // namespace qpid::messaging #endif /*!QPID_MESSAGING_MESSAGE_H*/