mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-05-30 17:31:03 +00:00
Encode and estimate Rococo/Wococo/Kusama/Polkadot messages (#1322)
* encode and estimate Rococo/Wococo/Kusama/Polkadot messages * allow send-message for non-bundled chains * weight -> dispatch-weight * fmt * fix spelling
This commit is contained in:
committed by
Bastian Köcher
parent
097a28418b
commit
efa3e97210
@@ -17,7 +17,7 @@
|
|||||||
#![cfg_attr(not(feature = "std"), no_std)]
|
#![cfg_attr(not(feature = "std"), no_std)]
|
||||||
|
|
||||||
use bp_messages::MessageNonce;
|
use bp_messages::MessageNonce;
|
||||||
use bp_runtime::Chain;
|
use bp_runtime::{Chain, EncodedOrDecodedCall};
|
||||||
use frame_support::{
|
use frame_support::{
|
||||||
dispatch::Dispatchable,
|
dispatch::Dispatchable,
|
||||||
parameter_types,
|
parameter_types,
|
||||||
@@ -228,8 +228,12 @@ pub type SignedBlock = generic::SignedBlock<Block>;
|
|||||||
pub type Balance = u128;
|
pub type Balance = u128;
|
||||||
|
|
||||||
/// Unchecked Extrinsic type.
|
/// Unchecked Extrinsic type.
|
||||||
pub type UncheckedExtrinsic<Call> =
|
pub type UncheckedExtrinsic<Call> = generic::UncheckedExtrinsic<
|
||||||
generic::UncheckedExtrinsic<AccountAddress, Call, Signature, SignedExtensions<Call>>;
|
AccountAddress,
|
||||||
|
EncodedOrDecodedCall<Call>,
|
||||||
|
Signature,
|
||||||
|
SignedExtensions<Call>,
|
||||||
|
>;
|
||||||
|
|
||||||
/// Account address, used by the Polkadot-like chain.
|
/// Account address, used by the Polkadot-like chain.
|
||||||
pub type Address = MultiAddress<AccountId, ()>;
|
pub type Address = MultiAddress<AccountId, ()>;
|
||||||
@@ -336,12 +340,12 @@ where
|
|||||||
|
|
||||||
fn pre_dispatch(
|
fn pre_dispatch(
|
||||||
self,
|
self,
|
||||||
who: &Self::AccountId,
|
_who: &Self::AccountId,
|
||||||
call: &Self::Call,
|
_call: &Self::Call,
|
||||||
info: &DispatchInfoOf<Self::Call>,
|
_info: &DispatchInfoOf<Self::Call>,
|
||||||
len: usize,
|
_len: usize,
|
||||||
) -> Result<Self::Pre, TransactionValidityError> {
|
) -> Result<Self::Pre, TransactionValidityError> {
|
||||||
Ok(self.validate(who, call, info, len).map(|_| ())?)
|
Ok(())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -14,6 +14,7 @@
|
|||||||
// You should have received a copy of the GNU General Public License
|
// You should have received a copy of the GNU General Public License
|
||||||
// along with Parity Bridges Common. If not, see <http://www.gnu.org/licenses/>.
|
// along with Parity Bridges Common. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
use codec::{Decode, Encode};
|
||||||
use frame_support::{weights::Weight, Parameter};
|
use frame_support::{weights::Weight, Parameter};
|
||||||
use num_traits::{AsPrimitive, Bounded, CheckedSub, Saturating, SaturatingAdd, Zero};
|
use num_traits::{AsPrimitive, Bounded, CheckedSub, Saturating, SaturatingAdd, Zero};
|
||||||
use sp_runtime::{
|
use sp_runtime::{
|
||||||
@@ -23,7 +24,69 @@ use sp_runtime::{
|
|||||||
},
|
},
|
||||||
FixedPointOperand,
|
FixedPointOperand,
|
||||||
};
|
};
|
||||||
use sp_std::{convert::TryFrom, fmt::Debug, hash::Hash, str::FromStr};
|
use sp_std::{convert::TryFrom, fmt::Debug, hash::Hash, str::FromStr, vec, vec::Vec};
|
||||||
|
|
||||||
|
/// Chain call, that is either SCALE-encoded, or decoded.
|
||||||
|
#[derive(Debug, Clone)]
|
||||||
|
pub enum EncodedOrDecodedCall<ChainCall> {
|
||||||
|
/// The call that is SCALE-encoded.
|
||||||
|
///
|
||||||
|
/// This variant is used when we the chain runtime is not bundled with the relay, but
|
||||||
|
/// we still need the represent call in some RPC calls or transactions.
|
||||||
|
Encoded(Vec<u8>),
|
||||||
|
/// The decoded call.
|
||||||
|
Decoded(ChainCall),
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<ChainCall: Clone + Decode> EncodedOrDecodedCall<ChainCall> {
|
||||||
|
/// Returns decoded call.
|
||||||
|
pub fn to_decoded(&self) -> Result<ChainCall, codec::Error> {
|
||||||
|
match self {
|
||||||
|
Self::Encoded(ref encoded_call) =>
|
||||||
|
ChainCall::decode(&mut &encoded_call[..]).map_err(Into::into),
|
||||||
|
Self::Decoded(ref decoded_call) => Ok(decoded_call.clone()),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Converts self to decoded call.
|
||||||
|
pub fn into_decoded(self) -> Result<ChainCall, codec::Error> {
|
||||||
|
match self {
|
||||||
|
Self::Encoded(encoded_call) =>
|
||||||
|
ChainCall::decode(&mut &encoded_call[..]).map_err(Into::into),
|
||||||
|
Self::Decoded(decoded_call) => Ok(decoded_call),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<ChainCall> From<ChainCall> for EncodedOrDecodedCall<ChainCall> {
|
||||||
|
fn from(call: ChainCall) -> EncodedOrDecodedCall<ChainCall> {
|
||||||
|
EncodedOrDecodedCall::Decoded(call)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<ChainCall: Decode> Decode for EncodedOrDecodedCall<ChainCall> {
|
||||||
|
fn decode<I: codec::Input>(input: &mut I) -> Result<Self, codec::Error> {
|
||||||
|
// having encoded version is better than decoded, because decoding isn't required
|
||||||
|
// everywhere and for mocked calls it may lead to **unneeded** errors
|
||||||
|
match input.remaining_len()? {
|
||||||
|
Some(remaining_len) => {
|
||||||
|
let mut encoded_call = vec![0u8; remaining_len];
|
||||||
|
input.read(&mut encoded_call)?;
|
||||||
|
Ok(EncodedOrDecodedCall::Encoded(encoded_call))
|
||||||
|
},
|
||||||
|
None => Ok(EncodedOrDecodedCall::Decoded(ChainCall::decode(input)?)),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<ChainCall: Encode> Encode for EncodedOrDecodedCall<ChainCall> {
|
||||||
|
fn encode(&self) -> Vec<u8> {
|
||||||
|
match *self {
|
||||||
|
Self::Encoded(ref encoded_call) => encoded_call.clone(),
|
||||||
|
Self::Decoded(ref decoded_call) => decoded_call.encode(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// Minimal Substrate-based chain representation that may be used from no_std environment.
|
/// Minimal Substrate-based chain representation that may be used from no_std environment.
|
||||||
pub trait Chain: Send + Sync + 'static {
|
pub trait Chain: Send + Sync + 'static {
|
||||||
|
|||||||
@@ -25,8 +25,8 @@ use sp_io::hashing::blake2_256;
|
|||||||
use sp_std::{convert::TryFrom, vec, vec::Vec};
|
use sp_std::{convert::TryFrom, vec, vec::Vec};
|
||||||
|
|
||||||
pub use chain::{
|
pub use chain::{
|
||||||
AccountIdOf, AccountPublicOf, BalanceOf, BlockNumberOf, Chain, HashOf, HasherOf, HeaderOf,
|
AccountIdOf, AccountPublicOf, BalanceOf, BlockNumberOf, Chain, EncodedOrDecodedCall, HashOf,
|
||||||
IndexOf, SignatureOf, TransactionEraOf,
|
HasherOf, HeaderOf, IndexOf, SignatureOf, TransactionEraOf,
|
||||||
};
|
};
|
||||||
pub use frame_support::storage::storage_prefix as storage_value_final_key;
|
pub use frame_support::storage::storage_prefix as storage_value_final_key;
|
||||||
pub use storage_proof::{Error as StorageProofError, StorageProofChecker};
|
pub use storage_proof::{Error as StorageProofError, StorageProofChecker};
|
||||||
|
|||||||
@@ -14,6 +14,9 @@
|
|||||||
// You should have received a copy of the GNU General Public License
|
// You should have received a copy of the GNU General Public License
|
||||||
// along with Parity Bridges Common. If not, see <http://www.gnu.org/licenses/>.
|
// along with Parity Bridges Common. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
use anyhow::anyhow;
|
||||||
|
use bp_message_dispatch::{CallOrigin, MessagePayload};
|
||||||
|
use bp_runtime::EncodedOrDecodedCall;
|
||||||
use codec::Decode;
|
use codec::Decode;
|
||||||
use frame_support::weights::{DispatchClass, DispatchInfo, Pays, Weight};
|
use frame_support::weights::{DispatchClass, DispatchInfo, Pays, Weight};
|
||||||
use relay_kusama_client::Kusama;
|
use relay_kusama_client::Kusama;
|
||||||
@@ -21,8 +24,10 @@ use sp_version::RuntimeVersion;
|
|||||||
|
|
||||||
use crate::cli::{
|
use crate::cli::{
|
||||||
bridge,
|
bridge,
|
||||||
encode_call::{Call, CliEncodeCall},
|
encode_call::{self, Call, CliEncodeCall},
|
||||||
encode_message, CliChain,
|
encode_message,
|
||||||
|
send_message::{self, DispatchFeePayment},
|
||||||
|
CliChain,
|
||||||
};
|
};
|
||||||
|
|
||||||
/// Weight of the `system::remark` call at Kusama.
|
/// Weight of the `system::remark` call at Kusama.
|
||||||
@@ -32,13 +37,15 @@ use crate::cli::{
|
|||||||
pub(crate) const SYSTEM_REMARK_CALL_WEIGHT: Weight = 2 * 1_345_000;
|
pub(crate) const SYSTEM_REMARK_CALL_WEIGHT: Weight = 2 * 1_345_000;
|
||||||
|
|
||||||
impl CliEncodeCall for Kusama {
|
impl CliEncodeCall for Kusama {
|
||||||
fn encode_call(call: &Call) -> anyhow::Result<Self::Call> {
|
fn encode_call(call: &Call) -> anyhow::Result<EncodedOrDecodedCall<Self::Call>> {
|
||||||
Ok(match call {
|
Ok(match call {
|
||||||
|
Call::Raw { data } => EncodedOrDecodedCall::Encoded(data.0.clone()),
|
||||||
Call::Remark { remark_payload, .. } => relay_kusama_client::runtime::Call::System(
|
Call::Remark { remark_payload, .. } => relay_kusama_client::runtime::Call::System(
|
||||||
relay_kusama_client::runtime::SystemCall::remark(
|
relay_kusama_client::runtime::SystemCall::remark(
|
||||||
remark_payload.as_ref().map(|x| x.0.clone()).unwrap_or_default(),
|
remark_payload.as_ref().map(|x| x.0.clone()).unwrap_or_default(),
|
||||||
),
|
),
|
||||||
),
|
)
|
||||||
|
.into(),
|
||||||
Call::BridgeSendMessage { lane, payload, fee, bridge_instance_index } =>
|
Call::BridgeSendMessage { lane, payload, fee, bridge_instance_index } =>
|
||||||
match *bridge_instance_index {
|
match *bridge_instance_index {
|
||||||
bridge::KUSAMA_TO_POLKADOT_INDEX => {
|
bridge::KUSAMA_TO_POLKADOT_INDEX => {
|
||||||
@@ -48,6 +55,7 @@ impl CliEncodeCall for Kusama {
|
|||||||
lane.0, payload, fee.0,
|
lane.0, payload, fee.0,
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
.into()
|
||||||
},
|
},
|
||||||
_ => anyhow::bail!(
|
_ => anyhow::bail!(
|
||||||
"Unsupported target bridge pallet with instance index: {}",
|
"Unsupported target bridge pallet with instance index: {}",
|
||||||
@@ -58,13 +66,11 @@ impl CliEncodeCall for Kusama {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_dispatch_info(
|
fn get_dispatch_info(call: &EncodedOrDecodedCall<Self::Call>) -> anyhow::Result<DispatchInfo> {
|
||||||
call: &relay_kusama_client::runtime::Call,
|
|
||||||
) -> anyhow::Result<DispatchInfo> {
|
|
||||||
match *call {
|
match *call {
|
||||||
relay_kusama_client::runtime::Call::System(
|
EncodedOrDecodedCall::Decoded(relay_kusama_client::runtime::Call::System(
|
||||||
relay_kusama_client::runtime::SystemCall::remark(_),
|
relay_kusama_client::runtime::SystemCall::remark(_),
|
||||||
) => Ok(DispatchInfo {
|
)) => Ok(DispatchInfo {
|
||||||
weight: crate::chains::kusama::SYSTEM_REMARK_CALL_WEIGHT,
|
weight: crate::chains::kusama::SYSTEM_REMARK_CALL_WEIGHT,
|
||||||
class: DispatchClass::Normal,
|
class: DispatchClass::Normal,
|
||||||
pays_fee: Pays::Yes,
|
pays_fee: Pays::Yes,
|
||||||
@@ -78,7 +84,12 @@ impl CliChain for Kusama {
|
|||||||
const RUNTIME_VERSION: RuntimeVersion = bp_kusama::VERSION;
|
const RUNTIME_VERSION: RuntimeVersion = bp_kusama::VERSION;
|
||||||
|
|
||||||
type KeyPair = sp_core::sr25519::Pair;
|
type KeyPair = sp_core::sr25519::Pair;
|
||||||
type MessagePayload = ();
|
type MessagePayload = MessagePayload<
|
||||||
|
bp_kusama::AccountId,
|
||||||
|
bp_polkadot::AccountPublic,
|
||||||
|
bp_polkadot::Signature,
|
||||||
|
Vec<u8>,
|
||||||
|
>;
|
||||||
|
|
||||||
fn ss58_format() -> u16 {
|
fn ss58_format() -> u16 {
|
||||||
sp_core::crypto::Ss58AddressFormat::from(
|
sp_core::crypto::Ss58AddressFormat::from(
|
||||||
@@ -88,8 +99,37 @@ impl CliChain for Kusama {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fn encode_message(
|
fn encode_message(
|
||||||
_message: encode_message::MessagePayload,
|
message: encode_message::MessagePayload,
|
||||||
) -> anyhow::Result<Self::MessagePayload> {
|
) -> anyhow::Result<Self::MessagePayload> {
|
||||||
anyhow::bail!("Sending messages from Kusama is not yet supported.")
|
match message {
|
||||||
|
encode_message::MessagePayload::Raw { data } => MessagePayload::decode(&mut &*data.0)
|
||||||
|
.map_err(|e| anyhow!("Failed to decode Kusama's MessagePayload: {:?}", e)),
|
||||||
|
encode_message::MessagePayload::Call { mut call, mut sender, dispatch_weight } => {
|
||||||
|
type Source = Kusama;
|
||||||
|
type Target = relay_polkadot_client::Polkadot;
|
||||||
|
|
||||||
|
sender.enforce_chain::<Source>();
|
||||||
|
let spec_version = Target::RUNTIME_VERSION.spec_version;
|
||||||
|
let origin = CallOrigin::SourceAccount(sender.raw_id());
|
||||||
|
encode_call::preprocess_call::<Source, Target>(
|
||||||
|
&mut call,
|
||||||
|
bridge::KUSAMA_TO_POLKADOT_INDEX,
|
||||||
|
);
|
||||||
|
let call = Target::encode_call(&call)?;
|
||||||
|
let dispatch_weight = dispatch_weight.map(Ok).unwrap_or_else(|| {
|
||||||
|
Err(anyhow::format_err!(
|
||||||
|
"Please specify dispatch weight of the encoded Polkadot call"
|
||||||
|
))
|
||||||
|
})?;
|
||||||
|
|
||||||
|
Ok(send_message::message_payload(
|
||||||
|
spec_version,
|
||||||
|
dispatch_weight,
|
||||||
|
origin,
|
||||||
|
&call,
|
||||||
|
DispatchFeePayment::AtSourceChain,
|
||||||
|
))
|
||||||
|
},
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -82,7 +82,7 @@ pub(crate) async fn update_polkadot_to_kusama_conversion_rate(
|
|||||||
let (spec_version, transaction_version) = client.simple_runtime_version().await?;
|
let (spec_version, transaction_version) = client.simple_runtime_version().await?;
|
||||||
client
|
client
|
||||||
.submit_signed_extrinsic(signer_id, move |_, transaction_nonce| {
|
.submit_signed_extrinsic(signer_id, move |_, transaction_nonce| {
|
||||||
Bytes(
|
Ok(Bytes(
|
||||||
Kusama::sign_transaction(SignParam {
|
Kusama::sign_transaction(SignParam {
|
||||||
spec_version,
|
spec_version,
|
||||||
transaction_version,
|
transaction_version,
|
||||||
@@ -96,12 +96,12 @@ pub(crate) async fn update_polkadot_to_kusama_conversion_rate(
|
|||||||
sp_runtime::FixedU128::from_float(updated_rate),
|
sp_runtime::FixedU128::from_float(updated_rate),
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
),
|
).into(),
|
||||||
transaction_nonce,
|
transaction_nonce,
|
||||||
),
|
),
|
||||||
})
|
})?
|
||||||
.encode(),
|
.encode(),
|
||||||
)
|
))
|
||||||
})
|
})
|
||||||
.await
|
.await
|
||||||
.map(drop)
|
.map(drop)
|
||||||
|
|||||||
@@ -25,24 +25,27 @@ use crate::cli::{
|
|||||||
};
|
};
|
||||||
use anyhow::anyhow;
|
use anyhow::anyhow;
|
||||||
use bp_message_dispatch::{CallOrigin, MessagePayload};
|
use bp_message_dispatch::{CallOrigin, MessagePayload};
|
||||||
|
use bp_runtime::EncodedOrDecodedCall;
|
||||||
use codec::Decode;
|
use codec::Decode;
|
||||||
use frame_support::weights::{DispatchInfo, GetDispatchInfo};
|
use frame_support::weights::{DispatchInfo, GetDispatchInfo};
|
||||||
use relay_millau_client::Millau;
|
use relay_millau_client::Millau;
|
||||||
use sp_version::RuntimeVersion;
|
use sp_version::RuntimeVersion;
|
||||||
|
|
||||||
impl CliEncodeCall for Millau {
|
impl CliEncodeCall for Millau {
|
||||||
fn encode_call(call: &Call) -> anyhow::Result<Self::Call> {
|
fn encode_call(call: &Call) -> anyhow::Result<EncodedOrDecodedCall<Self::Call>> {
|
||||||
Ok(match call {
|
Ok(match call {
|
||||||
Call::Raw { data } => Decode::decode(&mut &*data.0)?,
|
Call::Raw { data } => Self::Call::decode(&mut &*data.0)?.into(),
|
||||||
Call::Remark { remark_payload, .. } =>
|
Call::Remark { remark_payload, .. } =>
|
||||||
millau_runtime::Call::System(millau_runtime::SystemCall::remark {
|
millau_runtime::Call::System(millau_runtime::SystemCall::remark {
|
||||||
remark: remark_payload.as_ref().map(|x| x.0.clone()).unwrap_or_default(),
|
remark: remark_payload.as_ref().map(|x| x.0.clone()).unwrap_or_default(),
|
||||||
}),
|
})
|
||||||
|
.into(),
|
||||||
Call::Transfer { recipient, amount } =>
|
Call::Transfer { recipient, amount } =>
|
||||||
millau_runtime::Call::Balances(millau_runtime::BalancesCall::transfer {
|
millau_runtime::Call::Balances(millau_runtime::BalancesCall::transfer {
|
||||||
dest: recipient.raw_id(),
|
dest: recipient.raw_id(),
|
||||||
value: amount.cast(),
|
value: amount.cast(),
|
||||||
}),
|
})
|
||||||
|
.into(),
|
||||||
Call::BridgeSendMessage { lane, payload, fee, bridge_instance_index } =>
|
Call::BridgeSendMessage { lane, payload, fee, bridge_instance_index } =>
|
||||||
match *bridge_instance_index {
|
match *bridge_instance_index {
|
||||||
bridge::MILLAU_TO_RIALTO_INDEX => {
|
bridge::MILLAU_TO_RIALTO_INDEX => {
|
||||||
@@ -54,6 +57,7 @@ impl CliEncodeCall for Millau {
|
|||||||
delivery_and_dispatch_fee: fee.cast(),
|
delivery_and_dispatch_fee: fee.cast(),
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
.into()
|
||||||
},
|
},
|
||||||
_ => anyhow::bail!(
|
_ => anyhow::bail!(
|
||||||
"Unsupported target bridge pallet with instance index: {}",
|
"Unsupported target bridge pallet with instance index: {}",
|
||||||
@@ -63,8 +67,8 @@ impl CliEncodeCall for Millau {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_dispatch_info(call: &millau_runtime::Call) -> anyhow::Result<DispatchInfo> {
|
fn get_dispatch_info(call: &EncodedOrDecodedCall<Self::Call>) -> anyhow::Result<DispatchInfo> {
|
||||||
Ok(call.get_dispatch_info())
|
Ok(call.to_decoded()?.get_dispatch_info())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -90,7 +94,7 @@ impl CliChain for Millau {
|
|||||||
match message {
|
match message {
|
||||||
encode_message::MessagePayload::Raw { data } => MessagePayload::decode(&mut &*data.0)
|
encode_message::MessagePayload::Raw { data } => MessagePayload::decode(&mut &*data.0)
|
||||||
.map_err(|e| anyhow!("Failed to decode Millau's MessagePayload: {:?}", e)),
|
.map_err(|e| anyhow!("Failed to decode Millau's MessagePayload: {:?}", e)),
|
||||||
encode_message::MessagePayload::Call { mut call, mut sender } => {
|
encode_message::MessagePayload::Call { mut call, mut sender, dispatch_weight } => {
|
||||||
type Source = Millau;
|
type Source = Millau;
|
||||||
type Target = relay_rialto_client::Rialto;
|
type Target = relay_rialto_client::Rialto;
|
||||||
|
|
||||||
@@ -102,11 +106,13 @@ impl CliChain for Millau {
|
|||||||
bridge::MILLAU_TO_RIALTO_INDEX,
|
bridge::MILLAU_TO_RIALTO_INDEX,
|
||||||
);
|
);
|
||||||
let call = Target::encode_call(&call)?;
|
let call = Target::encode_call(&call)?;
|
||||||
let weight = call.get_dispatch_info().weight;
|
let dispatch_weight = dispatch_weight.map(Ok).unwrap_or_else(|| {
|
||||||
|
call.to_decoded().map(|call| call.get_dispatch_info().weight)
|
||||||
|
})?;
|
||||||
|
|
||||||
Ok(send_message::message_payload(
|
Ok(send_message::message_payload(
|
||||||
spec_version,
|
spec_version,
|
||||||
weight,
|
dispatch_weight,
|
||||||
origin,
|
origin,
|
||||||
&call,
|
&call,
|
||||||
DispatchFeePayment::AtSourceChain,
|
DispatchFeePayment::AtSourceChain,
|
||||||
|
|||||||
@@ -74,7 +74,7 @@ pub(crate) async fn update_rialto_to_millau_conversion_rate(
|
|||||||
let (spec_version, transaction_version) = client.simple_runtime_version().await?;
|
let (spec_version, transaction_version) = client.simple_runtime_version().await?;
|
||||||
client
|
client
|
||||||
.submit_signed_extrinsic(signer_id, move |_, transaction_nonce| {
|
.submit_signed_extrinsic(signer_id, move |_, transaction_nonce| {
|
||||||
Bytes(
|
Ok(Bytes(
|
||||||
Millau::sign_transaction(SignParam {
|
Millau::sign_transaction(SignParam {
|
||||||
spec_version,
|
spec_version,
|
||||||
transaction_version,
|
transaction_version,
|
||||||
@@ -82,17 +82,16 @@ pub(crate) async fn update_rialto_to_millau_conversion_rate(
|
|||||||
signer,
|
signer,
|
||||||
era: relay_substrate_client::TransactionEra::immortal(),
|
era: relay_substrate_client::TransactionEra::immortal(),
|
||||||
unsigned: UnsignedTransaction::new(
|
unsigned: UnsignedTransaction::new(
|
||||||
millau_runtime::MessagesCall::update_pallet_parameter {
|
millau_runtime::Call::from(millau_runtime::MessagesCall::update_pallet_parameter {
|
||||||
parameter: millau_runtime::rialto_messages::MillauToRialtoMessagesParameter::RialtoToMillauConversionRate(
|
parameter: millau_runtime::rialto_messages::MillauToRialtoMessagesParameter::RialtoToMillauConversionRate(
|
||||||
sp_runtime::FixedU128::from_float(updated_rate),
|
sp_runtime::FixedU128::from_float(updated_rate),
|
||||||
),
|
),
|
||||||
}
|
}).into(),
|
||||||
.into(),
|
|
||||||
transaction_nonce,
|
transaction_nonce,
|
||||||
),
|
),
|
||||||
})
|
})?
|
||||||
.encode(),
|
.encode(),
|
||||||
)
|
))
|
||||||
})
|
})
|
||||||
.await
|
.await
|
||||||
.map(drop)
|
.map(drop)
|
||||||
|
|||||||
@@ -210,8 +210,9 @@ mod tests {
|
|||||||
genesis_hash: Default::default(),
|
genesis_hash: Default::default(),
|
||||||
signer: sp_keyring::AccountKeyring::Alice.pair(),
|
signer: sp_keyring::AccountKeyring::Alice.pair(),
|
||||||
era: relay_substrate_client::TransactionEra::immortal(),
|
era: relay_substrate_client::TransactionEra::immortal(),
|
||||||
unsigned: UnsignedTransaction::new(rialto_call.clone(), 0),
|
unsigned: UnsignedTransaction::new(rialto_call.clone().into(), 0),
|
||||||
});
|
})
|
||||||
|
.unwrap();
|
||||||
let extra_bytes_in_transaction = rialto_tx.encode().len() - rialto_call.encode().len();
|
let extra_bytes_in_transaction = rialto_tx.encode().len() - rialto_call.encode().len();
|
||||||
assert!(
|
assert!(
|
||||||
bp_rialto::TX_EXTRA_BYTES as usize >= extra_bytes_in_transaction,
|
bp_rialto::TX_EXTRA_BYTES as usize >= extra_bytes_in_transaction,
|
||||||
@@ -231,8 +232,9 @@ mod tests {
|
|||||||
genesis_hash: Default::default(),
|
genesis_hash: Default::default(),
|
||||||
signer: sp_keyring::AccountKeyring::Alice.pair(),
|
signer: sp_keyring::AccountKeyring::Alice.pair(),
|
||||||
era: relay_substrate_client::TransactionEra::immortal(),
|
era: relay_substrate_client::TransactionEra::immortal(),
|
||||||
unsigned: UnsignedTransaction::new(millau_call.clone(), 0),
|
unsigned: UnsignedTransaction::new(millau_call.clone().into(), 0),
|
||||||
});
|
})
|
||||||
|
.unwrap();
|
||||||
let extra_bytes_in_transaction = millau_tx.encode().len() - millau_call.encode().len();
|
let extra_bytes_in_transaction = millau_tx.encode().len() - millau_call.encode().len();
|
||||||
assert!(
|
assert!(
|
||||||
bp_millau::TX_EXTRA_BYTES as usize >= extra_bytes_in_transaction,
|
bp_millau::TX_EXTRA_BYTES as usize >= extra_bytes_in_transaction,
|
||||||
|
|||||||
@@ -14,6 +14,9 @@
|
|||||||
// You should have received a copy of the GNU General Public License
|
// You should have received a copy of the GNU General Public License
|
||||||
// along with Parity Bridges Common. If not, see <http://www.gnu.org/licenses/>.
|
// along with Parity Bridges Common. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
use anyhow::anyhow;
|
||||||
|
use bp_message_dispatch::{CallOrigin, MessagePayload};
|
||||||
|
use bp_runtime::EncodedOrDecodedCall;
|
||||||
use codec::Decode;
|
use codec::Decode;
|
||||||
use frame_support::weights::{DispatchClass, DispatchInfo, Pays, Weight};
|
use frame_support::weights::{DispatchClass, DispatchInfo, Pays, Weight};
|
||||||
use relay_polkadot_client::Polkadot;
|
use relay_polkadot_client::Polkadot;
|
||||||
@@ -21,8 +24,10 @@ use sp_version::RuntimeVersion;
|
|||||||
|
|
||||||
use crate::cli::{
|
use crate::cli::{
|
||||||
bridge,
|
bridge,
|
||||||
encode_call::{Call, CliEncodeCall},
|
encode_call::{self, Call, CliEncodeCall},
|
||||||
encode_message, CliChain,
|
encode_message,
|
||||||
|
send_message::{self, DispatchFeePayment},
|
||||||
|
CliChain,
|
||||||
};
|
};
|
||||||
|
|
||||||
/// Weight of the `system::remark` call at Polkadot.
|
/// Weight of the `system::remark` call at Polkadot.
|
||||||
@@ -32,13 +37,15 @@ use crate::cli::{
|
|||||||
pub(crate) const SYSTEM_REMARK_CALL_WEIGHT: Weight = 2 * 1_345_000;
|
pub(crate) const SYSTEM_REMARK_CALL_WEIGHT: Weight = 2 * 1_345_000;
|
||||||
|
|
||||||
impl CliEncodeCall for Polkadot {
|
impl CliEncodeCall for Polkadot {
|
||||||
fn encode_call(call: &Call) -> anyhow::Result<Self::Call> {
|
fn encode_call(call: &Call) -> anyhow::Result<EncodedOrDecodedCall<Self::Call>> {
|
||||||
Ok(match call {
|
Ok(match call {
|
||||||
|
Call::Raw { data } => EncodedOrDecodedCall::Encoded(data.0.clone()),
|
||||||
Call::Remark { remark_payload, .. } => relay_polkadot_client::runtime::Call::System(
|
Call::Remark { remark_payload, .. } => relay_polkadot_client::runtime::Call::System(
|
||||||
relay_polkadot_client::runtime::SystemCall::remark(
|
relay_polkadot_client::runtime::SystemCall::remark(
|
||||||
remark_payload.as_ref().map(|x| x.0.clone()).unwrap_or_default(),
|
remark_payload.as_ref().map(|x| x.0.clone()).unwrap_or_default(),
|
||||||
),
|
),
|
||||||
),
|
)
|
||||||
|
.into(),
|
||||||
Call::BridgeSendMessage { lane, payload, fee, bridge_instance_index } =>
|
Call::BridgeSendMessage { lane, payload, fee, bridge_instance_index } =>
|
||||||
match *bridge_instance_index {
|
match *bridge_instance_index {
|
||||||
bridge::POLKADOT_TO_KUSAMA_INDEX => {
|
bridge::POLKADOT_TO_KUSAMA_INDEX => {
|
||||||
@@ -48,6 +55,7 @@ impl CliEncodeCall for Polkadot {
|
|||||||
lane.0, payload, fee.0,
|
lane.0, payload, fee.0,
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
.into()
|
||||||
},
|
},
|
||||||
_ => anyhow::bail!(
|
_ => anyhow::bail!(
|
||||||
"Unsupported target bridge pallet with instance index: {}",
|
"Unsupported target bridge pallet with instance index: {}",
|
||||||
@@ -58,13 +66,11 @@ impl CliEncodeCall for Polkadot {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_dispatch_info(
|
fn get_dispatch_info(call: &EncodedOrDecodedCall<Self::Call>) -> anyhow::Result<DispatchInfo> {
|
||||||
call: &relay_polkadot_client::runtime::Call,
|
|
||||||
) -> anyhow::Result<DispatchInfo> {
|
|
||||||
match *call {
|
match *call {
|
||||||
relay_polkadot_client::runtime::Call::System(
|
EncodedOrDecodedCall::Decoded(relay_polkadot_client::runtime::Call::System(
|
||||||
relay_polkadot_client::runtime::SystemCall::remark(_),
|
relay_polkadot_client::runtime::SystemCall::remark(_),
|
||||||
) => Ok(DispatchInfo {
|
)) => Ok(DispatchInfo {
|
||||||
weight: crate::chains::polkadot::SYSTEM_REMARK_CALL_WEIGHT,
|
weight: crate::chains::polkadot::SYSTEM_REMARK_CALL_WEIGHT,
|
||||||
class: DispatchClass::Normal,
|
class: DispatchClass::Normal,
|
||||||
pays_fee: Pays::Yes,
|
pays_fee: Pays::Yes,
|
||||||
@@ -78,7 +84,12 @@ impl CliChain for Polkadot {
|
|||||||
const RUNTIME_VERSION: RuntimeVersion = bp_polkadot::VERSION;
|
const RUNTIME_VERSION: RuntimeVersion = bp_polkadot::VERSION;
|
||||||
|
|
||||||
type KeyPair = sp_core::sr25519::Pair;
|
type KeyPair = sp_core::sr25519::Pair;
|
||||||
type MessagePayload = ();
|
type MessagePayload = MessagePayload<
|
||||||
|
bp_polkadot::AccountId,
|
||||||
|
bp_kusama::AccountPublic,
|
||||||
|
bp_kusama::Signature,
|
||||||
|
Vec<u8>,
|
||||||
|
>;
|
||||||
|
|
||||||
fn ss58_format() -> u16 {
|
fn ss58_format() -> u16 {
|
||||||
sp_core::crypto::Ss58AddressFormat::from(
|
sp_core::crypto::Ss58AddressFormat::from(
|
||||||
@@ -88,8 +99,37 @@ impl CliChain for Polkadot {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fn encode_message(
|
fn encode_message(
|
||||||
_message: encode_message::MessagePayload,
|
message: encode_message::MessagePayload,
|
||||||
) -> anyhow::Result<Self::MessagePayload> {
|
) -> anyhow::Result<Self::MessagePayload> {
|
||||||
anyhow::bail!("Sending messages from Polkadot is not yet supported.")
|
match message {
|
||||||
|
encode_message::MessagePayload::Raw { data } => MessagePayload::decode(&mut &*data.0)
|
||||||
|
.map_err(|e| anyhow!("Failed to decode Polkadot's MessagePayload: {:?}", e)),
|
||||||
|
encode_message::MessagePayload::Call { mut call, mut sender, dispatch_weight } => {
|
||||||
|
type Source = Polkadot;
|
||||||
|
type Target = relay_kusama_client::Kusama;
|
||||||
|
|
||||||
|
sender.enforce_chain::<Source>();
|
||||||
|
let spec_version = Target::RUNTIME_VERSION.spec_version;
|
||||||
|
let origin = CallOrigin::SourceAccount(sender.raw_id());
|
||||||
|
encode_call::preprocess_call::<Source, Target>(
|
||||||
|
&mut call,
|
||||||
|
bridge::POLKADOT_TO_KUSAMA_INDEX,
|
||||||
|
);
|
||||||
|
let call = Target::encode_call(&call)?;
|
||||||
|
let dispatch_weight = dispatch_weight.map(Ok).unwrap_or_else(|| {
|
||||||
|
Err(anyhow::format_err!(
|
||||||
|
"Please specify dispatch weight of the encoded Kusama call"
|
||||||
|
))
|
||||||
|
})?;
|
||||||
|
|
||||||
|
Ok(send_message::message_payload(
|
||||||
|
spec_version,
|
||||||
|
dispatch_weight,
|
||||||
|
origin,
|
||||||
|
&call,
|
||||||
|
DispatchFeePayment::AtSourceChain,
|
||||||
|
))
|
||||||
|
},
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -82,7 +82,7 @@ pub(crate) async fn update_kusama_to_polkadot_conversion_rate(
|
|||||||
let (spec_version, transaction_version) = client.simple_runtime_version().await?;
|
let (spec_version, transaction_version) = client.simple_runtime_version().await?;
|
||||||
client
|
client
|
||||||
.submit_signed_extrinsic(signer_id, move |_, transaction_nonce| {
|
.submit_signed_extrinsic(signer_id, move |_, transaction_nonce| {
|
||||||
Bytes(
|
Ok(Bytes(
|
||||||
Polkadot::sign_transaction(SignParam {
|
Polkadot::sign_transaction(SignParam {
|
||||||
spec_version,
|
spec_version,
|
||||||
transaction_version,
|
transaction_version,
|
||||||
@@ -96,12 +96,12 @@ pub(crate) async fn update_kusama_to_polkadot_conversion_rate(
|
|||||||
sp_runtime::FixedU128::from_float(updated_rate),
|
sp_runtime::FixedU128::from_float(updated_rate),
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
),
|
).into(),
|
||||||
transaction_nonce,
|
transaction_nonce,
|
||||||
)
|
)
|
||||||
})
|
})?
|
||||||
.encode(),
|
.encode(),
|
||||||
)
|
))
|
||||||
})
|
})
|
||||||
.await
|
.await
|
||||||
.map(drop)
|
.map(drop)
|
||||||
|
|||||||
@@ -25,24 +25,27 @@ use crate::cli::{
|
|||||||
};
|
};
|
||||||
use anyhow::anyhow;
|
use anyhow::anyhow;
|
||||||
use bp_message_dispatch::{CallOrigin, MessagePayload};
|
use bp_message_dispatch::{CallOrigin, MessagePayload};
|
||||||
|
use bp_runtime::EncodedOrDecodedCall;
|
||||||
use codec::Decode;
|
use codec::Decode;
|
||||||
use frame_support::weights::{DispatchInfo, GetDispatchInfo};
|
use frame_support::weights::{DispatchInfo, GetDispatchInfo};
|
||||||
use relay_rialto_client::Rialto;
|
use relay_rialto_client::Rialto;
|
||||||
use sp_version::RuntimeVersion;
|
use sp_version::RuntimeVersion;
|
||||||
|
|
||||||
impl CliEncodeCall for Rialto {
|
impl CliEncodeCall for Rialto {
|
||||||
fn encode_call(call: &Call) -> anyhow::Result<Self::Call> {
|
fn encode_call(call: &Call) -> anyhow::Result<EncodedOrDecodedCall<Self::Call>> {
|
||||||
Ok(match call {
|
Ok(match call {
|
||||||
Call::Raw { data } => Decode::decode(&mut &*data.0)?,
|
Call::Raw { data } => Self::Call::decode(&mut &*data.0)?.into(),
|
||||||
Call::Remark { remark_payload, .. } =>
|
Call::Remark { remark_payload, .. } =>
|
||||||
rialto_runtime::Call::System(rialto_runtime::SystemCall::remark {
|
rialto_runtime::Call::System(rialto_runtime::SystemCall::remark {
|
||||||
remark: remark_payload.as_ref().map(|x| x.0.clone()).unwrap_or_default(),
|
remark: remark_payload.as_ref().map(|x| x.0.clone()).unwrap_or_default(),
|
||||||
}),
|
})
|
||||||
|
.into(),
|
||||||
Call::Transfer { recipient, amount } =>
|
Call::Transfer { recipient, amount } =>
|
||||||
rialto_runtime::Call::Balances(rialto_runtime::BalancesCall::transfer {
|
rialto_runtime::Call::Balances(rialto_runtime::BalancesCall::transfer {
|
||||||
dest: recipient.raw_id().into(),
|
dest: recipient.raw_id().into(),
|
||||||
value: amount.0,
|
value: amount.0,
|
||||||
}),
|
})
|
||||||
|
.into(),
|
||||||
Call::BridgeSendMessage { lane, payload, fee, bridge_instance_index } =>
|
Call::BridgeSendMessage { lane, payload, fee, bridge_instance_index } =>
|
||||||
match *bridge_instance_index {
|
match *bridge_instance_index {
|
||||||
bridge::RIALTO_TO_MILLAU_INDEX => {
|
bridge::RIALTO_TO_MILLAU_INDEX => {
|
||||||
@@ -54,6 +57,7 @@ impl CliEncodeCall for Rialto {
|
|||||||
delivery_and_dispatch_fee: fee.0,
|
delivery_and_dispatch_fee: fee.0,
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
.into()
|
||||||
},
|
},
|
||||||
_ => anyhow::bail!(
|
_ => anyhow::bail!(
|
||||||
"Unsupported target bridge pallet with instance index: {}",
|
"Unsupported target bridge pallet with instance index: {}",
|
||||||
@@ -63,8 +67,8 @@ impl CliEncodeCall for Rialto {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_dispatch_info(call: &rialto_runtime::Call) -> anyhow::Result<DispatchInfo> {
|
fn get_dispatch_info(call: &EncodedOrDecodedCall<Self::Call>) -> anyhow::Result<DispatchInfo> {
|
||||||
Ok(call.get_dispatch_info())
|
Ok(call.to_decoded()?.get_dispatch_info())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -89,7 +93,7 @@ impl CliChain for Rialto {
|
|||||||
match message {
|
match message {
|
||||||
encode_message::MessagePayload::Raw { data } => MessagePayload::decode(&mut &*data.0)
|
encode_message::MessagePayload::Raw { data } => MessagePayload::decode(&mut &*data.0)
|
||||||
.map_err(|e| anyhow!("Failed to decode Rialto's MessagePayload: {:?}", e)),
|
.map_err(|e| anyhow!("Failed to decode Rialto's MessagePayload: {:?}", e)),
|
||||||
encode_message::MessagePayload::Call { mut call, mut sender } => {
|
encode_message::MessagePayload::Call { mut call, mut sender, dispatch_weight } => {
|
||||||
type Source = Rialto;
|
type Source = Rialto;
|
||||||
type Target = relay_millau_client::Millau;
|
type Target = relay_millau_client::Millau;
|
||||||
|
|
||||||
@@ -101,11 +105,13 @@ impl CliChain for Rialto {
|
|||||||
bridge::RIALTO_TO_MILLAU_INDEX,
|
bridge::RIALTO_TO_MILLAU_INDEX,
|
||||||
);
|
);
|
||||||
let call = Target::encode_call(&call)?;
|
let call = Target::encode_call(&call)?;
|
||||||
let weight = call.get_dispatch_info().weight;
|
let dispatch_weight = dispatch_weight.map(Ok).unwrap_or_else(|| {
|
||||||
|
call.to_decoded().map(|call| call.get_dispatch_info().weight)
|
||||||
|
})?;
|
||||||
|
|
||||||
Ok(send_message::message_payload(
|
Ok(send_message::message_payload(
|
||||||
spec_version,
|
spec_version,
|
||||||
weight,
|
dispatch_weight,
|
||||||
origin,
|
origin,
|
||||||
&call,
|
&call,
|
||||||
DispatchFeePayment::AtSourceChain,
|
DispatchFeePayment::AtSourceChain,
|
||||||
|
|||||||
@@ -74,7 +74,7 @@ pub(crate) async fn update_millau_to_rialto_conversion_rate(
|
|||||||
let (spec_version, transaction_version) = client.simple_runtime_version().await?;
|
let (spec_version, transaction_version) = client.simple_runtime_version().await?;
|
||||||
client
|
client
|
||||||
.submit_signed_extrinsic(signer_id, move |_, transaction_nonce| {
|
.submit_signed_extrinsic(signer_id, move |_, transaction_nonce| {
|
||||||
Bytes(
|
Ok(Bytes(
|
||||||
Rialto::sign_transaction(SignParam {
|
Rialto::sign_transaction(SignParam {
|
||||||
spec_version,
|
spec_version,
|
||||||
transaction_version,
|
transaction_version,
|
||||||
@@ -82,17 +82,16 @@ pub(crate) async fn update_millau_to_rialto_conversion_rate(
|
|||||||
signer,
|
signer,
|
||||||
era: relay_substrate_client::TransactionEra::immortal(),
|
era: relay_substrate_client::TransactionEra::immortal(),
|
||||||
unsigned: UnsignedTransaction::new(
|
unsigned: UnsignedTransaction::new(
|
||||||
rialto_runtime::MessagesCall::update_pallet_parameter {
|
rialto_runtime::Call::from(rialto_runtime::MessagesCall::update_pallet_parameter {
|
||||||
parameter: rialto_runtime::millau_messages::RialtoToMillauMessagesParameter::MillauToRialtoConversionRate(
|
parameter: rialto_runtime::millau_messages::RialtoToMillauMessagesParameter::MillauToRialtoConversionRate(
|
||||||
sp_runtime::FixedU128::from_float(updated_rate),
|
sp_runtime::FixedU128::from_float(updated_rate),
|
||||||
),
|
),
|
||||||
}
|
}).into(),
|
||||||
.into(),
|
|
||||||
transaction_nonce,
|
transaction_nonce,
|
||||||
)
|
)
|
||||||
})
|
})?
|
||||||
.encode(),
|
.encode(),
|
||||||
)
|
))
|
||||||
})
|
})
|
||||||
.await
|
.await
|
||||||
.map(drop)
|
.map(drop)
|
||||||
|
|||||||
@@ -21,34 +21,37 @@ use crate::cli::{
|
|||||||
encode_message, CliChain,
|
encode_message, CliChain,
|
||||||
};
|
};
|
||||||
use bp_message_dispatch::MessagePayload;
|
use bp_message_dispatch::MessagePayload;
|
||||||
|
use bp_runtime::EncodedOrDecodedCall;
|
||||||
use codec::Decode;
|
use codec::Decode;
|
||||||
use frame_support::weights::{DispatchInfo, GetDispatchInfo};
|
use frame_support::weights::{DispatchInfo, GetDispatchInfo};
|
||||||
use relay_rialto_parachain_client::RialtoParachain;
|
use relay_rialto_parachain_client::RialtoParachain;
|
||||||
use sp_version::RuntimeVersion;
|
use sp_version::RuntimeVersion;
|
||||||
|
|
||||||
impl CliEncodeCall for RialtoParachain {
|
impl CliEncodeCall for RialtoParachain {
|
||||||
fn encode_call(call: &Call) -> anyhow::Result<Self::Call> {
|
fn encode_call(call: &Call) -> anyhow::Result<EncodedOrDecodedCall<Self::Call>> {
|
||||||
Ok(match call {
|
Ok(match call {
|
||||||
Call::Raw { data } => Decode::decode(&mut &*data.0)?,
|
Call::Raw { data } => Self::Call::decode(&mut &*data.0)?.into(),
|
||||||
Call::Remark { remark_payload, .. } => rialto_parachain_runtime::Call::System(
|
Call::Remark { remark_payload, .. } => rialto_parachain_runtime::Call::System(
|
||||||
rialto_parachain_runtime::SystemCall::remark {
|
rialto_parachain_runtime::SystemCall::remark {
|
||||||
remark: remark_payload.as_ref().map(|x| x.0.clone()).unwrap_or_default(),
|
remark: remark_payload.as_ref().map(|x| x.0.clone()).unwrap_or_default(),
|
||||||
},
|
},
|
||||||
),
|
)
|
||||||
|
.into(),
|
||||||
Call::Transfer { recipient, amount } => rialto_parachain_runtime::Call::Balances(
|
Call::Transfer { recipient, amount } => rialto_parachain_runtime::Call::Balances(
|
||||||
rialto_parachain_runtime::BalancesCall::transfer {
|
rialto_parachain_runtime::BalancesCall::transfer {
|
||||||
dest: recipient.raw_id().into(),
|
dest: recipient.raw_id().into(),
|
||||||
value: amount.0,
|
value: amount.0,
|
||||||
},
|
},
|
||||||
),
|
)
|
||||||
|
.into(),
|
||||||
Call::BridgeSendMessage { .. } => {
|
Call::BridgeSendMessage { .. } => {
|
||||||
anyhow::bail!("Bridge messages are not (yet) supported here",)
|
anyhow::bail!("Bridge messages are not (yet) supported here",)
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_dispatch_info(call: &rialto_parachain_runtime::Call) -> anyhow::Result<DispatchInfo> {
|
fn get_dispatch_info(call: &EncodedOrDecodedCall<Self::Call>) -> anyhow::Result<DispatchInfo> {
|
||||||
Ok(call.get_dispatch_info())
|
Ok(call.to_decoded()?.get_dispatch_info())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -15,6 +15,8 @@
|
|||||||
// along with Parity Bridges Common. If not, see <http://www.gnu.org/licenses/>.
|
// along with Parity Bridges Common. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
use anyhow::anyhow;
|
use anyhow::anyhow;
|
||||||
|
use bp_message_dispatch::{CallOrigin, MessagePayload};
|
||||||
|
use bp_runtime::EncodedOrDecodedCall;
|
||||||
use codec::Decode;
|
use codec::Decode;
|
||||||
use frame_support::weights::{DispatchClass, DispatchInfo, Pays, Weight};
|
use frame_support::weights::{DispatchClass, DispatchInfo, Pays, Weight};
|
||||||
use relay_rococo_client::Rococo;
|
use relay_rococo_client::Rococo;
|
||||||
@@ -22,8 +24,10 @@ use sp_version::RuntimeVersion;
|
|||||||
|
|
||||||
use crate::cli::{
|
use crate::cli::{
|
||||||
bridge,
|
bridge,
|
||||||
encode_call::{Call, CliEncodeCall},
|
encode_call::{self, Call, CliEncodeCall},
|
||||||
encode_message, CliChain,
|
encode_message,
|
||||||
|
send_message::{self, DispatchFeePayment},
|
||||||
|
CliChain,
|
||||||
};
|
};
|
||||||
|
|
||||||
/// Weight of the `system::remark` call at Rococo.
|
/// Weight of the `system::remark` call at Rococo.
|
||||||
@@ -33,13 +37,15 @@ use crate::cli::{
|
|||||||
pub(crate) const SYSTEM_REMARK_CALL_WEIGHT: Weight = 2 * 1_345_000;
|
pub(crate) const SYSTEM_REMARK_CALL_WEIGHT: Weight = 2 * 1_345_000;
|
||||||
|
|
||||||
impl CliEncodeCall for Rococo {
|
impl CliEncodeCall for Rococo {
|
||||||
fn encode_call(call: &Call) -> anyhow::Result<Self::Call> {
|
fn encode_call(call: &Call) -> anyhow::Result<EncodedOrDecodedCall<Self::Call>> {
|
||||||
Ok(match call {
|
Ok(match call {
|
||||||
|
Call::Raw { data } => EncodedOrDecodedCall::Encoded(data.0.clone()),
|
||||||
Call::Remark { remark_payload, .. } => relay_rococo_client::runtime::Call::System(
|
Call::Remark { remark_payload, .. } => relay_rococo_client::runtime::Call::System(
|
||||||
relay_rococo_client::runtime::SystemCall::remark(
|
relay_rococo_client::runtime::SystemCall::remark(
|
||||||
remark_payload.as_ref().map(|x| x.0.clone()).unwrap_or_default(),
|
remark_payload.as_ref().map(|x| x.0.clone()).unwrap_or_default(),
|
||||||
),
|
),
|
||||||
),
|
)
|
||||||
|
.into(),
|
||||||
Call::BridgeSendMessage { lane, payload, fee, bridge_instance_index } =>
|
Call::BridgeSendMessage { lane, payload, fee, bridge_instance_index } =>
|
||||||
match *bridge_instance_index {
|
match *bridge_instance_index {
|
||||||
bridge::ROCOCO_TO_WOCOCO_INDEX => {
|
bridge::ROCOCO_TO_WOCOCO_INDEX => {
|
||||||
@@ -49,6 +55,7 @@ impl CliEncodeCall for Rococo {
|
|||||||
lane.0, payload, fee.0,
|
lane.0, payload, fee.0,
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
.into()
|
||||||
},
|
},
|
||||||
_ => anyhow::bail!(
|
_ => anyhow::bail!(
|
||||||
"Unsupported target bridge pallet with instance index: {}",
|
"Unsupported target bridge pallet with instance index: {}",
|
||||||
@@ -59,13 +66,11 @@ impl CliEncodeCall for Rococo {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_dispatch_info(
|
fn get_dispatch_info(call: &EncodedOrDecodedCall<Self::Call>) -> anyhow::Result<DispatchInfo> {
|
||||||
call: &relay_rococo_client::runtime::Call,
|
|
||||||
) -> anyhow::Result<DispatchInfo> {
|
|
||||||
match *call {
|
match *call {
|
||||||
relay_rococo_client::runtime::Call::System(
|
EncodedOrDecodedCall::Decoded(relay_rococo_client::runtime::Call::System(
|
||||||
relay_rococo_client::runtime::SystemCall::remark(_),
|
relay_rococo_client::runtime::SystemCall::remark(_),
|
||||||
) => Ok(DispatchInfo {
|
)) => Ok(DispatchInfo {
|
||||||
weight: SYSTEM_REMARK_CALL_WEIGHT,
|
weight: SYSTEM_REMARK_CALL_WEIGHT,
|
||||||
class: DispatchClass::Normal,
|
class: DispatchClass::Normal,
|
||||||
pays_fee: Pays::Yes,
|
pays_fee: Pays::Yes,
|
||||||
@@ -79,15 +84,49 @@ impl CliChain for Rococo {
|
|||||||
const RUNTIME_VERSION: RuntimeVersion = bp_rococo::VERSION;
|
const RUNTIME_VERSION: RuntimeVersion = bp_rococo::VERSION;
|
||||||
|
|
||||||
type KeyPair = sp_core::sr25519::Pair;
|
type KeyPair = sp_core::sr25519::Pair;
|
||||||
type MessagePayload = ();
|
type MessagePayload = MessagePayload<
|
||||||
|
bp_rococo::AccountId,
|
||||||
|
bp_wococo::AccountPublic,
|
||||||
|
bp_wococo::Signature,
|
||||||
|
Vec<u8>,
|
||||||
|
>;
|
||||||
|
|
||||||
fn ss58_format() -> u16 {
|
fn ss58_format() -> u16 {
|
||||||
42
|
42
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_message(
|
fn encode_message(
|
||||||
_message: encode_message::MessagePayload,
|
message: encode_message::MessagePayload,
|
||||||
) -> anyhow::Result<Self::MessagePayload> {
|
) -> anyhow::Result<Self::MessagePayload> {
|
||||||
Err(anyhow!("Sending messages from Rococo is not yet supported."))
|
match message {
|
||||||
|
encode_message::MessagePayload::Raw { data } => MessagePayload::decode(&mut &*data.0)
|
||||||
|
.map_err(|e| anyhow!("Failed to decode Rococo's MessagePayload: {:?}", e)),
|
||||||
|
encode_message::MessagePayload::Call { mut call, mut sender, dispatch_weight } => {
|
||||||
|
type Source = Rococo;
|
||||||
|
type Target = relay_wococo_client::Wococo;
|
||||||
|
|
||||||
|
sender.enforce_chain::<Source>();
|
||||||
|
let spec_version = Target::RUNTIME_VERSION.spec_version;
|
||||||
|
let origin = CallOrigin::SourceAccount(sender.raw_id());
|
||||||
|
encode_call::preprocess_call::<Source, Target>(
|
||||||
|
&mut call,
|
||||||
|
bridge::ROCOCO_TO_WOCOCO_INDEX,
|
||||||
|
);
|
||||||
|
let call = Target::encode_call(&call)?;
|
||||||
|
let dispatch_weight = dispatch_weight.map(Ok).unwrap_or_else(|| {
|
||||||
|
Err(anyhow::format_err!(
|
||||||
|
"Please specify dispatch weight of the encoded Wococo call"
|
||||||
|
))
|
||||||
|
})?;
|
||||||
|
|
||||||
|
Ok(send_message::message_payload(
|
||||||
|
spec_version,
|
||||||
|
dispatch_weight,
|
||||||
|
origin,
|
||||||
|
&call,
|
||||||
|
DispatchFeePayment::AtSourceChain,
|
||||||
|
))
|
||||||
|
},
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -15,6 +15,8 @@
|
|||||||
// along with Parity Bridges Common. If not, see <http://www.gnu.org/licenses/>.
|
// along with Parity Bridges Common. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
use anyhow::anyhow;
|
use anyhow::anyhow;
|
||||||
|
use bp_message_dispatch::{CallOrigin, MessagePayload};
|
||||||
|
use bp_runtime::EncodedOrDecodedCall;
|
||||||
use codec::Decode;
|
use codec::Decode;
|
||||||
use frame_support::weights::{DispatchClass, DispatchInfo, Pays};
|
use frame_support::weights::{DispatchClass, DispatchInfo, Pays};
|
||||||
use relay_wococo_client::Wococo;
|
use relay_wococo_client::Wococo;
|
||||||
@@ -22,18 +24,22 @@ use sp_version::RuntimeVersion;
|
|||||||
|
|
||||||
use crate::cli::{
|
use crate::cli::{
|
||||||
bridge,
|
bridge,
|
||||||
encode_call::{Call, CliEncodeCall},
|
encode_call::{self, Call, CliEncodeCall},
|
||||||
encode_message, CliChain,
|
encode_message,
|
||||||
|
send_message::{self, DispatchFeePayment},
|
||||||
|
CliChain,
|
||||||
};
|
};
|
||||||
|
|
||||||
impl CliEncodeCall for Wococo {
|
impl CliEncodeCall for Wococo {
|
||||||
fn encode_call(call: &Call) -> anyhow::Result<Self::Call> {
|
fn encode_call(call: &Call) -> anyhow::Result<EncodedOrDecodedCall<Self::Call>> {
|
||||||
Ok(match call {
|
Ok(match call {
|
||||||
|
Call::Raw { data } => EncodedOrDecodedCall::Encoded(data.0.clone()),
|
||||||
Call::Remark { remark_payload, .. } => relay_wococo_client::runtime::Call::System(
|
Call::Remark { remark_payload, .. } => relay_wococo_client::runtime::Call::System(
|
||||||
relay_wococo_client::runtime::SystemCall::remark(
|
relay_wococo_client::runtime::SystemCall::remark(
|
||||||
remark_payload.as_ref().map(|x| x.0.clone()).unwrap_or_default(),
|
remark_payload.as_ref().map(|x| x.0.clone()).unwrap_or_default(),
|
||||||
),
|
),
|
||||||
),
|
)
|
||||||
|
.into(),
|
||||||
Call::BridgeSendMessage { lane, payload, fee, bridge_instance_index } =>
|
Call::BridgeSendMessage { lane, payload, fee, bridge_instance_index } =>
|
||||||
match *bridge_instance_index {
|
match *bridge_instance_index {
|
||||||
bridge::WOCOCO_TO_ROCOCO_INDEX => {
|
bridge::WOCOCO_TO_ROCOCO_INDEX => {
|
||||||
@@ -43,6 +49,7 @@ impl CliEncodeCall for Wococo {
|
|||||||
lane.0, payload, fee.0,
|
lane.0, payload, fee.0,
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
.into()
|
||||||
},
|
},
|
||||||
_ => anyhow::bail!(
|
_ => anyhow::bail!(
|
||||||
"Unsupported target bridge pallet with instance index: {}",
|
"Unsupported target bridge pallet with instance index: {}",
|
||||||
@@ -53,18 +60,16 @@ impl CliEncodeCall for Wococo {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_dispatch_info(
|
fn get_dispatch_info(call: &EncodedOrDecodedCall<Self::Call>) -> anyhow::Result<DispatchInfo> {
|
||||||
call: &relay_wococo_client::runtime::Call,
|
|
||||||
) -> anyhow::Result<DispatchInfo> {
|
|
||||||
match *call {
|
match *call {
|
||||||
relay_wococo_client::runtime::Call::System(
|
EncodedOrDecodedCall::Decoded(relay_wococo_client::runtime::Call::System(
|
||||||
relay_wococo_client::runtime::SystemCall::remark(_),
|
relay_wococo_client::runtime::SystemCall::remark(_),
|
||||||
) => Ok(DispatchInfo {
|
)) => Ok(DispatchInfo {
|
||||||
weight: crate::chains::rococo::SYSTEM_REMARK_CALL_WEIGHT,
|
weight: crate::chains::rococo::SYSTEM_REMARK_CALL_WEIGHT,
|
||||||
class: DispatchClass::Normal,
|
class: DispatchClass::Normal,
|
||||||
pays_fee: Pays::Yes,
|
pays_fee: Pays::Yes,
|
||||||
}),
|
}),
|
||||||
_ => anyhow::bail!("Unsupported Rococo call: {:?}", call),
|
_ => anyhow::bail!("Unsupported Wococo call: {:?}", call),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -73,15 +78,49 @@ impl CliChain for Wococo {
|
|||||||
const RUNTIME_VERSION: RuntimeVersion = bp_wococo::VERSION;
|
const RUNTIME_VERSION: RuntimeVersion = bp_wococo::VERSION;
|
||||||
|
|
||||||
type KeyPair = sp_core::sr25519::Pair;
|
type KeyPair = sp_core::sr25519::Pair;
|
||||||
type MessagePayload = ();
|
type MessagePayload = MessagePayload<
|
||||||
|
bp_wococo::AccountId,
|
||||||
|
bp_rococo::AccountPublic,
|
||||||
|
bp_rococo::Signature,
|
||||||
|
Vec<u8>,
|
||||||
|
>;
|
||||||
|
|
||||||
fn ss58_format() -> u16 {
|
fn ss58_format() -> u16 {
|
||||||
42
|
42
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_message(
|
fn encode_message(
|
||||||
_message: encode_message::MessagePayload,
|
message: encode_message::MessagePayload,
|
||||||
) -> anyhow::Result<Self::MessagePayload> {
|
) -> anyhow::Result<Self::MessagePayload> {
|
||||||
Err(anyhow!("Sending messages from Wococo is not yet supported."))
|
match message {
|
||||||
|
encode_message::MessagePayload::Raw { data } => MessagePayload::decode(&mut &*data.0)
|
||||||
|
.map_err(|e| anyhow!("Failed to decode Wococo's MessagePayload: {:?}", e)),
|
||||||
|
encode_message::MessagePayload::Call { mut call, mut sender, dispatch_weight } => {
|
||||||
|
type Source = Wococo;
|
||||||
|
type Target = relay_rococo_client::Rococo;
|
||||||
|
|
||||||
|
sender.enforce_chain::<Source>();
|
||||||
|
let spec_version = Target::RUNTIME_VERSION.spec_version;
|
||||||
|
let origin = CallOrigin::SourceAccount(sender.raw_id());
|
||||||
|
encode_call::preprocess_call::<Source, Target>(
|
||||||
|
&mut call,
|
||||||
|
bridge::WOCOCO_TO_ROCOCO_INDEX,
|
||||||
|
);
|
||||||
|
let call = Target::encode_call(&call)?;
|
||||||
|
let dispatch_weight = dispatch_weight.map(Ok).unwrap_or_else(|| {
|
||||||
|
Err(anyhow::format_err!(
|
||||||
|
"Please specify dispatch weight of the encoded Rococo call"
|
||||||
|
))
|
||||||
|
})?;
|
||||||
|
|
||||||
|
Ok(send_message::message_payload(
|
||||||
|
spec_version,
|
||||||
|
dispatch_weight,
|
||||||
|
origin,
|
||||||
|
&call,
|
||||||
|
DispatchFeePayment::AtSourceChain,
|
||||||
|
))
|
||||||
|
},
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -20,6 +20,7 @@ use crate::{
|
|||||||
},
|
},
|
||||||
select_full_bridge,
|
select_full_bridge,
|
||||||
};
|
};
|
||||||
|
use bp_runtime::EncodedOrDecodedCall;
|
||||||
use frame_support::weights::DispatchInfo;
|
use frame_support::weights::DispatchInfo;
|
||||||
use relay_substrate_client::Chain;
|
use relay_substrate_client::Chain;
|
||||||
use structopt::StructOpt;
|
use structopt::StructOpt;
|
||||||
@@ -85,10 +86,10 @@ pub enum Call {
|
|||||||
|
|
||||||
pub trait CliEncodeCall: Chain {
|
pub trait CliEncodeCall: Chain {
|
||||||
/// Encode a CLI call.
|
/// Encode a CLI call.
|
||||||
fn encode_call(call: &Call) -> anyhow::Result<Self::Call>;
|
fn encode_call(call: &Call) -> anyhow::Result<EncodedOrDecodedCall<Self::Call>>;
|
||||||
|
|
||||||
/// Get dispatch info for the call.
|
/// Get dispatch info for the call.
|
||||||
fn get_dispatch_info(call: &Self::Call) -> anyhow::Result<DispatchInfo>;
|
fn get_dispatch_info(call: &EncodedOrDecodedCall<Self::Call>) -> anyhow::Result<DispatchInfo>;
|
||||||
}
|
}
|
||||||
|
|
||||||
impl EncodeCall {
|
impl EncodeCall {
|
||||||
@@ -100,7 +101,10 @@ impl EncodeCall {
|
|||||||
let encoded = HexBytes::encode(&call);
|
let encoded = HexBytes::encode(&call);
|
||||||
|
|
||||||
log::info!(target: "bridge", "Generated {} call: {:#?}", Source::NAME, call);
|
log::info!(target: "bridge", "Generated {} call: {:#?}", Source::NAME, call);
|
||||||
log::info!(target: "bridge", "Weight of {} call: {}", Source::NAME, Source::get_dispatch_info(&call)?.weight);
|
log::info!(target: "bridge", "Weight of {} call: {}", Source::NAME, Source::get_dispatch_info(&call)
|
||||||
|
.map(|dispatch_info| format!("{}", dispatch_info.weight))
|
||||||
|
.unwrap_or_else(|_| "<unknown>".to_string())
|
||||||
|
);
|
||||||
log::info!(target: "bridge", "Encoded {} call: {:?}", Source::NAME, encoded);
|
log::info!(target: "bridge", "Encoded {} call: {:?}", Source::NAME, encoded);
|
||||||
|
|
||||||
Ok(encoded)
|
Ok(encoded)
|
||||||
|
|||||||
@@ -18,6 +18,7 @@ use crate::{
|
|||||||
cli::{bridge::FullBridge, AccountId, CliChain, HexBytes},
|
cli::{bridge::FullBridge, AccountId, CliChain, HexBytes},
|
||||||
select_full_bridge,
|
select_full_bridge,
|
||||||
};
|
};
|
||||||
|
use frame_support::weights::Weight;
|
||||||
use structopt::StructOpt;
|
use structopt::StructOpt;
|
||||||
use strum::VariantNames;
|
use strum::VariantNames;
|
||||||
|
|
||||||
@@ -37,6 +38,12 @@ pub enum MessagePayload {
|
|||||||
/// SS58 encoded Source account that will send the payload.
|
/// SS58 encoded Source account that will send the payload.
|
||||||
#[structopt(long)]
|
#[structopt(long)]
|
||||||
sender: AccountId,
|
sender: AccountId,
|
||||||
|
/// Weight of the call.
|
||||||
|
///
|
||||||
|
/// It must be specified if the chain runtime is not bundled with the relay, or if
|
||||||
|
/// you want to override bundled weight.
|
||||||
|
#[structopt(long)]
|
||||||
|
dispatch_weight: Option<Weight>,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -97,6 +104,8 @@ mod tests {
|
|||||||
"call",
|
"call",
|
||||||
"--sender",
|
"--sender",
|
||||||
&sender,
|
&sender,
|
||||||
|
"--dispatch-weight",
|
||||||
|
"42",
|
||||||
"remark",
|
"remark",
|
||||||
"--remark-size",
|
"--remark-size",
|
||||||
"12",
|
"12",
|
||||||
@@ -106,6 +115,6 @@ mod tests {
|
|||||||
let hex = encode_message.encode().unwrap();
|
let hex = encode_message.encode().unwrap();
|
||||||
|
|
||||||
// then
|
// then
|
||||||
assert_eq!(format!("{:?}", hex), "0x01000000000000000000000002d43593c715fdd31c61141abd04a99fd6822c8558854ccde39a5684e7a56da27d003c000130000000000000000000000000");
|
assert_eq!(format!("{:?}", hex), "0x010000002a0000000000000002d43593c715fdd31c61141abd04a99fd6822c8558854ccde39a5684e7a56da27d003c000130000000000000000000000000");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -103,6 +103,8 @@ mod tests {
|
|||||||
"call",
|
"call",
|
||||||
"--sender",
|
"--sender",
|
||||||
&alice,
|
&alice,
|
||||||
|
"--dispatch-weight",
|
||||||
|
"42",
|
||||||
"remark",
|
"remark",
|
||||||
"--remark-payload",
|
"--remark-payload",
|
||||||
"1234",
|
"1234",
|
||||||
@@ -129,7 +131,8 @@ mod tests {
|
|||||||
call: encode_call::Call::Remark {
|
call: encode_call::Call::Remark {
|
||||||
remark_payload: Some(HexBytes(vec![0x12, 0x34])),
|
remark_payload: Some(HexBytes(vec![0x12, 0x34])),
|
||||||
remark_size: None,
|
remark_size: None,
|
||||||
}
|
},
|
||||||
|
dispatch_weight: Some(42),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|||||||
@@ -222,7 +222,7 @@ impl InitBridge {
|
|||||||
target_client.clone(),
|
target_client.clone(),
|
||||||
target_sign.public().into(),
|
target_sign.public().into(),
|
||||||
move |transaction_nonce, initialization_data| {
|
move |transaction_nonce, initialization_data| {
|
||||||
Bytes(
|
Ok(Bytes(
|
||||||
Target::sign_transaction(SignParam {
|
Target::sign_transaction(SignParam {
|
||||||
spec_version,
|
spec_version,
|
||||||
transaction_version,
|
transaction_version,
|
||||||
@@ -230,12 +230,12 @@ impl InitBridge {
|
|||||||
signer: target_sign,
|
signer: target_sign,
|
||||||
era: relay_substrate_client::TransactionEra::immortal(),
|
era: relay_substrate_client::TransactionEra::immortal(),
|
||||||
unsigned: UnsignedTransaction::new(
|
unsigned: UnsignedTransaction::new(
|
||||||
encode_init_bridge(initialization_data),
|
encode_init_bridge(initialization_data).into(),
|
||||||
transaction_nonce,
|
transaction_nonce,
|
||||||
),
|
),
|
||||||
})
|
})?
|
||||||
.encode(),
|
.encode(),
|
||||||
)
|
))
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
.await;
|
.await;
|
||||||
|
|||||||
@@ -132,7 +132,7 @@ impl RegisterParachain {
|
|||||||
.submit_and_watch_signed_extrinsic(
|
.submit_and_watch_signed_extrinsic(
|
||||||
relay_sudo_account.clone(),
|
relay_sudo_account.clone(),
|
||||||
move |_, transaction_nonce| {
|
move |_, transaction_nonce| {
|
||||||
Bytes(
|
Ok(Bytes(
|
||||||
Relaychain::sign_transaction(SignParam {
|
Relaychain::sign_transaction(SignParam {
|
||||||
spec_version,
|
spec_version,
|
||||||
transaction_version,
|
transaction_version,
|
||||||
@@ -140,12 +140,12 @@ impl RegisterParachain {
|
|||||||
signer: reserve_parachain_signer,
|
signer: reserve_parachain_signer,
|
||||||
era: relay_substrate_client::TransactionEra::immortal(),
|
era: relay_substrate_client::TransactionEra::immortal(),
|
||||||
unsigned: UnsignedTransaction::new(
|
unsigned: UnsignedTransaction::new(
|
||||||
reserve_parachain_id_call,
|
reserve_parachain_id_call.into(),
|
||||||
transaction_nonce,
|
transaction_nonce,
|
||||||
),
|
),
|
||||||
})
|
})?
|
||||||
.encode(),
|
.encode(),
|
||||||
)
|
))
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
.await?,
|
.await?,
|
||||||
@@ -181,7 +181,7 @@ impl RegisterParachain {
|
|||||||
.submit_and_watch_signed_extrinsic(
|
.submit_and_watch_signed_extrinsic(
|
||||||
relay_sudo_account.clone(),
|
relay_sudo_account.clone(),
|
||||||
move |_, transaction_nonce| {
|
move |_, transaction_nonce| {
|
||||||
Bytes(
|
Ok(Bytes(
|
||||||
Relaychain::sign_transaction(SignParam {
|
Relaychain::sign_transaction(SignParam {
|
||||||
spec_version,
|
spec_version,
|
||||||
transaction_version,
|
transaction_version,
|
||||||
@@ -189,12 +189,12 @@ impl RegisterParachain {
|
|||||||
signer: register_parathread_signer,
|
signer: register_parathread_signer,
|
||||||
era: relay_substrate_client::TransactionEra::immortal(),
|
era: relay_substrate_client::TransactionEra::immortal(),
|
||||||
unsigned: UnsignedTransaction::new(
|
unsigned: UnsignedTransaction::new(
|
||||||
register_parathread_call,
|
register_parathread_call.into(),
|
||||||
transaction_nonce,
|
transaction_nonce,
|
||||||
),
|
),
|
||||||
})
|
})?
|
||||||
.encode(),
|
.encode(),
|
||||||
)
|
))
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
.await?,
|
.await?,
|
||||||
@@ -243,17 +243,20 @@ impl RegisterParachain {
|
|||||||
let force_lease_signer = relay_sign.clone();
|
let force_lease_signer = relay_sign.clone();
|
||||||
relay_client
|
relay_client
|
||||||
.submit_signed_extrinsic(relay_sudo_account.clone(), move |_, transaction_nonce| {
|
.submit_signed_extrinsic(relay_sudo_account.clone(), move |_, transaction_nonce| {
|
||||||
Bytes(
|
Ok(Bytes(
|
||||||
Relaychain::sign_transaction(SignParam {
|
Relaychain::sign_transaction(SignParam {
|
||||||
spec_version,
|
spec_version,
|
||||||
transaction_version,
|
transaction_version,
|
||||||
genesis_hash: relay_genesis_hash,
|
genesis_hash: relay_genesis_hash,
|
||||||
signer: force_lease_signer,
|
signer: force_lease_signer,
|
||||||
era: relay_substrate_client::TransactionEra::immortal(),
|
era: relay_substrate_client::TransactionEra::immortal(),
|
||||||
unsigned: UnsignedTransaction::new(force_lease_call, transaction_nonce),
|
unsigned: UnsignedTransaction::new(
|
||||||
})
|
force_lease_call.into(),
|
||||||
|
transaction_nonce,
|
||||||
|
),
|
||||||
|
})?
|
||||||
.encode(),
|
.encode(),
|
||||||
)
|
))
|
||||||
})
|
})
|
||||||
.await?;
|
.await?;
|
||||||
log::info!(target: "bridge", "Registered parachain leases: {:?}. Waiting for onboarding", para_id);
|
log::info!(target: "bridge", "Registered parachain leases: {:?}. Waiting for onboarding", para_id);
|
||||||
|
|||||||
@@ -615,17 +615,17 @@ where
|
|||||||
let (spec_version, transaction_version) = client.simple_runtime_version().await?;
|
let (spec_version, transaction_version) = client.simple_runtime_version().await?;
|
||||||
client
|
client
|
||||||
.submit_signed_extrinsic(sign.public().into(), move |_, transaction_nonce| {
|
.submit_signed_extrinsic(sign.public().into(), move |_, transaction_nonce| {
|
||||||
Bytes(
|
Ok(Bytes(
|
||||||
C::sign_transaction(SignParam {
|
C::sign_transaction(SignParam {
|
||||||
spec_version,
|
spec_version,
|
||||||
transaction_version,
|
transaction_version,
|
||||||
genesis_hash,
|
genesis_hash,
|
||||||
signer: sign,
|
signer: sign,
|
||||||
era: relay_substrate_client::TransactionEra::immortal(),
|
era: relay_substrate_client::TransactionEra::immortal(),
|
||||||
unsigned: UnsignedTransaction::new(call, transaction_nonce),
|
unsigned: UnsignedTransaction::new(call.into(), transaction_nonce),
|
||||||
})
|
})?
|
||||||
.encode(),
|
.encode(),
|
||||||
)
|
))
|
||||||
})
|
})
|
||||||
.await
|
.await
|
||||||
.map(drop)
|
.map(drop)
|
||||||
|
|||||||
@@ -445,7 +445,7 @@ async fn update_transaction_tip<C: Chain, S: TransactionSignScheme<Chain = C>>(
|
|||||||
signer: key_pair.clone(),
|
signer: key_pair.clone(),
|
||||||
era: relay_substrate_client::TransactionEra::immortal(),
|
era: relay_substrate_client::TransactionEra::immortal(),
|
||||||
unsigned: unsigned_tx.clone(),
|
unsigned: unsigned_tx.clone(),
|
||||||
}),
|
})?,
|
||||||
)
|
)
|
||||||
.await??
|
.await??
|
||||||
.priority;
|
.priority;
|
||||||
@@ -468,7 +468,7 @@ async fn update_transaction_tip<C: Chain, S: TransactionSignScheme<Chain = C>>(
|
|||||||
signer: key_pair.clone(),
|
signer: key_pair.clone(),
|
||||||
era: relay_substrate_client::TransactionEra::immortal(),
|
era: relay_substrate_client::TransactionEra::immortal(),
|
||||||
unsigned: unsigned_tx,
|
unsigned: unsigned_tx,
|
||||||
}),
|
})?,
|
||||||
))
|
))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -124,9 +124,13 @@ impl SendMessage {
|
|||||||
let payload = {
|
let payload = {
|
||||||
let target_call_weight = prepare_call_dispatch_weight(
|
let target_call_weight = prepare_call_dispatch_weight(
|
||||||
dispatch_weight,
|
dispatch_weight,
|
||||||
ExplicitOrMaximal::Explicit(Target::get_dispatch_info(&target_call)?.weight),
|
|| {
|
||||||
|
Ok(ExplicitOrMaximal::Explicit(
|
||||||
|
Target::get_dispatch_info(&target_call)?.weight,
|
||||||
|
))
|
||||||
|
},
|
||||||
compute_maximal_message_dispatch_weight(Target::max_extrinsic_weight()),
|
compute_maximal_message_dispatch_weight(Target::max_extrinsic_weight()),
|
||||||
);
|
)?;
|
||||||
let source_sender_public: MultiSigner = source_sign.public().into();
|
let source_sender_public: MultiSigner = source_sign.public().into();
|
||||||
let source_account_id = source_sender_public.into_account();
|
let source_account_id = source_sender_public.into_account();
|
||||||
|
|
||||||
@@ -200,7 +204,7 @@ impl SendMessage {
|
|||||||
signer: source_sign.clone(),
|
signer: source_sign.clone(),
|
||||||
era: relay_substrate_client::TransactionEra::immortal(),
|
era: relay_substrate_client::TransactionEra::immortal(),
|
||||||
unsigned: UnsignedTransaction::new(send_message_call.clone(), 0),
|
unsigned: UnsignedTransaction::new(send_message_call.clone(), 0),
|
||||||
})
|
})?
|
||||||
.encode(),
|
.encode(),
|
||||||
))
|
))
|
||||||
.await?;
|
.await?;
|
||||||
@@ -213,7 +217,7 @@ impl SendMessage {
|
|||||||
signer: source_sign.clone(),
|
signer: source_sign.clone(),
|
||||||
era: relay_substrate_client::TransactionEra::immortal(),
|
era: relay_substrate_client::TransactionEra::immortal(),
|
||||||
unsigned: UnsignedTransaction::new(send_message_call, transaction_nonce),
|
unsigned: UnsignedTransaction::new(send_message_call, transaction_nonce),
|
||||||
})
|
})?
|
||||||
.encode();
|
.encode();
|
||||||
|
|
||||||
log::info!(
|
log::info!(
|
||||||
@@ -241,7 +245,7 @@ impl SendMessage {
|
|||||||
HexBytes::encode(&signed_source_call)
|
HexBytes::encode(&signed_source_call)
|
||||||
);
|
);
|
||||||
|
|
||||||
Bytes(signed_source_call)
|
Ok(Bytes(signed_source_call))
|
||||||
})
|
})
|
||||||
.await?;
|
.await?;
|
||||||
});
|
});
|
||||||
@@ -252,12 +256,16 @@ impl SendMessage {
|
|||||||
|
|
||||||
fn prepare_call_dispatch_weight(
|
fn prepare_call_dispatch_weight(
|
||||||
user_specified_dispatch_weight: &Option<ExplicitOrMaximal<Weight>>,
|
user_specified_dispatch_weight: &Option<ExplicitOrMaximal<Weight>>,
|
||||||
weight_from_pre_dispatch_call: ExplicitOrMaximal<Weight>,
|
weight_from_pre_dispatch_call: impl Fn() -> anyhow::Result<ExplicitOrMaximal<Weight>>,
|
||||||
maximal_allowed_weight: Weight,
|
maximal_allowed_weight: Weight,
|
||||||
) -> Weight {
|
) -> anyhow::Result<Weight> {
|
||||||
match user_specified_dispatch_weight.clone().unwrap_or(weight_from_pre_dispatch_call) {
|
match user_specified_dispatch_weight
|
||||||
ExplicitOrMaximal::Explicit(weight) => weight,
|
.clone()
|
||||||
ExplicitOrMaximal::Maximal => maximal_allowed_weight,
|
.map(Ok)
|
||||||
|
.unwrap_or_else(weight_from_pre_dispatch_call)?
|
||||||
|
{
|
||||||
|
ExplicitOrMaximal::Explicit(weight) => Ok(weight),
|
||||||
|
ExplicitOrMaximal::Maximal => Ok(maximal_allowed_weight),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -245,7 +245,7 @@ impl SwapTokens {
|
|||||||
.submit_and_watch_signed_extrinsic(
|
.submit_and_watch_signed_extrinsic(
|
||||||
accounts.source_account_at_this_chain.clone(),
|
accounts.source_account_at_this_chain.clone(),
|
||||||
move |_, transaction_nonce| {
|
move |_, transaction_nonce| {
|
||||||
Bytes(
|
Ok(Bytes(
|
||||||
Source::sign_transaction(SignParam {
|
Source::sign_transaction(SignParam {
|
||||||
spec_version,
|
spec_version,
|
||||||
transaction_version,
|
transaction_version,
|
||||||
@@ -253,12 +253,12 @@ impl SwapTokens {
|
|||||||
signer: create_swap_signer,
|
signer: create_swap_signer,
|
||||||
era: relay_substrate_client::TransactionEra::immortal(),
|
era: relay_substrate_client::TransactionEra::immortal(),
|
||||||
unsigned: UnsignedTransaction::new(
|
unsigned: UnsignedTransaction::new(
|
||||||
create_swap_call,
|
create_swap_call.into(),
|
||||||
transaction_nonce,
|
transaction_nonce,
|
||||||
),
|
),
|
||||||
})
|
})?
|
||||||
.encode(),
|
.encode(),
|
||||||
)
|
))
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
.await?,
|
.await?,
|
||||||
@@ -386,7 +386,7 @@ impl SwapTokens {
|
|||||||
.submit_and_watch_signed_extrinsic(
|
.submit_and_watch_signed_extrinsic(
|
||||||
accounts.target_account_at_bridged_chain.clone(),
|
accounts.target_account_at_bridged_chain.clone(),
|
||||||
move |_, transaction_nonce| {
|
move |_, transaction_nonce| {
|
||||||
Bytes(
|
Ok(Bytes(
|
||||||
Target::sign_transaction(SignParam {
|
Target::sign_transaction(SignParam {
|
||||||
spec_version,
|
spec_version,
|
||||||
transaction_version,
|
transaction_version,
|
||||||
@@ -394,12 +394,12 @@ impl SwapTokens {
|
|||||||
signer: target_sign,
|
signer: target_sign,
|
||||||
era: relay_substrate_client::TransactionEra::immortal(),
|
era: relay_substrate_client::TransactionEra::immortal(),
|
||||||
unsigned: UnsignedTransaction::new(
|
unsigned: UnsignedTransaction::new(
|
||||||
send_message_call,
|
send_message_call.into(),
|
||||||
transaction_nonce,
|
transaction_nonce,
|
||||||
),
|
),
|
||||||
})
|
})?
|
||||||
.encode(),
|
.encode(),
|
||||||
)
|
))
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
.await?,
|
.await?,
|
||||||
@@ -430,7 +430,7 @@ impl SwapTokens {
|
|||||||
.submit_and_watch_signed_extrinsic(
|
.submit_and_watch_signed_extrinsic(
|
||||||
accounts.source_account_at_this_chain.clone(),
|
accounts.source_account_at_this_chain.clone(),
|
||||||
move |_, transaction_nonce| {
|
move |_, transaction_nonce| {
|
||||||
Bytes(
|
Ok(Bytes(
|
||||||
Source::sign_transaction(SignParam {
|
Source::sign_transaction(SignParam {
|
||||||
spec_version,
|
spec_version,
|
||||||
transaction_version,
|
transaction_version,
|
||||||
@@ -438,12 +438,12 @@ impl SwapTokens {
|
|||||||
signer: source_sign,
|
signer: source_sign,
|
||||||
era: relay_substrate_client::TransactionEra::immortal(),
|
era: relay_substrate_client::TransactionEra::immortal(),
|
||||||
unsigned: UnsignedTransaction::new(
|
unsigned: UnsignedTransaction::new(
|
||||||
cancel_swap_call,
|
cancel_swap_call.into(),
|
||||||
transaction_nonce,
|
transaction_nonce,
|
||||||
),
|
),
|
||||||
})
|
})?
|
||||||
.encode(),
|
.encode(),
|
||||||
)
|
))
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
.await?,
|
.await?,
|
||||||
|
|||||||
@@ -20,8 +20,8 @@ use bp_messages::MessageNonce;
|
|||||||
use codec::Encode;
|
use codec::Encode;
|
||||||
use frame_support::weights::Weight;
|
use frame_support::weights::Weight;
|
||||||
use relay_substrate_client::{
|
use relay_substrate_client::{
|
||||||
Chain, ChainBase, ChainWithBalances, ChainWithGrandpa, ChainWithMessages, SignParam,
|
Chain, ChainBase, ChainWithBalances, ChainWithGrandpa, ChainWithMessages,
|
||||||
TransactionSignScheme, UnsignedTransaction,
|
Error as SubstrateError, SignParam, TransactionSignScheme, UnsignedTransaction,
|
||||||
};
|
};
|
||||||
use sp_core::{storage::StorageKey, Pair};
|
use sp_core::{storage::StorageKey, Pair};
|
||||||
use sp_runtime::{generic::SignedPayload, traits::IdentifyAccount};
|
use sp_runtime::{generic::SignedPayload, traits::IdentifyAccount};
|
||||||
@@ -101,7 +101,7 @@ impl TransactionSignScheme for Kusama {
|
|||||||
type AccountKeyPair = sp_core::sr25519::Pair;
|
type AccountKeyPair = sp_core::sr25519::Pair;
|
||||||
type SignedTransaction = crate::runtime::UncheckedExtrinsic;
|
type SignedTransaction = crate::runtime::UncheckedExtrinsic;
|
||||||
|
|
||||||
fn sign_transaction(param: SignParam<Self>) -> Self::SignedTransaction {
|
fn sign_transaction(param: SignParam<Self>) -> Result<Self::SignedTransaction, SubstrateError> {
|
||||||
let raw_payload = SignedPayload::new(
|
let raw_payload = SignedPayload::new(
|
||||||
param.unsigned.call.clone(),
|
param.unsigned.call.clone(),
|
||||||
bp_kusama::SignedExtensions::new(
|
bp_kusama::SignedExtensions::new(
|
||||||
@@ -119,12 +119,12 @@ impl TransactionSignScheme for Kusama {
|
|||||||
let signer: sp_runtime::MultiSigner = param.signer.public().into();
|
let signer: sp_runtime::MultiSigner = param.signer.public().into();
|
||||||
let (call, extra, _) = raw_payload.deconstruct();
|
let (call, extra, _) = raw_payload.deconstruct();
|
||||||
|
|
||||||
bp_kusama::UncheckedExtrinsic::new_signed(
|
Ok(bp_kusama::UncheckedExtrinsic::new_signed(
|
||||||
call,
|
call,
|
||||||
sp_runtime::MultiAddress::Id(signer.into_account()),
|
sp_runtime::MultiAddress::Id(signer.into_account()),
|
||||||
signature.into(),
|
signature.into(),
|
||||||
extra,
|
extra,
|
||||||
)
|
))
|
||||||
}
|
}
|
||||||
|
|
||||||
fn is_signed(tx: &Self::SignedTransaction) -> bool {
|
fn is_signed(tx: &Self::SignedTransaction) -> bool {
|
||||||
|
|||||||
@@ -20,8 +20,8 @@ use bp_messages::MessageNonce;
|
|||||||
use codec::{Compact, Decode, Encode};
|
use codec::{Compact, Decode, Encode};
|
||||||
use frame_support::weights::Weight;
|
use frame_support::weights::Weight;
|
||||||
use relay_substrate_client::{
|
use relay_substrate_client::{
|
||||||
BalanceOf, Chain, ChainBase, ChainWithBalances, ChainWithGrandpa, ChainWithMessages, IndexOf,
|
BalanceOf, Chain, ChainBase, ChainWithBalances, ChainWithGrandpa, ChainWithMessages,
|
||||||
SignParam, TransactionSignScheme, UnsignedTransaction,
|
Error as SubstrateError, IndexOf, SignParam, TransactionSignScheme, UnsignedTransaction,
|
||||||
};
|
};
|
||||||
use sp_core::{storage::StorageKey, Pair};
|
use sp_core::{storage::StorageKey, Pair};
|
||||||
use sp_runtime::{generic::SignedPayload, traits::IdentifyAccount};
|
use sp_runtime::{generic::SignedPayload, traits::IdentifyAccount};
|
||||||
@@ -103,7 +103,7 @@ impl TransactionSignScheme for Millau {
|
|||||||
type AccountKeyPair = sp_core::sr25519::Pair;
|
type AccountKeyPair = sp_core::sr25519::Pair;
|
||||||
type SignedTransaction = millau_runtime::UncheckedExtrinsic;
|
type SignedTransaction = millau_runtime::UncheckedExtrinsic;
|
||||||
|
|
||||||
fn sign_transaction(param: SignParam<Self>) -> Self::SignedTransaction {
|
fn sign_transaction(param: SignParam<Self>) -> Result<Self::SignedTransaction, SubstrateError> {
|
||||||
let raw_payload = SignedPayload::from_raw(
|
let raw_payload = SignedPayload::from_raw(
|
||||||
param.unsigned.call.clone(),
|
param.unsigned.call.clone(),
|
||||||
(
|
(
|
||||||
@@ -129,12 +129,12 @@ impl TransactionSignScheme for Millau {
|
|||||||
let signer: sp_runtime::MultiSigner = param.signer.public().into();
|
let signer: sp_runtime::MultiSigner = param.signer.public().into();
|
||||||
let (call, extra, _) = raw_payload.deconstruct();
|
let (call, extra, _) = raw_payload.deconstruct();
|
||||||
|
|
||||||
millau_runtime::UncheckedExtrinsic::new_signed(
|
Ok(millau_runtime::UncheckedExtrinsic::new_signed(
|
||||||
call,
|
call.into_decoded()?,
|
||||||
signer.into_account(),
|
signer.into_account(),
|
||||||
signature.into(),
|
signature.into(),
|
||||||
extra,
|
extra,
|
||||||
)
|
))
|
||||||
}
|
}
|
||||||
|
|
||||||
fn is_signed(tx: &Self::SignedTransaction) -> bool {
|
fn is_signed(tx: &Self::SignedTransaction) -> bool {
|
||||||
@@ -153,7 +153,7 @@ impl TransactionSignScheme for Millau {
|
|||||||
fn parse_transaction(tx: Self::SignedTransaction) -> Option<UnsignedTransaction<Self::Chain>> {
|
fn parse_transaction(tx: Self::SignedTransaction) -> Option<UnsignedTransaction<Self::Chain>> {
|
||||||
let extra = &tx.signature.as_ref()?.2;
|
let extra = &tx.signature.as_ref()?.2;
|
||||||
Some(UnsignedTransaction {
|
Some(UnsignedTransaction {
|
||||||
call: tx.function,
|
call: tx.function.into(),
|
||||||
nonce: Compact::<IndexOf<Self::Chain>>::decode(&mut &extra.4.encode()[..]).ok()?.into(),
|
nonce: Compact::<IndexOf<Self::Chain>>::decode(&mut &extra.4.encode()[..]).ok()?.into(),
|
||||||
tip: Compact::<BalanceOf<Self::Chain>>::decode(&mut &extra.6.encode()[..])
|
tip: Compact::<BalanceOf<Self::Chain>>::decode(&mut &extra.6.encode()[..])
|
||||||
.ok()?
|
.ok()?
|
||||||
|
|||||||
@@ -20,8 +20,8 @@ use bp_messages::MessageNonce;
|
|||||||
use codec::Encode;
|
use codec::Encode;
|
||||||
use frame_support::weights::Weight;
|
use frame_support::weights::Weight;
|
||||||
use relay_substrate_client::{
|
use relay_substrate_client::{
|
||||||
Chain, ChainBase, ChainWithBalances, ChainWithGrandpa, ChainWithMessages, SignParam,
|
Chain, ChainBase, ChainWithBalances, ChainWithGrandpa, ChainWithMessages,
|
||||||
TransactionSignScheme, UnsignedTransaction,
|
Error as SubstrateError, SignParam, TransactionSignScheme, UnsignedTransaction,
|
||||||
};
|
};
|
||||||
use sp_core::{storage::StorageKey, Pair};
|
use sp_core::{storage::StorageKey, Pair};
|
||||||
use sp_runtime::{generic::SignedPayload, traits::IdentifyAccount};
|
use sp_runtime::{generic::SignedPayload, traits::IdentifyAccount};
|
||||||
@@ -102,7 +102,7 @@ impl TransactionSignScheme for Polkadot {
|
|||||||
type AccountKeyPair = sp_core::sr25519::Pair;
|
type AccountKeyPair = sp_core::sr25519::Pair;
|
||||||
type SignedTransaction = crate::runtime::UncheckedExtrinsic;
|
type SignedTransaction = crate::runtime::UncheckedExtrinsic;
|
||||||
|
|
||||||
fn sign_transaction(param: SignParam<Self>) -> Self::SignedTransaction {
|
fn sign_transaction(param: SignParam<Self>) -> Result<Self::SignedTransaction, SubstrateError> {
|
||||||
let raw_payload = SignedPayload::new(
|
let raw_payload = SignedPayload::new(
|
||||||
param.unsigned.call.clone(),
|
param.unsigned.call.clone(),
|
||||||
bp_polkadot::SignedExtensions::new(
|
bp_polkadot::SignedExtensions::new(
|
||||||
@@ -120,12 +120,12 @@ impl TransactionSignScheme for Polkadot {
|
|||||||
let signer: sp_runtime::MultiSigner = param.signer.public().into();
|
let signer: sp_runtime::MultiSigner = param.signer.public().into();
|
||||||
let (call, extra, _) = raw_payload.deconstruct();
|
let (call, extra, _) = raw_payload.deconstruct();
|
||||||
|
|
||||||
bp_polkadot::UncheckedExtrinsic::new_signed(
|
Ok(bp_polkadot::UncheckedExtrinsic::new_signed(
|
||||||
call,
|
call,
|
||||||
sp_runtime::MultiAddress::Id(signer.into_account()),
|
sp_runtime::MultiAddress::Id(signer.into_account()),
|
||||||
signature.into(),
|
signature.into(),
|
||||||
extra,
|
extra,
|
||||||
)
|
))
|
||||||
}
|
}
|
||||||
|
|
||||||
fn is_signed(tx: &Self::SignedTransaction) -> bool {
|
fn is_signed(tx: &Self::SignedTransaction) -> bool {
|
||||||
|
|||||||
@@ -20,8 +20,8 @@ use bp_messages::MessageNonce;
|
|||||||
use codec::{Compact, Decode, Encode};
|
use codec::{Compact, Decode, Encode};
|
||||||
use frame_support::weights::Weight;
|
use frame_support::weights::Weight;
|
||||||
use relay_substrate_client::{
|
use relay_substrate_client::{
|
||||||
BalanceOf, Chain, ChainBase, ChainWithBalances, ChainWithGrandpa, ChainWithMessages, IndexOf,
|
BalanceOf, Chain, ChainBase, ChainWithBalances, ChainWithGrandpa, ChainWithMessages,
|
||||||
SignParam, TransactionSignScheme, UnsignedTransaction,
|
Error as SubstrateError, IndexOf, SignParam, TransactionSignScheme, UnsignedTransaction,
|
||||||
};
|
};
|
||||||
use sp_core::{storage::StorageKey, Pair};
|
use sp_core::{storage::StorageKey, Pair};
|
||||||
use sp_runtime::{generic::SignedPayload, traits::IdentifyAccount};
|
use sp_runtime::{generic::SignedPayload, traits::IdentifyAccount};
|
||||||
@@ -103,7 +103,7 @@ impl TransactionSignScheme for Rialto {
|
|||||||
type AccountKeyPair = sp_core::sr25519::Pair;
|
type AccountKeyPair = sp_core::sr25519::Pair;
|
||||||
type SignedTransaction = rialto_runtime::UncheckedExtrinsic;
|
type SignedTransaction = rialto_runtime::UncheckedExtrinsic;
|
||||||
|
|
||||||
fn sign_transaction(param: SignParam<Self>) -> Self::SignedTransaction {
|
fn sign_transaction(param: SignParam<Self>) -> Result<Self::SignedTransaction, SubstrateError> {
|
||||||
let raw_payload = SignedPayload::from_raw(
|
let raw_payload = SignedPayload::from_raw(
|
||||||
param.unsigned.call.clone(),
|
param.unsigned.call.clone(),
|
||||||
(
|
(
|
||||||
@@ -129,12 +129,12 @@ impl TransactionSignScheme for Rialto {
|
|||||||
let signer: sp_runtime::MultiSigner = param.signer.public().into();
|
let signer: sp_runtime::MultiSigner = param.signer.public().into();
|
||||||
let (call, extra, _) = raw_payload.deconstruct();
|
let (call, extra, _) = raw_payload.deconstruct();
|
||||||
|
|
||||||
rialto_runtime::UncheckedExtrinsic::new_signed(
|
Ok(rialto_runtime::UncheckedExtrinsic::new_signed(
|
||||||
call,
|
call.into_decoded()?,
|
||||||
signer.into_account().into(),
|
signer.into_account().into(),
|
||||||
signature.into(),
|
signature.into(),
|
||||||
extra,
|
extra,
|
||||||
)
|
))
|
||||||
}
|
}
|
||||||
|
|
||||||
fn is_signed(tx: &Self::SignedTransaction) -> bool {
|
fn is_signed(tx: &Self::SignedTransaction) -> bool {
|
||||||
@@ -151,7 +151,7 @@ impl TransactionSignScheme for Rialto {
|
|||||||
fn parse_transaction(tx: Self::SignedTransaction) -> Option<UnsignedTransaction<Self::Chain>> {
|
fn parse_transaction(tx: Self::SignedTransaction) -> Option<UnsignedTransaction<Self::Chain>> {
|
||||||
let extra = &tx.signature.as_ref()?.2;
|
let extra = &tx.signature.as_ref()?.2;
|
||||||
Some(UnsignedTransaction {
|
Some(UnsignedTransaction {
|
||||||
call: tx.function,
|
call: tx.function.into(),
|
||||||
nonce: Compact::<IndexOf<Self::Chain>>::decode(&mut &extra.4.encode()[..]).ok()?.into(),
|
nonce: Compact::<IndexOf<Self::Chain>>::decode(&mut &extra.4.encode()[..]).ok()?.into(),
|
||||||
tip: Compact::<BalanceOf<Self::Chain>>::decode(&mut &extra.6.encode()[..])
|
tip: Compact::<BalanceOf<Self::Chain>>::decode(&mut &extra.6.encode()[..])
|
||||||
.ok()?
|
.ok()?
|
||||||
|
|||||||
@@ -20,8 +20,8 @@ use bp_messages::MessageNonce;
|
|||||||
use codec::Encode;
|
use codec::Encode;
|
||||||
use frame_support::weights::Weight;
|
use frame_support::weights::Weight;
|
||||||
use relay_substrate_client::{
|
use relay_substrate_client::{
|
||||||
Chain, ChainBase, ChainWithBalances, ChainWithGrandpa, ChainWithMessages, SignParam,
|
Chain, ChainBase, ChainWithBalances, ChainWithGrandpa, ChainWithMessages,
|
||||||
TransactionSignScheme, UnsignedTransaction,
|
Error as SubstrateError, SignParam, TransactionSignScheme, UnsignedTransaction,
|
||||||
};
|
};
|
||||||
use sp_core::{storage::StorageKey, Pair};
|
use sp_core::{storage::StorageKey, Pair};
|
||||||
use sp_runtime::{generic::SignedPayload, traits::IdentifyAccount};
|
use sp_runtime::{generic::SignedPayload, traits::IdentifyAccount};
|
||||||
@@ -104,7 +104,7 @@ impl TransactionSignScheme for Rococo {
|
|||||||
type AccountKeyPair = sp_core::sr25519::Pair;
|
type AccountKeyPair = sp_core::sr25519::Pair;
|
||||||
type SignedTransaction = crate::runtime::UncheckedExtrinsic;
|
type SignedTransaction = crate::runtime::UncheckedExtrinsic;
|
||||||
|
|
||||||
fn sign_transaction(param: SignParam<Self>) -> Self::SignedTransaction {
|
fn sign_transaction(param: SignParam<Self>) -> Result<Self::SignedTransaction, SubstrateError> {
|
||||||
let raw_payload = SignedPayload::new(
|
let raw_payload = SignedPayload::new(
|
||||||
param.unsigned.call.clone(),
|
param.unsigned.call.clone(),
|
||||||
bp_rococo::SignedExtensions::new(
|
bp_rococo::SignedExtensions::new(
|
||||||
@@ -122,12 +122,12 @@ impl TransactionSignScheme for Rococo {
|
|||||||
let signer: sp_runtime::MultiSigner = param.signer.public().into();
|
let signer: sp_runtime::MultiSigner = param.signer.public().into();
|
||||||
let (call, extra, _) = raw_payload.deconstruct();
|
let (call, extra, _) = raw_payload.deconstruct();
|
||||||
|
|
||||||
bp_rococo::UncheckedExtrinsic::new_signed(
|
Ok(bp_rococo::UncheckedExtrinsic::new_signed(
|
||||||
call,
|
call,
|
||||||
sp_runtime::MultiAddress::Id(signer.into_account()),
|
sp_runtime::MultiAddress::Id(signer.into_account()),
|
||||||
signature.into(),
|
signature.into(),
|
||||||
extra,
|
extra,
|
||||||
)
|
))
|
||||||
}
|
}
|
||||||
|
|
||||||
fn is_signed(tx: &Self::SignedTransaction) -> bool {
|
fn is_signed(tx: &Self::SignedTransaction) -> bool {
|
||||||
|
|||||||
@@ -15,7 +15,7 @@
|
|||||||
// along with Parity Bridges Common. If not, see <http://www.gnu.org/licenses/>.
|
// along with Parity Bridges Common. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
use bp_messages::MessageNonce;
|
use bp_messages::MessageNonce;
|
||||||
use bp_runtime::{Chain as ChainBase, HashOf, TransactionEraOf};
|
use bp_runtime::{Chain as ChainBase, EncodedOrDecodedCall, HashOf, TransactionEraOf};
|
||||||
use codec::{Codec, Encode};
|
use codec::{Codec, Encode};
|
||||||
use frame_support::weights::{Weight, WeightToFeePolynomial};
|
use frame_support::weights::{Weight, WeightToFeePolynomial};
|
||||||
use jsonrpsee_ws_client::types::{DeserializeOwned, Serialize};
|
use jsonrpsee_ws_client::types::{DeserializeOwned, Serialize};
|
||||||
@@ -141,7 +141,7 @@ pub trait BlockWithJustification<Header> {
|
|||||||
#[derive(Clone, Debug)]
|
#[derive(Clone, Debug)]
|
||||||
pub struct UnsignedTransaction<C: Chain> {
|
pub struct UnsignedTransaction<C: Chain> {
|
||||||
/// Runtime call of this transaction.
|
/// Runtime call of this transaction.
|
||||||
pub call: C::Call,
|
pub call: EncodedOrDecodedCall<C::Call>,
|
||||||
/// Transaction nonce.
|
/// Transaction nonce.
|
||||||
pub nonce: C::Index,
|
pub nonce: C::Index,
|
||||||
/// Tip included into transaction.
|
/// Tip included into transaction.
|
||||||
@@ -150,7 +150,7 @@ pub struct UnsignedTransaction<C: Chain> {
|
|||||||
|
|
||||||
impl<C: Chain> UnsignedTransaction<C> {
|
impl<C: Chain> UnsignedTransaction<C> {
|
||||||
/// Create new unsigned transaction with given call, nonce and zero tip.
|
/// Create new unsigned transaction with given call, nonce and zero tip.
|
||||||
pub fn new(call: C::Call, nonce: C::Index) -> Self {
|
pub fn new(call: EncodedOrDecodedCall<C::Call>, nonce: C::Index) -> Self {
|
||||||
Self { call, nonce, tip: Zero::zero() }
|
Self { call, nonce, tip: Zero::zero() }
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -174,7 +174,7 @@ pub trait TransactionSignScheme {
|
|||||||
type SignedTransaction: Clone + Debug + Codec + Send + 'static;
|
type SignedTransaction: Clone + Debug + Codec + Send + 'static;
|
||||||
|
|
||||||
/// Create transaction for given runtime call, signed by given account.
|
/// Create transaction for given runtime call, signed by given account.
|
||||||
fn sign_transaction(param: SignParam<Self>) -> Self::SignedTransaction
|
fn sign_transaction(param: SignParam<Self>) -> Result<Self::SignedTransaction, crate::Error>
|
||||||
where
|
where
|
||||||
Self: Sized;
|
Self: Sized;
|
||||||
|
|
||||||
|
|||||||
@@ -373,7 +373,7 @@ impl<C: Chain> Client<C> {
|
|||||||
pub async fn submit_signed_extrinsic(
|
pub async fn submit_signed_extrinsic(
|
||||||
&self,
|
&self,
|
||||||
extrinsic_signer: C::AccountId,
|
extrinsic_signer: C::AccountId,
|
||||||
prepare_extrinsic: impl FnOnce(HeaderIdOf<C>, C::Index) -> Bytes + Send + 'static,
|
prepare_extrinsic: impl FnOnce(HeaderIdOf<C>, C::Index) -> Result<Bytes> + Send + 'static,
|
||||||
) -> Result<C::Hash> {
|
) -> Result<C::Hash> {
|
||||||
let _guard = self.submit_signed_extrinsic_lock.lock().await;
|
let _guard = self.submit_signed_extrinsic_lock.lock().await;
|
||||||
let transaction_nonce = self.next_account_index(extrinsic_signer).await?;
|
let transaction_nonce = self.next_account_index(extrinsic_signer).await?;
|
||||||
@@ -390,7 +390,7 @@ impl<C: Chain> Client<C> {
|
|||||||
};
|
};
|
||||||
|
|
||||||
self.jsonrpsee_execute(move |client| async move {
|
self.jsonrpsee_execute(move |client| async move {
|
||||||
let extrinsic = prepare_extrinsic(best_header_id, transaction_nonce);
|
let extrinsic = prepare_extrinsic(best_header_id, transaction_nonce)?;
|
||||||
let tx_hash = Substrate::<C>::author_submit_extrinsic(&*client, extrinsic).await?;
|
let tx_hash = Substrate::<C>::author_submit_extrinsic(&*client, extrinsic).await?;
|
||||||
log::trace!(target: "bridge", "Sent transaction to {} node: {:?}", C::NAME, tx_hash);
|
log::trace!(target: "bridge", "Sent transaction to {} node: {:?}", C::NAME, tx_hash);
|
||||||
Ok(tx_hash)
|
Ok(tx_hash)
|
||||||
@@ -403,7 +403,7 @@ impl<C: Chain> Client<C> {
|
|||||||
pub async fn submit_and_watch_signed_extrinsic(
|
pub async fn submit_and_watch_signed_extrinsic(
|
||||||
&self,
|
&self,
|
||||||
extrinsic_signer: C::AccountId,
|
extrinsic_signer: C::AccountId,
|
||||||
prepare_extrinsic: impl FnOnce(HeaderIdOf<C>, C::Index) -> Bytes + Send + 'static,
|
prepare_extrinsic: impl FnOnce(HeaderIdOf<C>, C::Index) -> Result<Bytes> + Send + 'static,
|
||||||
) -> Result<Subscription<TransactionStatusOf<C>>> {
|
) -> Result<Subscription<TransactionStatusOf<C>>> {
|
||||||
let _guard = self.submit_signed_extrinsic_lock.lock().await;
|
let _guard = self.submit_signed_extrinsic_lock.lock().await;
|
||||||
let transaction_nonce = self.next_account_index(extrinsic_signer).await?;
|
let transaction_nonce = self.next_account_index(extrinsic_signer).await?;
|
||||||
@@ -411,7 +411,7 @@ impl<C: Chain> Client<C> {
|
|||||||
let best_header_id = HeaderId(*best_header.number(), best_header.hash());
|
let best_header_id = HeaderId(*best_header.number(), best_header.hash());
|
||||||
let subscription = self
|
let subscription = self
|
||||||
.jsonrpsee_execute(move |client| async move {
|
.jsonrpsee_execute(move |client| async move {
|
||||||
let extrinsic = prepare_extrinsic(best_header_id, transaction_nonce);
|
let extrinsic = prepare_extrinsic(best_header_id, transaction_nonce)?;
|
||||||
let tx_hash = C::Hasher::hash(&extrinsic.0);
|
let tx_hash = C::Hasher::hash(&extrinsic.0);
|
||||||
let subscription = client
|
let subscription = client
|
||||||
.subscribe(
|
.subscribe(
|
||||||
|
|||||||
@@ -20,8 +20,8 @@ use bp_messages::MessageNonce;
|
|||||||
use codec::Encode;
|
use codec::Encode;
|
||||||
use frame_support::weights::Weight;
|
use frame_support::weights::Weight;
|
||||||
use relay_substrate_client::{
|
use relay_substrate_client::{
|
||||||
Chain, ChainBase, ChainWithBalances, ChainWithGrandpa, ChainWithMessages, SignParam,
|
Chain, ChainBase, ChainWithBalances, ChainWithGrandpa, ChainWithMessages,
|
||||||
TransactionSignScheme, UnsignedTransaction,
|
Error as SubstrateError, SignParam, TransactionSignScheme, UnsignedTransaction,
|
||||||
};
|
};
|
||||||
use sp_core::{storage::StorageKey, Pair};
|
use sp_core::{storage::StorageKey, Pair};
|
||||||
use sp_runtime::{generic::SignedPayload, traits::IdentifyAccount};
|
use sp_runtime::{generic::SignedPayload, traits::IdentifyAccount};
|
||||||
@@ -104,7 +104,7 @@ impl TransactionSignScheme for Wococo {
|
|||||||
type AccountKeyPair = sp_core::sr25519::Pair;
|
type AccountKeyPair = sp_core::sr25519::Pair;
|
||||||
type SignedTransaction = crate::runtime::UncheckedExtrinsic;
|
type SignedTransaction = crate::runtime::UncheckedExtrinsic;
|
||||||
|
|
||||||
fn sign_transaction(param: SignParam<Self>) -> Self::SignedTransaction {
|
fn sign_transaction(param: SignParam<Self>) -> Result<Self::SignedTransaction, SubstrateError> {
|
||||||
let raw_payload = SignedPayload::new(
|
let raw_payload = SignedPayload::new(
|
||||||
param.unsigned.call.clone(),
|
param.unsigned.call.clone(),
|
||||||
bp_wococo::SignedExtensions::new(
|
bp_wococo::SignedExtensions::new(
|
||||||
@@ -122,12 +122,12 @@ impl TransactionSignScheme for Wococo {
|
|||||||
let signer: sp_runtime::MultiSigner = param.signer.public().into();
|
let signer: sp_runtime::MultiSigner = param.signer.public().into();
|
||||||
let (call, extra, _) = raw_payload.deconstruct();
|
let (call, extra, _) = raw_payload.deconstruct();
|
||||||
|
|
||||||
bp_wococo::UncheckedExtrinsic::new_signed(
|
Ok(bp_wococo::UncheckedExtrinsic::new_signed(
|
||||||
call,
|
call,
|
||||||
sp_runtime::MultiAddress::Id(signer.into_account()),
|
sp_runtime::MultiAddress::Id(signer.into_account()),
|
||||||
signature.into(),
|
signature.into(),
|
||||||
extra,
|
extra,
|
||||||
)
|
))
|
||||||
}
|
}
|
||||||
|
|
||||||
fn is_signed(tx: &Self::SignedTransaction) -> bool {
|
fn is_signed(tx: &Self::SignedTransaction) -> bool {
|
||||||
|
|||||||
@@ -123,17 +123,17 @@ where
|
|||||||
.submit_signed_extrinsic(
|
.submit_signed_extrinsic(
|
||||||
self.transaction_params.signer.public().into(),
|
self.transaction_params.signer.public().into(),
|
||||||
move |best_block_id, transaction_nonce| {
|
move |best_block_id, transaction_nonce| {
|
||||||
Bytes(
|
Ok(Bytes(
|
||||||
P::TransactionSignScheme::sign_transaction(SignParam {
|
P::TransactionSignScheme::sign_transaction(SignParam {
|
||||||
spec_version,
|
spec_version,
|
||||||
transaction_version,
|
transaction_version,
|
||||||
genesis_hash,
|
genesis_hash,
|
||||||
signer: transaction_params.signer.clone(),
|
signer: transaction_params.signer.clone(),
|
||||||
era: TransactionEra::new(best_block_id, transaction_params.mortality),
|
era: TransactionEra::new(best_block_id, transaction_params.mortality),
|
||||||
unsigned: UnsignedTransaction::new(call, transaction_nonce),
|
unsigned: UnsignedTransaction::new(call.into(), transaction_nonce),
|
||||||
})
|
})?
|
||||||
.encode(),
|
.encode(),
|
||||||
)
|
))
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
.await
|
.await
|
||||||
|
|||||||
@@ -31,7 +31,9 @@ use bp_header_chain::{
|
|||||||
use codec::Decode;
|
use codec::Decode;
|
||||||
use finality_grandpa::voter_set::VoterSet;
|
use finality_grandpa::voter_set::VoterSet;
|
||||||
use num_traits::{One, Zero};
|
use num_traits::{One, Zero};
|
||||||
use relay_substrate_client::{BlockNumberOf, Chain, ChainWithGrandpa, Client, HashOf};
|
use relay_substrate_client::{
|
||||||
|
BlockNumberOf, Chain, ChainWithGrandpa, Client, Error as SubstrateError, HashOf,
|
||||||
|
};
|
||||||
use sp_core::Bytes;
|
use sp_core::Bytes;
|
||||||
use sp_finality_grandpa::AuthorityList as GrandpaAuthoritiesSet;
|
use sp_finality_grandpa::AuthorityList as GrandpaAuthoritiesSet;
|
||||||
use sp_runtime::traits::Header as HeaderT;
|
use sp_runtime::traits::Header as HeaderT;
|
||||||
@@ -41,7 +43,10 @@ pub async fn initialize<SourceChain: ChainWithGrandpa, TargetChain: Chain>(
|
|||||||
source_client: Client<SourceChain>,
|
source_client: Client<SourceChain>,
|
||||||
target_client: Client<TargetChain>,
|
target_client: Client<TargetChain>,
|
||||||
target_transactions_signer: TargetChain::AccountId,
|
target_transactions_signer: TargetChain::AccountId,
|
||||||
prepare_initialize_transaction: impl FnOnce(TargetChain::Index, InitializationData<SourceChain::Header>) -> Bytes
|
prepare_initialize_transaction: impl FnOnce(
|
||||||
|
TargetChain::Index,
|
||||||
|
InitializationData<SourceChain::Header>,
|
||||||
|
) -> Result<Bytes, SubstrateError>
|
||||||
+ Send
|
+ Send
|
||||||
+ 'static,
|
+ 'static,
|
||||||
) {
|
) {
|
||||||
@@ -77,7 +82,10 @@ async fn do_initialize<SourceChain: ChainWithGrandpa, TargetChain: Chain>(
|
|||||||
source_client: Client<SourceChain>,
|
source_client: Client<SourceChain>,
|
||||||
target_client: Client<TargetChain>,
|
target_client: Client<TargetChain>,
|
||||||
target_transactions_signer: TargetChain::AccountId,
|
target_transactions_signer: TargetChain::AccountId,
|
||||||
prepare_initialize_transaction: impl FnOnce(TargetChain::Index, InitializationData<SourceChain::Header>) -> Bytes
|
prepare_initialize_transaction: impl FnOnce(
|
||||||
|
TargetChain::Index,
|
||||||
|
InitializationData<SourceChain::Header>,
|
||||||
|
) -> Result<Bytes, SubstrateError>
|
||||||
+ Send
|
+ Send
|
||||||
+ 'static,
|
+ 'static,
|
||||||
) -> Result<
|
) -> Result<
|
||||||
|
|||||||
@@ -282,8 +282,8 @@ where
|
|||||||
Ok(v) => v,
|
Ok(v) => v,
|
||||||
Err(_) => return BalanceOf::<P::SourceChain>::max_value(),
|
Err(_) => return BalanceOf::<P::SourceChain>::max_value(),
|
||||||
};
|
};
|
||||||
self.client
|
async {
|
||||||
.estimate_extrinsic_fee(make_messages_delivery_proof_transaction::<P>(
|
let dummy_tx = make_messages_delivery_proof_transaction::<P>(
|
||||||
runtime_version.spec_version,
|
runtime_version.spec_version,
|
||||||
runtime_version.transaction_version,
|
runtime_version.transaction_version,
|
||||||
self.client.genesis_hash(),
|
self.client.genesis_hash(),
|
||||||
@@ -292,9 +292,13 @@ where
|
|||||||
Zero::zero(),
|
Zero::zero(),
|
||||||
prepare_dummy_messages_delivery_proof::<P::SourceChain, P::TargetChain>(),
|
prepare_dummy_messages_delivery_proof::<P::SourceChain, P::TargetChain>(),
|
||||||
false,
|
false,
|
||||||
))
|
)?;
|
||||||
|
self.client
|
||||||
|
.estimate_extrinsic_fee(dummy_tx)
|
||||||
.await
|
.await
|
||||||
.map(|fee| fee.inclusion_fee())
|
.map(|fee| fee.inclusion_fee())
|
||||||
|
}
|
||||||
|
.await
|
||||||
.unwrap_or_else(|_| BalanceOf::<P::SourceChain>::max_value())
|
.unwrap_or_else(|_| BalanceOf::<P::SourceChain>::max_value())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -328,7 +332,7 @@ fn make_messages_delivery_proof_transaction<P: SubstrateMessageLane>(
|
|||||||
transaction_nonce: IndexOf<P::SourceChain>,
|
transaction_nonce: IndexOf<P::SourceChain>,
|
||||||
proof: SubstrateMessagesDeliveryProof<P::TargetChain>,
|
proof: SubstrateMessagesDeliveryProof<P::TargetChain>,
|
||||||
trace_call: bool,
|
trace_call: bool,
|
||||||
) -> Bytes
|
) -> Result<Bytes, SubstrateError>
|
||||||
where
|
where
|
||||||
P::SourceTransactionSignScheme: TransactionSignScheme<Chain = P::SourceChain>,
|
P::SourceTransactionSignScheme: TransactionSignScheme<Chain = P::SourceChain>,
|
||||||
{
|
{
|
||||||
@@ -336,17 +340,17 @@ where
|
|||||||
P::ReceiveMessagesDeliveryProofCallBuilder::build_receive_messages_delivery_proof_call(
|
P::ReceiveMessagesDeliveryProofCallBuilder::build_receive_messages_delivery_proof_call(
|
||||||
proof, trace_call,
|
proof, trace_call,
|
||||||
);
|
);
|
||||||
Bytes(
|
Ok(Bytes(
|
||||||
P::SourceTransactionSignScheme::sign_transaction(SignParam {
|
P::SourceTransactionSignScheme::sign_transaction(SignParam {
|
||||||
spec_version,
|
spec_version,
|
||||||
transaction_version,
|
transaction_version,
|
||||||
genesis_hash: *source_genesis_hash,
|
genesis_hash: *source_genesis_hash,
|
||||||
signer: source_transaction_params.signer.clone(),
|
signer: source_transaction_params.signer.clone(),
|
||||||
era: TransactionEra::new(source_best_block_id, source_transaction_params.mortality),
|
era: TransactionEra::new(source_best_block_id, source_transaction_params.mortality),
|
||||||
unsigned: UnsignedTransaction::new(call, transaction_nonce),
|
unsigned: UnsignedTransaction::new(call.into(), transaction_nonce),
|
||||||
})
|
})?
|
||||||
.encode(),
|
.encode(),
|
||||||
)
|
))
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Prepare 'dummy' messages delivery proof that will compose the delivery confirmation transaction.
|
/// Prepare 'dummy' messages delivery proof that will compose the delivery confirmation transaction.
|
||||||
|
|||||||
@@ -298,7 +298,7 @@ where
|
|||||||
total_size,
|
total_size,
|
||||||
),
|
),
|
||||||
false,
|
false,
|
||||||
);
|
)?;
|
||||||
let delivery_tx_fee = self.client.estimate_extrinsic_fee(delivery_tx).await?;
|
let delivery_tx_fee = self.client.estimate_extrinsic_fee(delivery_tx).await?;
|
||||||
let inclusion_fee_in_target_tokens = delivery_tx_fee.inclusion_fee();
|
let inclusion_fee_in_target_tokens = delivery_tx_fee.inclusion_fee();
|
||||||
|
|
||||||
@@ -323,9 +323,7 @@ where
|
|||||||
|
|
||||||
let (spec_version, transaction_version) = self.client.simple_runtime_version().await?;
|
let (spec_version, transaction_version) = self.client.simple_runtime_version().await?;
|
||||||
let larger_dispatch_weight = total_dispatch_weight.saturating_add(WEIGHT_DIFFERENCE);
|
let larger_dispatch_weight = total_dispatch_weight.saturating_add(WEIGHT_DIFFERENCE);
|
||||||
let larger_delivery_tx_fee = self
|
let dummy_tx = make_messages_delivery_transaction::<P>(
|
||||||
.client
|
|
||||||
.estimate_extrinsic_fee(make_messages_delivery_transaction::<P>(
|
|
||||||
spec_version,
|
spec_version,
|
||||||
transaction_version,
|
transaction_version,
|
||||||
self.client.genesis_hash(),
|
self.client.genesis_hash(),
|
||||||
@@ -340,8 +338,8 @@ where
|
|||||||
total_size,
|
total_size,
|
||||||
),
|
),
|
||||||
false,
|
false,
|
||||||
))
|
)?;
|
||||||
.await?;
|
let larger_delivery_tx_fee = self.client.estimate_extrinsic_fee(dummy_tx).await?;
|
||||||
|
|
||||||
compute_prepaid_messages_refund::<P::TargetChain>(
|
compute_prepaid_messages_refund::<P::TargetChain>(
|
||||||
total_prepaid_nonces,
|
total_prepaid_nonces,
|
||||||
@@ -402,7 +400,7 @@ fn make_messages_delivery_transaction<P: SubstrateMessageLane>(
|
|||||||
nonces: RangeInclusive<MessageNonce>,
|
nonces: RangeInclusive<MessageNonce>,
|
||||||
proof: SubstrateMessagesProof<P::SourceChain>,
|
proof: SubstrateMessagesProof<P::SourceChain>,
|
||||||
trace_call: bool,
|
trace_call: bool,
|
||||||
) -> Bytes
|
) -> Result<Bytes, SubstrateError>
|
||||||
where
|
where
|
||||||
P::TargetTransactionSignScheme: TransactionSignScheme<Chain = P::TargetChain>,
|
P::TargetTransactionSignScheme: TransactionSignScheme<Chain = P::TargetChain>,
|
||||||
{
|
{
|
||||||
@@ -415,17 +413,17 @@ where
|
|||||||
dispatch_weight,
|
dispatch_weight,
|
||||||
trace_call,
|
trace_call,
|
||||||
);
|
);
|
||||||
Bytes(
|
Ok(Bytes(
|
||||||
P::TargetTransactionSignScheme::sign_transaction(SignParam {
|
P::TargetTransactionSignScheme::sign_transaction(SignParam {
|
||||||
spec_version,
|
spec_version,
|
||||||
transaction_version,
|
transaction_version,
|
||||||
genesis_hash: *target_genesis_hash,
|
genesis_hash: *target_genesis_hash,
|
||||||
signer: target_transaction_params.signer.clone(),
|
signer: target_transaction_params.signer.clone(),
|
||||||
era: TransactionEra::new(target_best_block_id, target_transaction_params.mortality),
|
era: TransactionEra::new(target_best_block_id, target_transaction_params.mortality),
|
||||||
unsigned: UnsignedTransaction::new(call, transaction_nonce),
|
unsigned: UnsignedTransaction::new(call.into(), transaction_nonce),
|
||||||
})
|
})?
|
||||||
.encode(),
|
.encode(),
|
||||||
)
|
))
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Prepare 'dummy' messages proof that will compose the delivery transaction.
|
/// Prepare 'dummy' messages proof that will compose the delivery transaction.
|
||||||
|
|||||||
Reference in New Issue
Block a user