15 releases
new 0.1.14 | Nov 4, 2024 |
---|---|
0.1.13 | Oct 20, 2024 |
0.1.5 | Sep 28, 2024 |
#682 in Magic Beans
1,096 downloads per month
1MB
24K
SLoC
wallet_standard_wallets
A collection of solana wallet implementations primarily used for testing.
Installation
To install you can used the following command:
cargo add wallet_standard_wallets
Or directly add the following to your Cargo.toml
:
[dependencies]
wallet_standard_wallets = "0.1" # replace with the latest version
Features
ssr
Enables thessr
feature for thewallet_standard
crate.js
Enables thejs
feature to unlock wasm support for thewallet_standard
crate.
Usage
The memory wallet is a simple wallet that stores all accounts in memory and conforms to the WalletStandard
trait.
use anyhow::Result;
use solana_sdk::native_token::sol_to_lamports;
use solana_sdk::pubkey::Pubkey;
use solana_sdk::signature::Keypair;
use solana_sdk::signature::Signature;
use solana_sdk::system_instruction;
use solana_sdk::transaction::VersionedTransaction;
use wallet_standard::SolanaSignTransactionProps;
use wallet_standard_wallets::MemoryWallet;
use wallet_standard_wallets::prelude::*;
use wasm_client_solana::DEVNET;
use wasm_client_solana::SolanaRpcClient;
async fn run() -> Result<()> {
let keypair = Keypair::new();
let pubkey = keypair.pubkey();
let target_pubkey = Pubkey::new_unique();
let instruction = system_instruction::transfer(&pubkey, &target_pubkey, sol_to_lamports(0.5));
let rpc = SolanaRpcClient::new(DEVNET);
let blockhash = rpc.get_latest_blockhash().await?;
let transaction =
VersionedTransaction::new_unsigned_v0(&pubkey, &[instruction], &[], blockhash)?;
let mut memory_wallet = MemoryWallet::new(rpc, &[keypair]);
// connect the first account in the memory wallet accounts list
memory_wallet.connect().await?;
let props = SolanaSignTransactionProps::builder()
.transaction(transaction)
.build();
let signed_transaction: VersionedTransaction = memory_wallet.sign_transaction(props).await?;
Ok(())
}
Dependencies
~32–45MB
~748K SLoC