pub type AssetConversion = Pallet<Runtime>;
Aliased Type§
struct AssetConversion(/* private fields */);
Implementations
Source§impl<T> Pallet<T>where
T: Config,
impl<T> Pallet<T>where
T: Config,
Pallet’s callable functions.
Sourcepub fn create_pool(
origin: <T as Config>::RuntimeOrigin,
asset1: Box<<T as Config>::AssetKind>,
asset2: Box<<T as Config>::AssetKind>,
) -> Result<(), DispatchError>
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.
Sourcepub 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>
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
.
Sourcepub 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>
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.
Sourcepub 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>
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.
Sourcepub 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>
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.
Sourcepub fn touch(
origin: <T as Config>::RuntimeOrigin,
asset1: Box<<T as Config>::AssetKind>,
asset2: Box<<T as Config>::AssetKind>,
) -> Result<PostDispatchInfo, DispatchErrorWithPostInfo<PostDispatchInfo>>
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,
impl<T> Pallet<T>where
T: Config,
Sourcepub fn get_reserves(
asset1: <T as Config>::AssetKind,
asset2: <T as Config>::AssetKind,
) -> Result<(<T as Config>::Balance, <T as Config>::Balance), Error<T>>
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).
Sourcepub 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>
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.
Sourcepub 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>
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.
Sourcepub fn quote(
amount: &<T as Config>::Balance,
reserve1: &<T as Config>::Balance,
reserve2: &<T as Config>::Balance,
) -> Result<<T as Config>::Balance, Error<T>>
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.
Sourcepub 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>>
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.
Sourcepub 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>>
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.
Sourcepub fn get_next_pool_asset_id() -> <T as Config>::PoolAssetId
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,
impl<T> BeforeAllRuntimeMigrations for Pallet<T>where
T: Config,
Source§fn before_all_runtime_migrations() -> Weight
fn before_all_runtime_migrations() -> Weight
Source§impl<T> Benchmarking for Pallet<T>
impl<T> Benchmarking for Pallet<T>
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> DispatchViewFunction for Pallet<T>where
T: Config,
impl<T> DispatchViewFunction for Pallet<T>where
T: Config,
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,
impl<T> GetStorageVersion for Pallet<T>where
T: Config,
Source§fn in_code_storage_version() -> <Pallet<T> as GetStorageVersion>::InCodeStorageVersion
fn in_code_storage_version() -> <Pallet<T> as GetStorageVersion>::InCodeStorageVersion
storage_version
attribute, or
NoStorageVersionSet
if the attribute is missing.Source§fn on_chain_storage_version() -> StorageVersion
fn on_chain_storage_version() -> StorageVersion
Source§fn current_storage_version() -> Self::InCodeStorageVersion
fn current_storage_version() -> Self::InCodeStorageVersion
in_code_storage_version
and will be removed after March 2024.Self::current_storage_version
instead. Read moreSource§impl<T> Hooks<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>where
T: Config,
impl<T> Hooks<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>where
T: Config,
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_poll(_n: BlockNumber, _weight: &mut WeightMeter)
fn on_poll(_n: BlockNumber, _weight: &mut WeightMeter)
Source§fn on_runtime_upgrade() -> Weight
fn on_runtime_upgrade() -> Weight
Executive
pallet. Read moreSource§fn try_state(_n: BlockNumber) -> Result<(), DispatchError>
fn try_state(_n: BlockNumber) -> Result<(), DispatchError>
Source§fn pre_upgrade() -> Result<Vec<u8>, DispatchError>
fn pre_upgrade() -> Result<Vec<u8>, DispatchError>
Source§fn post_upgrade(_state: Vec<u8>) -> Result<(), DispatchError>
fn post_upgrade(_state: Vec<u8>) -> Result<(), DispatchError>
Source§fn offchain_worker(_n: BlockNumber)
fn offchain_worker(_n: BlockNumber)
Source§impl<T> IntegrityTest for Pallet<T>where
T: Config,
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,
impl<T> OffchainWorker<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>where
T: Config,
Source§impl<T> OnFinalize<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>where
T: Config,
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,
)
fn on_finalize( n: <<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number, )
Hooks::on_finalize
.Source§impl<T> OnGenesis for Pallet<T>where
T: Config,
impl<T> OnGenesis for Pallet<T>where
T: Config,
Source§fn on_genesis()
fn on_genesis()
Source§impl<T> OnIdle<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>where
T: Config,
impl<T> OnIdle<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>where
T: Config,
Source§impl<T> OnInitialize<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>where
T: Config,
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
fn on_initialize( n: <<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number, ) -> Weight
Hooks::on_initialize
.Source§impl<T> OnPoll<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>where
T: Config,
impl<T> OnPoll<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>where
T: Config,
Source§impl<T> OnRuntimeUpgrade for Pallet<T>where
T: Config,
impl<T> OnRuntimeUpgrade for Pallet<T>where
T: Config,
Source§fn on_runtime_upgrade() -> Weight
fn on_runtime_upgrade() -> Weight
Source§fn pre_upgrade() -> Result<Vec<u8>, DispatchError>
fn pre_upgrade() -> Result<Vec<u8>, DispatchError>
Hooks::pre_upgrade
.Source§fn post_upgrade(state: Vec<u8>) -> Result<(), DispatchError>
fn post_upgrade(state: Vec<u8>) -> Result<(), DispatchError>
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> PalletInfoAccess for Pallet<T>where
T: Config,
impl<T> PalletInfoAccess for Pallet<T>where
T: Config,
Source§fn module_name() -> &'static str
fn module_name() -> &'static str
Source§fn crate_version() -> CrateVersion
fn crate_version() -> CrateVersion
Source§impl<T> PalletsInfoAccess for Pallet<T>where
T: Config,
impl<T> PalletsInfoAccess for Pallet<T>where
T: Config,
Source§impl<T> QuotePrice for Pallet<T>where
T: Config,
impl<T> QuotePrice for Pallet<T>where
T: Config,
Source§type AssetKind = <T as Config>::AssetKind
type AssetKind = <T as Config>::AssetKind
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>
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>
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>
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>
Source§impl<T> StorageInfoTrait for Pallet<T>where
T: Config,
impl<T> StorageInfoTrait for Pallet<T>where
T: Config,
fn storage_info() -> Vec<StorageInfo>
Source§impl<T> Swap<<T as Config>::AccountId> for Pallet<T>where
T: Config,
impl<T> Swap<<T as Config>::AccountId> for Pallet<T>where
T: Config,
Source§fn max_path_len() -> u32
fn max_path_len() -> u32
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>
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>
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 moreSource§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>
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>
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 moreSource§impl<T> SwapCredit<<T as Config>::AccountId> for Pallet<T>where
T: Config,
impl<T> SwapCredit<<T as Config>::AccountId> for Pallet<T>where
T: Config,
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>
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>
Source§fn max_path_len() -> u32
fn max_path_len() -> u32
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)>
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)>
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 moreSource§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)>
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)>
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 moreSource§impl<T> TryDecodeEntireStorage for Pallet<T>where
T: Config,
impl<T> TryDecodeEntireStorage for Pallet<T>where
T: Config,
Source§fn try_decode_entire_state() -> Result<usize, Vec<TryDecodeEntireStorageError>>
fn try_decode_entire_state() -> Result<usize, Vec<TryDecodeEntireStorageError>>
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,
impl<T> TryState<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>where
T: Config,
Source§impl<T> WhitelistedStorageKeys for Pallet<T>where
T: Config,
impl<T> WhitelistedStorageKeys for Pallet<T>where
T: Config,
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.