23 releases (major breaking)

20.0.0 Sep 26, 2024
19.0.0 Jul 18, 2024
18.0.0 Jul 12, 2024
17.0.0 Jun 21, 2024
0.0.0 Mar 31, 2023

#20 in #price

Download history 932/week @ 2024-08-27 618/week @ 2024-09-03 1111/week @ 2024-09-10 854/week @ 2024-09-17 1422/week @ 2024-09-24 1318/week @ 2024-10-01 1370/week @ 2024-10-08 1792/week @ 2024-10-15 1967/week @ 2024-10-22 1842/week @ 2024-10-29 2057/week @ 2024-11-05 25622/week @ 2024-11-12 26948/week @ 2024-11-19 26855/week @ 2024-11-26 26410/week @ 2024-12-03 22550/week @ 2024-12-10

107,932 downloads per month
Used in 87 crates (10 directly)

Apache-2.0

3MB
52K SLoC

asset-conversion

A swap pallet

This pallet allows assets to be converted from one type to another by means of a constant product formula. The pallet based is based on Uniswap V2 logic.

Overview

This pallet allows you to:

  • create a liquidity pool for 2 assets
  • provide the liquidity and receive back an LP token
  • exchange the LP token back to assets
  • swap 2 assets if there is a pool created
  • query for an exchange price via a new runtime call endpoint
  • query the size of a liquidity pool.

Please see the rust module documentation for full details:

cargo doc -p pallet-asset-conversion --open

License

License: Apache-2.0

Release

Polkadot SDK stable2409


lib.rs:

Substrate Asset Conversion pallet

Substrate Asset Conversion pallet based on the Uniswap V2 logic.

Overview

This pallet allows you to:

The quote_price_exact_tokens_for_tokens and quote_price_tokens_for_exact_tokens functions both take a path parameter of the route to take. If you want to swap from native asset to non-native asset 1, you would pass in a path of [DOT, 1] or [1, DOT]. If you want to swap from non-native asset 1 to non-native asset 2, you would pass in a path of [1, DOT, 2].

(For an example of configuring this pallet to use Location as an asset id, see the cumulus repo).

Here is an example state_call that asks for a quote of a pool of native versus asset 1:

curl -sS -H "Content-Type: application/json" -d \
'{"id":1, "jsonrpc":"2.0", "method": "state_call", "params": ["AssetConversionApi_quote_price_tokens_for_exact_tokens", "0x0101000000000000000000000011000000000000000000"]}' \
http://localhost:9933/

(This can be run against the kitchen sync node in the node folder of this repo.)

Dependencies

~17–31MB
~519K SLoC