Skip to content
Snippets Groups Projects

Nostr

2 unresolved threads
Open poka requested to merge nostr into master
2 unresolved threads
5 files
+ 2
57
Compare changes
  • Side-by-side
  • Inline
Files
5
+ 238
30
@@ -25,34 +25,56 @@ pub fn compute_vault_key_files_table(vault_key_addresses: &[String]) -> Result<T
@@ -25,34 +25,56 @@ pub fn compute_vault_key_files_table(vault_key_addresses: &[String]) -> Result<T
pub fn compute_vault_accounts_table(
pub fn compute_vault_accounts_table(
account_tree_nodes: &[Rc<RefCell<AccountTreeNode>>],
account_tree_nodes: &[Rc<RefCell<AccountTreeNode>>],
 
) -> Result<Table, GcliError> {
 
// Appel to the new function with show_g1v1 = true to maintain compatibility
 
compute_vault_accounts_table_with_g1v1(account_tree_nodes, true, false)
 
}
 
 
pub fn compute_vault_accounts_table_with_g1v1(
 
account_tree_nodes: &[Rc<RefCell<AccountTreeNode>>],
 
show_g1v1: bool,
 
show_type: bool,
) -> Result<Table, GcliError> {
) -> Result<Table, GcliError> {
let mut table = Table::new();
let mut table = Table::new();
table.load_preset(comfy_table::presets::UTF8_BORDERS_ONLY);
table.load_preset(comfy_table::presets::UTF8_BORDERS_ONLY);
table.set_header(vec![
"SS58 Address/G1v1 public key",
// Prepare header based on options
 
let mut header = vec![
 
if show_g1v1 { "SS58 Address/G1v1 public key" } else { "SS58 Address" },
"Crypto",
"Crypto",
"Path",
];
"Name",
]);
// Add Type column if show_type is true
 
if show_type {
 
header.push("Type");
 
}
 
 
// Add remaining columns
 
header.push("Path");
 
header.push("Name");
 
 
table.set_header(header);
for account_tree_node in account_tree_nodes {
for account_tree_node in account_tree_nodes {
let _ = add_account_tree_node_to_table(&mut table, account_tree_node);
let _ = add_account_tree_node_to_table_with_g1v1(&mut table, account_tree_node, show_g1v1, show_type);
}
}
Ok(table)
Ok(table)
}
}
fn add_account_tree_node_to_table(
fn add_account_tree_node_to_table_with_g1v1(
table: &mut Table,
table: &mut Table,
account_tree_node: &Rc<RefCell<AccountTreeNode>>,
account_tree_node: &Rc<RefCell<AccountTreeNode>>,
 
show_g1v1: bool,
 
show_type: bool,
) -> Result<(), GcliError> {
) -> Result<(), GcliError> {
let rows = compute_vault_accounts_row(account_tree_node)?;
let rows = compute_vault_accounts_row_with_g1v1(account_tree_node, show_g1v1, show_type)?;
rows.iter().for_each(|row| {
rows.iter().for_each(|row| {
table.add_row(row.clone());
table.add_row(row.clone());
});
});
for child in &account_tree_node.borrow().children {
for child in &account_tree_node.borrow().children {
let _ = add_account_tree_node_to_table(table, child);
let _ = add_account_tree_node_to_table_with_g1v1(table, child, show_g1v1, show_type);
}
}
Ok(())
Ok(())
@@ -60,9 +82,11 @@ fn add_account_tree_node_to_table(
@@ -60,9 +82,11 @@ fn add_account_tree_node_to_table(
/// Computes one or more row of the table for selected account_tree_node
/// Computes one or more row of the table for selected account_tree_node
///
///
/// For ed25519 keys, will display over 2 rows to also show the base 58 G1v1 public key
/// For ed25519 keys, will display over 2 rows to also show the base 58 G1v1 public key if show_g1v1 is true
pub fn compute_vault_accounts_row(
pub fn compute_vault_accounts_row_with_g1v1(
account_tree_node: &Rc<RefCell<AccountTreeNode>>,
account_tree_node: &Rc<RefCell<AccountTreeNode>>,
 
show_g1v1: bool,
 
show_type: bool,
) -> Result<Vec<Vec<Cell>>, GcliError> {
) -> Result<Vec<Vec<Cell>>, GcliError> {
let empty_string = "".to_string();
let empty_string = "".to_string();
@@ -89,38 +113,70 @@ pub fn compute_vault_accounts_row(
@@ -89,38 +113,70 @@ pub fn compute_vault_accounts_row(
let mut rows: Vec<Vec<Cell>> = vec![];
let mut rows: Vec<Vec<Cell>> = vec![];
let (path, crypto) = if let Some(path) = account_tree_node.account.path.clone() {
let (path, crypto, wallet_type) = if let Some(path) = account_tree_node.account.path.clone() {
(path, empty_string.clone())
(path, empty_string.clone(), empty_string.clone())
} else {
} else {
let crypto_scheme = CryptoScheme::from(account_tree_node.account.crypto_scheme.unwrap());
let crypto_scheme = CryptoScheme::from(account_tree_node.account.crypto_scheme.unwrap());
let crypto_scheme_str: &str = crypto_scheme.into();
// Adding 2nd row for G1v1 public key
if CryptoScheme::Ed25519 == crypto_scheme {
// Determine the wallet type based on the secret format
rows.push(vec![Cell::new(format!(
let wallet_type = if let Some(secret_format) = &account_tree_node.account.secret_format {
 
// If the secret format is available, use it to determine the type
 
match crate::keys::SecretFormat::from(*secret_format) {
 
crate::keys::SecretFormat::G1v1 => "G1v1".to_string(),
 
crate::keys::SecretFormat::Substrate => "Mnemonic".to_string(),
 
crate::keys::SecretFormat::Seed => "Seed".to_string(),
 
crate::keys::SecretFormat::Predefined => "Predefined".to_string(),
 
}
 
} else {
 
// If the secret format is not available, display "Unknown"
 
"Unknown".to_string()
 
};
 
 
// Add a second line for the G1v1 public key only if show_g1v1 is true and it's an Ed25519 key
 
let is_ed25519 = crypto_scheme == CryptoScheme::Ed25519;
 
if show_g1v1 && is_ed25519 {
 
let mut g1v1_row = vec![Cell::new(format!(
"└ G1v1: {}",
"└ G1v1: {}",
cesium::compute_g1v1_public_key_from_ed25519_account_id(
cesium::compute_g1v1_public_key_from_ed25519_account_id(
&account_tree_node.account.address.0
&account_tree_node.account.address.0
)
)
))]);
))];
 
 
// Add empty cells to align with the main line
 
g1v1_row.push(Cell::new(""));
 
if show_type {
 
g1v1_row.push(Cell::new(""));
 
}
 
g1v1_row.push(Cell::new(""));
 
g1v1_row.push(Cell::new(""));
 
 
rows.push(g1v1_row);
}
}
let crypto_scheme_str: &str = crypto_scheme.into();
(
(
format!("<{}>", account_tree_node.account.account_type()),
format!("<{}>", account_tree_node.account.account_type()),
crypto_scheme_str.to_string(),
crypto_scheme_str.to_string(),
 
wallet_type,
)
)
};
};
// Adding 1st row
// Add the first line
rows.insert(
let mut main_row = vec![
0,
Cell::new(&address),
vec![
Cell::new(crypto),
Cell::new(&address),
];
Cell::new(crypto),
Cell::new(&path),
// Add the Type column if show_type is true
Cell::new(&name),
if show_type {
],
main_row.push(Cell::new(wallet_type));
);
}
 
 
// Add the remaining columns
 
main_row.push(Cell::new(&path));
 
main_row.push(Cell::new(&name));
 
 
rows.insert(0, main_row);
Ok(rows)
Ok(rows)
}
}
@@ -128,12 +184,13 @@ pub fn compute_vault_accounts_row(
@@ -128,12 +184,13 @@ pub fn compute_vault_accounts_row(
#[cfg(test)]
#[cfg(test)]
mod tests {
mod tests {
mod vault_accounts_table_tests {
mod vault_accounts_table_tests {
use crate::commands::vault::display::compute_vault_accounts_table;
use crate::commands::vault::display::{compute_vault_accounts_table, compute_vault_accounts_table_with_g1v1};
use crate::entities::vault_account::tests::account_tree_node_tests::{
use crate::entities::vault_account::tests::account_tree_node_tests::{
mother_account_tree_node, mother_g1v1_account_tree_node,
mother_account_tree_node, mother_g1v1_account_tree_node,
};
};
use indoc::indoc;
use indoc::indoc;
 
// Tests for compute_vault_accounts_table (old function)
#[test]
#[test]
fn test_compute_vault_accounts_table_empty() {
fn test_compute_vault_accounts_table_empty() {
let table = compute_vault_accounts_table(&[]).unwrap();
let table = compute_vault_accounts_table(&[]).unwrap();
@@ -191,5 +248,156 @@ mod tests {
@@ -191,5 +248,156 @@ mod tests {
assert_eq!(table.to_string(), expected_table);
assert_eq!(table.to_string(), expected_table);
}
}
 
 
// Tests for compute_vault_accounts_table_with_g1v1
 
#[test]
 
fn test_compute_vault_accounts_table_with_g1v1_empty() {
 
// Test with show_g1v1 = true (default behavior)
 
let table = compute_vault_accounts_table_with_g1v1(&[], true, false).unwrap();
 
 
let expected_table_with_g1v1 = indoc! {r#"
 
┌─────────────────────────────────────────────────────┐
 
│ SS58 Address/G1v1 public key Crypto Path Name │
 
╞═════════════════════════════════════════════════════╡
 
└─────────────────────────────────────────────────────┘"#
 
};
 
 
assert_eq!(table.to_string(), expected_table_with_g1v1);
 
 
// Test with show_g1v1 = false
 
let table = compute_vault_accounts_table_with_g1v1(&[], false, false).unwrap();
 
 
let expected_table_without_g1v1 = indoc! {r#"
 
┌─────────────────────────────────────┐
 
│ SS58 Address Crypto Path Name │
 
╞═════════════════════════════════════╡
 
└─────────────────────────────────────┘"#
 
};
 
 
assert_eq!(table.to_string(), expected_table_without_g1v1);
 
}
 
 
#[test]
 
fn test_compute_vault_accounts_table_with_g1v1() {
 
let account_tree_node = mother_account_tree_node();
 
let g1v1_account_tree_node = mother_g1v1_account_tree_node();
 
let account_tree_nodes = vec![account_tree_node, g1v1_account_tree_node];
 
 
// Test with show_g1v1 = true (default behavior)
 
let table_with_g1v1 = compute_vault_accounts_table_with_g1v1(&account_tree_nodes, true, false).unwrap();
 
 
let expected_table_with_g1v1 = indoc! {r#"
 
┌──────────────────────────────────────────────────────────────────────────────────────────┐
 
│ SS58 Address/G1v1 public key Crypto Path Name │
 
╞══════════════════════════════════════════════════════════════════════════════════════════╡
 
│ 5DfhGyQdFobKM8NsWvEeAKk5EQQgYe9AydgJ7rMB6E1EqRzV sr25519 <Base> Mother │
 
│ ├ 5D34dL5prEUaGNQtPPZ3yN5Y6BnkfXunKXXz6fo7ZJbLwRRH //0 Child 1 │
 
│ │ ├ 5Fh5PLQNt1xuEXm71dfDtQdnwceSew4oHewWBLsWAkKspV7d //0 Grandchild 1 │
 
│ ├ 5GBNeWRhZc2jXu7D55rBimKYDk8PGk8itRYFTPfC8RJLKG5o //1 <Mother//1> │
 
│ │ ├ 5CvdJuB9HLXSi5FS9LW57cyHF13iCv5HDimo2C45KxnxriCT //1 <Mother//1//1> │
 
│ 5ET2jhgJFoNQUpgfdSkdwftK8DKWdqZ1FKm5GKWdPfMWhPr4 ed25519 <Base> MotherG1v1 │
 
│ └ G1v1: 86pW1doyJPVH3jeDPZNQa1UZFBo5zcdvHERcaeE758W7 │
 
└──────────────────────────────────────────────────────────────────────────────────────────┘"#
 
};
 
 
assert_eq!(table_with_g1v1.to_string(), expected_table_with_g1v1);
 
 
// Test with show_g1v1 = false
 
let table_without_g1v1 = compute_vault_accounts_table_with_g1v1(&account_tree_nodes, false, false).unwrap();
 
 
let expected_table_without_g1v1 = indoc! {r#"
 
┌──────────────────────────────────────────────────────────────────────────────────────────┐
 
│ SS58 Address Crypto Path Name │
 
╞══════════════════════════════════════════════════════════════════════════════════════════╡
 
│ 5DfhGyQdFobKM8NsWvEeAKk5EQQgYe9AydgJ7rMB6E1EqRzV sr25519 <Base> Mother │
 
│ ├ 5D34dL5prEUaGNQtPPZ3yN5Y6BnkfXunKXXz6fo7ZJbLwRRH //0 Child 1 │
 
│ │ ├ 5Fh5PLQNt1xuEXm71dfDtQdnwceSew4oHewWBLsWAkKspV7d //0 Grandchild 1 │
 
│ ├ 5GBNeWRhZc2jXu7D55rBimKYDk8PGk8itRYFTPfC8RJLKG5o //1 <Mother//1> │
 
│ │ ├ 5CvdJuB9HLXSi5FS9LW57cyHF13iCv5HDimo2C45KxnxriCT //1 <Mother//1//1> │
 
│ 5ET2jhgJFoNQUpgfdSkdwftK8DKWdqZ1FKm5GKWdPfMWhPr4 ed25519 <Base> MotherG1v1 │
 
└──────────────────────────────────────────────────────────────────────────────────────────┘"#
 
};
 
 
assert_eq!(table_without_g1v1.to_string(), expected_table_without_g1v1);
 
}
 
 
#[test]
 
fn test_compute_vault_accounts_table_with_g1v1_partial() {
 
let mother = mother_account_tree_node();
 
let child1 = mother.borrow().children[0].clone();
 
let account_tree_nodes = vec![child1];
 
 
// Test with show_g1v1 = true (default behavior)
 
let table_with_g1v1 = compute_vault_accounts_table_with_g1v1(&account_tree_nodes, true, false).unwrap();
 
 
let expected_table_with_g1v1 = indoc! {r#"
 
┌─────────────────────────────────────────────────────────────────────────────────────┐
 
│ SS58 Address/G1v1 public key Crypto Path Name │
 
╞═════════════════════════════════════════════════════════════════════════════════════╡
 
│ ├ 5D34dL5prEUaGNQtPPZ3yN5Y6BnkfXunKXXz6fo7ZJbLwRRH //0 Child 1 │
 
│ │ ├ 5Fh5PLQNt1xuEXm71dfDtQdnwceSew4oHewWBLsWAkKspV7d //0 Grandchild 1 │
 
└─────────────────────────────────────────────────────────────────────────────────────┘"#
 
};
 
 
assert_eq!(table_with_g1v1.to_string(), expected_table_with_g1v1);
 
 
// Test with show_g1v1 = false
 
let table_without_g1v1 = compute_vault_accounts_table_with_g1v1(&account_tree_nodes, false, false).unwrap();
 
 
let expected_table_without_g1v1 = indoc! {r#"
 
┌─────────────────────────────────────────────────────────────────────────────────────┐
 
│ SS58 Address Crypto Path Name │
 
╞═════════════════════════════════════════════════════════════════════════════════════╡
 
│ ├ 5D34dL5prEUaGNQtPPZ3yN5Y6BnkfXunKXXz6fo7ZJbLwRRH //0 Child 1 │
 
│ │ ├ 5Fh5PLQNt1xuEXm71dfDtQdnwceSew4oHewWBLsWAkKspV7d //0 Grandchild 1 │
 
└─────────────────────────────────────────────────────────────────────────────────────┘"#
 
};
 
 
assert_eq!(table_without_g1v1.to_string(), expected_table_without_g1v1);
 
}
 
 
#[test]
 
fn test_compute_vault_accounts_table_with_type() {
 
let account_tree_node = mother_account_tree_node();
 
let g1v1_account_tree_node = mother_g1v1_account_tree_node();
 
let account_tree_nodes = vec![account_tree_node, g1v1_account_tree_node];
 
 
// Test with show_type = true and show_g1v1 = true
 
let table_with_g1v1_and_type = compute_vault_accounts_table_with_g1v1(&account_tree_nodes, true, true).unwrap();
 
 
let expected_table_with_g1v1_and_type = indoc! {r#"
 
┌─────────────────────────────────────────────────────────────────────────────────────────────────────┐
 
│ SS58 Address/G1v1 public key Crypto Type Path Name │
 
╞═════════════════════════════════════════════════════════════════════════════════════════════════════╡
 
│ 5DfhGyQdFobKM8NsWvEeAKk5EQQgYe9AydgJ7rMB6E1EqRzV sr25519 Mnemonic <Base> Mother │
 
│ ├ 5D34dL5prEUaGNQtPPZ3yN5Y6BnkfXunKXXz6fo7ZJbLwRRH //0 Child 1 │
 
│ │ ├ 5Fh5PLQNt1xuEXm71dfDtQdnwceSew4oHewWBLsWAkKspV7d //0 Grandchild 1 │
 
│ ├ 5GBNeWRhZc2jXu7D55rBimKYDk8PGk8itRYFTPfC8RJLKG5o //1 <Mother//1> │
 
│ │ ├ 5CvdJuB9HLXSi5FS9LW57cyHF13iCv5HDimo2C45KxnxriCT //1 <Mother//1//1> │
 
│ 5ET2jhgJFoNQUpgfdSkdwftK8DKWdqZ1FKm5GKWdPfMWhPr4 ed25519 G1v1 <Base> MotherG1v1 │
 
│ └ G1v1: 86pW1doyJPVH3jeDPZNQa1UZFBo5zcdvHERcaeE758W7 │
 
└─────────────────────────────────────────────────────────────────────────────────────────────────────┘"#
 
};
 
 
assert_eq!(table_with_g1v1_and_type.to_string(), expected_table_with_g1v1_and_type);
 
 
// Test with show_type = true and show_g1v1 = false
 
let table_with_type = compute_vault_accounts_table_with_g1v1(&account_tree_nodes, false, true).unwrap();
 
 
let expected_table_with_type = indoc! {r#"
 
┌─────────────────────────────────────────────────────────────────────────────────────────────────────┐
 
│ SS58 Address Crypto Type Path Name │
 
╞═════════════════════════════════════════════════════════════════════════════════════════════════════╡
 
│ 5DfhGyQdFobKM8NsWvEeAKk5EQQgYe9AydgJ7rMB6E1EqRzV sr25519 Mnemonic <Base> Mother │
 
│ ├ 5D34dL5prEUaGNQtPPZ3yN5Y6BnkfXunKXXz6fo7ZJbLwRRH //0 Child 1 │
 
│ │ ├ 5Fh5PLQNt1xuEXm71dfDtQdnwceSew4oHewWBLsWAkKspV7d //0 Grandchild 1 │
 
│ ├ 5GBNeWRhZc2jXu7D55rBimKYDk8PGk8itRYFTPfC8RJLKG5o //1 <Mother//1> │
 
│ │ ├ 5CvdJuB9HLXSi5FS9LW57cyHF13iCv5HDimo2C45KxnxriCT //1 <Mother//1//1> │
 
│ 5ET2jhgJFoNQUpgfdSkdwftK8DKWdqZ1FKm5GKWdPfMWhPr4 ed25519 G1v1 <Base> MotherG1v1 │
 
└─────────────────────────────────────────────────────────────────────────────────────────────────────┘"#
 
};
 
 
assert_eq!(table_with_type.to_string(), expected_table_with_type);
 
}
}
}
}
}
Loading