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
use futures::prelude::*;
use crate::types::{Id, DataKind};
#[derive(Debug, Clone, PartialEq)]
pub struct ServiceHandle {
pub id: Id,
}
pub type FutureResult<I, E> = Box<dyn Future<Item=I, Error=E> + Send>;
pub trait Create {
type Options;
type Error;
fn create(options: &Self::Options) -> FutureResult<ServiceHandle, Self::Error>;
}
pub trait Register {
type Error;
fn register(&mut self, s: &mut ServiceHandle) -> FutureResult<(), Self::Error>;
}
pub trait Locate {
type Error;
fn locate(&mut self, id: &Id) -> FutureResult<ServiceHandle, Self::Error>;
}
pub trait Publish {
type Error;
fn publish(&mut self, s: &ServiceHandle, kind: Option<DataKind>, data: Option<&[u8]>) -> FutureResult<(), Self::Error>;
}
pub type FutureStream<I, E> = FutureResult<Box<dyn Stream<Item=I, Error=E>>, E>;
pub trait Subscribe {
type Options;
type Data;
type Error;
fn subscribe(&mut self, service: &ServiceHandle, options: Self::Options) -> FutureStream<Self::Data, Self::Error>;
}