mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-25 12:57:58 +00:00
d7124b56f7
* WIP backend trait * WIP converting higher level stuff to using Backend impl * more implementing new backend trait, mainly storage focused * Get core code compiling with new backend bits * subxt crate checks passing * fix tests * cargo fmt * clippy/fixes * merging and other fixes * fix test * fix lightclient code * Fix some broken doc links * another book link fix * fix broken test when moving default_rpc_client * fix dry_run test * fix more tests; lightclient and wasm * fix wasm tests * fix some doc examples * use next() instead of next_item() * missing next_item() -> next()s * move legacy RPc methods to LegacyRpcMethods type to host generic param instead of RpcClient * standardise on all RpcClient types prefixed with Rpc, and 'raw' trait types prefixed with RawRpc so it's less ocnfusing which is which * rename fixes * doc fixes * Add back system_dryRun RPC method and rename tx.dry_run() to tx.validate(), to signal that the calls are different * Add a test that we return the correct extrinsic hash from submit() * add TransactionValid details back, and protect against out of range bytes * add test for decoding transaction validation from empty bytes * fix clippy warning
55 lines
2.1 KiB
Rust
55 lines
2.1 KiB
Rust
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::InFinalizedBlock(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(())
|
|
}
|