31 releases (major breaking)

27.0.0 Dec 18, 2025
26.0.0 Dec 7, 2025
25.0.0 Oct 2, 2025
24.0.0 Aug 1, 2025
0.0.0 Mar 31, 2023

#1 in #liquidity-pool

Download history 5352/week @ 2025-09-22 4979/week @ 2025-09-29 4912/week @ 2025-10-06 5313/week @ 2025-10-13 5303/week @ 2025-10-20 4401/week @ 2025-10-27 5086/week @ 2025-11-03 5247/week @ 2025-11-10 5312/week @ 2025-11-17 4058/week @ 2025-11-24 4341/week @ 2025-12-01 5151/week @ 2025-12-08 5180/week @ 2025-12-15 3108/week @ 2025-12-22 2428/week @ 2025-12-29 3327/week @ 2026-01-05

14,304 downloads per month
Used in 157 crates (15 directly)

Apache-2.0

3.5MB
60K 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


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

~28–50MB
~711K SLoC