123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109 |
- use std::sync::Arc;
- use cdk::amount::SplitTarget;
- use cdk::error::Error;
- use cdk::nuts::{CurrencyUnit, MintQuoteState, NotificationPayload, SecretKey, SpendingConditions};
- use cdk::wallet::{ReceiveOptions, SendOptions, Wallet, WalletSubscription};
- use cdk::Amount;
- use cdk_sqlite::wallet::memory;
- use rand::random;
- use tracing_subscriber::EnvFilter;
- #[tokio::main]
- async fn main() -> Result<(), Error> {
- let default_filter = "debug";
- let sqlx_filter = "sqlx=warn,hyper_util=warn,reqwest=warn,rustls=warn";
- let env_filter = EnvFilter::new(format!("{},{}", default_filter, sqlx_filter));
- // Parse input
- tracing_subscriber::fmt().with_env_filter(env_filter).init();
- // Initialize the memory store for the wallet
- let localstore = Arc::new(memory::empty().await?);
- // Generate a random seed for the wallet
- let seed = random::<[u8; 32]>();
- // Define the mint URL and currency unit
- let mint_url = "https://fake.thesimplekid.dev";
- let unit = CurrencyUnit::Sat;
- let amount = Amount::from(100);
- // Create a new wallet
- let wallet = Wallet::new(mint_url, unit, localstore, &seed, None).unwrap();
- // Request a mint quote from the wallet
- let quote = wallet.mint_quote(amount, None).await?;
- println!("Minting nuts ...");
- // Subscribe to updates on the mint quote state
- let mut subscription = wallet
- .subscribe(WalletSubscription::Bolt11MintQuoteState(vec![quote
- .id
- .clone()]))
- .await;
- // Wait for the mint quote to be paid
- while let Some(msg) = subscription.recv().await {
- if let NotificationPayload::MintQuoteBolt11Response(response) = msg {
- if response.state == MintQuoteState::Paid {
- break;
- }
- }
- }
- // Mint the received amount
- let received_proofs = wallet.mint("e.id, SplitTarget::default(), None).await?;
- println!(
- "Minted nuts: {:?}",
- received_proofs
- .into_iter()
- .map(|p| p.amount)
- .collect::<Vec<_>>()
- );
- // Generate a secret key for spending conditions
- let secret = SecretKey::generate();
- // Create spending conditions using the generated public key
- let spending_conditions = SpendingConditions::new_p2pk(secret.public_key(), None);
- // Get the total balance of the wallet
- let bal = wallet.total_balance().await?;
- println!("Total balance: {}", bal);
- // Send a token with the specified amount and spending conditions
- let prepared_send = wallet
- .prepare_send(
- 10.into(),
- SendOptions {
- conditions: Some(spending_conditions),
- include_fee: true,
- ..Default::default()
- },
- )
- .await?;
- println!("Fee: {}", prepared_send.fee());
- let token = wallet.send(prepared_send, None).await?;
- println!("Created token locked to pubkey: {}", secret.public_key());
- println!("{}", token);
- // Receive the token using the secret key
- let amount = wallet
- .receive(
- &token.to_string(),
- ReceiveOptions {
- p2pk_signing_keys: vec![secret],
- ..Default::default()
- },
- )
- .await?;
- println!("Redeemed locked token worth: {}", u64::from(amount));
- Ok(())
- }
|