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
use super::{
super::encoding::{deserialise, serialise},
Error, Key, Result, Value,
};
use crate::types::{Chunk, ChunkAddress, Keypair, PublicKey, RegisterAddress};
use serde::{de::DeserializeOwned, Serialize};
use xor_name::XorName;
pub(crate) trait ToDbKey: Serialize {
fn to_db_key(&self) -> Result<String> {
let serialised = serialise(&self)?;
Ok(hex::encode(&serialised))
}
}
pub(crate) fn from_db_key<T: DeserializeOwned>(key: &str) -> Result<T> {
let decoded = hex::decode(key).map_err(|_| Error::CouldNotDecodeDbKey(key.to_string()))?;
deserialise(&decoded)
}
impl ToDbKey for RegisterAddress {}
impl ToDbKey for Keypair {}
impl ToDbKey for ChunkAddress {}
impl ToDbKey for PublicKey {}
impl ToDbKey for XorName {}
impl Key for ChunkAddress {}
impl Value for Chunk {
type Key = ChunkAddress;
fn key(&self) -> &Self::Key {
self.address()
}
}
#[cfg(test)]
mod test {
use super::*;
use crate::node::Result;
use crate::types::PublicKey;
use bls::SecretKey;
#[test]
fn to_from_db_key() -> Result<()> {
let key = get_random_pk();
let serialised = key.to_db_key()?;
let deserialised: PublicKey = from_db_key(&serialised)?;
assert_eq!(key, deserialised);
Ok(())
}
fn get_random_pk() -> PublicKey {
PublicKey::from(SecretKey::random().public_key())
}
}