From 05467080ee2bd8442dab1300430f667c882ea37e Mon Sep 17 00:00:00 2001 From: Igor Papandinas <26460174+ipapandinas@users.noreply.github.com> Date: Wed, 11 Sep 2024 19:29:36 +0200 Subject: [PATCH] weight_to_fee implemeted in pallet-xc-asset-config --- Cargo.lock | 44 +++++++++++++++--------------- pallets/xc-asset-config/src/lib.rs | 13 ++++++++- primitives/src/xcm/mod.rs | 10 ------- runtime/astar/src/lib.rs | 4 +-- runtime/shibuya/src/lib.rs | 4 +-- runtime/shiden/src/lib.rs | 4 +-- tests/integration/src/xcm_api.rs | 3 +- 7 files changed, 41 insertions(+), 41 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index b0f928765d..82a11ab9d7 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -966,7 +966,7 @@ dependencies = [ "futures-lite 2.3.0", "parking", "polling 3.7.3", - "rustix 0.38.36", + "rustix 0.38.37", "slab", "tracing", "windows-sys 0.59.0", @@ -1016,7 +1016,7 @@ dependencies = [ "cfg-if", "event-listener 3.1.0", "futures-lite 1.13.0", - "rustix 0.38.36", + "rustix 0.38.37", "windows-sys 0.48.0", ] @@ -1032,7 +1032,7 @@ dependencies = [ "cfg-if", "futures-core", "futures-io", - "rustix 0.38.36", + "rustix 0.38.37", "signal-hook-registry", "slab", "windows-sys 0.59.0", @@ -4678,7 +4678,7 @@ version = "0.7.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "29f9df8a11882c4e3335eb2d18a0137c505d9ca927470b0cac9c6f0ae07d28f7" dependencies = [ - "rustix 0.38.36", + "rustix 0.38.37", "windows-sys 0.48.0", ] @@ -6763,7 +6763,7 @@ version = "0.6.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b2cffa4ad52c6f791f4f8b15f0c05f9824b2ced1160e88cc393d64fff9a8ac64" dependencies = [ - "rustix 0.38.36", + "rustix 0.38.37", ] [[package]] @@ -11361,7 +11361,7 @@ dependencies = [ "concurrent-queue", "hermit-abi 0.4.0", "pin-project-lite 0.2.14", - "rustix 0.38.36", + "rustix 0.38.37", "tracing", "windows-sys 0.59.0", ] @@ -12556,9 +12556,9 @@ dependencies = [ [[package]] name = "rustix" -version = "0.38.36" +version = "0.38.37" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3f55e80d50763938498dd5ebb18647174e0c76dc38c5505294bb224624f30f36" +checksum = "8acb788b847c24f28525660c4d7758620a7210875711f79e7f663cc152726811" dependencies = [ "bitflags 2.6.0", "errno", @@ -15220,7 +15220,7 @@ dependencies = [ [[package]] name = "sp-crypto-ec-utils" version = "0.10.0" -source = "git+https://github.com/paritytech/polkadot-sdk#7c90f51dfd541db6df057d3c0ff787e92104c221" +source = "git+https://github.com/paritytech/polkadot-sdk#0f7acb52ada19ef934189a2ff02bdb5981634ead" dependencies = [ "ark-bls12-377", "ark-bls12-377-ext", @@ -15282,7 +15282,7 @@ dependencies = [ [[package]] name = "sp-debug-derive" version = "14.0.0" -source = "git+https://github.com/paritytech/polkadot-sdk#7c90f51dfd541db6df057d3c0ff787e92104c221" +source = "git+https://github.com/paritytech/polkadot-sdk#0f7acb52ada19ef934189a2ff02bdb5981634ead" dependencies = [ "proc-macro2", "quote", @@ -15302,7 +15302,7 @@ dependencies = [ [[package]] name = "sp-externalities" version = "0.25.0" -source = "git+https://github.com/paritytech/polkadot-sdk#7c90f51dfd541db6df057d3c0ff787e92104c221" +source = "git+https://github.com/paritytech/polkadot-sdk#0f7acb52ada19ef934189a2ff02bdb5981634ead" dependencies = [ "environmental", "parity-scale-codec", @@ -15518,7 +15518,7 @@ dependencies = [ [[package]] name = "sp-runtime-interface" version = "24.0.0" -source = "git+https://github.com/paritytech/polkadot-sdk#7c90f51dfd541db6df057d3c0ff787e92104c221" +source = "git+https://github.com/paritytech/polkadot-sdk#0f7acb52ada19ef934189a2ff02bdb5981634ead" dependencies = [ "bytes", "impl-trait-for-tuples", @@ -15550,7 +15550,7 @@ dependencies = [ [[package]] name = "sp-runtime-interface-proc-macro" version = "17.0.0" -source = "git+https://github.com/paritytech/polkadot-sdk#7c90f51dfd541db6df057d3c0ff787e92104c221" +source = "git+https://github.com/paritytech/polkadot-sdk#0f7acb52ada19ef934189a2ff02bdb5981634ead" dependencies = [ "Inflector", "expander", @@ -15639,7 +15639,7 @@ source = "git+https://github.com/paritytech/polkadot-sdk?branch=release-polkadot [[package]] name = "sp-std" version = "14.0.0" -source = "git+https://github.com/paritytech/polkadot-sdk#7c90f51dfd541db6df057d3c0ff787e92104c221" +source = "git+https://github.com/paritytech/polkadot-sdk#0f7acb52ada19ef934189a2ff02bdb5981634ead" [[package]] name = "sp-storage" @@ -15656,7 +15656,7 @@ dependencies = [ [[package]] name = "sp-storage" version = "19.0.0" -source = "git+https://github.com/paritytech/polkadot-sdk#7c90f51dfd541db6df057d3c0ff787e92104c221" +source = "git+https://github.com/paritytech/polkadot-sdk#0f7acb52ada19ef934189a2ff02bdb5981634ead" dependencies = [ "impl-serde", "parity-scale-codec", @@ -15691,7 +15691,7 @@ dependencies = [ [[package]] name = "sp-tracing" version = "16.0.0" -source = "git+https://github.com/paritytech/polkadot-sdk#7c90f51dfd541db6df057d3c0ff787e92104c221" +source = "git+https://github.com/paritytech/polkadot-sdk#0f7acb52ada19ef934189a2ff02bdb5981634ead" dependencies = [ "parity-scale-codec", "tracing", @@ -15788,7 +15788,7 @@ dependencies = [ [[package]] name = "sp-wasm-interface" version = "20.0.0" -source = "git+https://github.com/paritytech/polkadot-sdk#7c90f51dfd541db6df057d3c0ff787e92104c221" +source = "git+https://github.com/paritytech/polkadot-sdk#0f7acb52ada19ef934189a2ff02bdb5981634ead" dependencies = [ "anyhow", "impl-trait-for-tuples", @@ -16268,7 +16268,7 @@ dependencies = [ "cfg-if", "fastrand 2.1.1", "once_cell", - "rustix 0.38.36", + "rustix 0.38.37", "windows-sys 0.59.0", ] @@ -16287,7 +16287,7 @@ version = "0.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "21bebf2b7c9e0a515f6e0f8c51dc0f8e4696391e6f1ff30379559f8365fb0df7" dependencies = [ - "rustix 0.38.36", + "rustix 0.38.37", "windows-sys 0.48.0", ] @@ -16933,9 +16933,9 @@ checksum = "08f95100a766bf4f8f28f90d77e0a5461bbdb219042e7679bebe79004fed8d75" [[package]] name = "unicode-ident" -version = "1.0.12" +version = "1.0.13" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3354b9ac3fae1ff6755cb6db53683adb661634f67557942dea4facebec0fee4b" +checksum = "e91b56cd4cadaeb79bbf1a5645f6b4f8dc5bde8834ad5894a8db35fda9efa1fe" [[package]] name = "unicode-normalization" @@ -17696,7 +17696,7 @@ dependencies = [ "either", "home", "once_cell", - "rustix 0.38.36", + "rustix 0.38.37", ] [[package]] diff --git a/pallets/xc-asset-config/src/lib.rs b/pallets/xc-asset-config/src/lib.rs index b788a4ef4e..5854e71ad5 100644 --- a/pallets/xc-asset-config/src/lib.rs +++ b/pallets/xc-asset-config/src/lib.rs @@ -49,6 +49,7 @@ //! `ExecutionPaymentRate` interface for fetching `units per second` if asset is supported payment asset //! - `get_units_per_second` //! +//! - `weight_to_fee` method is used to convert weight to fee based on units per second and weight. #![cfg_attr(not(feature = "std"), no_std)] @@ -72,7 +73,9 @@ pub use weights::WeightInfo; pub mod pallet { use crate::weights::WeightInfo; - use frame_support::{pallet_prelude::*, traits::EnsureOrigin}; + use frame_support::{ + pallet_prelude::*, traits::EnsureOrigin, weights::constants::WEIGHT_REF_TIME_PER_SECOND, + }; use frame_system::pallet_prelude::*; use parity_scale_codec::HasCompact; use sp_std::boxed::Box; @@ -116,6 +119,14 @@ pub mod pallet { } } + impl Pallet { + /// Convert weight to fee based on units per second and weight. + pub fn weight_to_fee(weight: Weight, units_per_second: u128) -> u128 { + units_per_second.saturating_mul(weight.ref_time() as u128) + / (WEIGHT_REF_TIME_PER_SECOND as u128) + } + } + #[pallet::config] pub trait Config: frame_system::Config { type RuntimeEvent: From> + IsType<::RuntimeEvent>; diff --git a/primitives/src/xcm/mod.rs b/primitives/src/xcm/mod.rs index 079689fe6e..65db50e0ec 100644 --- a/primitives/src/xcm/mod.rs +++ b/primitives/src/xcm/mod.rs @@ -26,7 +26,6 @@ //! - `FixedRateOfForeignAsset` - weight trader for execution payment in foreign asset //! - `ReserveAssetFilter` - used to check whether asset/origin are a valid reserve location //! - `XcmFungibleFeeHandler` - used to handle XCM fee execution fees -//! - `WeightToForeignAssetFee` - used to convert weight to fee based on units per second and weight. //! //! Please refer to implementation below for more info. //! @@ -356,12 +355,3 @@ impl> ShouldExecute for AllowTopLevelPaidExecutionFrom Ok(()) } } - -pub struct WeightToForeignAssetFee; -impl WeightToForeignAssetFee { - /// Convert weight to fee based on units per second and weight. - pub fn weight_to_fee(weight: Weight, units_per_second: u128) -> u128 { - units_per_second.saturating_mul(weight.ref_time() as u128) - / (WEIGHT_REF_TIME_PER_SECOND as u128) - } -} diff --git a/runtime/astar/src/lib.rs b/runtime/astar/src/lib.rs index 823e84b99e..e5bbb6d07d 100644 --- a/runtime/astar/src/lib.rs +++ b/runtime/astar/src/lib.rs @@ -83,7 +83,7 @@ use astar_primitives::{ }, evm::EvmRevertCodeHandler, oracle::{CurrencyAmount, CurrencyId, DummyCombineData, Price}, - xcm::{AssetLocationIdConverter, WeightToForeignAssetFee}, + xcm::AssetLocationIdConverter, Address, AssetId, BlockNumber, Hash, Header, Nonce, UnfreezeChainOnFailedMigration, }; pub use astar_primitives::{governance::OracleMembershipInst, AccountId, Balance, Signature}; @@ -1946,7 +1946,7 @@ impl_runtime_apis! { match pallet_xc_asset_config::AssetLocationUnitsPerSecond::::get(versioned_location) { Some(units_per_sec) => { - Ok(WeightToForeignAssetFee::weight_to_fee(weight, units_per_sec)) + Ok(pallet_xc_asset_config::Pallet::::weight_to_fee(weight, units_per_sec)) } None => Err(XcmPaymentApiError::AssetNotFound), } diff --git a/runtime/shibuya/src/lib.rs b/runtime/shibuya/src/lib.rs index 7a4a0c5a7c..e6a7ea7c4c 100644 --- a/runtime/shibuya/src/lib.rs +++ b/runtime/shibuya/src/lib.rs @@ -93,7 +93,7 @@ use astar_primitives::{ TechnicalCommitteeMembershipInst, }, oracle::{CurrencyAmount, CurrencyId, DummyCombineData, Price}, - xcm::{AssetLocationIdConverter, WeightToForeignAssetFee}, + xcm::AssetLocationIdConverter, Address, AssetId, BlockNumber, Hash, Header, Nonce, UnfreezeChainOnFailedMigration, }; pub use astar_primitives::{AccountId, Balance, Signature}; @@ -2277,7 +2277,7 @@ impl_runtime_apis! { match pallet_xc_asset_config::AssetLocationUnitsPerSecond::::get(versioned_location) { Some(units_per_sec) => { - Ok(WeightToForeignAssetFee::weight_to_fee(weight, units_per_sec)) + Ok(pallet_xc_asset_config::Pallet::::weight_to_fee(weight, units_per_sec)) } None => Err(XcmPaymentApiError::AssetNotFound), } diff --git a/runtime/shiden/src/lib.rs b/runtime/shiden/src/lib.rs index 75e56275ee..3292ca8594 100644 --- a/runtime/shiden/src/lib.rs +++ b/runtime/shiden/src/lib.rs @@ -83,7 +83,7 @@ use astar_primitives::{ evm::EvmRevertCodeHandler, governance::OracleMembershipInst, oracle::{CurrencyAmount, CurrencyId, DummyCombineData, Price}, - xcm::{AssetLocationIdConverter, WeightToForeignAssetFee}, + xcm::AssetLocationIdConverter, Address, AssetId, BlockNumber, Hash, Header, Nonce, UnfreezeChainOnFailedMigration, }; pub use astar_primitives::{AccountId, Balance, Signature}; @@ -1947,7 +1947,7 @@ impl_runtime_apis! { match pallet_xc_asset_config::AssetLocationUnitsPerSecond::::get(versioned_location) { Some(units_per_sec) => { - Ok(WeightToForeignAssetFee::weight_to_fee(weight, units_per_sec)) + Ok(pallet_xc_asset_config::Pallet::::weight_to_fee(weight, units_per_sec)) } None => Err(XcmPaymentApiError::AssetNotFound), } diff --git a/tests/integration/src/xcm_api.rs b/tests/integration/src/xcm_api.rs index e8a54db261..24a5245692 100644 --- a/tests/integration/src/xcm_api.rs +++ b/tests/integration/src/xcm_api.rs @@ -18,7 +18,6 @@ use crate::setup::*; -pub use astar_primitives::xcm::WeightToForeignAssetFee; use sp_runtime::traits::Zero; use xcm::{ v4::{ @@ -140,7 +139,7 @@ fn query_weight_to_asset_fee_is_ok() { ); let weight = Weight::from_parts(1_000_000_000, 1_000_000); - let expected_fee = WeightToForeignAssetFee::weight_to_fee(weight, units_per_second); + let expected_fee = XcAssetConfig::weight_to_fee(weight, units_per_second); let fee = Runtime::query_weight_to_asset_fee(weight, XcmAssetId(payable_location).into()) .expect("Must return fee for payable asset.");