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
use fibers_rpc::server::{HandleCall, Reply, ServerBuilder};
use futures::Future;
use crate::protobuf::PutLumpRequestDecoderFactory;
use crate::registry::DeviceRegistryHandle;
use crate::rpc;
macro_rules! rpc_try {
($expr:expr) => {
match $expr {
Err(e) => return Reply::done(Err(track!(e))),
Ok(v) => v,
}
};
}
#[derive(Debug)]
pub struct Server {
registry: DeviceRegistryHandle,
}
impl Server {
pub fn new(registry: DeviceRegistryHandle) -> Self {
Server { registry }
}
pub fn register(self, builder: &mut ServerBuilder) {
let registry = self.registry.clone();
let clone = move || Server {
registry: registry.clone(),
};
builder.add_call_handler::<rpc::GetLumpRpc, _>(clone());
builder.add_call_handler::<rpc::HeadLumpRpc, _>(clone());
builder.add_call_handler_with_decoder::<rpc::PutLumpRpc, _, _>(
clone(),
PutLumpRequestDecoderFactory::new(self.registry),
);
builder.add_call_handler::<rpc::DeleteLumpRpc, _>(clone());
builder.add_call_handler::<rpc::ListLumpRpc, _>(clone());
builder.add_call_handler::<rpc::UsageRangeRpc, _>(clone());
builder.add_call_handler::<rpc::DeleteRangeRpc, _>(clone());
}
}
impl HandleCall<rpc::GetLumpRpc> for Server {
fn handle_call(&self, request: rpc::LumpRequest) -> Reply<rpc::GetLumpRpc> {
let device = rpc_try!(self.registry.get_device(&request.device_id));
let future = request.options.with(&device).get(request.lump_id).then(Ok);
Reply::future(future)
}
}
impl HandleCall<rpc::HeadLumpRpc> for Server {
fn handle_call(&self, request: rpc::LumpRequest) -> Reply<rpc::HeadLumpRpc> {
let device = rpc_try!(self.registry.get_device(&request.device_id));
let future = request.options.with(&device).head(request.lump_id).then(Ok);
Reply::future(future)
}
}
impl HandleCall<rpc::PutLumpRpc> for Server {
fn handle_call(&self, request: rpc::PutLumpRequest) -> Reply<rpc::PutLumpRpc> {
let device = rpc_try!(self.registry.get_device(&request.device_id));
let lump_data = request.lump_data;
let future = request
.options
.with(&device)
.put(request.lump_id, lump_data)
.then(Ok);
Reply::future(future)
}
}
impl HandleCall<rpc::DeleteLumpRpc> for Server {
fn handle_call(&self, request: rpc::LumpRequest) -> Reply<rpc::DeleteLumpRpc> {
let device = rpc_try!(self.registry.get_device(&request.device_id));
let future = request
.options
.with(&device)
.delete(request.lump_id)
.then(Ok);
Reply::future(future)
}
}
impl HandleCall<rpc::ListLumpRpc> for Server {
fn handle_call(&self, request: rpc::DeviceRequest) -> Reply<rpc::ListLumpRpc> {
let device = rpc_try!(self.registry.get_device(&request.device_id));
let future = request.options.with(&device).list().then(Ok);
Reply::future(future)
}
}
impl HandleCall<rpc::UsageRangeRpc> for Server {
fn handle_call(&self, request: rpc::UsageRangeRequest) -> Reply<rpc::UsageRangeRpc> {
let device = rpc_try!(self.registry.get_device(&request.device_id));
let future = request
.options
.with(&device)
.usage_range(request.range)
.then(Ok);
Reply::future(future)
}
}
impl HandleCall<rpc::DeleteRangeRpc> for Server {
fn handle_call(&self, request: rpc::RangeLumpRequest) -> Reply<rpc::DeleteRangeRpc> {
let device = rpc_try!(self.registry.get_device(&request.device_id));
let future = request
.options
.with(&device)
.delete_range(request.range)
.then(Ok);
Reply::future(future)
}
}