Add Xcm sender. (#2489)

* Add Xcm sender.

* Rename XCM sender and add description.

* Update copyright header.

Co-authored-by: Shawn Tabrizi <shawntabrizi@gmail.com>
This commit is contained in:
Shaun Wang
2021-03-02 02:25:55 +13:00
committed by GitHub
parent c4b89e11da
commit 135cce9055
5 changed files with 55 additions and 2 deletions
+1
View File
@@ -26,6 +26,7 @@ pub mod purchase;
pub mod impls; pub mod impls;
pub mod paras_sudo_wrapper; pub mod paras_sudo_wrapper;
pub mod paras_registrar; pub mod paras_registrar;
pub mod xcm_sender;
use primitives::v1::{BlockNumber, ValidatorId, AssignmentId}; use primitives::v1::{BlockNumber, ValidatorId, AssignmentId};
use sp_runtime::{Perquintill, Perbill, FixedPointNumber}; use sp_runtime::{Perquintill, Perbill, FixedPointNumber};
+42
View File
@@ -0,0 +1,42 @@
// Copyright 2021 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/>.
//! Xcm sender for relay chain.
use parity_scale_codec::Encode;
use sp_std::marker::PhantomData;
use xcm::{VersionedXcm, v0::{SendXcm, MultiLocation, Junction, Xcm, Result, Error}};
use runtime_parachains::{configuration, dmp};
/// Xcm sender for relay chain. It only sends downward message.
pub struct RelayChainXcmSender<T>(PhantomData<T>);
impl<T: configuration::Config + dmp::Config> SendXcm for RelayChainXcmSender<T> {
fn send_xcm(dest: MultiLocation, msg: Xcm) -> Result {
if let MultiLocation::X1(Junction::Parachain { id }) = dest {
// Downward message passing.
let config = <configuration::Module<T>>::config();
<dmp::Module<T>>::queue_downward_message(
&config,
id.into(),
VersionedXcm::from(msg).encode(),
).map_err(Into::<Error>::into)?;
Ok(())
} else {
Err(Error::CannotReachDestination)
}
}
}
+9
View File
@@ -22,6 +22,7 @@ use frame_support::{decl_module, decl_storage, StorageMap, weights::Weight, trai
use sp_std::{fmt, prelude::*}; use sp_std::{fmt, prelude::*};
use sp_runtime::traits::{BlakeTwo256, Hash as HashT, SaturatedConversion}; use sp_runtime::traits::{BlakeTwo256, Hash as HashT, SaturatedConversion};
use primitives::v1::{Id as ParaId, DownwardMessage, InboundDownwardMessage, Hash}; use primitives::v1::{Id as ParaId, DownwardMessage, InboundDownwardMessage, Hash};
use xcm::v0::Error as XcmError;
/// An error sending a downward message. /// An error sending a downward message.
#[cfg_attr(test, derive(Debug))] #[cfg_attr(test, derive(Debug))]
@@ -30,6 +31,14 @@ pub enum QueueDownwardMessageError {
ExceedsMaxMessageSize, ExceedsMaxMessageSize,
} }
impl From<QueueDownwardMessageError> for XcmError {
fn from(err: QueueDownwardMessageError) -> Self {
match err {
QueueDownwardMessageError::ExceedsMaxMessageSize => XcmError::ExceedsMaxMessageSize,
}
}
}
/// An error returned by [`check_processed_downward_messages`] that indicates an acceptance check /// An error returned by [`check_processed_downward_messages`] that indicates an acceptance check
/// didn't pass. /// didn't pass.
pub enum ProcessedDownwardMessagesAcceptanceErr { pub enum ProcessedDownwardMessagesAcceptanceErr {
+2 -2
View File
@@ -61,7 +61,7 @@ use sp_core::OpaqueMetadata;
use sp_staking::SessionIndex; use sp_staking::SessionIndex;
use pallet_session::historical as session_historical; use pallet_session::historical as session_historical;
use frame_system::{EnsureRoot, EnsureOneOf, EnsureSigned}; use frame_system::{EnsureRoot, EnsureOneOf, EnsureSigned};
use runtime_common::{paras_sudo_wrapper, paras_registrar}; use runtime_common::{paras_sudo_wrapper, paras_registrar, xcm_sender};
use runtime_parachains::origin as parachains_origin; use runtime_parachains::origin as parachains_origin;
use runtime_parachains::configuration as parachains_configuration; use runtime_parachains::configuration as parachains_configuration;
@@ -553,7 +553,7 @@ type LocalOriginConverter = (
pub struct XcmConfig; pub struct XcmConfig;
impl xcm_executor::Config for XcmConfig { impl xcm_executor::Config for XcmConfig {
type Call = Call; type Call = Call;
type XcmSender = (); type XcmSender = xcm_sender::RelayChainXcmSender<Runtime>;
type AssetTransactor = LocalAssetTransactor; type AssetTransactor = LocalAssetTransactor;
type OriginConverter = LocalOriginConverter; type OriginConverter = LocalOriginConverter;
type IsReserve = (); type IsReserve = ();
+1
View File
@@ -36,6 +36,7 @@ pub enum Error {
MultiLocationFull, MultiLocationFull,
FailedToDecode, FailedToDecode,
BadOrigin, BadOrigin,
ExceedsMaxMessageSize,
} }
impl From<()> for Error { impl From<()> for Error {