NAME

Crixa::Message - A Crixa Message

VERSION

version 0.11

DESCRIPTION

This class represents a single queue. With RabbitMQ, messages are published to exchanges, which then routes the message to one or more queues. You then consume those messages from the queue.

METHODS

This class provides the following methods:

$message->ack

This send an acknowledgement for the message on the channel that was used to receive the message.

$message->body

This returns the message's body. If the message does not have any content-encoding set _or_ the message contains an encoding with the string "utf-8" (case insensitive), then the message is returned as character data. Otherwise it is returned as binary data.

Property methods

There are a number of properties that can be associated with a message. This class provides reader and predicate methods for all properties of the form $message->foo and $message->has_foo. None of the properties are required.

The properties supported are:

  • content_type

  • content_encoding

  • correlation_id

  • reply_to

  • expiration

  • message_id

  • type

  • user_id

  • app_id

  • priority

  • delivery_mode

  • timestamp

  • headers

See the publish method in the Crixa::Exchange docs for more details.

$message->redelivered

A boolean indicating whether or not the message has already been delivered at least once. RabbitMQ guarantees that each message will be delivered at least once, and it is not uncommon for a message to be redelivered before the first consumer to receive it has had a chance to acknowledge it.

$message->message_count

The number of messages left in the queue at the time this message was delivered.

Note that this is only set for messages which are not received via the Crixa::Queue->consume() method.

$message->routing_key

The routing path on which the message was received.

$message->exchange

The exchange to which this message was published

$message->delivery_tag

The delivery tag for a given message. This is used when the $message->ack() method is called.

$message->consumer_tag

The tag for the consumer associated with the message, if one exists.

Note that this is only set for messages which are received via the Crixa::Queue->consume() method.

Crixa::Message->new(...)

There is no reason to call this method directly. It will be called by a Crixa::Queue object to inflate messages into objects.

AUTHORS

  • Chris Prather <chris@prather.org>

  • Dave Rolsky <autarch@urth.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2012 - 2015 by Chris Prather.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.