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
use super::Error;
use keystore::{CryptoType, KeyFile, decode_str};
use rustc_serialize::{Decodable, Decoder, Encodable, Encoder};
#[derive(Clone, Debug, Eq, PartialEq)]
pub struct HdwalletCrypto {
pub cipher: String,
pub hardware: String,
pub hd_path: String,
}
impl Default for HdwalletCrypto {
fn default() -> HdwalletCrypto {
HdwalletCrypto {
cipher: String::new(),
hardware: String::new(),
hd_path: String::new(),
}
}
}
impl HdwalletCrypto {
pub fn try_from(kf: KeyFile) -> Result<Self, Error> {
match kf.crypto {
CryptoType::HdWallet(ref hd) => {
Ok(Self {
cipher: hd.cipher.clone(),
hardware: hd.hardware.clone(),
hd_path: hd.hd_path.clone(),
})
}
_ => Err(Error::HDWalletError("HD wallet".to_string())),
}
}
}
impl Into<KeyFile> for HdwalletCrypto {
fn into(self) -> KeyFile {
KeyFile {
crypto: CryptoType::HdWallet(self),
..Default::default()
}
}
}
impl Decodable for HdwalletCrypto {
fn decode<D: Decoder>(d: &mut D) -> Result<Self, D::Error> {
d.read_struct("Crypto", 3, |d| {
let cipher = d.read_struct_field("cipher", 0, |d| decode_str(d))?;
let hardware = d.read_struct_field("hardware", 1, |d| decode_str(d))?;
let hd_path = d.read_struct_field("hd_path", 2, |d| decode_str(d))?;
Ok(Self {
cipher: cipher,
hardware: hardware,
hd_path: hd_path,
})
})
}
}
impl Encodable for HdwalletCrypto {
fn encode<S: Encoder>(&self, s: &mut S) -> Result<(), S::Error> {
s.emit_struct("Crypto", 3, |s| {
s.emit_struct_field(
"cipher",
0,
|s| s.emit_str(&self.cipher.to_string()),
)?;
s.emit_struct_field(
"hardware",
1,
|s| self.hardware.encode(s),
)?;
s.emit_struct_field(
"hd_path",
2,
|s| self.hd_path.encode(s),
)?;
Ok(())
})
}
}