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
use rand_core::{OsRng, RngCore};
#[macro_use]
extern crate arrayref;
extern crate aead;
extern crate ed25519_dalek;
extern crate chacha20poly1305;
extern crate thiserror;
pub mod contents;
pub mod locked;
pub mod unlocked;
mod error;
pub mod prelude {
pub use crate::contents::{
key_pair::KeyPair,
public_key_info::{to_recoverable_signature, KeyType, PublicKeyInfo},
Content, ContentEntity,
};
pub use crate::locked::LockedWallet;
pub use crate::unlocked::UnlockedWallet;
}
pub use error::Error as Error;
pub fn get_random(bytes: usize) -> Result<Vec<u8>, Error> {
let mut value = vec![0u8; bytes];
OsRng.fill_bytes(value.as_mut_slice());
Ok(value)
}
#[cfg(test)]
mod tests {
use crate::prelude::*;
use super::error::Error;
#[test]
fn secp256k1_recoverable_round_trip() -> Result<(), Error> {
let message = "hello".as_bytes();
let mut w = UnlockedWallet::new("thing is very beautiful!");
let pk_info = w.new_key(KeyType::EcdsaSecp256k1RecoveryMethod2020, None)?;
let sig = w.sign_raw(&pk_info.id, &message)?;
assert!(
match pk_info.content {
Content::PublicKey(r_pk_inf) => r_pk_inf.verify(&message, &sig)?,
_ => false,
}
);
Ok(())
}
#[test]
fn wallet() -> Result<(), Error> {
let mut w = UnlockedWallet::new("thing is very beautiful!");
w.new_key(KeyType::EcdsaSecp256k1RecoveryMethod2020, None)?;
w.new_key(KeyType::EcdsaSecp256k1RecoveryMethod2020, None)?;
w.new_key(KeyType::EcdsaSecp256k1RecoveryMethod2020, None)?;
w.new_key(KeyType::EcdsaSecp256k1RecoveryMethod2020, None)?;
w.new_key(KeyType::EcdsaSecp256k1RecoveryMethod2020, None)?;
let pass = "My Password".to_string();
let lw = w.lock(pass.as_bytes())?;
let uw = lw.unlock(pass.as_bytes())?;
assert_eq!(5, uw.get_keys().len());
Ok(())
}
}