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
use std::ops::Deref;
use std::rc::Rc;
use cid::{multihash, Cid};
use serde::{Deserialize, Serialize};
use super::errors::Error;
use crate::{de, from_slice, ser, to_vec};
pub const DAG_CBOR: u64 = 0x71;
pub trait Cbor: ser::Serialize + de::DeserializeOwned {
fn marshal_cbor(&self) -> Result<Vec<u8>, Error> {
to_vec(&self)
}
fn unmarshal_cbor(bz: &[u8]) -> Result<Self, Error> {
from_slice(bz)
}
fn cid(&self) -> Result<Cid, Error> {
use multihash::MultihashDigest;
const DIGEST_SIZE: u32 = 32;
let data = &self.marshal_cbor()?;
let hash = multihash::Code::Blake2b256.digest(data);
debug_assert_eq!(
u32::from(hash.size()),
DIGEST_SIZE,
"expected 32byte digest"
);
Ok(Cid::new_v1(DAG_CBOR, hash))
}
}
impl<T> Cbor for Vec<T> where T: Cbor {}
impl<T> Cbor for Option<T> where T: Cbor {}
#[derive(Clone, PartialEq, Debug, Serialize, Deserialize, Hash, Eq, Default)]
#[serde(transparent)]
pub struct RawBytes {
#[serde(with = "serde_bytes")]
bytes: Vec<u8>,
}
impl From<RawBytes> for Vec<u8> {
fn from(b: RawBytes) -> Vec<u8> {
b.bytes
}
}
impl From<Vec<u8>> for RawBytes {
fn from(v: Vec<u8>) -> RawBytes {
RawBytes::new(v)
}
}
impl From<RawBytes> for Rc<[u8]> {
fn from(b: RawBytes) -> Rc<[u8]> {
b.bytes.into()
}
}
impl Cbor for RawBytes {}
impl Deref for RawBytes {
type Target = Vec<u8>;
fn deref(&self) -> &Self::Target {
&self.bytes
}
}
impl RawBytes {
pub fn new(bytes: Vec<u8>) -> Self {
Self { bytes }
}
pub fn serialize<O: Serialize>(obj: O) -> Result<Self, Error> {
Ok(Self {
bytes: to_vec(&obj)?,
})
}
pub fn bytes(&self) -> &[u8] {
&self.bytes
}
pub fn deserialize<O: de::DeserializeOwned>(&self) -> Result<O, Error> {
from_slice(&self.bytes)
}
}