-
Shaun Wang authored
* Update xcm support. * Fix unit tests. * fmt * Add patches. * Update xtokens. * fmt * Clean up. * Cross-chain transfer weight. * Weight for xcm execution. * Keep clippy happy. * Clean up. * Buy execution on dest location. * Better transfer error handling. * Update deps. * fmt * fix fmt * Update events in unit tests.
Shaun Wang authored* Update xcm support. * Fix unit tests. * fmt * Add patches. * Update xtokens. * fmt * Clean up. * Cross-chain transfer weight. * Weight for xcm execution. * Keep clippy happy. * Clean up. * Buy execution on dest location. * Better transfer error handling. * Update deps. * fmt * fix fmt * Update events in unit tests.
lib.rs 2.51 KiB
//! # XCM Support Module.
//!
//! ## Overview
//!
//! The XCM support module provides supporting traits, types and
//! implementations, to support cross-chain message(XCM) integration with ORML
//! modules.
#![cfg_attr(not(feature = "std"), no_std)]
#![allow(clippy::unused_unit)]
use frame_support::dispatch::{DispatchError, DispatchResult};
use sp_runtime::traits::{CheckedConversion, Convert};
use sp_std::{convert::TryFrom, marker::PhantomData, prelude::*};
use xcm::v0::{MultiAsset, MultiLocation, Xcm};
use xcm_executor::traits::{FilterAssetLocation, MatchesFungible};
use orml_traits::location::Reserve;
pub use currency_adapter::MultiCurrencyAdapter;
mod currency_adapter;
mod tests;
/// The XCM handler to execute XCM locally.
pub trait ExecuteXcm<AccountId, Call> {
fn execute_xcm(origin: AccountId, xcm: Xcm<Call>) -> DispatchResult;
}
/// A `MatchesFungible` implementation. It matches concrete fungible assets
/// whose `id` could be converted into `CurrencyId`.
pub struct IsNativeConcrete<CurrencyId, CurrencyIdConvert>(PhantomData<(CurrencyId, CurrencyIdConvert)>);
impl<CurrencyId, CurrencyIdConvert, Amount> MatchesFungible<Amount> for IsNativeConcrete<CurrencyId, CurrencyIdConvert>
where
CurrencyIdConvert: Convert<MultiLocation, Option<CurrencyId>>,
Amount: TryFrom<u128>,
{
fn matches_fungible(a: &MultiAsset) -> Option<Amount> {
if let MultiAsset::ConcreteFungible { id, amount } = a {
if CurrencyIdConvert::convert(id.clone()).is_some() {
return CheckedConversion::checked_from(*amount);
}
}
None
}
}
/// A `FilterAssetLocation` implementation. Filters multi native assets whose
/// reserve is same with `origin`.
pub struct MultiNativeAsset;
impl FilterAssetLocation for MultiNativeAsset {
fn filter_asset_location(asset: &MultiAsset, origin: &MultiLocation) -> bool {
if let Some(ref reserve) = asset.reserve() {
if reserve == origin {
return true;
}
}
false
}
}
/// Handlers unknown asset deposit and withdraw.
pub trait UnknownAsset {
/// Deposit unknown asset.
fn deposit(asset: &MultiAsset, to: &MultiLocation) -> DispatchResult;
/// Withdraw unknown asset.
fn withdraw(asset: &MultiAsset, from: &MultiLocation) -> DispatchResult;
}
const NO_UNKNOWN_ASSET_IMPL: &str = "NoUnknownAssetImpl";
impl UnknownAsset for () {
fn deposit(_asset: &MultiAsset, _to: &MultiLocation) -> DispatchResult {
Err(DispatchError::Other(NO_UNKNOWN_ASSET_IMPL))
}
fn withdraw(_asset: &MultiAsset, _from: &MultiLocation) -> DispatchResult {
Err(DispatchError::Other(NO_UNKNOWN_ASSET_IMPL))
}
}