referrerpolicy=no-referrer-when-downgrade
asset_hub_westend_runtime

Type Alias AssetConversion

Source
pub type AssetConversion = Pallet<Runtime>;

Aliased Type§

struct AssetConversion(/* private fields */);

Implementations

Source§

impl<T> Pallet<T>
where T: Config,

Pallet’s callable functions.

Source

pub fn create_pool( origin: <T as Config>::RuntimeOrigin, asset1: Box<<T as Config>::AssetKind>, asset2: Box<<T as Config>::AssetKind>, ) -> Result<(), DispatchError>

Creates an empty liquidity pool and an associated new lp_token asset (the id of which is returned in the Event::PoolCreated event).

Once a pool is created, someone may Pallet::add_liquidity to it.

Source

pub fn add_liquidity( origin: <T as Config>::RuntimeOrigin, asset1: Box<<T as Config>::AssetKind>, asset2: Box<<T as Config>::AssetKind>, amount1_desired: <T as Config>::Balance, amount2_desired: <T as Config>::Balance, amount1_min: <T as Config>::Balance, amount2_min: <T as Config>::Balance, mint_to: <T as Config>::AccountId, ) -> Result<(), DispatchError>

Provide liquidity into the pool of asset1 and asset2. NOTE: an optimal amount of asset1 and asset2 will be calculated and might be different than the provided amount1_desired/amount2_desired thus you should provide the min amount you’re happy to provide. Params amount1_min/amount2_min represent that. mint_to will be sent the liquidity tokens that represent this share of the pool.

NOTE: when encountering an incorrect exchange rate and non-withdrawable pool liquidity, batch an atomic call with Pallet::add_liquidity and Pallet::swap_exact_tokens_for_tokens or Pallet::swap_tokens_for_exact_tokens calls to render the liquidity withdrawable and rectify the exchange rate.

Once liquidity is added, someone may successfully call Pallet::swap_exact_tokens_for_tokens.

Source

pub fn remove_liquidity( origin: <T as Config>::RuntimeOrigin, asset1: Box<<T as Config>::AssetKind>, asset2: Box<<T as Config>::AssetKind>, lp_token_burn: <T as Config>::Balance, amount1_min_receive: <T as Config>::Balance, amount2_min_receive: <T as Config>::Balance, withdraw_to: <T as Config>::AccountId, ) -> Result<(), DispatchError>

Allows you to remove liquidity by providing the lp_token_burn tokens that will be burned in the process. With the usage of amount1_min_receive/amount2_min_receive it’s possible to control the min amount of returned tokens you’re happy with.

Source

pub fn swap_exact_tokens_for_tokens( origin: <T as Config>::RuntimeOrigin, path: Vec<Box<<T as Config>::AssetKind>>, amount_in: <T as Config>::Balance, amount_out_min: <T as Config>::Balance, send_to: <T as Config>::AccountId, keep_alive: bool, ) -> Result<(), DispatchError>

Swap the exact amount of asset1 into asset2. amount_out_min param allows you to specify the min amount of the asset2 you’re happy to receive.

AssetConversionApi::quote_price_exact_tokens_for_tokens runtime call can be called for a quote.

Source

pub fn swap_tokens_for_exact_tokens( origin: <T as Config>::RuntimeOrigin, path: Vec<Box<<T as Config>::AssetKind>>, amount_out: <T as Config>::Balance, amount_in_max: <T as Config>::Balance, send_to: <T as Config>::AccountId, keep_alive: bool, ) -> Result<(), DispatchError>

Swap any amount of asset1 to get the exact amount of asset2. amount_in_max param allows to specify the max amount of the asset1 you’re happy to provide.

AssetConversionApi::quote_price_tokens_for_exact_tokens runtime call can be called for a quote.

Source

