From bdda695bbb9c55cad22dfa37268edabc1dfbac50 Mon Sep 17 00:00:00 2001 From: Philipp Gackstatter Date: Tue, 14 May 2024 10:18:29 +0200 Subject: [PATCH] Fix block issuer key from bytes conversion (#2249) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Fix block issuer key from bytes conversion * Sync basic_outputs of account outputs by default, changelog, bump cli version --------- Co-authored-by: Thoralf Müller --- Cargo.lock | 2 +- cli/CHANGELOG.md | 10 ++++++++++ cli/Cargo.toml | 2 +- cli/src/wallet_cli/mod.rs | 31 +++++++++++++++++++++++-------- 4 files changed, 35 insertions(+), 10 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 17e7574623..5baf1fdc04 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -503,7 +503,7 @@ checksum = "98cc8fbded0c607b7ba9dd60cd98df59af97e84d24e49c8557331cfc26d301ce" [[package]] name = "cli-wallet" -version = "2.0.0-beta.1" +version = "2.0.0-beta.2" dependencies = [ "chrono", "clap", diff --git a/cli/CHANGELOG.md b/cli/CHANGELOG.md index 1e0ab558c4..27757e281a 100644 --- a/cli/CHANGELOG.md +++ b/cli/CHANGELOG.md @@ -19,6 +19,16 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ### Security --> +## 2.0.0-beta.2 - 2024-05-14 + +### Changed + +- Set `SyncOptions::account::basic_outputs` to true; + +### Fixed + +- Hash public key in `add-block-issuer-key` and `remove-block-issuer-key`; + ## 2.0.0-beta.1 - 2024-05-08 ### Fixed diff --git a/cli/Cargo.toml b/cli/Cargo.toml index 45ea1fa631..05a453fbb4 100644 --- a/cli/Cargo.toml +++ b/cli/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "cli-wallet" -version = "2.0.0-beta.1" +version = "2.0.0-beta.2" authors = ["IOTA Stiftung"] edition = "2021" homepage = "https://iota.org" diff --git a/cli/src/wallet_cli/mod.rs b/cli/src/wallet_cli/mod.rs index 03cda828c4..65a424d8e5 100644 --- a/cli/src/wallet_cli/mod.rs +++ b/cli/src/wallet_cli/mod.rs @@ -10,6 +10,7 @@ use colored::Colorize; use eyre::Error; use iota_sdk::{ client::{api::options::TransactionOptions, request_funds_from_faucet, secret::SecretManager}, + crypto::signatures::ed25519::PublicKey, types::block::{ address::{AccountAddress, Bech32Address, ToBech32Ext}, mana::ManaAllotment, @@ -25,9 +26,9 @@ use iota_sdk::{ }, utils::ConvertTo, wallet::{ - types::OutputData, BeginStakingParams, ConsolidationParams, CreateDelegationParams, CreateNativeTokenParams, - MintNftParams, ModifyAccountBlockIssuerKey, OutputsToClaim, ReturnStrategy, SendManaParams, - SendNativeTokenParams, SendNftParams, SendParams, SyncOptions, Wallet, WalletError, + types::OutputData, AccountSyncOptions, BeginStakingParams, ConsolidationParams, CreateDelegationParams, + CreateNativeTokenParams, MintNftParams, ModifyAccountBlockIssuerKey, OutputsToClaim, ReturnStrategy, + SendManaParams, SendNativeTokenParams, SendNftParams, SendParams, SyncOptions, Wallet, WalletError, }, U256, }; @@ -751,7 +752,17 @@ pub async fn create_native_token_command( .wait_for_transaction_acceptance(&transaction.transaction_id, None, None) .await?; // Sync wallet after the transaction got confirmed, so the account output is available - wallet.sync(None).await?; + wallet + .sync(Some(SyncOptions { + sync_native_token_foundries: true, + sync_implicit_accounts: true, + account: AccountSyncOptions { + basic_outputs: true, + ..Default::default() + }, + ..Default::default() + })) + .await?; } let params = CreateNativeTokenParams { @@ -942,10 +953,10 @@ pub async fn implicit_accounts_command(wallet: &Wallet) -> Result<(), Error> { // `add-block-issuer-key` command pub async fn add_block_issuer_key(wallet: &Wallet, account_id: AccountId, issuer_key: &str) -> Result<(), Error> { - let issuer_key: [u8; Ed25519PublicKeyHashBlockIssuerKey::LENGTH] = prefix_hex::decode(issuer_key)?; + let public_key = PublicKey::try_from_bytes(prefix_hex::decode(issuer_key)?)?; let params = ModifyAccountBlockIssuerKey { account_id, - keys_to_add: vec![Ed25519PublicKeyHashBlockIssuerKey::new(issuer_key).into()], + keys_to_add: vec![Ed25519PublicKeyHashBlockIssuerKey::from_public_key(public_key).into()], keys_to_remove: vec![], }; @@ -962,11 +973,11 @@ pub async fn add_block_issuer_key(wallet: &Wallet, account_id: AccountId, issuer // `remove-block-issuer-key` command pub async fn remove_block_issuer_key(wallet: &Wallet, account_id: AccountId, issuer_key: &str) -> Result<(), Error> { - let issuer_key: [u8; Ed25519PublicKeyHashBlockIssuerKey::LENGTH] = prefix_hex::decode(issuer_key)?; + let public_key = PublicKey::try_from_bytes(prefix_hex::decode(issuer_key)?)?; let params = ModifyAccountBlockIssuerKey { account_id, keys_to_add: vec![], - keys_to_remove: vec![Ed25519PublicKeyHashBlockIssuerKey::new(issuer_key).into()], + keys_to_remove: vec![Ed25519PublicKeyHashBlockIssuerKey::from_public_key(public_key).into()], }; let transaction = wallet.modify_account_output_block_issuer_keys(params, None).await?; @@ -1199,6 +1210,10 @@ pub async fn sync_command(wallet: &Wallet) -> Result<(), Error> { .sync(Some(SyncOptions { sync_native_token_foundries: true, sync_implicit_accounts: true, + account: AccountSyncOptions { + basic_outputs: true, + ..Default::default() + }, ..Default::default() })) .await?;