Struct rabbit_mqr::RabbitMQ

source ·
pub struct RabbitMQ {
    pub queues: HashMap<String, Queue>,
    pub connection: Connection,
}
Expand description

Simplified RabbitMQ client


Example Usage:


let mut rabbit_mq = RabbitMQ::new("amqp://guest:guest@localhost:5672/%2f", None).await?;

rabbit_mq.register_queue("test_queue", None, None).await?;

rabbit_mq.publish_message("test_queue", b"1337".to_vec(), None).await?;

if let Some(test_queue) = rabbit_mq.get_queue("test_queue") {
   while let Some(GetMessageResult {
        message,
       delivery_tag,
    }) = test_queue.get_message().await? {
    ...
}

Fields§

§queues: HashMap<String, Queue>§connection: Connection

Implementations§

source§

impl RabbitMQ

source

pub async fn new( uri: &str, options: Option<ConnectionProperties> ) -> Result<Self, Error>

Construct the RabbitMQ client.


Example Usage:


let rabbit_mq = RabbitMQ::new("amqp://guest:guest@localhost:5672/", None).await?;
source

pub async fn register_queue( &mut self, queue_name: &str, options: Option<QueueDeclareOptions>, arguments: Option<FieldTable> ) -> Result<(), Error>

Register a Queue.


Example Usage:


let mut rabbit_mq = ...;

rabbit_mq.register_queue("my_queue", None, None).await?;
source

pub fn get_queue(&self, queue_name: &str) -> Option<&Queue>

Get a &Queue.

Returns None if the Queue was not found.


Example Usage:


let mut rabbit_mq = ...;

let queue: Option<&Queue> = rabbit_mq.get_queue("my_queue").await?;
source

pub async fn publish_message( &self, queue_name: &str, message: Vec<u8>, properties: Option<BasicProperties> ) -> Result<Option<()>, Error>

Publish a message to a Queue.

Returns None if the Queue was not found.


Example Usage:


let mut rabbit_mq = ...;

let message = b"1337".to_vec();

rabbit_mq.publish_message(
    "my_queue",
    &message,
    None
).await?;
source

pub async fn publish_messages_unchecked( &self, queue_name: &str, messages: Vec<Vec<u8>>, properties: Option<BasicProperties> ) -> Option<()>

Publish a batch messages to a Queue, unchecked.

Meaning, does not handle errors, just attempts to post all messages in the list to the Queue.

Returns None if the Queue was not found.


Example Usage:


let mut rabbit_mq = ...;

let messages = vec![
    ...
];

rabbit_mq.publish_messages_unchecked(
    "my_queue",
    messages,
    None
).await;

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more