pub fn touch( origin: <T as Config>::RuntimeOrigin, asset1: Box<<T as Config>::AssetKind>, asset2: Box<<T as Config>::AssetKind>, ) -> Result<PostDispatchInfo, DispatchErrorWithPostInfo<PostDispatchInfo>>

Touch an existing pool to fulfill prerequisites before providing liquidity, such as ensuring that the pool’s accounts are in place. It is typically useful when a pool creator removes the pool’s accounts and does not provide a liquidity. This action may involve holding assets from the caller as a deposit for creating the pool’s accounts.

The origin must be Signed.

  • asset1: The asset ID of an existing pool with a pair (asset1, asset2).
  • asset2: The asset ID of an existing pool with a pair (asset1, asset2).

Emits Touched event when successful.

Source§

impl<T> Pallet<T>
where T: Config,

Source

pub fn get_reserves( asset1: <T as Config>::AssetKind, asset2: <T as Config>::AssetKind, ) -> Result<(<T as Config>::Balance, <T as Config>::Balance), Error<T>>

Returns the balance of each asset in the pool. The tuple result is in the order requested (not necessarily the same as pool order).

Source

pub fn quote_price_exact_tokens_for_tokens( asset1: <T as Config>::AssetKind, asset2: <T as Config>::AssetKind, amount: <T as Config>::Balance, include_fee: bool, ) -> Option<<T as Config>::Balance>

Used by the RPC service to provide current prices.

Source

pub fn quote_price_tokens_for_exact_tokens( asset1: <T as Config>::AssetKind, asset2: <T as Config>::AssetKind, amount: <T as Config>::Balance, include_fee: bool, ) -> Option<<T as Config>::Balance>

Used by the RPC service to provide current prices.

Source

pub fn quote( amount: &<T as Config>::Balance, reserve1: &<T as Config>::Balance, reserve2: &<T as Config>::Balance, ) -> Result<<T as Config>::Balance, Error<T>>

Calculates the optimal amount from the reserves.

Source

pub fn get_amount_out( amount_in: &<T as Config>::Balance, reserve_in: &<T as Config>::Balance, reserve_out: &<T as Config>::Balance, ) -> Result<<T as Config>::Balance, Error<T>>

Calculates amount out.

Given an input amount of an asset and pair reserves, returns the maximum output amount of the other asset.

Source

pub fn get_amount_in( amount_out: &<T as Config>::Balance, reserve_in: &<T as Config>::Balance, reserve_out: &<T as Config>::Balance, ) -> Result<<T as Config>::Balance, Error<T>>

Calculates amount in.

Given an output amount of an asset and pair reserves, returns a required input amount of the other asset.

Source

pub fn get_next_pool_asset_id() -> <T as Config>::PoolAssetId

Returns the next pool asset id for benchmark purposes only.

Trait Implementations

Source§

impl<T> BeforeAllRuntimeMigrations for Pallet<T>
where T: Config,

Source§

fn before_all_runtime_migrations() -> Weight

Something that should happen before runtime migrations are executed.
Source§

impl<T> Benchmarking for Pallet<T>
where T: Config + Config, <T as Config>::Assets: Create<<T as Config>::AccountId> + Mutate<<T as Config>::AccountId>, <T as Config>::PoolAssetId: Into<u32>,

Source§

fn benchmarks(extra: bool) -> Vec<BenchmarkMetadata>

Get the benchmarks available for this pallet. Generally there is one benchmark per extrinsic, so these are sometimes just called “extrinsics”. Read more
Source§

fn run_benchmark( extrinsic: &[u8], c: &[(BenchmarkParameter, u32)], whitelist: &[TrackedStorageKey], verify: bool, internal_repeats: u32, ) -> Result<Vec<BenchmarkResult>, BenchmarkError>

Run the benchmarks for this pallet.
Source§

impl<T> Callable<T> for Pallet<T>
where T: Config,

Source§

impl<T> Clone for Pallet<T>

Source§

fn clone(&self) -> Pallet<T>

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<T> Debug for Pallet<T>

