DLMM SDK
This Typescript SDK is meant to help developers easily integrate Meteora's DLMM pools into their protocols. This SDK uses the latest AddLiquidityByStrategy endpoint (instead of AddLiquidityByWeight).
Getting started
SDK on github: https://github.com/MeteoraAg/dlmm-sdk
Get help on Discord: https://discord.com/channels/841152225564950528/864859354335412224
Program ID: LBUZKhRxPF3XUpBCjp4YzTKgLccjZhTSDM9YuVaPwxo
Devnet Testing
Devnet: https://devnet.meteora.ag/
List of sections
CPI call example
Access this repo in the SDK, import, CPI:
Rust examples
Access these repos in the SDK, import, and use the necessary functions:
Example codes for key DLMM actions
Below we have provided example codes for the key DLMM actions:
Getting the active bin
Creating a position
Getting the list of positions
Adding liquidity to an existing position
Removing liquidity from an existing position
Swapping tokens within a specified pool
We have also provided a list of the necessary static functions and DLMM instance functions. To view other SDK files on github, click here.
Main Steps for SDK testing
Install
Install dependencies
You will need to first install these SDK dependencies in order for it to function properly
Initialize DLMM instance
To interact with the AmmImpl
Changing Ammlmpl parameters to interact with the lb_pair / or pool
Get Active Bin
To get the active bin where the current pool price resides
Create Position
To create a new liquidity position
Get list of positions
To get the list of liquidity positions for a specified pair and pool
Add liquidity to existing position
To add liquidity to an existing liquidity position
Remove Liquidity
To remove liquidity from an existing liquidity position
Swap
To swap tokens within the specified liquidity pool
Static functions
create
Given the DLMM address, create an instance to access the state and functions
Promise<DLMM>
createMultiple
Given a list of DLMM addresses, create instances to access the state and functions
Promise<Array<DLMM>>
getAllLbPairPositionsByUser
Given a list of DLMM addresses, create instances to access the state and functions
Promise<Map<string, PositionInfo>>
DLMM instance functions
refetchStates
Update onchain state of DLMM instance. It's recommend to call this before interact with the program (Deposit/ Withdraw/ Swap)
Promise<void>
getBinArrays
Retrieves List of Bin Arrays
Promise<BinArrayAccount[]>
getBinArrayForSwap
Retrieves List of Bin Arrays for swap purpose
Promise<BinArrayAccount[]>
getFeeInfo
Retrieves LbPair's fee info including base fee
, protocol fee
& max fee
FeeInfo
getDynamicFee
Retrieves LbPair's dynamic fee
Decimal
getBinsAroundActiveBin
retrieves a specified number of bins to the left and right of the active bin and returns them along with the active bin ID.
Promise<{ activeBin: number; bins: BinLiquidity[] }>
getBinsBetweenMinAndMaxPrice
Retrieves a list of bins within a specified price
Promise<{ activeBin: number; bins: BinLiquidity[] }>
getBinsBetweenLowerAndUpperBound
retrieves a list of bins between a lower and upper bin ID and returns the active bin ID and the list of bins.
Promise<{ activeBin: number; bins: BinLiquidity[] }>
toPricePerLamport
Converts a real price of bin to lamport price
string
fromPricePerLamport
converts a price per lamport value to a real price of bin
string
getActiveBin
Retrieves the active bin ID and its corresponding price
Promise<{ binId: number; price: string }>
getPriceOfBinByBinId
Get the price of a bin based on its bin ID
string
getBinIdFromPrice
get bin ID based on a given price and a boolean flag indicating whether to round down or up.
number
getPositionsByUserAndLbPair
Retrieves positions by user and LB pair, including active bin and user positions.
Promise<{ activeBin: { binId: any; price: string; }; userPositions: Array<Position>;}>
initializePositionAndAddLiquidityByStrategy
Initializes a position and adds liquidity
Promise<Transaction|Transaction[]>
addLiquidityByStrategy
Add liquidity to existing position
Promise<Transaction|Transaction[]>
removeLiquidity
function is used to remove liquidity from a position, with the option to claim rewards and close the position.
Promise<Transaction|Transaction[]>
closePosition
Closes a position
Promise<Transaction|Transaction[]>
swapQuote
Quote for a swap
SwapQuote
swap
Swap token within the LbPair
Promise<Transaction>
claimLMReward
Claim rewards for a specific position owned by a specific owner
Promise<Transaction>
claimAllLMRewards
Claim all liquidity mining rewards for a given owner and their positions.
Promise<Transaction[]>
claimSwapFee
Claim swap fees for a specific position owned by a specific owner
Promise<Transaction>
claimAllSwapFee
Claim swap fees for multiple positions owned by a specific owner
Promise<Transaction>
claimAllRewards
Claim swap fees and LM rewards for multiple positions owned by a specific owner
Promise<Transaction[]>
Last updated