10 releases
Uses new Rust 2024
| 0.2.0 | Nov 8, 2025 |
|---|---|
| 0.1.24 | Oct 3, 2025 |
| 0.1.23 | Mar 15, 2025 |
| 0.1.21 | Jan 17, 2025 |
| 0.1.19 | Dec 21, 2024 |
#30 in #blockchain-wallet
345KB
9K
SLoC
memory_wallet
A memory based wallet standard implementation primarily used for testing.
Installation
To install you can used the following command:
cargo add memory_wallet
Or directly add the following to your Cargo.toml:
[dependencies]
memory_wallet = "0.2.0"
Features
ssrEnables thessrfeature for thewallet_standardcrate.jsEnables thejsfeature to unlock wasm support for thewallet_standardcrate.
Usage
The memory wallet is a simple wallet that stores all accounts in memory and conforms to the WalletStandard trait.
use anyhow::Result;
use memory_wallet::MemoryWallet;
use memory_wallet::prelude::*;
use solana_keypair::Keypair;
use solana_native_token::sol_str_to_lamports;
use solana_pubkey::Pubkey;
use solana_signature::Signature;
use solana_system_interface::instruction::transfer;
use solana_transaction::versioned::VersionedTransaction;
use wallet_standard::SolanaSignTransactionProps;
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 = transfer(&pubkey, &target_pubkey, sol_str_to_lamports("0.5").unwrap());
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
~30–49MB
~679K SLoC