A Rust SDK for building applications on top of Uniswap V3. Migration from the TypeScript Uniswap/v3-sdk.
It is feature-complete with unit tests matching the TypeScript SDK. But error handling is not as graceful as one may expect. The error handling is still a work in progress.
-
Opinionated Rust implementation of the Uniswap V3 SDK with a focus on readability and performance
-
Usage of alloy-rs types
-
Reimplementation of the math libraries in Uniswap V3 Math In Rust based on optimizations presented in Uni V3 Lib
-
Extensive unit tests and benchmarks
-
An
extensions
feature for additional functionalities related to Uniswap V3, including:pool
module for creating aPool
struct from a pool key and fetching the liquidity map within a tick range for the specified pool, using RPC clientposition
module for creating aPosition
struct from a token id and fetching the state and pool for all positions of the specified owner, using RPC client, etcprice_tick_conversions
module for converting between prices and ticksephemeral_tick_data_provider
module for fetching ticks using an ephemeral contract in a singleeth_call
Expand to see the benchmarks
Function | Time | Reference |
---|---|---|
most_significant_bit | 8.3693 µs | 39.691 µs |
least_significant_bit | 5.0592 µs | 16.619 µs |
get_sqrt_ratio_at_tick | 5.2105 µs | 71.137 µs |
get_tick_at_sqrt_ratio | 34.331 µs | 191.08 µs |
Add the following to your Cargo.toml
file:
uniswap-v3-sdk = { version = "0.32.0", features = ["extensions", "std"] }
The package structure follows that of the TypeScript SDK, but with snake_case
instead of camelCase
.
For easy import, use the prelude:
use uniswap_v3_sdk::prelude::*;
Contributions are welcome. Please open an issue if you have any questions or suggestions.
Tests are run with
cargo test
for the core library. To run the tests for the extensions, use
cargo test --all-features --lib extensions -- --test-threads=1
To test a specific module, use cargo test --test <module_name>
.
Linting is done with clippy
and rustfmt
. To run the linter, use:
cargo clippy --all-targets --all-features -- -D warnings
cargo fmt --all -- --check
Benchmarking is done with criterion
. To run the benchmarks, use cargo bench
.
This project is licensed under the MIT License.
This project is inspired by and adapted from the following projects: