2.5 KiB
Creating a Dex Adapter
Architecture Summary
Router will call initialize on every Dex Adapter to gather a list of edge and account/program subscriptions for live refresh.
Dex must also provide a map of key to edge(s) so that we know what quote should be refreshed when some accounts are modified on chain.
Edge = One way (pool/market) to exchange an input token for an output token
Implementation
Please create a new library inside the lib
folder named like this: dex-<your-name>
You will need to implement three traits:
- DexInterface
- DexEdgeIdentifier
- DexEdge
Looking at existing implementation (raydium for example) is recommended to start.
DexInterface
Trait used to:
- Load pools / list accounts for which a change should trigger a repricing
- Compute quote
- Generate swap IX
DexEdgeIdentifier
Static data used to identify an edge (pool/market+direction)
key()
input_mint()
output_mint()
accounts_needed()
this should count all account needed to make a swap, excluding:- user wallet address
- user output ATA
Long living object.
Warning: key + input_mint should be unique
DexEdge
Accounts data needed to compute a quote for a given edge.
Short living object, loaded by Autobahn when updating prices and finding best path.
Testing and validating
Also see Testing.MD
Please create a test directory in your dex adapter lib with, at least, one end-to-end test.
A three steps design is preferred:
- 1/ Capture all accounts needed
- 2/ Generate at least one swap for every edge
- 3/ Simulate execution
You can basically copy and paste the test_raydium.rs
for a simple example of 1 and 2.
For 3, you need to update test_swap_from_dump.rs
in the simulator test program (again, take inspiration from raydium implementation: test_quote_match_swap_for_raydium
).
Running should be done like this:
DUMP_MAINNET_DATA=1 RUST_LOG=info RPC_HTTP_URL="..." cargo test --package dex-<your-name>
cargo test-sbf --package simulator -- --nocapture cases::test_swap_from_dump::test_quote_match_swap_for_<your-name>
Note the test runner automatically captures accounts that were not specified in the dex adapters subscription_mode fn. This is based on observation of the generated instructions and ensures all accounts used even the ones not used to calculate a quote are included in the snapshot. This can cause data hazards bc. the snapshot is not generated at a consistent blockheight, it's recommended to update the subscription mode fn in this case.