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
101
102
103
104
105
106
//! # Subscription client
//!
//! This crates supports subscribing to one or multiple channels. (s. [Redis Pub/Sub](https://redis.io/docs/manual/pubsub/)).
//!
//! A regular client can be turned to a [Subscription] in the following way.
//!
//! ```
//!# use core::str::FromStr;
//!# use embedded_nal::SocketAddr;
//!# use std_embedded_nal::Stack;
//!# use std_embedded_time::StandardClock;
//!# use embedded_redis::network::ConnectionHandler;
//!#
//!# let mut stack = Stack::default();
//!# let clock = StandardClock::default();
//!#
//!# let server_address = SocketAddr::from_str("127.0.0.1:6379").unwrap();
//!# let mut connection_handler = ConnectionHandler::resp3(server_address);
//! let client = connection_handler
//!                 .connect(&mut stack, Some(&clock)).unwrap()
//!                 .subscribe(["first_channel".into(), "second_channel".into()])
//!                 .unwrap();
//! ```
//!
//! If the subscriptions fails, it's recommended to close the connection, as a the
//! state is undefined. A further reuse of the connection could cause subsequent errors.
//!
//! ## Receiving messages
//!
//! Messages can be received using the `receive()` method. Which returns [Some(Message)](Message) in case a message is pending.
//!
//! ```
//!# use core::str::FromStr;
//!# use std::{thread, time};
//!# use embedded_nal::SocketAddr;
//!# use std_embedded_nal::Stack;
//!# use std_embedded_time::StandardClock;
//!# use embedded_redis::network::ConnectionHandler;
//!#
//!# thread::spawn(|| {
//!#     let mut stack = Stack::default();
//!#     let clock = StandardClock::default();
//!#
//!#     let server_address = SocketAddr::from_str("127.0.0.1:6379").unwrap();
//!#     let mut connection_handler = ConnectionHandler::resp3(server_address);
//!#     let mut  client = connection_handler.connect(&mut stack, Some(&clock)).unwrap();
//!#
//!#     loop {
//!#         client.publish("first_channel", "example payload").unwrap().wait().unwrap();
//!#         thread::sleep(time::Duration::from_millis(10));
//!#     }
//!# });
//!#
//!# let mut stack = Stack::default();
//!# let clock = StandardClock::default();
//!#
//!# let server_address = SocketAddr::from_str("127.0.0.1:6379").unwrap();
//!# let mut connection_handler = ConnectionHandler::resp3(server_address);
//!# let mut  client = connection_handler
//!#                 .connect(&mut stack, Some(&clock)).unwrap()
//!#                 .subscribe(["first_channel".into(), "second_channel".into()])
//!#                 .unwrap();
//!#
//! loop {
//!     let message = client.receive().unwrap();
//!
//!     if let Some(message) = message {
//!         assert_eq!("first_channel", core::str::from_utf8(&message.channel[..]).unwrap());
//!         assert_eq!("example payload", core::str::from_utf8(&message.payload[..]).unwrap());
//!         break;
//!     }
//! }
//! ```
//!
//! ## Unsubscribing
//!
//! To leave a clean connection state, unsubscribe from all channels at the end.
//!
//! ```
//!# use core::str::FromStr;
//!# use embedded_nal::SocketAddr;
//!# use std_embedded_nal::Stack;
//!# use std_embedded_time::StandardClock;
//!# use embedded_redis::network::ConnectionHandler;
//!#
//!# let mut stack = Stack::default();
//!# let clock = StandardClock::default();
//!#
//!# let server_address = SocketAddr::from_str("127.0.0.1:6379").unwrap();
//!# let mut connection_handler = ConnectionHandler::resp3(server_address);
//!# let client = connection_handler
//!#                 .connect(&mut stack, Some(&clock)).unwrap()
//!#                 .subscribe(["first_channel".into(), "second_channel".into()])
//!#                 .unwrap();
//!#
//! client.unsubscribe().unwrap();
//! ```
//!
//! *Note: `unsubscribe()` is called automatically when the client is dropped*
pub use client::{Error, Message, Subscription};

pub(crate) mod client;
pub(crate) mod messages;

#[cfg(test)]
mod tests;