Struct fuels_accounts::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) -> &mut Wallet
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.
Methods from Deref<Target = Wallet>§
Trait Implementations§
source§impl Account for WalletUnlocked
impl Account for WalletUnlocked
source§fn get_asset_inputs_for_amount<'life0, 'async_trait>(
&'life0 self,
asset_id: AssetId,
amount: u64,
witness_index: Option<u8>
) -> Pin<Box<dyn Future<Output = Result<Vec<Input>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn get_asset_inputs_for_amount<'life0, 'async_trait>( &'life0 self, asset_id: AssetId, amount: u64, witness_index: Option<u8> ) -> Pin<Box<dyn Future<Output = Result<Vec<Input>>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,
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.
fn add_fee_resources<'life0, 'async_trait, Tb>( &'life0 self, tb: Tb, previous_base_amount: u64, witness_index: Option<u8> ) -> Pin<Box<dyn Future<Output = Result<Tb::TxType>> + Send + 'async_trait>>where Tb: 'async_trait + TransactionBuilder, Self: 'async_trait, 'life0: 'async_trait,
source§fn get_asset_outputs_for_amount(
&self,
to: &Bech32Address,
asset_id: AssetId,
amount: u64
) -> Vec<Output>
fn get_asset_outputs_for_amount( &self, to: &Bech32Address, asset_id: AssetId, amount: u64 ) -> Vec<Output>
source§fn transfer<'life0, 'life1, 'async_trait>(
&'life0 self,
to: &'life1 Bech32Address,
amount: u64,
asset_id: AssetId,
tx_parameters: TxParameters
) -> Pin<Box<dyn Future<Output = Result<(String, Vec<Receipt>)>> + Send + 'async_trait>>where
Self: Sync + 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn transfer<'life0, 'life1, 'async_trait>( &'life0 self, to: &'life1 Bech32Address, amount: u64, asset_id: AssetId, tx_parameters: TxParameters ) -> Pin<Box<dyn Future<Output = Result<(String, Vec<Receipt>)>> + Send + 'async_trait>>where Self: Sync + 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,
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.source§fn force_transfer_to_contract<'life0, 'life1, 'async_trait>(
&'life0 self,
to: &'life1 Bech32ContractId,
balance: u64,
asset_id: AssetId,
tx_parameters: TxParameters
) -> Pin<Box<dyn Future<Output = Result<(String, Vec<Receipt>), Error>> + Send + 'async_trait>>where
Self: Sync + 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn force_transfer_to_contract<'life0, 'life1, 'async_trait>( &'life0 self, to: &'life1 Bech32ContractId, balance: u64, asset_id: AssetId, tx_parameters: TxParameters ) -> Pin<Box<dyn Future<Output = Result<(String, Vec<Receipt>), Error>> + Send + 'async_trait>>where Self: Sync + 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,
balance
of type asset_id
to
the contract at to
.
Fails if balance for asset_id
is larger than this account’s spendable balance.
Returns the corresponding transaction ID and the list of receipts. Read moresource§fn withdraw_to_base_layer<'life0, 'life1, 'async_trait>(
&'life0 self,
to: &'life1 Bech32Address,
amount: u64,
tx_parameters: TxParameters
) -> Pin<Box<dyn Future<Output = Result<(String, String, Vec<Receipt>), Error>> + Send + 'async_trait>>where
Self: Sync + 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn withdraw_to_base_layer<'life0, 'life1, 'async_trait>( &'life0 self, to: &'life1 Bech32Address, amount: u64, tx_parameters: TxParameters ) -> Pin<Box<dyn Future<Output = Result<(String, String, Vec<Receipt>), Error>> + Send + 'async_trait>>where Self: Sync + 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,
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
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(
&self,
tx: &mut impl Transaction
) -> Result<Signature, WalletError>
fn sign_transaction( &self, tx: &mut impl Transaction ) -> Result<Signature, WalletError>
source§impl ViewOnlyAccount for WalletUnlocked
impl ViewOnlyAccount for WalletUnlocked
fn address(&self) -> &Bech32Address
fn try_provider(&self) -> Result<&Provider, AccountError>
fn set_provider(&mut self, provider: Provider) -> &mut Self
fn get_transactions<'life0, 'async_trait>( &'life0 self, request: PaginationRequest<String> ) -> Pin<Box<dyn Future<Output = Result<PaginatedResult<TransactionResponse, String>>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,
source§fn get_coins<'life0, 'async_trait>(
&'life0 self,
asset_id: AssetId
) -> Pin<Box<dyn Future<Output = Result<Vec<Coin>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn get_coins<'life0, 'async_trait>( &'life0 self, asset_id: AssetId ) -> Pin<Box<dyn Future<Output = Result<Vec<Coin>>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,
asset_id
owned by the account.source§fn get_asset_balance<'life0, 'life1, 'async_trait>(
&'life0 self,
asset_id: &'life1 AssetId
) -> Pin<Box<dyn Future<Output = Result<u64>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn get_asset_balance<'life0, 'life1, 'async_trait>( &'life0 self, asset_id: &'life1 AssetId ) -> Pin<Box<dyn Future<Output = Result<u64>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,
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.source§fn get_messages<'life0, 'async_trait>(
&'life0 self
) -> Pin<Box<dyn Future<Output = Result<Vec<Message>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn get_messages<'life0, 'async_trait>( &'life0 self ) -> Pin<Box<dyn Future<Output = Result<Vec<Message>>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,
source§fn get_balances<'life0, 'async_trait>(
&'life0 self
) -> Pin<Box<dyn Future<Output = Result<HashMap<String, u64>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn get_balances<'life0, 'async_trait>( &'life0 self ) -> Pin<Box<dyn Future<Output = Result<HashMap<String, u64>>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,
fn get_spendable_resources<'life0, 'async_trait>( &'life0 self, asset_id: AssetId, amount: u64 ) -> Pin<Box<dyn Future<Output = Result<Vec<Resource>>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,
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
.