forked from zslayton/stomp-rs
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathsubscription_builder.rs
68 lines (61 loc) · 2.07 KB
/
subscription_builder.rs
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
use crate::frame::Frame;
use crate::header::HeaderList;
use crate::option_setter::OptionSetter;
use crate::session::{OutstandingReceipt, ReceiptRequest, Session};
use crate::subscription::{AckMode, Subscription};
pub struct SubscriptionBuilder<'a> {
pub session: &'a mut Session,
pub destination: String,
pub ack_mode: AckMode,
pub headers: HeaderList,
pub receipt_request: Option<ReceiptRequest>,
}
impl<'a> SubscriptionBuilder<'a> {
pub fn new(session: &'a mut Session, destination: String) -> Self {
SubscriptionBuilder {
session: session,
destination: destination,
ack_mode: AckMode::Auto,
headers: HeaderList::new(),
receipt_request: None,
}
}
#[allow(dead_code)]
pub fn start(mut self) -> String {
let next_id = self.session.generate_subscription_id();
let subscription = Subscription::new(
next_id,
&self.destination,
self.ack_mode,
self.headers.clone(),
);
let mut subscribe_frame =
Frame::subscribe(&subscription.id, &self.destination, self.ack_mode);
subscribe_frame.headers.concat(&mut self.headers);
self.session.send_frame(subscribe_frame.clone());
debug!(
"Registering callback for subscription id '{}' from builder",
subscription.id
);
let id_to_return = subscription.id.to_string();
self.session
.state
.subscriptions
.insert(subscription.id.to_string(), subscription);
if self.receipt_request.is_some() {
let request = self.receipt_request.unwrap();
self.session
.state
.outstanding_receipts
.insert(request.id, OutstandingReceipt::new(subscribe_frame.clone()));
}
id_to_return
}
#[allow(dead_code)]
pub fn with<T>(self, option_setter: T) -> SubscriptionBuilder<'a>
where
T: OptionSetter<SubscriptionBuilder<'a>>,
{
option_setter.set_option(self)
}
}