mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-07-04 15:07:23 +00:00
adc238ad86
* Remove unused relaying XCM * Aggregate HRMP (XCMP/HMP) messages. Payloads for spambot. * Revert lock * Fix * Broken example * Introduce fee payment mechanics into XCM. * Weight limitations on XCM execution * Mock environment for tests and the first test * Tests for XCM and a few refactors. * Remove code that's not ready * Fix for an XCM and an additional test * Query response system * XCMP message dispatch system reimagining - Moved most of the logic into xcm-handler pallet - Altered the outgoing XCMP API from push to pull - Changed underlying outgoing queue data structures to avoid multi-page read/writes - Introduced queuing for incoming messages - Introduced signal messages as a flow-control sub-stream - Introduced flow-control with basic threshold back-pressure - Introduced overall weight limitation on messages executed - Additonal alterations to XCM APIs for the new system * Some build fixes * Remove the Encode bounds sprayed around * More faff * Fix bounds amek use latest scale codec. * remove println * fixes * Fix XcmExecutor Tests * Fix XCM bounds using derivative crate * Refactor names of XcmGeneric &c into Xcm * Repot the xcm-executor into xcm-builder * Docs * Docs * Fixes * Update xcm/src/lib.rs Co-authored-by: Shawn Tabrizi <shawntabrizi@gmail.com> * Fixes * Docs * Update runtime/parachains/src/ump.rs Co-authored-by: Shawn Tabrizi <shawntabrizi@gmail.com> * Docs * Fixes * Fixes * Fixes * Docs * Fixes * Fixes * Introduce transfer_asset specialisation. * Fixes * Fixes Co-authored-by: Shawn Tabrizi <shawntabrizi@gmail.com>
61 lines
2.3 KiB
Rust
61 lines
2.3 KiB
Rust
// Copyright 2020 Parity Technologies (UK) Ltd.
|
|
// This file is part of Polkadot.
|
|
|
|
// Polkadot is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
|
|
// Polkadot is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with Polkadot. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
use sp_std::result::Result;
|
|
use xcm::v0::{Xcm, MultiLocation};
|
|
use frame_support::weights::Weight;
|
|
|
|
/// Trait to determine whether the execution engine should actually execute a given XCM.
|
|
pub trait ShouldExecute {
|
|
/// Returns `true` if the given `message` may be executed.
|
|
///
|
|
/// - `origin`: The origin (sender) of the message.
|
|
/// - `top_level`: `true`` indicates the initial XCM coming from the `origin`, `false` indicates an embedded
|
|
/// XCM executed internally as part of another message or an `Order`.
|
|
/// - `message`: The message itself.
|
|
/// - `shallow_weight`: The weight of the non-negotiable execution of the message. This does not include any
|
|
/// embedded XCMs sat behind mechanisms like `BuyExecution` which would need to answer for their own weight.
|
|
/// - `weight_credit`: The pre-established amount of weight that the system has determined this message
|
|
/// may utilise in its execution. Typically non-zero only because of prior fee payment, but could
|
|
/// in principle be due to other factors.
|
|
fn should_execute<Call>(
|
|
origin: &MultiLocation,
|
|
top_level: bool,
|
|
message: &Xcm<Call>,
|
|
shallow_weight: Weight,
|
|
weight_credit: &mut Weight,
|
|
) -> Result<(), ()>;
|
|
}
|
|
|
|
#[impl_trait_for_tuples::impl_for_tuples(30)]
|
|
impl ShouldExecute for Tuple {
|
|
fn should_execute<Call>(
|
|
origin: &MultiLocation,
|
|
top_level: bool,
|
|
message: &Xcm<Call>,
|
|
shallow_weight: Weight,
|
|
weight_credit: &mut Weight,
|
|
) -> Result<(), ()> {
|
|
for_tuples!( #(
|
|
match Tuple::should_execute(origin, top_level, message, shallow_weight, weight_credit) {
|
|
o @ Ok(()) => return o,
|
|
_ => (),
|
|
}
|
|
)* );
|
|
Err(())
|
|
}
|
|
}
|