mirror of
https://github.com/logos-blockchain/logos-execution-zone.git
synced 2026-05-26 01:49:29 +00:00
* feat: add basic commands for communicating with keycard * initialize changes * reorganization * add script file for easier wallet access * update commands * fixes * fixed load for non continuous run * Updates for signatures with keycard * fix BIP-340 signatures for fixed sized messages * fmt * refactor and add pin support to program facades * fix unit test * fixes * Revert "fixes" This reverts commit 41f34f4ff4145b7abb60fd9bec168ae4b60f23b4. * fixes * fixes * Removed privacy keycard calls * Revert "Removed privacy keycard calls" This reverts commit d70ef505a1f40b87159099761f5fce5a31e3f17b. * Add domain separators * Removed privacy txs for keycard * CI fixes * CI fixes * addressed some comments * fix ci * ci fixes * fix integration test issue and updated keycard firmware * addressed more comments * fixed deny * remove keycard-py * fixed from earlier merge * add hash_message tests * add test * fix deny * CI fixes * fixed integration tests * Update public.rs * update artifacts * ci and comments * addressed comments * comment fixes * fixes from merging main * first round of comments * Revert "Merge branch 'main' into marvin/keycard-commands" This reverts commit 3fce53f663a3996938dddf77680854570063ca21, reversing changes made to e7b42a5177641455a8917bd2e29db20afd9690e5. * python comments * addressed comments * compile error fixed * fix artifacts * fix main merge error * adjust signer logic workflow * fmt * merge main and shift keycard tests * deny fix * artifacts fix * remove keycard scripts from root * tps fix * fmt
80 lines
2.6 KiB
Rust
80 lines
2.6 KiB
Rust
use std::{path::PathBuf, str::FromStr as _};
|
|
|
|
use anyhow::{Context as _, Result};
|
|
use nssa_core::account::Nonce;
|
|
use rand::{RngCore as _, rngs::OsRng};
|
|
|
|
use crate::HOME_DIR_ENV_VAR;
|
|
|
|
/// Read the Keycard PIN without echoing it.
|
|
///
|
|
/// Checks `KEYCARD_PIN` first so non-interactive callers (CI, scripts) can
|
|
/// supply it via the environment. Falls back to a TTY prompt via `rpassword`
|
|
/// so the value never appears in argv, shell history, or `ps` output.
|
|
pub fn read_pin() -> anyhow::Result<zeroize::Zeroizing<String>> {
|
|
if let Ok(pin) = std::env::var("KEYCARD_PIN") {
|
|
return Ok(zeroize::Zeroizing::new(pin));
|
|
}
|
|
rpassword::prompt_password("Keycard PIN: ")
|
|
.map(zeroize::Zeroizing::new)
|
|
.map_err(Into::into)
|
|
}
|
|
|
|
/// Read the mnemonic phrase without echoing it.
|
|
///
|
|
/// Checks `KEYCARD_MNEMONIC` first for non-interactive callers. Falls back to
|
|
/// a TTY prompt so the phrase never appears in argv, shell history, or `ps`.
|
|
pub fn read_mnemonic() -> anyhow::Result<zeroize::Zeroizing<String>> {
|
|
if let Ok(mnemonic) = std::env::var("KEYCARD_MNEMONIC") {
|
|
return Ok(zeroize::Zeroizing::new(mnemonic));
|
|
}
|
|
rpassword::prompt_password("Mnemonic phrase: ")
|
|
.map(zeroize::Zeroizing::new)
|
|
.map_err(Into::into)
|
|
}
|
|
|
|
/// Get home dir for wallet. Env var `NSSA_WALLET_HOME_DIR` must be set before execution to succeed.
|
|
fn get_home_nssa_var() -> Result<PathBuf> {
|
|
Ok(PathBuf::from_str(&std::env::var(HOME_DIR_ENV_VAR)?)?)
|
|
}
|
|
|
|
/// Get home dir for wallet. Env var `HOME` must be set before execution to succeed.
|
|
fn get_home_default_path() -> Result<PathBuf> {
|
|
std::env::home_dir()
|
|
.map(|path| path.join(".nssa").join("wallet"))
|
|
.context("Failed to get HOME")
|
|
}
|
|
|
|
/// Get home dir for wallet.
|
|
pub fn get_home() -> Result<PathBuf> {
|
|
get_home_nssa_var().or_else(|_| get_home_default_path())
|
|
}
|
|
|
|
/// Fetch config path from default home.
|
|
pub fn fetch_config_path() -> Result<PathBuf> {
|
|
let home = get_home()?;
|
|
let config_path = home.join("wallet_config.json");
|
|
Ok(config_path)
|
|
}
|
|
|
|
/// Fetch path to data storage from default home.
|
|
///
|
|
/// File must be created through setup beforehand.
|
|
pub fn fetch_persistent_storage_path() -> Result<PathBuf> {
|
|
let home = get_home()?;
|
|
let accs_path = home.join("storage.json");
|
|
Ok(accs_path)
|
|
}
|
|
|
|
#[expect(dead_code, reason = "Maybe used later")]
|
|
pub(crate) fn produce_random_nonces(size: usize) -> Vec<Nonce> {
|
|
let mut result = vec![[0; 16]; size];
|
|
for bytes in &mut result {
|
|
OsRng.fill_bytes(bytes);
|
|
}
|
|
result
|
|
.into_iter()
|
|
.map(|x| Nonce(u128::from_le_bytes(x)))
|
|
.collect()
|
|
}
|