1 #ifndef PROTON_MESSAGE_H
2 #define PROTON_MESSAGE_H 1
25 #include <proton/import_export.h>
29 #include <proton/type_compat.h>
56 #define PN_DEFAULT_PRIORITY (4)
AMQP data encoding and decoding.
int64_t pn_timestamp_t
A 64-bit timestamp in milliseconds since the Unix epoch.
Definition: types.h:170
uint32_t pn_sequence_t
A sequence number.
Definition: types.h:142
uint32_t pn_millis_t
A span of time in milliseconds.
Definition: types.h:149
A discriminated union that holds any scalar AMQP value.
Definition: codec.h:200
A const byte buffer.
Definition: types.h:216
A non-const byte buffer.
Definition: types.h:235
struct pn_data_t pn_data_t
An AMQP Data object.
Definition: codec.h:375
struct pn_error_t pn_error_t
An int error code and some string text to describe the error.
Definition: error.h:44
struct pn_link_t pn_link_t
An AMQP Link object.
Definition: types.h:315
int pn_message_data(pn_message_t *msg, pn_data_t *data)
Save message content into a pn_data_t object data.
pn_data_t * pn_message_instructions(pn_message_t *msg)
Get/set the delivery instructions for a message.
int pn_message_set_id(pn_message_t *msg, pn_msgid_t id)
Set the id for a message.
int pn_message_set_group_id(pn_message_t *msg, const char *group_id)
Set the group_id for a message.
pn_data_t * pn_message_body(pn_message_t *msg)
Get and set the body of a message.
int pn_message_set_delivery_count(pn_message_t *msg, uint32_t count)
Set the delivery count for a message.
int pn_message_encode(pn_message_t *msg, char *bytes, size_t *size)
Encode a message as AMQP formatted binary data.
const char * pn_message_get_content_type(pn_message_t *msg)
Get the content_type for a message.
pn_data_t * pn_message_id(pn_message_t *msg)
Get/set the id for a message.
pn_millis_t pn_message_get_ttl(pn_message_t *msg)
Get the ttl for a message.
int pn_message_set_group_sequence(pn_message_t *msg, pn_sequence_t n)
Set the group sequence for a message.
pn_msgid_t pn_message_get_id(pn_message_t *msg)
Get the id for a message.
int pn_message_set_reply_to_group_id(pn_message_t *msg, const char *reply_to_group_id)
Set the reply_to_group_id for a message.
int pn_message_set_address(pn_message_t *msg, const char *address)
Set the address for a message.
pn_data_t * pn_message_properties(pn_message_t *msg)
Get and set the properties for a message.
pn_timestamp_t pn_message_get_creation_time(pn_message_t *msg)
Get the creation time for a message.
pn_sequence_t pn_message_get_group_sequence(pn_message_t *msg)
Get the group sequence for a message.
const char * pn_message_get_group_id(pn_message_t *msg)
Get the group_id for a message.
const char * pn_message_get_reply_to(pn_message_t *msg)
Get the reply_to for a message.
bool pn_message_is_inferred(pn_message_t *msg)
Get the inferred flag for a message.
uint8_t pn_message_get_priority(pn_message_t *msg)
Get the priority for a message.
int pn_message_set_user_id(pn_message_t *msg, pn_bytes_t user_id)
Set the user id for a message.
int pn_message_set_priority(pn_message_t *msg, uint8_t priority)
Set the priority for a message.
int pn_message_set_inferred(pn_message_t *msg, bool inferred)
Set the inferred flag for a message.
int pn_message_set_durable(pn_message_t *msg, bool durable)
Set the durable flag for a message.
int pn_message_set_first_acquirer(pn_message_t *msg, bool first)
Set the first acquirer flag for a message.
void pn_message_free(pn_message_t *msg)
Free a previously constructed pn_message_t.
int pn_message_set_expiry_time(pn_message_t *msg, pn_timestamp_t time)
Set the expiry time for a message.
const char * pn_message_get_reply_to_group_id(pn_message_t *msg)
Get the reply_to_group_id for a message.
ssize_t pn_message_send(pn_message_t *msg, pn_link_t *sender, pn_rwbytes_t *buf)
Unsettled API
pn_msgid_t pn_message_get_correlation_id(pn_message_t *msg)
Get the correlation id for a message.
pn_timestamp_t pn_message_get_expiry_time(pn_message_t *msg)
Get the expiry time for a message.
void pn_message_clear(pn_message_t *msg)
Clears the content of a pn_message_t.
pn_bytes_t pn_message_get_user_id(pn_message_t *msg)
Get the user id for a message.
pn_error_t * pn_message_error(pn_message_t *msg)
Access the error information for a message.
int pn_message_set_content_type(pn_message_t *msg, const char *type)
Set the content_type for a message.
const char * pn_message_get_address(pn_message_t *msg)
Get the address for a message.
int pn_message_set_subject(pn_message_t *msg, const char *subject)
Set the subject for a message.
int pn_message_set_reply_to(pn_message_t *msg, const char *reply_to)
Set the reply_to for a message.
ssize_t pn_message_encode2(pn_message_t *msg, pn_rwbytes_t *buf)
Unsettled API: Encode a message, allocating space if necessary
pn_message_t * pn_message(void)
Construct a new pn_message_t.
int pn_message_decode(pn_message_t *msg, const char *bytes, size_t size)
Decode/load message content from AMQP formatted binary data.
int pn_message_set_creation_time(pn_message_t *msg, pn_timestamp_t time)
Set the creation time for a message.
int pn_message_errno(pn_message_t *msg)
Access the error code of a message.
bool pn_message_is_first_acquirer(pn_message_t *msg)
Get the first acquirer flag for a message.
const char * pn_message_get_content_encoding(pn_message_t *msg)
Get the content_encoding for a message.
pn_data_t * pn_message_correlation_id(pn_message_t *msg)
Get/set the correlation id for a message.
int pn_message_set_correlation_id(pn_message_t *msg, pn_msgid_t id)
Set the correlation id for a message.
uint32_t pn_message_get_delivery_count(pn_message_t *msg)
Get the delivery count for a message.
struct pn_message_t pn_message_t
An AMQP Message object.
Definition: message.h:51
pn_data_t * pn_message_annotations(pn_message_t *msg)
Get/set the annotations for a message.
const char * pn_message_get_subject(pn_message_t *msg)
Get the subject for a message.
int pn_message_set_ttl(pn_message_t *msg, pn_millis_t ttl)
Set the ttl for a message.
bool pn_message_is_durable(pn_message_t *msg)
Get the durable flag for a message.
int pn_message_set_content_encoding(pn_message_t *msg, const char *encoding)
Set the content_encoding for a message.