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
use super::*;
use tox_binary_io::*;
use tox_crypto::*;
use nom::combinator::rest;
#[derive(Debug, PartialEq, Clone)]
pub struct OobReceive {
pub sender_pk: PublicKey,
pub data: Vec<u8>
}
impl FromBytes for OobReceive {
named!(from_bytes<OobReceive>, do_parse!(
tag!("\x07") >>
sender_pk: call!(PublicKey::from_bytes) >>
data: rest >>
(OobReceive { sender_pk, data: data.to_vec() })
));
}
impl ToBytes for OobReceive {
fn to_bytes<'a>(&self, buf: (&'a mut [u8], usize)) -> Result<(&'a mut [u8], usize), GenError> {
do_gen!(buf,
gen_be_u8!(0x07) >>
gen_slice!(self.sender_pk.as_ref()) >>
gen_slice!(self.data.as_slice())
)
}
}
#[cfg(test)]
mod test {
use super::*;
encode_decode_test!(
tox_crypto::crypto_init().unwrap(),
oob_receive_encode_decode,
OobReceive {
sender_pk: gen_keypair().0,
data: vec![42; 123]
}
);
}