mirror of
https://github.com/Qortal/piratewallet-light-cli.git
synced 2025-08-01 12:51:28 +00:00
Add lightclient encryption test
This commit is contained in:
@@ -196,8 +196,10 @@ impl Command for ExportCommand {
|
|||||||
}
|
}
|
||||||
|
|
||||||
let address = if args.is_empty() { None } else { Some(args[0].to_string()) };
|
let address = if args.is_empty() { None } else { Some(args[0].to_string()) };
|
||||||
|
match lightclient.do_export(address) {
|
||||||
format!("{}", lightclient.do_export(address).pretty(2))
|
Ok(j) => j,
|
||||||
|
Err(e) => object!{ "error" => e }
|
||||||
|
}.pretty(2)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -462,7 +464,10 @@ impl Command for SeedCommand {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fn exec(&self, _args: &[&str], lightclient: &LightClient) -> String {
|
fn exec(&self, _args: &[&str], lightclient: &LightClient) -> String {
|
||||||
format!("{}", lightclient.do_seed_phrase().pretty(2))
|
match lightclient.do_seed_phrase() {
|
||||||
|
Ok(j) => j,
|
||||||
|
Err(e) => object!{ "error" => e }
|
||||||
|
}.pretty(2)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -537,7 +542,10 @@ impl Command for NewAddressCommand {
|
|||||||
return format!("No address type specified\n{}", self.help());
|
return format!("No address type specified\n{}", self.help());
|
||||||
}
|
}
|
||||||
|
|
||||||
format!("{}", lightclient.do_new_address(args[0]).pretty(2))
|
match lightclient.do_new_address(args[0]) {
|
||||||
|
Ok(j) => j,
|
||||||
|
Err(e) => object!{ "error" => e }
|
||||||
|
}.pretty(2)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -224,6 +224,26 @@ impl LightClient {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Method to create a test-only version of the LightClient
|
||||||
|
#[allow(dead_code)]
|
||||||
|
fn unconnected(seed_phrase: String) -> io::Result<Self> {
|
||||||
|
let config = LightClientConfig::create_unconnected("test".to_string());
|
||||||
|
let mut l = LightClient {
|
||||||
|
wallet : Arc::new(RwLock::new(LightWallet::new(Some(seed_phrase), &config, 0)?)),
|
||||||
|
config : config.clone(),
|
||||||
|
sapling_output : vec![],
|
||||||
|
sapling_spend : vec![]
|
||||||
|
};
|
||||||
|
|
||||||
|
l.set_wallet_initial_state();
|
||||||
|
l.read_sapling_params();
|
||||||
|
|
||||||
|
info!("Created new wallet!");
|
||||||
|
info!("Created LightClient to {}", &config.server);
|
||||||
|
|
||||||
|
Ok(l)
|
||||||
|
}
|
||||||
|
|
||||||
pub fn new_from_phrase(seed_phrase: String, config: &LightClientConfig, latest_block: u64) -> io::Result<Self> {
|
pub fn new_from_phrase(seed_phrase: String, config: &LightClientConfig, latest_block: u64) -> io::Result<Self> {
|
||||||
if config.get_wallet_path().exists() {
|
if config.get_wallet_path().exists() {
|
||||||
return Err(Error::new(ErrorKind::AlreadyExists,
|
return Err(Error::new(ErrorKind::AlreadyExists,
|
||||||
@@ -281,12 +301,10 @@ impl LightClient {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Export private keys
|
// Export private keys
|
||||||
pub fn do_export(&self, addr: Option<String>) -> JsonValue {
|
pub fn do_export(&self, addr: Option<String>) -> Result<JsonValue, &str> {
|
||||||
if !self.wallet.read().unwrap().is_unlocked_for_spending() {
|
if !self.wallet.read().unwrap().is_unlocked_for_spending() {
|
||||||
error!("Wallet is locked");
|
error!("Wallet is locked");
|
||||||
return object!{
|
return Err("Wallet is locked");
|
||||||
"error" => "Wallet is locked"
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Clone address so it can be moved into the closure
|
// Clone address so it can be moved into the closure
|
||||||
@@ -319,11 +337,12 @@ impl LightClient {
|
|||||||
all_keys.extend_from_slice(&z_keys);
|
all_keys.extend_from_slice(&z_keys);
|
||||||
all_keys.extend_from_slice(&t_keys);
|
all_keys.extend_from_slice(&t_keys);
|
||||||
|
|
||||||
all_keys.into()
|
Ok(all_keys.into())
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn do_address(&self) -> JsonValue {
|
pub fn do_address(&self) -> JsonValue {
|
||||||
let wallet = self.wallet.read().unwrap();
|
let wallet = self.wallet.read().unwrap();
|
||||||
|
|
||||||
// Collect z addresses
|
// Collect z addresses
|
||||||
let z_addresses = wallet.zaddress.read().unwrap().iter().map( |ad| {
|
let z_addresses = wallet.zaddress.read().unwrap().iter().map( |ad| {
|
||||||
encode_payment_address(self.config.hrp_sapling_address(), &ad)
|
encode_payment_address(self.config.hrp_sapling_address(), &ad)
|
||||||
@@ -425,19 +444,17 @@ impl LightClient {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn do_seed_phrase(&self) -> JsonValue {
|
pub fn do_seed_phrase(&self) -> Result<JsonValue, &str> {
|
||||||
if !self.wallet.read().unwrap().is_unlocked_for_spending() {
|
if !self.wallet.read().unwrap().is_unlocked_for_spending() {
|
||||||
error!("Wallet is locked");
|
error!("Wallet is locked");
|
||||||
return object!{
|
return Err("Wallet is locked");
|
||||||
"error" => "Wallet is locked"
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
let wallet = self.wallet.read().unwrap();
|
let wallet = self.wallet.read().unwrap();
|
||||||
object!{
|
Ok(object!{
|
||||||
"seed" => wallet.get_seed_phrase(),
|
"seed" => wallet.get_seed_phrase(),
|
||||||
"birthday" => wallet.get_birthday()
|
"birthday" => wallet.get_birthday()
|
||||||
}
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
// Return a list of all notes, spent and unspent
|
// Return a list of all notes, spent and unspent
|
||||||
@@ -612,12 +629,10 @@ impl LightClient {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Create a new address, deriving it from the seed.
|
/// Create a new address, deriving it from the seed.
|
||||||
pub fn do_new_address(&self, addr_type: &str) -> JsonValue {
|
pub fn do_new_address(&self, addr_type: &str) -> Result<JsonValue, String> {
|
||||||
if !self.wallet.read().unwrap().is_unlocked_for_spending() {
|
if !self.wallet.read().unwrap().is_unlocked_for_spending() {
|
||||||
error!("Wallet is locked");
|
error!("Wallet is locked");
|
||||||
return object!{
|
return Err("Wallet is locked".to_string());
|
||||||
"error" => "Wallet is locked"
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
let wallet = self.wallet.write().unwrap();
|
let wallet = self.wallet.write().unwrap();
|
||||||
@@ -628,13 +643,11 @@ impl LightClient {
|
|||||||
_ => {
|
_ => {
|
||||||
let e = format!("Unrecognized address type: {}", addr_type);
|
let e = format!("Unrecognized address type: {}", addr_type);
|
||||||
error!("{}", e);
|
error!("{}", e);
|
||||||
return object!{
|
return Err(e);
|
||||||
"error" => e
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
array![new_address]
|
Ok(array![new_address])
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn do_rescan(&self) -> String {
|
pub fn do_rescan(&self) -> String {
|
||||||
@@ -874,3 +887,38 @@ impl LightClient {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
pub mod tests {
|
||||||
|
use lazy_static::lazy_static;
|
||||||
|
//use super::LightClient;
|
||||||
|
|
||||||
|
lazy_static!{
|
||||||
|
static ref TEST_SEED: String = "youth strong sweet gorilla hammer unhappy congress stamp left stereo riot salute road tag clean toilet artefact fork certain leopard entire civil degree wonder".to_string();
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
pub fn test_encrypt_decrypt() {
|
||||||
|
let lc = super::LightClient::unconnected(TEST_SEED.to_string()).unwrap();
|
||||||
|
|
||||||
|
assert!(!lc.do_export(None).is_err());
|
||||||
|
assert!(!lc.do_new_address("z").is_err());
|
||||||
|
assert!(!lc.do_new_address("t").is_err());
|
||||||
|
assert_eq!(lc.do_seed_phrase().unwrap()["seed"], TEST_SEED.to_string());
|
||||||
|
|
||||||
|
// Encrypt and Lock the wallet
|
||||||
|
lc.wallet.write().unwrap().encrypt("password".to_string()).unwrap();
|
||||||
|
assert!(lc.do_export(None).is_err());
|
||||||
|
assert!(lc.do_seed_phrase().is_err());
|
||||||
|
assert!(lc.do_new_address("t").is_err());
|
||||||
|
assert!(lc.do_new_address("z").is_err());
|
||||||
|
assert!(lc.do_send(vec![("z", 0, None)]).is_err());
|
||||||
|
|
||||||
|
// Do a unlock, and make sure it all works now
|
||||||
|
lc.wallet.write().unwrap().unlock("password".to_string()).unwrap();
|
||||||
|
assert!(!lc.do_export(None).is_err());
|
||||||
|
assert!(!lc.do_seed_phrase().is_err());
|
||||||
|
assert!(!lc.do_new_address("t").is_err());
|
||||||
|
assert!(!lc.do_new_address("z").is_err());
|
||||||
|
}
|
||||||
|
}
|
Reference in New Issue
Block a user