Struct pallet_asset_conversion::pallet::Pallet
source · pub struct Pallet<T>(_);
Expand description
The Pallet
struct, the main type that implements traits and standalone
functions within the pallet.
Implementations§
source§impl<T: Config> Pallet<T>
impl<T: Config> Pallet<T>
Pallet’s callable functions.
sourcepub fn create_pool(
origin: OriginFor<T>,
asset1: T::MultiAssetId,
asset2: T::MultiAssetId
) -> DispatchResult
pub fn create_pool( origin: OriginFor<T>, asset1: T::MultiAssetId, asset2: T::MultiAssetId ) -> DispatchResult
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.
sourcepub fn add_liquidity(
origin: OriginFor<T>,
asset1: T::MultiAssetId,
asset2: T::MultiAssetId,
amount1_desired: T::AssetBalance,
amount2_desired: T::AssetBalance,
amount1_min: T::AssetBalance,
amount2_min: T::AssetBalance,
mint_to: T::AccountId
) -> DispatchResult
pub fn add_liquidity( origin: OriginFor<T>, asset1: T::MultiAssetId, asset2: T::MultiAssetId, amount1_desired: T::AssetBalance, amount2_desired: T::AssetBalance, amount1_min: T::AssetBalance, amount2_min: T::AssetBalance, mint_to: T::AccountId ) -> DispatchResult
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.
Once liquidity is added, someone may successfully call
Pallet::swap_exact_tokens_for_tokens
successfully.
sourcepub fn remove_liquidity(
origin: OriginFor<T>,
asset1: T::MultiAssetId,
asset2: T::MultiAssetId,
lp_token_burn: T::AssetBalance,
amount1_min_receive: T::AssetBalance,
amount2_min_receive: T::AssetBalance,
withdraw_to: T::AccountId
) -> DispatchResult
pub fn remove_liquidity( origin: OriginFor<T>, asset1: T::MultiAssetId, asset2: T::MultiAssetId, lp_token_burn: T::AssetBalance, amount1_min_receive: T::AssetBalance, amount2_min_receive: T::AssetBalance, withdraw_to: T::AccountId ) -> DispatchResult
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.
sourcepub fn swap_exact_tokens_for_tokens(
origin: OriginFor<T>,
path: BoundedVec<T::MultiAssetId, T::MaxSwapPathLength>,
amount_in: T::AssetBalance,
amount_out_min: T::AssetBalance,
send_to: T::AccountId,
keep_alive: bool
) -> DispatchResult
pub fn swap_exact_tokens_for_tokens( origin: OriginFor<T>, path: BoundedVec<T::MultiAssetId, T::MaxSwapPathLength>, amount_in: T::AssetBalance, amount_out_min: T::AssetBalance, send_to: T::AccountId, keep_alive: bool ) -> DispatchResult
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.
sourcepub fn swap_tokens_for_exact_tokens(
origin: OriginFor<T>,
path: BoundedVec<T::MultiAssetId, T::MaxSwapPathLength>,
amount_out: T::AssetBalance,
amount_in_max: T::AssetBalance,
send_to: T::AccountId,
keep_alive: bool
) -> DispatchResult
pub fn swap_tokens_for_exact_tokens( origin: OriginFor<T>, path: BoundedVec<T::MultiAssetId, T::MaxSwapPathLength>, amount_out: T::AssetBalance, amount_in_max: T::AssetBalance, send_to: T::AccountId, keep_alive: bool ) -> DispatchResult
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§impl<T: Config> Pallet<T>
impl<T: Config> Pallet<T>
sourcepub fn do_swap_exact_tokens_for_tokens(
sender: T::AccountId,
path: BoundedVec<T::MultiAssetId, T::MaxSwapPathLength>,
amount_in: T::AssetBalance,
amount_out_min: Option<T::AssetBalance>,
send_to: T::AccountId,
keep_alive: bool
) -> Result<T::AssetBalance, DispatchError>
pub fn do_swap_exact_tokens_for_tokens( sender: T::AccountId, path: BoundedVec<T::MultiAssetId, T::MaxSwapPathLength>, amount_in: T::AssetBalance, amount_out_min: Option<T::AssetBalance>, send_to: T::AccountId, keep_alive: bool ) -> Result<T::AssetBalance, DispatchError>
Swap exactly amount_in
of asset path[0]
for asset path[1]
.
If an amount_out_min
is specified, it will return an error if it is unable to acquire
the amount desired.
Withdraws the path[0]
asset from sender
, deposits the path[1]
asset to send_to
,
respecting keep_alive
.
If successful, returns the amount of path[1]
acquired for the amount_in
.
sourcepub fn do_swap_tokens_for_exact_tokens(
sender: T::AccountId,
path: BoundedVec<T::MultiAssetId, T::MaxSwapPathLength>,
amount_out: T::AssetBalance,
amount_in_max: Option<T::AssetBalance>,
send_to: T::AccountId,
keep_alive: bool
) -> Result<T::AssetBalance, DispatchError>
pub fn do_swap_tokens_for_exact_tokens( sender: T::AccountId, path: BoundedVec<T::MultiAssetId, T::MaxSwapPathLength>, amount_out: T::AssetBalance, amount_in_max: Option<T::AssetBalance>, send_to: T::AccountId, keep_alive: bool ) -> Result<T::AssetBalance, DispatchError>
Take the path[0]
asset and swap some amount for amount_out
of the path[1]
. If an
amount_in_max
is specified, it will return an error if acquiring amount_out
would be
too costly.
Withdraws path[0]
asset from sender
, deposits the path[1]
asset to send_to
,
respecting keep_alive
.
If successful returns the amount of the path[0]
taken to provide path[1]
.
sourcepub fn get_pool_account(
pool_id: &(<T as Config>::MultiAssetId, <T as Config>::MultiAssetId)
) -> T::AccountId
pub fn get_pool_account( pool_id: &(<T as Config>::MultiAssetId, <T as Config>::MultiAssetId) ) -> T::AccountId
The account ID of the pool.
This actually does computation. If you need to keep using it, then make sure you cache the value and only call this once.
sourcepub fn get_pool_id(
asset1: T::MultiAssetId,
asset2: T::MultiAssetId
) -> (<T as Config>::MultiAssetId, <T as Config>::MultiAssetId)
pub fn get_pool_id( asset1: T::MultiAssetId, asset2: T::MultiAssetId ) -> (<T as Config>::MultiAssetId, <T as Config>::MultiAssetId)
Returns a pool id constructed from 2 assets.
- Native asset should be lower than the other asset ids.
- Two native or two non-native assets are compared by their
Ord
implementation.
We expect deterministic order, so (asset1, asset2) or (asset2, asset1) returns the same result.
sourcepub fn get_reserves(
asset1: &T::MultiAssetId,
asset2: &T::MultiAssetId
) -> Result<(T::AssetBalance, T::AssetBalance), Error<T>>
pub fn get_reserves( asset1: &T::MultiAssetId, asset2: &T::MultiAssetId ) -> Result<(T::AssetBalance, T::AssetBalance), 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).
sourcepub fn quote_price_exact_tokens_for_tokens(
asset1: T::MultiAssetId,
asset2: T::MultiAssetId,
amount: T::AssetBalance,
include_fee: bool
) -> Option<T::AssetBalance>
pub fn quote_price_exact_tokens_for_tokens( asset1: T::MultiAssetId, asset2: T::MultiAssetId, amount: T::AssetBalance, include_fee: bool ) -> Option<T::AssetBalance>
Used by the RPC service to provide current prices.
sourcepub fn quote_price_tokens_for_exact_tokens(
asset1: T::MultiAssetId,
asset2: T::MultiAssetId,
amount: T::AssetBalance,
include_fee: bool
) -> Option<T::AssetBalance>
pub fn quote_price_tokens_for_exact_tokens( asset1: T::MultiAssetId, asset2: T::MultiAssetId, amount: T::AssetBalance, include_fee: bool ) -> Option<T::AssetBalance>
Used by the RPC service to provide current prices.
sourcepub fn quote(
amount: &T::AssetBalance,
reserve1: &T::AssetBalance,
reserve2: &T::AssetBalance
) -> Result<T::AssetBalance, Error<T>>
pub fn quote( amount: &T::AssetBalance, reserve1: &T::AssetBalance, reserve2: &T::AssetBalance ) -> Result<T::AssetBalance, Error<T>>
Calculates the optimal amount from the reserves.
sourcepub fn get_amount_out(
amount_in: &T::AssetBalance,
reserve_in: &T::AssetBalance,
reserve_out: &T::AssetBalance
) -> Result<T::AssetBalance, Error<T>>
pub fn get_amount_out( amount_in: &T::AssetBalance, reserve_in: &T::AssetBalance, reserve_out: &T::AssetBalance ) -> Result<T::AssetBalance, Error<T>>
Calculates amount out.
Given an input amount of an asset and pair reserves, returns the maximum output amount of the other asset.
sourcepub fn get_amount_in(
amount_out: &T::AssetBalance,
reserve_in: &T::AssetBalance,
reserve_out: &T::AssetBalance
) -> Result<T::AssetBalance, Error<T>>
pub fn get_amount_in( amount_out: &T::AssetBalance, reserve_in: &T::AssetBalance, reserve_out: &T::AssetBalance ) -> Result<T::AssetBalance, Error<T>>
Calculates amount in.
Given an output amount of an asset and pair reserves, returns a required input amount of the other asset.
sourcepub fn get_next_pool_asset_id() -> T::PoolAssetId
pub fn get_next_pool_asset_id() -> T::PoolAssetId
Returns the next pool asset id for benchmark purposes only.
Trait Implementations§
source§impl<T> Benchmarking for Pallet<T>where
T: Config + Config,
T::AssetBalance: From<u128> + Into<u128>,
T::Currency: Unbalanced<T::AccountId>,
T::Balance: From<u128> + Into<u128>,
T::Assets: Create<T::AccountId> + Mutate<T::AccountId>,
T::PoolAssetId: Into<u32>,
impl<T> Benchmarking for Pallet<T>where T: Config + Config, T::AssetBalance: From<u128> + Into<u128>, T::Currency: Unbalanced<T::AccountId>, T::Balance: From<u128> + Into<u128>, T::Assets: Create<T::AccountId> + Mutate<T::AccountId>, T::PoolAssetId: Into<u32>,
source§fn benchmarks(extra: bool) -> Vec<BenchmarkMetadata>
fn benchmarks(extra: bool) -> Vec<BenchmarkMetadata>
source§fn run_benchmark(
extrinsic: &[u8],
c: &[(BenchmarkParameter, u32)],
whitelist: &[TrackedStorageKey],
verify: bool,
internal_repeats: u32
) -> Result<Vec<BenchmarkResult>, BenchmarkError>
fn run_benchmark( extrinsic: &[u8], c: &[(BenchmarkParameter, u32)], whitelist: &[TrackedStorageKey], verify: bool, internal_repeats: u32 ) -> Result<Vec<BenchmarkResult>, BenchmarkError>
source§impl<T: Config> GetStorageVersion for Pallet<T>
impl<T: Config> GetStorageVersion for Pallet<T>
source§fn current_storage_version() -> Self::CurrentStorageVersion
fn current_storage_version() -> Self::CurrentStorageVersion
source§fn on_chain_storage_version() -> StorageVersion
fn on_chain_storage_version() -> StorageVersion
source§impl<T: Config> Hooks<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
impl<T: Config> Hooks<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
source§fn integrity_test()
fn integrity_test()
source§fn on_initialize(_n: BlockNumber) -> Weight
fn on_initialize(_n: BlockNumber) -> Weight
source§fn on_finalize(_n: BlockNumber)
fn on_finalize(_n: BlockNumber)
source§fn on_idle(_n: BlockNumber, _remaining_weight: Weight) -> Weight
fn on_idle(_n: BlockNumber, _remaining_weight: Weight) -> Weight
Hooks::on_finalize
). Read moresource§fn on_runtime_upgrade() -> Weight
fn on_runtime_upgrade() -> Weight
source§fn try_state(_n: BlockNumber) -> Result<(), DispatchError>
fn try_state(_n: BlockNumber) -> Result<(), DispatchError>
source§fn pre_upgrade() -> Result<Vec<u8, Global>, DispatchError>
fn pre_upgrade() -> Result<Vec<u8, Global>, DispatchError>
source§fn post_upgrade(_state: Vec<u8, Global>) -> Result<(), DispatchError>
fn post_upgrade(_state: Vec<u8, Global>) -> Result<(), DispatchError>
source§fn offchain_worker(_n: BlockNumber)
fn offchain_worker(_n: BlockNumber)
source§impl<T: Config> IntegrityTest for Pallet<T>
impl<T: Config> IntegrityTest for Pallet<T>
source§impl<T: Config> OffchainWorker<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
impl<T: Config> OffchainWorker<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
source§fn offchain_worker(n: BlockNumberFor<T>)
fn offchain_worker(n: BlockNumberFor<T>)
source§impl<T: Config> OnFinalize<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
impl<T: Config> OnFinalize<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
source§fn on_finalize(n: BlockNumberFor<T>)
fn on_finalize(n: BlockNumberFor<T>)
Hooks::on_finalize
.source§impl<T: Config> OnGenesis for Pallet<T>
impl<T: Config> OnGenesis for Pallet<T>
source§fn on_genesis()
fn on_genesis()
source§impl<T: Config> OnIdle<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
impl<T: Config> OnIdle<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
source§fn on_idle(n: BlockNumberFor<T>, remaining_weight: Weight) -> Weight
fn on_idle(n: BlockNumberFor<T>, remaining_weight: Weight) -> Weight
Hooks::on_idle
.source§impl<T: Config> OnInitialize<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
impl<T: Config> OnInitialize<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
source§fn on_initialize(n: BlockNumberFor<T>) -> Weight
fn on_initialize(n: BlockNumberFor<T>) -> Weight
Hooks::on_initialize
.source§impl<T: Config> OnRuntimeUpgrade for Pallet<T>
impl<T: Config> OnRuntimeUpgrade for Pallet<T>
source§fn on_runtime_upgrade() -> Weight
fn on_runtime_upgrade() -> Weight
source§fn pre_upgrade() -> Result<Vec<u8>, TryRuntimeError>
fn pre_upgrade() -> Result<Vec<u8>, TryRuntimeError>
Hooks::pre_upgrade
.source§fn post_upgrade(state: Vec<u8>) -> Result<(), TryRuntimeError>
fn post_upgrade(state: Vec<u8>) -> Result<(), TryRuntimeError>
Hooks::post_upgrade
.source§fn try_on_runtime_upgrade(checks: bool) -> Result<Weight, DispatchError>
fn try_on_runtime_upgrade(checks: bool) -> Result<Weight, DispatchError>
pre_upgrade
->
on_runtime_upgrade
-> post_upgrade
hooks for a migration. Read moresource§impl<T: Config> PalletInfoAccess for Pallet<T>
impl<T: Config> PalletInfoAccess for Pallet<T>
source§fn module_name() -> &'static str
fn module_name() -> &'static str
source§fn crate_version() -> CrateVersion
fn crate_version() -> CrateVersion
source§impl<T: Config> PalletsInfoAccess for Pallet<T>
impl<T: Config> PalletsInfoAccess for Pallet<T>
source§impl<T> PartialEq<Pallet<T>> for Pallet<T>
impl<T> PartialEq<Pallet<T>> for Pallet<T>
source§impl<T: Config> StorageInfoTrait for Pallet<T>
impl<T: Config> StorageInfoTrait for Pallet<T>
fn storage_info() -> Vec<StorageInfo>
source§impl<T: Config> Swap<<T as Config>::AccountId, <T as Config>::HigherPrecisionBalance, <T as Config>::MultiAssetId> for Pallet<T>
impl<T: Config> Swap<<T as Config>::AccountId, <T as Config>::HigherPrecisionBalance, <T as Config>::MultiAssetId> for Pallet<T>
source§fn swap_exact_tokens_for_tokens(
sender: T::AccountId,
path: Vec<T::MultiAssetId>,
amount_in: T::HigherPrecisionBalance,
amount_out_min: Option<T::HigherPrecisionBalance>,
send_to: T::AccountId,
keep_alive: bool
) -> Result<T::HigherPrecisionBalance, DispatchError>
fn swap_exact_tokens_for_tokens( sender: T::AccountId, path: Vec<T::MultiAssetId>, amount_in: T::HigherPrecisionBalance, amount_out_min: Option<T::HigherPrecisionBalance>, send_to: T::AccountId, keep_alive: bool ) -> Result<T::HigherPrecisionBalance, DispatchError>
amount_in
of asset path[0]
for asset path[1]
.
If an amount_out_min
is specified, it will return an error if it is unable to acquire
the amount desired. Read moresource§fn swap_tokens_for_exact_tokens(
sender: T::AccountId,
path: Vec<T::MultiAssetId>,
amount_out: T::HigherPrecisionBalance,
amount_in_max: Option<T::HigherPrecisionBalance>,
send_to: T::AccountId,
keep_alive: bool
) -> Result<T::HigherPrecisionBalance, DispatchError>
fn swap_tokens_for_exact_tokens( sender: T::AccountId, path: Vec<T::MultiAssetId>, amount_out: T::HigherPrecisionBalance, amount_in_max: Option<T::HigherPrecisionBalance>, send_to: T::AccountId, keep_alive: bool ) -> Result<T::HigherPrecisionBalance, DispatchError>
path[0]
asset and swap some amount for amount_out
of the path[1]
. If an
amount_in_max
is specified, it will return an error if acquiring amount_out
would be
too costly. Read moresource§impl<T: Config> TryState<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
impl<T: Config> TryState<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
source§fn try_state(
n: BlockNumberFor<T>,
_s: TryStateSelect
) -> Result<(), TryRuntimeError>
fn try_state( n: BlockNumberFor<T>, _s: TryStateSelect ) -> Result<(), TryRuntimeError>
source§impl<T: Config> WhitelistedStorageKeys for Pallet<T>
impl<T: Config> WhitelistedStorageKeys for Pallet<T>
source§fn whitelisted_storage_keys() -> Vec<TrackedStorageKey>
fn whitelisted_storage_keys() -> Vec<TrackedStorageKey>
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.impl<T> Eq for Pallet<T>
Auto Trait Implementations§
impl<T> RefUnwindSafe for Pallet<T>where T: RefUnwindSafe,
impl<T> Send for Pallet<T>where T: Send,
impl<T> Sync for Pallet<T>where T: Sync,
impl<T> Unpin for Pallet<T>where T: Unpin,
impl<T> UnwindSafe for Pallet<T>where T: UnwindSafe,
Blanket Implementations§
source§impl<T> CheckedConversion for T
impl<T> CheckedConversion for T
source§impl<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.§impl<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
source§impl<T> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T, Outer> IsWrappedBy<Outer> for Twhere
Outer: AsRef<T> + AsMut<T> + From<T>,
T: From<Outer>,
impl<T, Outer> IsWrappedBy<Outer> for Twhere Outer: AsRef<T> + AsMut<T> + From<T>, T: From<Outer>,
§impl<T> Pointable for T
impl<T> Pointable for T
source§impl<T> SaturatedConversion for T
impl<T> SaturatedConversion for T
source§fn saturated_from<T>(t: T) -> Selfwhere
Self: UniqueSaturatedFrom<T>,
fn saturated_from<T>(t: T) -> Selfwhere Self: UniqueSaturatedFrom<T>,
source§fn saturated_into<T>(self) -> Twhere
Self: UniqueSaturatedInto<T>,
fn saturated_into<T>(self) -> Twhere Self: UniqueSaturatedInto<T>,
T
. Read more§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere SS: SubsetOf<SP>,
§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
self
from the equivalent element of its
superset. Read more§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
self
is actually part of its subset T
(and can be converted to it).§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
self.to_subset
but without any property checks. Always succeeds.§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
self
to the equivalent element of its superset.source§impl<S, T> UncheckedInto<T> for Swhere
T: UncheckedFrom<S>,
impl<S, T> UncheckedInto<T> for Swhere T: UncheckedFrom<S>,
source§fn unchecked_into(self) -> T
fn unchecked_into(self) -> T
unchecked_from
.source§impl<T, S> UniqueSaturatedInto<T> for Swhere
T: Bounded,
S: TryInto<T>,
impl<T, S> UniqueSaturatedInto<T> for Swhere T: Bounded, S: TryInto<T>,
source§fn unique_saturated_into(self) -> T
fn unique_saturated_into(self) -> T
T
.