mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-06-21 19:11:05 +00:00
ce0a82e322
* remove unneeded Config bounds and BlockNumber associated type * clippy and fmt
40 lines
1.2 KiB
Rust
40 lines
1.2 KiB
Rust
// Copyright 2019-2022 Parity Technologies (UK) Ltd.
|
|
// This file is dual-licensed as Apache-2.0 or GPL-3.0.
|
|
// see LICENSE for license details.
|
|
|
|
//! To run this example, a local polkadot node should be running. Example verified against polkadot v0.9.28-9ffe6e9e3da.
|
|
//!
|
|
//! E.g.
|
|
//! ```bash
|
|
//! curl "https://github.com/paritytech/polkadot/releases/download/v0.9.28/polkadot" --output /usr/local/bin/polkadot --location
|
|
//! polkadot --dev --tmp
|
|
//! ```
|
|
|
|
use std::time::Duration;
|
|
use subxt::{
|
|
OnlineClient,
|
|
PolkadotConfig,
|
|
};
|
|
|
|
#[tokio::main]
|
|
async fn main() -> Result<(), Box<dyn std::error::Error>> {
|
|
tracing_subscriber::fmt::init();
|
|
|
|
// Create a client to use:
|
|
let api = OnlineClient::<PolkadotConfig>::new().await?;
|
|
|
|
// Start a new tokio task to perform the runtime updates while
|
|
// utilizing the API for other use cases.
|
|
let update_client = api.updater();
|
|
tokio::spawn(async move {
|
|
let result = update_client.perform_runtime_updates().await;
|
|
println!("Runtime update failed with result={result:?}");
|
|
});
|
|
|
|
// If this client is kept in use a while, it'll update its metadata and such
|
|
// as needed when the node it's pointed at updates.
|
|
tokio::time::sleep(Duration::from_secs(10_000)).await;
|
|
|
|
Ok(())
|
|
}
|