Source§

fn fmt(&self, fmt: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
Source§

impl<T> DispatchViewFunction for Pallet<T>
where T: Config,

Source§

fn dispatch_view_function<O>( id: &ViewFunctionId, input: &mut &[u8], output: &mut O, ) -> Result<(), ViewFunctionDispatchError>
where O: Output,

Source§

impl<T> GetStorageVersion for Pallet<T>
where T: Config,

Source§

type InCodeStorageVersion = NoStorageVersionSet

This type is generated by the pallet macro. Read more
Source§

fn in_code_storage_version() -> <Pallet<T> as GetStorageVersion>::InCodeStorageVersion

Returns the in-code storage version as specified in the storage_version attribute, or NoStorageVersionSet if the attribute is missing.
Source§

fn on_chain_storage_version() -> StorageVersion

Returns the storage version of the pallet as last set in the actual on-chain storage.
Source§

fn current_storage_version() -> Self::InCodeStorageVersion

👎Deprecated: This method has been renamed to in_code_storage_version and will be removed after March 2024.
DEPRECATED: Use Self::current_storage_version instead. Read more
Source§

impl<T> Hooks<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
where T: Config,

Source§

fn integrity_test()

Check the integrity of this pallet’s configuration. Read more
Source§

fn on_initialize(_n: BlockNumber) -> Weight

Block initialization hook. This is called at the very beginning of block execution. Read more
Source§

fn on_finalize(_n: BlockNumber)

Block finalization hook. This is called at the very end of block execution. Read more
Source§

fn on_idle(_n: BlockNumber, _remaining_weight: Weight) -> Weight

Hook to consume a block’s idle time. This will run when the block is being finalized (before Hooks::on_finalize). Read more
Source§

fn on_poll(_n: BlockNumber, _weight: &mut WeightMeter)

A hook to run logic after inherent application. Read more
Source§

fn on_runtime_upgrade() -> Weight

Hook executed when a code change (aka. a “runtime upgrade”) is detected by the FRAME Executive pallet. Read more
Source§

fn try_state(_n: BlockNumber) -> Result<(), DispatchError>

Execute the sanity checks of this pallet, per block. Read more
Source§

fn pre_upgrade() -> Result<Vec<u8>, DispatchError>

Execute some pre-checks prior to a runtime upgrade. Read more
Source§

fn post_upgrade(_state: Vec<u8>) -> Result<(), DispatchError>

Execute some post-checks after a runtime upgrade. Read more
Source§

fn offchain_worker(_n: BlockNumber)

Implementing this function on a pallet allows you to perform long-running tasks that are dispatched as separate threads, and entirely independent of the main blockchain execution. Read more
Source§

impl<T> IntegrityTest for Pallet<T>
where T: Config,

Source§

impl<T> OffchainWorker<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
where T: Config,

Source§

fn offchain_worker( n: <<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number, )

This function is being called after every block import (when fully synced). Read more
Source§

impl<T> OnFinalize<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
where T: Config,

Source§

fn on_finalize( n: <<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number, )

Source§

impl<T> OnGenesis for Pallet<T>
where T: Config,

Source§

fn on_genesis()

Something that should happen at genesis.
Source§

impl<T> OnIdle<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
where T: Config,

Source§

fn on_idle( n: <<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number, remaining_weight: Weight, ) -> Weight

Source§

impl<T> OnInitialize<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
where T: Config,

Source§

fn on_initialize( n: <<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number, ) -> Weight

Source§

impl<T> OnPoll<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
where T: Config,

Source§

fn on_poll( n: <<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number, weight: &mut WeightMeter, )

Code to execute every now and then at the beginning of the block after inherent application. Read more
Source§

impl<T> OnRuntimeUpgrade for Pallet<T>
where T: Config,

Source§

fn on_runtime_upgrade() -> Weight

Source§

fn pre_upgrade() -> Result<Vec<u8>, DispatchError>

Source§

fn post_upgrade(state: Vec<u8>) -> Result<(), DispatchError>

Source§

fn try_on_runtime_upgrade(checks: bool) -> Result<Weight, DispatchError>

The expected and default behavior of this method is to handle executing pre_upgrade -> on_runtime_upgrade -> post_upgrade hooks for a migration. Read more
Source§

impl<T> PalletInfoAccess for Pallet<T>
where T: Config,

Source§

fn index() -> usize

Index of the pallet as configured in the runtime.
Source§

fn name() -> &'static str

Name of the pallet as configured in the runtime.
Source§

fn name_hash() -> [u8; 16]

Two128 hash of name.
Source§

fn module_name() -> &'static str

Name of the Rust module containing the pallet.
Source§

fn crate_version() -> CrateVersion

Version of the crate containing the pallet.
Source§

impl<T> PalletsInfoAccess for Pallet<T>
where T: Config,

Source§

fn count() -> usize

The number of pallets’ information that this type represents. Read more
Source§

fn infos() -> Vec<PalletInfoData>

All of the pallets’ information that this type represents.
Source§

impl<T> PartialEq for Pallet<T>

Source§

fn eq(&self, other: &Pallet<T>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<T> QuotePrice for Pallet<T>
where T: Config,

Source§

type Balance = <T as Config>::Balance

Measurement units of the asset classes for pricing.
Source§

type AssetKind = <T as Config>::AssetKind

Type representing the kind of assets for which the price is being quoted.
Source§

fn quote_price_exact_tokens_for_tokens( asset1: <Pallet<T> as QuotePrice>::AssetKind, asset2: <Pallet<T> as QuotePrice>::AssetKind, amount: <Pallet<T> as QuotePrice>::Balance, include_fee: bool, ) -> Option<<Pallet<T> as QuotePrice>::Balance>

Quotes the amount of asset2 resulting from swapping the exact amount of asset1. Read more
Source§

fn quote_price_tokens_for_exact_tokens( asset1: <Pallet<T> as QuotePrice>::AssetKind, asset2: <Pallet<T> as QuotePrice>::AssetKind, amount: <Pallet<T> as QuotePrice>::Balance, include_fee: bool, ) -> Option<<Pallet<T> as QuotePrice>::Balance>

Quotes the amount of asset1 required to obtain the exact amount of asset2. Read more
Source§

impl<T> StorageInfoTrait for Pallet<T>
where T: Config,

Source§

impl<T> Swap<<T as Config>::AccountId> for Pallet<T>
where T: Config,

Source§

type Balance = <T as Config>::Balance

Measure units of the asset classes for swapping.
Source§

type AssetKind = <T as Config>::AssetKind

Kind of assets that are going to be swapped.
Source§

fn max_path_len() -> u32

Returns the upper limit on the length of the swap path.
Source§

fn swap_exact_tokens_for_tokens( sender: <T as Config>::AccountId, path: Vec<<Pallet<T> as Swap<<T as Config>::AccountId>>::AssetKind>, amount_in: <Pallet<T> as Swap<<T as Config>::AccountId>>::Balance, amount_out_min: Option<<Pallet<T> as Swap<<T as Config>::AccountId>>::Balance>, send_to: <T as Config>::AccountId, keep_alive: bool, ) -> Result<<Pallet<T> as Swap<<T as Config>::AccountId>>::Balance, DispatchError>

Swap exactly amount_in of asset path[0] for asset path[last]. If an amount_out_min is specified, it will return an error if it is unable to acquire the amount desired. Read more
Source§

fn swap_tokens_for_exact_tokens( sender: <T as Config>::AccountId, path: Vec<<Pallet<T> as Swap<<T as Config>::AccountId>>::AssetKind>, amount_out: <Pallet<T> as Swap<<T as Config>::AccountId>>::Balance, amount_in_max: Option<<Pallet<T> as Swap<<T as Config>::AccountId>>::Balance>, send_to: <T as Config>::AccountId, keep_alive: bool, ) -> Result<<Pallet<T> as Swap<<T as Config>::AccountId>>::Balance, DispatchError>

Take the path[0] asset and swap some amount for amount_out of the path[last]. If an amount_in_max is specified, it will return an error if acquiring amount_out would be too costly. Read more
Source§

impl<T> SwapCredit<<T as Config>::AccountId> for Pallet<T>
where T: Config,

Source§

type Balance = <T as Config>::Balance

Measure units of the asset classes for swapping.
Source§

type AssetKind = <T as Config>::AssetKind

Kind of assets that are going to be swapped.
Source§

type Credit = Imbalance<<<T as Config>::Assets as Inspect<<T as Config>::AccountId>>::AssetId, <<T as Config>::Assets as Inspect<<T as Config>::AccountId>>::Balance, <<T as Config>::Assets as Balanced<<T as Config>::AccountId>>::OnDropCredit, <<T as Config>::Assets as Balanced<<T as Config>::AccountId>>::OnDropDebt>

Credit implying a negative imbalance in the system that can be placed into an account or alter the total supply.
Source§

fn max_path_len() -> u32

Returns the upper limit on the length of the swap path.
Source§

fn swap_exact_tokens_for_tokens( path: Vec<<Pallet<T> as SwapCredit<<T as Config>::AccountId>>::AssetKind>, credit_in: <Pallet<T> as SwapCredit<<T as Config>::AccountId>>::Credit, amount_out_min: Option<<Pallet<T> as SwapCredit<<T as Config>::AccountId>>::Balance>, ) -> Result<<Pallet<T> as SwapCredit<<T as Config>::AccountId>>::Credit, (<Pallet<T> as SwapCredit<<T as Config>::AccountId>>::Credit, DispatchError)>

Swap exactly credit_in of asset path[0] for asset path[last]. If amount_out_min is provided and the swap can’t achieve at least this amount, an error is returned. Read more
Source§

fn swap_tokens_for_exact_tokens( path: Vec<<Pallet<T> as SwapCredit<<T as Config>::AccountId>>::AssetKind>, credit_in: <Pallet<T> as SwapCredit<<T as Config>::AccountId>>::Credit, amount_out: <Pallet<T> as SwapCredit<<T as Config>::AccountId>>::Balance, ) -> Result<(<Pallet<T> as SwapCredit<<T as Config>::AccountId>>::Credit, <Pallet<T> as SwapCredit<<T as Config>::AccountId>>::Credit), (<Pallet<T> as SwapCredit<<T as Config>::AccountId>>::Credit, DispatchError)>

Swaps a portion of credit_in of path[0] asset to obtain the desired amount_out of the path[last] asset. The provided credit_in must be adequate to achieve the target amount_out, or an error will occur. Read more
Source§

impl<T> TryDecodeEntireStorage for Pallet<T>
where T: Config,

Source§

fn try_decode_entire_state() -> Result<usize, Vec<TryDecodeEntireStorageError>>

Decode the entire data under the given storage, returning Ok(bytes_decoded) if success.
Source§

impl<T> TryState<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
where T: Config,

Source§

fn try_state( n: <<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number, _s: Select, ) -> Result<(), DispatchError>

Execute the state checks.
Source§

impl<T> ViewFunctionIdPrefix for Pallet<T>
where T: Config,

Source§

fn prefix() -> [u8; 16]

Source§

impl<T> WhitelistedStorageKeys for Pallet<T>
where T: Config,

Source§

fn whitelisted_storage_keys() -> Vec<TrackedStorageKey>

Returns a Vec<TrackedStorageKey> indicating the storage keys that should be whitelisted during benchmarking. This means that those keys will be excluded from the benchmarking performance calculation.
Source§

impl<T> Eq for Pallet<T>