Struct fuels_signers::wallet::WalletUnlocked
source · pub struct WalletUnlocked { /* private fields */ }
Expand description
A WalletUnlocked
is equivalent to a Wallet
whose private key is known and stored
alongside in-memory. Knowing the private key allows a WalletUlocked
to sign operations, send
transactions, and more.
Implementations§
source§impl WalletUnlocked
impl WalletUnlocked
pub fn set_provider(&mut self, provider: Provider)
sourcepub fn new_random(provider: Option<Provider>) -> Self
pub fn new_random(provider: Option<Provider>) -> Self
Creates a new wallet with a random private key.
sourcepub fn new_from_private_key(
private_key: SecretKey,
provider: Option<Provider>
) -> Self
pub fn new_from_private_key( private_key: SecretKey, provider: Option<Provider> ) -> Self
Creates a new wallet from the given private key.
sourcepub fn new_from_mnemonic_phrase(
phrase: &str,
provider: Option<Provider>
) -> Result<Self, WalletError>
pub fn new_from_mnemonic_phrase( phrase: &str, provider: Option<Provider> ) -> Result<Self, WalletError>
Creates a new wallet from a mnemonic phrase. The default derivation path is used.
sourcepub fn new_from_mnemonic_phrase_with_path(
phrase: &str,
provider: Option<Provider>,
path: &str
) -> Result<Self, WalletError>
pub fn new_from_mnemonic_phrase_with_path( phrase: &str, provider: Option<Provider>, path: &str ) -> Result<Self, WalletError>
Creates a new wallet from a mnemonic phrase. It takes a path to a BIP32 derivation path.
sourcepub fn new_from_keystore<P, R, S>(
dir: P,
rng: &mut R,
password: S,
provider: Option<Provider>
) -> Result<(Self, String), WalletError>where
P: AsRef<Path>,
R: Rng + CryptoRng + CryptoRng,
S: AsRef<[u8]>,
pub fn new_from_keystore<P, R, S>( dir: P, rng: &mut R, password: S, provider: Option<Provider> ) -> Result<(Self, String), WalletError>where P: AsRef<Path>, R: Rng + CryptoRng + CryptoRng, S: AsRef<[u8]>,
Creates a new wallet and stores its encrypted version in the given path.
sourcepub fn encrypt<P, S>(&self, dir: P, password: S) -> Result<String, WalletError>where
P: AsRef<Path>,
S: AsRef<[u8]>,
pub fn encrypt<P, S>(&self, dir: P, password: S) -> Result<String, WalletError>where P: AsRef<Path>, S: AsRef<[u8]>,
Encrypts the wallet’s private key with the given password and saves it to the given path.
sourcepub fn load_keystore<P, S>(
keypath: P,
password: S,
provider: Option<Provider>
) -> Result<Self, WalletError>where
P: AsRef<Path>,
S: AsRef<[u8]>,
pub fn load_keystore<P, S>( keypath: P, password: S, provider: Option<Provider> ) -> Result<Self, WalletError>where P: AsRef<Path>, S: AsRef<[u8]>,
Recreates a wallet from an encrypted JSON wallet given the provided path and password.
sourcepub async fn add_fee_resources(
&self,
tx: &mut impl Transaction,
previous_base_amount: u64,
witness_index: u8
) -> Result<()>
pub async fn add_fee_resources( &self, tx: &mut impl Transaction, previous_base_amount: u64, witness_index: u8 ) -> Result<()>
Add base asset inputs to the transaction to cover the estimated fee. The original base asset amount cannot be calculated reliably from the existing transaction inputs because the selected resources may exceed the required amount to avoid dust. Therefore we require it as an argument.
Requires contract inputs to be at the start of the transactions inputs vec so that their indexes are retained
sourcepub async fn transfer(
&self,
to: &Bech32Address,
amount: u64,
asset_id: AssetId,
tx_parameters: TxParameters
) -> Result<(String, Vec<Receipt>)>
pub async fn transfer( &self, to: &Bech32Address, amount: u64, asset_id: AssetId, tx_parameters: TxParameters ) -> Result<(String, Vec<Receipt>)>
Transfer funds from this wallet to another Address
.
Fails if amount for asset ID is larger than address’s spendable coins.
Returns the transaction ID that was sent and the list of receipts.
sourcepub async fn withdraw_to_base_layer(
&self,
to: &Bech32Address,
amount: u64,
tx_parameters: TxParameters
) -> Result<(String, String, Vec<Receipt>)>
pub async fn withdraw_to_base_layer( &self, to: &Bech32Address, amount: u64, tx_parameters: TxParameters ) -> Result<(String, String, Vec<Receipt>)>
Withdraws an amount of the base asset to an address on the base chain. Returns the transaction ID, message ID and the list of receipts.
pub async fn spend_predicate( &self, predicate_address: &Bech32Address, code: Vec<u8>, amount: u64, asset_id: AssetId, to: &Bech32Address, predicate_data: UnresolvedBytes, tx_parameters: TxParameters ) -> Result<Vec<Receipt>>
pub async fn receive_from_predicate( &self, predicate_address: &Bech32Address, predicate_code: Vec<u8>, amount: u64, asset_id: AssetId, predicate_data: UnresolvedBytes, tx_parameters: TxParameters ) -> Result<Vec<Receipt>>
sourcepub async fn force_transfer_to_contract(
&self,
to: &Bech32ContractId,
balance: u64,
asset_id: AssetId,
tx_parameters: TxParameters
) -> Result<(String, Vec<Receipt>)>
pub async fn force_transfer_to_contract( &self, to: &Bech32ContractId, balance: u64, asset_id: AssetId, tx_parameters: TxParameters ) -> Result<(String, Vec<Receipt>)>
Unconditionally transfers balance
of type asset_id
to
the contract at to
.
Fails if balance for asset_id
is larger than this wallet’s spendable balance.
Returns the corresponding transaction ID and the list of receipts.
CAUTION !!!
This will transfer coins to a contract, possibly leading to the PERMANENT LOSS OF COINS if not used with care.
Methods from Deref<Target = Wallet>§
pub fn get_provider(&self) -> Result<&Provider, WalletError>
pub fn address(&self) -> &Bech32Address
pub async fn get_transactions( &self, request: PaginationRequest<String> ) -> Result<PaginatedResult<TransactionResponse, String>>
sourcepub async fn get_asset_inputs_for_amount(
&self,
asset_id: AssetId,
amount: u64,
witness_index: u8
) -> Result<Vec<Input>>
pub async fn get_asset_inputs_for_amount( &self, asset_id: AssetId, amount: u64, witness_index: u8 ) -> Result<Vec<Input>>
Returns a vector consisting of Input::Coin
s and Input::Message
s for the given
asset ID and amount. The witness_index
is the position of the witness (signature)
in the transaction’s list of witnesses. In the validation process, the node will
use the witness at this index to validate the coins returned by this method.
sourcepub fn get_asset_outputs_for_amount(
&self,
to: &Bech32Address,
asset_id: AssetId,
amount: u64
) -> Vec<Output> ⓘ
pub fn get_asset_outputs_for_amount( &self, to: &Bech32Address, asset_id: AssetId, amount: u64 ) -> Vec<Output> ⓘ
Returns a vector containing the output coin and change output given an asset and amount
sourcepub async fn get_coins(&self, asset_id: AssetId) -> Result<Vec<Coin>>
pub async fn get_coins(&self, asset_id: AssetId) -> Result<Vec<Coin>>
Gets all unspent coins of asset asset_id
owned by the wallet.
sourcepub async fn get_spendable_resources(
&self,
asset_id: AssetId,
amount: u64
) -> Result<Vec<Resource>>
pub async fn get_spendable_resources( &self, asset_id: AssetId, amount: u64 ) -> Result<Vec<Resource>>
Get some spendable resources (coins and messages) of asset asset_id
owned by the wallet
that add up at least to amount amount
. The returned coins (UTXOs) are actual coins that
can be spent. The number of UXTOs is optimized to prevent dust accumulation.
sourcepub async fn get_asset_balance(&self, asset_id: &AssetId) -> Result<u64>
pub async fn get_asset_balance(&self, asset_id: &AssetId) -> Result<u64>
Get the balance of all spendable coins asset_id
for address address
. This is different
from getting coins because we are just returning a number (the sum of UTXOs amount) instead
of the UTXOs.
sourcepub async fn get_balances(&self) -> Result<HashMap<String, u64>>
pub async fn get_balances(&self) -> Result<HashMap<String, u64>>
Get all the spendable balances of all assets for the wallet. This is different from getting the coins because we are only returning the sum of UTXOs coins amount and not the UTXOs coins themselves.
pub async fn get_messages(&self) -> Result<Vec<InputMessage>>
Trait Implementations§
source§impl Clone for WalletUnlocked
impl Clone for WalletUnlocked
source§fn clone(&self) -> WalletUnlocked
fn clone(&self) -> WalletUnlocked
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for WalletUnlocked
impl Debug for WalletUnlocked
source§impl Deref for WalletUnlocked
impl Deref for WalletUnlocked
source§impl Signer for WalletUnlocked
impl Signer for WalletUnlocked
type Error = WalletError
source§fn sign_message<'life0, 'async_trait, S>(
&'life0 self,
message: S
) -> Pin<Box<dyn Future<Output = Result<Signature, WalletError>> + Send + 'async_trait>>where
S: 'async_trait + Send + Sync + AsRef<[u8]>,
Self: 'async_trait,
'life0: 'async_trait,
fn sign_message<'life0, 'async_trait, S>( &'life0 self, message: S ) -> Pin<Box<dyn Future<Output = Result<Signature, WalletError>> + Send + 'async_trait>>where S: 'async_trait + Send + Sync + AsRef<[u8]>, Self: 'async_trait, 'life0: 'async_trait,
source§fn sign_transaction<'life0, 'life1, 'async_trait, T>(
&'life0 self,
tx: &'life1 mut T
) -> Pin<Box<dyn Future<Output = Result<Signature, WalletError>> + Send + 'async_trait>>where
T: 'async_trait + Transaction + Send,
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn sign_transaction<'life0, 'life1, 'async_trait, T>( &'life0 self, tx: &'life1 mut T ) -> Pin<Box<dyn Future<Output = Result<Signature, WalletError>> + Send + 'async_trait>>where T: 'async_trait + Transaction + Send, Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,
source§fn address(&self) -> &Bech32Address
fn address(&self) -> &Bech32Address
Auto Trait Implementations§
impl RefUnwindSafe for WalletUnlocked
impl Send for WalletUnlocked
impl Sync for WalletUnlocked
impl Unpin for WalletUnlocked
impl UnwindSafe for WalletUnlocked
Blanket Implementations§
source§impl<T> AnyDebug for Twhere
T: Any + Debug,
impl<T> AnyDebug for Twhere T: Any + Debug,
source§fn as_any_ref(&self) -> &(dyn Any + 'static)
fn as_any_ref(&self) -> &(dyn Any + 'static)
Any
.