1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
//! # Message queue
//!
//! The `mq` module provides an abstraction for representing a message queue that supports pushing and consuming messages. It defines the MessageQueue trait, which can be implemented by different types of message queues.

use futures::Future;

use crate::{request::Request, Backend};

/// Represents a message queue that can be pushed and consumed.
pub trait MessageQueue<Message>: Backend<Request<Message>> {
    /// The error produced by the queue
    type Error;

    /// Enqueues a message to the queue.
    fn enqueue(&self, message: Message) -> impl Future<Output = Result<(), Self::Error>> + Send;

    /// Attempts to dequeue a message from the queue.
    /// Returns `None` if the queue is empty.
    fn dequeue(&self) -> impl Future<Output = Result<Option<Message>, Self::Error>> + Send;

    /// Returns the current size of the queue.
    fn size(&self) -> impl Future<Output = Result<usize, Self::Error>> + Send;
}

/// Trait representing a job.
///
///
/// # Example
/// ```rust
/// # use apalis_core::mq::Message;
/// # struct Email;
/// impl Message for Email {
///     const NAME: &'static str = "redis::Email";
/// }
/// ```
pub trait Message {
    /// Represents the name for job.
    const NAME: &'static str;
}