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
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
use core::future::Future;
use std::{collections::HashMap, pin::Pin, sync::Arc};
use crate::stream_protocol::Generator;
pub type Response<T> = Pin<Box<dyn Future<Output = T> + Send>>;
pub type CommonPayload = Vec<u8>;
pub type UnaryResponse = Response<Vec<u8>>;
pub type UnaryRequestHandler<Context> =
dyn Fn(CommonPayload, Arc<Context>) -> UnaryResponse + Send + Sync;
pub type ServerStreamsResponse = Response<Generator<Vec<u8>>>;
pub type ServerStreamsRequestHandler<Context> =
dyn Fn(CommonPayload, Arc<Context>) -> ServerStreamsResponse + Send + Sync;
pub type ClientStreamsPayload = Generator<Vec<u8>>;
pub type ClientStreamsResponse = Response<Vec<u8>>;
pub type ClientStreamsRequestHandler<Context> =
dyn Fn(ClientStreamsPayload, Arc<Context>) -> ClientStreamsResponse + Send + Sync;
pub type BiStreamsPayload = Generator<Vec<u8>>;
pub type BiStreamsResponse = Response<Generator<Vec<u8>>>;
pub type BiStreamsRequestHandler<Context> =
dyn Fn(BiStreamsPayload, Arc<Context>) -> BiStreamsResponse + Send + Sync;
pub enum Definition<Context> {
Unary(Arc<UnaryRequestHandler<Context>>),
ServerStreams(Arc<ServerStreamsRequestHandler<Context>>),
ClientStreams(Arc<ClientStreamsRequestHandler<Context>>),
BiStreams(Arc<BiStreamsRequestHandler<Context>>),
}
pub struct ServiceModuleDefinition<Context> {
definitions: HashMap<String, Definition<Context>>,
}
impl<Context> ServiceModuleDefinition<Context> {
pub fn new() -> Self {
Self {
definitions: HashMap::new(),
}
}
pub fn add_unary<
H: Fn(CommonPayload, Arc<Context>) -> UnaryResponse + Send + Sync + 'static,
>(
&mut self,
name: &str,
handler: H,
) {
self.add_definition(name, Definition::Unary(Arc::new(handler)));
}
pub fn add_server_streams<
H: Fn(CommonPayload, Arc<Context>) -> ServerStreamsResponse + Send + Sync + 'static,
>(
&mut self,
name: &str,
handler: H,
) {
self.add_definition(name, Definition::ServerStreams(Arc::new(handler)));
}
pub fn add_client_streams<
H: Fn(ClientStreamsPayload, Arc<Context>) -> ClientStreamsResponse + Send + Sync + 'static,
>(
&mut self,
name: &str,
handler: H,
) {
self.add_definition(name, Definition::ClientStreams(Arc::new(handler)));
}
pub fn add_bidir_streams<
H: Fn(BiStreamsPayload, Arc<Context>) -> BiStreamsResponse + Send + Sync + 'static,
>(
&mut self,
name: &str,
handler: H,
) {
self.add_definition(name, Definition::BiStreams(Arc::new(handler)));
}
fn add_definition(&mut self, name: &str, definition: Definition<Context>) {
self.definitions.insert(name.to_string(), definition);
}
pub fn get_definitions(&self) -> &HashMap<String, Definition<Context>> {
&self.definitions
}
}
impl<Context> Default for ServiceModuleDefinition<Context> {
fn default() -> Self {
Self::new()
}
}