mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-26 22:47:56 +00:00
ef89752904
* rpc/types: Decode `SubstrateTxStatus` for substrate and smoldot Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * lightclient: Add light client Error Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * lightclient: Add background task to manage RPC responses Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * lightclient: Implement the light client RPC in subxt Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * subxt: Expose light client under experimental feature-flag Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * artifacts: Add development chain spec for local nodes Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Update cargo lock Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * examples: Add light client example Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Update sp-* crates and smoldot to use git with branch / rev Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Apply cargo fmt Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Fix clippy Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Import hashmap entry Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * lightclient: Fetch spec only if jsonrpsee feature is enabled Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Update subxt/src/rpc/lightclient/background.rs Co-authored-by: Niklas Adolfsson <niklasadolfsson1@gmail.com> * Fix typo Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * artifacts: Update dev chain spec Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * types: Handle storage replies from chainHead_storage Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * artifacts: Add polkadot spec Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * lightclient: Handle RPC error responses Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * examples: Tx basic with light client for local nodes Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * example: Light client coprehensive example for live chains Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * examples: Remove prior light client example Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * feature: Rename experimental to unstable Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * book: Add light client section Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * testing: Fix clippy Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * lightclient: Ignore validated events Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Adjust tests for light-clients and normal clients Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * testing: Keep lightclient variant Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Remove support for chainHead_storage for light client Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Update light client to point to crates.io Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Update sp-crates from crates.io Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Replace Atomic with u64 Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Add LightClientBuilder Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Adjust chainspec with provided bootnodes Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Add potential_relay_chains to light client builder Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Move the light-client to the background task Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Adjust tracing logs Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Update book and example Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Apply cargo fmt Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Remove dev_spec.json artifact Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Examples fix duplicate Cargo.toml Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Use tracing_subscriber crate Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Fix clippy for different features Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Add comment about bootNodes Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Add comment about tracing-sub dependency Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Run integration-tests with light-client Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Feature guard some incompatible tests Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * ci: Enable light-client tests under feature flag Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * ci: Fix git step name Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Adjust flags for testing Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Adjust warnings Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Rename feature flag jsonrpsee-ws to jsonrpsee Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Fix cargo check Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * ci: Run tests on just 2 threads Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Move light-client to subxt/src/client Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Adjust LightClientBuilder Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Use ws_url to construct light client for testing Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Refactor background Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Address feedback Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Remove polkadot.spec and trim sub_id Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Wait for substrate to produce block before connecting light client Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Adjust builder and tests Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Apply fmt Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * ci: Use release for light client testing Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Add single test for light-client Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Wait for more blocks Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Use polkadot endpoint for testing Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Adjust cargo check Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * examples: Remove light client chain connection example Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Adjust cargo.toml section for the old example Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Adjust background task to use usize for subscription Id Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Build bootnodes with serde_json::Value directly Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Make channel between subxt user and subxt background unbounded Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Update subxt/src/client/lightclient/builder.rs Co-authored-by: Niklas Adolfsson <niklasadolfsson1@gmail.com> * Switch to smoldot 0.6.0 from 0.5.0 Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Move testing to `full_client` and `light_client` higher modules Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Remove subscriptionID type Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Remove subxt/integration-testing feature flag Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Adjust wait_for_blocks documentation Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Adjust utils import for testing Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> * Remove into_iter from builder construction Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> --------- Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io> Co-authored-by: Niklas Adolfsson <niklasadolfsson1@gmail.com>
302 lines
9.6 KiB
Rust
302 lines
9.6 KiB
Rust
// Copyright 2019-2023 Parity Technologies (UK) Ltd.
|
|
// This file is dual-licensed as Apache-2.0 or GPL-3.0.
|
|
// see LICENSE for license details.
|
|
|
|
//! Subxt is a library for interacting with Substrate based nodes. Using it looks something like this:
|
|
//!
|
|
//! ```rust,ignore
|
|
#![doc = include_str!("../examples/tx_basic.rs")]
|
|
//! ```
|
|
//!
|
|
//! Take a look at [the Subxt guide](book) to learn more about how to use Subxt.
|
|
|
|
#![deny(
|
|
bad_style,
|
|
improper_ctypes,
|
|
missing_docs,
|
|
non_shorthand_field_patterns,
|
|
no_mangle_generic_items,
|
|
overflowing_literals,
|
|
path_statements,
|
|
patterns_in_fns_without_body,
|
|
private_in_public,
|
|
unconditional_recursion,
|
|
unused_allocation,
|
|
unused_comparisons,
|
|
unused_parens,
|
|
while_true,
|
|
trivial_casts,
|
|
trivial_numeric_casts,
|
|
unused_crate_dependencies,
|
|
unused_extern_crates,
|
|
clippy::all
|
|
)]
|
|
#![allow(clippy::type_complexity)]
|
|
|
|
#[cfg(any(
|
|
all(feature = "web", feature = "native"),
|
|
not(any(feature = "web", feature = "native"))
|
|
))]
|
|
compile_error!("subxt: exactly one of the 'web' and 'native' features should be used.");
|
|
|
|
#[cfg(all(feature = "web", feature = "substrate-compat"))]
|
|
compile_error!("subxt: the 'substrate-compat' feature is not compatible with the 'web' feature.");
|
|
|
|
// The guide is here.
|
|
pub mod book;
|
|
|
|
// Suppress an unused dependency warning because tokio is
|
|
// only used in example code snippets at the time of writing.
|
|
#[cfg(test)]
|
|
mod only_used_in_docs_or_tests {
|
|
use subxt_signer as _;
|
|
use tokio as _;
|
|
}
|
|
|
|
// Suppress an unused dependency warning because tracing_subscriber is
|
|
// only used in example code snippets at the time of writing.
|
|
#[cfg(test)]
|
|
use tracing_subscriber as _;
|
|
|
|
// Used to enable the js feature for wasm.
|
|
#[cfg(feature = "web")]
|
|
#[allow(unused_imports)]
|
|
pub use getrandom as _;
|
|
|
|
pub mod blocks;
|
|
pub mod client;
|
|
pub mod config;
|
|
pub mod constants;
|
|
pub mod dynamic;
|
|
pub mod error;
|
|
pub mod events;
|
|
pub mod metadata;
|
|
pub mod rpc;
|
|
pub mod runtime_api;
|
|
pub mod storage;
|
|
pub mod tx;
|
|
pub mod utils;
|
|
|
|
// Expose a few of the most common types at root,
|
|
// but leave most types behind their respective modules.
|
|
pub use crate::{
|
|
client::{OfflineClient, OnlineClient},
|
|
config::{Config, PolkadotConfig, SubstrateConfig},
|
|
error::Error,
|
|
metadata::Metadata,
|
|
};
|
|
|
|
/// Re-export external crates that are made use of in the subxt API.
|
|
pub mod ext {
|
|
pub use codec;
|
|
pub use frame_metadata;
|
|
pub use scale_bits;
|
|
pub use scale_decode;
|
|
pub use scale_encode;
|
|
pub use scale_value;
|
|
#[cfg(feature = "substrate-compat")]
|
|
pub use sp_core;
|
|
#[cfg(feature = "substrate-compat")]
|
|
pub use sp_runtime;
|
|
}
|
|
|
|
/// Generate a strongly typed API for interacting with a Substrate runtime from its metadata.
|
|
///
|
|
/// # Metadata
|
|
///
|
|
/// First, you'll need to get hold of some metadata for the node you'd like to interact with. One
|
|
/// way to do this is by using the `subxt` CLI tool:
|
|
///
|
|
/// ```bash
|
|
/// # Install the CLI tool:
|
|
/// cargo install subxt-cli
|
|
/// # Use it to download metadata (in this case, from a node running locally)
|
|
/// subxt metadata > polkadot_metadata.scale
|
|
/// ```
|
|
///
|
|
/// Run `subxt metadata --help` for more options.
|
|
///
|
|
/// # Basic usage
|
|
///
|
|
/// Annotate a Rust module with the `subxt` attribute referencing the aforementioned metadata file.
|
|
///
|
|
/// ```rust,no_run
|
|
/// #[subxt::subxt(
|
|
/// runtime_metadata_path = "../artifacts/polkadot_metadata_full.scale",
|
|
/// )]
|
|
/// mod polkadot {}
|
|
/// ```
|
|
///
|
|
/// The `subxt` macro will populate the annotated module with all of the methods and types required
|
|
/// for interacting with the runtime that the metadata came from via Subxt.
|
|
///
|
|
/// # Configuration
|
|
///
|
|
/// This macro supports a number of attributes to configure what is generated:
|
|
///
|
|
/// ## `crate = "..."`
|
|
///
|
|
/// Use this attribute to specify a custom path to the `subxt` crate:
|
|
///
|
|
/// ```rust
|
|
/// # pub extern crate subxt;
|
|
/// # pub mod path { pub mod to { pub use subxt; } }
|
|
/// # fn main() {}
|
|
/// #[subxt::subxt(
|
|
/// runtime_metadata_path = "../artifacts/polkadot_metadata_full.scale",
|
|
/// crate = "crate::path::to::subxt"
|
|
/// )]
|
|
/// mod polkadot {}
|
|
/// ```
|
|
///
|
|
/// This is useful if you write a library which uses this macro, but don't want to force users to depend on `subxt`
|
|
/// at the top level too. By default the path `::subxt` is used.
|
|
///
|
|
/// ## `substitute_type(path = "...", with = "...")`
|
|
///
|
|
/// This attribute replaces any reference to the generated type at the path given by `path` with a
|
|
/// reference to the path given by `with`.
|
|
///
|
|
/// ```rust
|
|
/// #[subxt::subxt(
|
|
/// runtime_metadata_path = "../artifacts/polkadot_metadata_full.scale",
|
|
/// substitute_type(path = "sp_arithmetic::per_things::Perbill", with = "crate::Foo")
|
|
/// )]
|
|
/// mod polkadot {}
|
|
///
|
|
/// # #[derive(
|
|
/// # scale_encode::EncodeAsType,
|
|
/// # scale_decode::DecodeAsType,
|
|
/// # codec::Encode,
|
|
/// # codec::Decode,
|
|
/// # Clone,
|
|
/// # Debug,
|
|
/// # )]
|
|
/// // In reality this needs some traits implementing on
|
|
/// // it to allow it to be used in place of Perbill:
|
|
/// pub struct Foo(u32);
|
|
/// # impl codec::CompactAs for Foo {
|
|
/// # type As = u32;
|
|
/// # fn encode_as(&self) -> &Self::As {
|
|
/// # &self.0
|
|
/// # }
|
|
/// # fn decode_from(x: Self::As) -> Result<Self, codec::Error> {
|
|
/// # Ok(Foo(x))
|
|
/// # }
|
|
/// # }
|
|
/// # impl From<codec::Compact<Foo>> for Foo {
|
|
/// # fn from(v: codec::Compact<Foo>) -> Foo {
|
|
/// # v.0
|
|
/// # }
|
|
/// # }
|
|
/// # fn main() {}
|
|
/// ```
|
|
///
|
|
/// If the type you're substituting contains generic parameters, you can "pattern match" on those, and
|
|
/// make use of them in the substituted type, like so:
|
|
///
|
|
/// ```rust,no_run
|
|
/// #[subxt::subxt(
|
|
/// runtime_metadata_path = "../artifacts/polkadot_metadata_full.scale",
|
|
/// substitute_type(
|
|
/// path = "sp_runtime::multiaddress::MultiAddress<A, B>",
|
|
/// with = "::subxt::utils::Static<::sp_runtime::MultiAddress<A, B>>"
|
|
/// )
|
|
/// )]
|
|
/// mod polkadot {}
|
|
/// ```
|
|
///
|
|
/// The above is also an example of using the [`crate::utils::Static`] type to wrap some type which doesn't
|
|
/// on it's own implement [`scale_encode::EncodeAsType`] or [`scale_decode::DecodeAsType`], which are required traits
|
|
/// for any substitute type to implement by default.
|
|
///
|
|
/// ## `derive_for_all_types = "..."`
|
|
///
|
|
/// By default, all generated types derive a small set of traits. This attribute allows you to derive additional
|
|
/// traits on all generated types:
|
|
///
|
|
/// ```rust,no_run
|
|
/// #[subxt::subxt(
|
|
/// runtime_metadata_path = "../artifacts/polkadot_metadata_full.scale",
|
|
/// derive_for_all_types = "Eq, PartialEq"
|
|
/// )]
|
|
/// mod polkadot {}
|
|
/// ```
|
|
///
|
|
/// Any substituted types (including the default substitutes) must also implement these traits in order to avoid errors
|
|
/// here.
|
|
///
|
|
/// ## `derive_for_type(path = "...", derive = "...")`
|
|
///
|
|
/// Unlike the above, which derives some trait on every generated type, this attribute allows you to derive traits only
|
|
/// for specific types. Note that any types which are used inside the specified type may also need to derive the same traits.
|
|
///
|
|
/// ```rust,no_run
|
|
/// #[subxt::subxt(
|
|
/// runtime_metadata_path = "../artifacts/polkadot_metadata_full.scale",
|
|
/// derive_for_all_types = "Eq, PartialEq",
|
|
/// derive_for_type(path = "frame_support::PalletId", derive = "Ord, PartialOrd"),
|
|
/// derive_for_type(path = "sp_runtime::ModuleError", derive = "Hash"),
|
|
/// )]
|
|
/// mod polkadot {}
|
|
/// ```
|
|
///
|
|
/// ## `runtime_metadata_url = "..."`
|
|
///
|
|
/// This attribute can be used instead of `runtime_metadata_path` and will tell the macro to download metadata from a node running
|
|
/// at the provided URL, rather than a node running locally. This can be useful in CI, but is **not recommended** in production code,
|
|
/// since it runs at compile time and will cause compilation to fail if the node at the given address is unavailable or unresponsive.
|
|
///
|
|
/// ```rust,ignore
|
|
/// #[subxt::subxt(
|
|
/// runtime_metadata_url = "wss://rpc.polkadot.io:443"
|
|
/// )]
|
|
/// mod polkadot {}
|
|
/// ```
|
|
///
|
|
/// ## `generate_docs`
|
|
///
|
|
/// By default, documentation is not generated via the macro, since IDEs do not typically make use of it. This attribute
|
|
/// forces documentation to be generated, too.
|
|
///
|
|
/// ```rust,no_run
|
|
/// #[subxt::subxt(
|
|
/// runtime_metadata_path = "../artifacts/polkadot_metadata_full.scale",
|
|
/// generate_docs
|
|
/// )]
|
|
/// mod polkadot {}
|
|
/// ```
|
|
///
|
|
/// ## `runtime_types_only`
|
|
///
|
|
/// By default, the macro will generate various interfaces to make using Subxt simpler in addition with any types that need
|
|
/// generating to make this possible. This attribute makes the codegen only generate the types and not the Subxt interface.
|
|
///
|
|
/// ```rust,no_run
|
|
/// #[subxt::subxt(
|
|
/// runtime_metadata_path = "../artifacts/polkadot_metadata_full.scale",
|
|
/// runtime_types_only
|
|
/// )]
|
|
/// mod polkadot {}
|
|
/// ```
|
|
/// ## `no_default_derives`
|
|
///
|
|
/// By default, the macro will add all derives necessary for the generated code to play nicely with Subxt. Adding this attribute
|
|
/// removes all default derives.
|
|
///
|
|
/// ```rust,no_run
|
|
/// #[subxt::subxt(
|
|
/// runtime_metadata_path = "../artifacts/polkadot_metadata_full.scale",
|
|
/// runtime_types_only,
|
|
/// no_default_derives,
|
|
/// derive_for_all_types="codec::Encode, codec::Decode"
|
|
/// )]
|
|
/// mod polkadot {}
|
|
/// ```
|
|
///
|
|
/// **Note**: At the moment, you must derive at least one of `codec::Encode` or `codec::Decode` or `scale_encode::EncodeAsType` or
|
|
/// `scale_decode::DecodeAsType` (because we add `#[codec(..)]` attributes on some fields/types during codegen), and you must use this
|
|
/// feature in conjunction with `runtime_types_only` (or manually specify a bunch of defaults to make codegen work properly when
|
|
/// generating the subxt interfaces).
|
|
pub use subxt_macro::subxt;
|