mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-06-20 11:41:02 +00:00
Allow tx payloads to be boxed (#1690)
* Allow tx payloads to be boxed * Add example of boxed payloads * explicit box import * box import at top * cargo fmt
This commit is contained in:
@@ -9,6 +9,7 @@ use crate::error::MetadataError;
|
|||||||
use crate::metadata::Metadata;
|
use crate::metadata::Metadata;
|
||||||
use crate::Error;
|
use crate::Error;
|
||||||
use alloc::borrow::{Cow, ToOwned};
|
use alloc::borrow::{Cow, ToOwned};
|
||||||
|
use alloc::boxed::Box;
|
||||||
use alloc::string::String;
|
use alloc::string::String;
|
||||||
|
|
||||||
use alloc::vec::Vec;
|
use alloc::vec::Vec;
|
||||||
@@ -38,6 +39,32 @@ pub trait Payload {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
macro_rules! boxed_payload {
|
||||||
|
($ty:path) => {
|
||||||
|
impl<T: Payload + ?Sized> Payload for $ty {
|
||||||
|
fn encode_call_data_to(
|
||||||
|
&self,
|
||||||
|
metadata: &Metadata,
|
||||||
|
out: &mut Vec<u8>,
|
||||||
|
) -> Result<(), Error> {
|
||||||
|
self.as_ref().encode_call_data_to(metadata, out)
|
||||||
|
}
|
||||||
|
fn encode_call_data(&self, metadata: &Metadata) -> Result<Vec<u8>, Error> {
|
||||||
|
self.as_ref().encode_call_data(metadata)
|
||||||
|
}
|
||||||
|
fn validation_details(&self) -> Option<ValidationDetails<'_>> {
|
||||||
|
self.as_ref().validation_details()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
boxed_payload!(Box<T>);
|
||||||
|
#[cfg(feature = "std")]
|
||||||
|
boxed_payload!(std::sync::Arc<T>);
|
||||||
|
#[cfg(feature = "std")]
|
||||||
|
boxed_payload!(std::rc::Rc<T>);
|
||||||
|
|
||||||
/// Details required to validate the shape of a transaction payload against some metadata.
|
/// Details required to validate the shape of a transaction payload against some metadata.
|
||||||
pub struct ValidationDetails<'a> {
|
pub struct ValidationDetails<'a> {
|
||||||
/// The pallet name.
|
/// The pallet name.
|
||||||
|
|||||||
@@ -0,0 +1,43 @@
|
|||||||
|
#![allow(missing_docs)]
|
||||||
|
use subxt::{OnlineClient, PolkadotConfig};
|
||||||
|
use subxt_signer::sr25519::dev;
|
||||||
|
|
||||||
|
#[subxt::subxt(runtime_metadata_path = "../artifacts/polkadot_metadata_small.scale")]
|
||||||
|
pub mod polkadot {}
|
||||||
|
|
||||||
|
#[tokio::main]
|
||||||
|
async fn main() -> Result<(), Box<dyn std::error::Error>> {
|
||||||
|
let api = OnlineClient::<PolkadotConfig>::new().await?;
|
||||||
|
|
||||||
|
// Prepare some extrinsics. These are boxed so that they can live alongside each other.
|
||||||
|
let txs = [dynamic_remark(), balance_transfer(), remark()];
|
||||||
|
|
||||||
|
for tx in txs {
|
||||||
|
let from = dev::alice();
|
||||||
|
api.tx()
|
||||||
|
.sign_and_submit_then_watch_default(&tx, &from)
|
||||||
|
.await?
|
||||||
|
.wait_for_finalized_success()
|
||||||
|
.await?;
|
||||||
|
|
||||||
|
println!("Submitted tx");
|
||||||
|
}
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
|
fn balance_transfer() -> Box<dyn subxt::tx::Payload> {
|
||||||
|
let dest = dev::bob().public_key().into();
|
||||||
|
Box::new(polkadot::tx().balances().transfer_allow_death(dest, 10_000))
|
||||||
|
}
|
||||||
|
|
||||||
|
fn remark() -> Box<dyn subxt::tx::Payload> {
|
||||||
|
Box::new(polkadot::tx().system().remark(vec![1, 2, 3, 4, 5]))
|
||||||
|
}
|
||||||
|
|
||||||
|
fn dynamic_remark() -> Box<dyn subxt::tx::Payload> {
|
||||||
|
use subxt::dynamic::{tx, Value};
|
||||||
|
let tx_payload = tx("System", "remark", vec![Value::from_bytes("Hello")]);
|
||||||
|
|
||||||
|
Box::new(tx_payload)
|
||||||
|
}
|
||||||
@@ -196,6 +196,14 @@
|
|||||||
//! This example doesn't wait for the transaction to be included in a block; it just submits it and
|
//! This example doesn't wait for the transaction to be included in a block; it just submits it and
|
||||||
//! hopes for the best!
|
//! hopes for the best!
|
||||||
//!
|
//!
|
||||||
|
//! ### Boxing transaction payloads
|
||||||
|
//!
|
||||||
|
//! Transaction payloads can be boxed so that they all share a common type and can be stored together.
|
||||||
|
//!
|
||||||
|
//! ```rust,ignore
|
||||||
|
#![doc = include_str!("../../../examples/tx_boxed.rs")]
|
||||||
|
//! ```
|
||||||
|
//!
|
||||||
//! ### Custom handling of transaction status updates
|
//! ### Custom handling of transaction status updates
|
||||||
//!
|
//!
|
||||||
//! If you'd like more control or visibility over exactly which status updates are being emitted for
|
//! If you'd like more control or visibility over exactly which status updates are being emitted for
|
||||||
|
|||||||
Reference in New Issue
Block a user