mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-22 23:08:00 +00:00
b4eb406ee5
* Add and use subxt-signer crate for WASM compatible signing * cargo fmt * dev keypairs already references * WIP fix various breakages * re-jig features to be simpler and various test fixes etc * doc and web fix * fix various bits and pieces * fix a test I broke * dev-deps can't be linked to in docs, hrmph * cargo fmt * another doc link * document the subxt_signer crate more thoroughly * move feature flag for consistency * more docs, no default subxt feature flag on signer, update release instrs * Add missing license header * unwrap_inner => into_inner * extend a test a little to better check derive junctions * note more clearly that the crypto bits come from sp_core::crypto
56 lines
2.1 KiB
Rust
56 lines
2.1 KiB
Rust
use futures::StreamExt;
|
|
use subxt::{tx::TxStatus, OnlineClient, PolkadotConfig};
|
|
use subxt_signer::sr25519::dev;
|
|
|
|
// Generate an interface that we can use from the node's metadata.
|
|
#[subxt::subxt(runtime_metadata_path = "../artifacts/polkadot_metadata_small.scale")]
|
|
pub mod polkadot {}
|
|
|
|
#[tokio::main]
|
|
async fn main() -> Result<(), Box<dyn std::error::Error>> {
|
|
// Create a new API client, configured to talk to Polkadot nodes.
|
|
let api = OnlineClient::<PolkadotConfig>::new().await?;
|
|
|
|
// Build a balance transfer extrinsic.
|
|
let dest = dev::bob().public_key().into();
|
|
let balance_transfer_tx = polkadot::tx().balances().transfer(dest, 10_000);
|
|
|
|
// Submit the balance transfer extrinsic from Alice, and then monitor the
|
|
// progress of it.
|
|
let from = dev::alice();
|
|
let mut balance_transfer_progress = api
|
|
.tx()
|
|
.sign_and_submit_then_watch_default(&balance_transfer_tx, &from)
|
|
.await?;
|
|
|
|
while let Some(status) = balance_transfer_progress.next().await {
|
|
match status? {
|
|
// It's finalized in a block!
|
|
TxStatus::Finalized(in_block) => {
|
|
println!(
|
|
"Transaction {:?} is finalized in block {:?}",
|
|
in_block.extrinsic_hash(),
|
|
in_block.block_hash()
|
|
);
|
|
|
|
// grab the events and fail if no ExtrinsicSuccess event seen:
|
|
let events = in_block.wait_for_success().await?;
|
|
// We can look for events (this uses the static interface; we can also iterate
|
|
// over them and dynamically decode them):
|
|
let transfer_event = events.find_first::<polkadot::balances::events::Transfer>()?;
|
|
|
|
if let Some(event) = transfer_event {
|
|
println!("Balance transfer success: {event:?}");
|
|
} else {
|
|
println!("Failed to find Balances::Transfer Event");
|
|
}
|
|
}
|
|
// Just log any other status we encounter:
|
|
other => {
|
|
println!("Status: {other:?}");
|
|
}
|
|
}
|
|
}
|
|
Ok(())
|
|
}
|