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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
//! # Rediq
//!
//! Rediq is a distributed task queue framework based on Rust and Redis.
//!
//! ## Features
//!
//! - Task creation, enqueue, delayed execution
//! - Multi-queue support, priority queues
//! - Automatic retry mechanism, dead letter queue
//! - Middleware system
//! - Prometheus monitoring
//!
//! ## Quick Start
//!
//! ```rust,no_run
//! use rediq::client::Client;
//! use rediq::processor::{Handler, Mux};
//! use rediq::server::{Server, ServerBuilder};
//! use rediq::task::TaskBuilder;
//! use async_trait::async_trait;
//! use std::time::Duration;
//!
//! # struct EmailHandler;
//! # #[async_trait]
//! # impl Handler for EmailHandler {
//! # async fn handle(&self, task: &rediq::Task) -> rediq::Result<()> {
//! # Ok(())
//! # }
//! # }
//! # async fn example() -> Result<(), Box<dyn std::error::Error>> {
//! // Client side: create and enqueue tasks
//! let client = Client::builder()
//! .redis_url("redis://localhost:6379")
//! .build()
//! .await?;
//!
//! # let email_data = serde_json::json!({"to": "user@example.com"});
//! let task = TaskBuilder::new("email:send")
//! .queue("default")
//! .payload(&email_data)?
//! .max_retry(5)
//! .build()?;
//!
//! client.enqueue(task).await?;
//!
//! // Server side: process tasks
//! let state = ServerBuilder::new()
//! .redis_url("redis://localhost:6379")
//! .queues(&["default"])
//! .build()
//! .await?;
//!
//! let server = Server::from(state);
//! let mut mux = Mux::new();
//! mux.handle("email:send", EmailHandler);
//! server.run(mux).await?;
//! # Ok(())
//! # }
//! ```
// Public module exports
// Client SDK
// Server/Worker
// Processor
// Middleware
// Storage layer
// Aggregation
// Observability
// Progress tracking
// Re-export common types
pub use ;
pub use Task;
pub use ;
// Re-export proc macros when the feature is enabled
pub use ;