This project is for RAYDIUM SDK V2 demonstration
yarn install
this will install the dependencies for running the demo script
Modify config.ts.template
to fit your configuration, and rename it to config.ts
<YOUR_WALLET_SECRET_KEY>
: replace to your own one<YOUR_RPC_URL>
: replace to your prefer one<API_HOST>
: by default it's no needed to provide raydium api host, only provide it when test on devent.
yarn dev src/<FOLDER>/<SCRIPT_NAME>
run the specific demo script, e.g. yarn dev src/cpmm/deposit.ts. Note: if you want to execute tx, remember to uncomment code in last lineyarn clmm-market 8sLbNZoA1cfnvMJLPfp98ZLAnFSYCFApfJKMbiXNLwxj 10 20
run clmm market maker, arguments 0: poolId, 1: create position deviation, 2: close position deviation, remember to uncommentclose position
andcreate new position
code part
all transaction related build function (e.g. await raydium.clmm.openPositionFromBase/ await raydium.cpmm.createPool ..etc) will return all transactions and instructions
const { execute, transaction, builder, extInfo } = await raydium.clmm.openPositionFromBase({ xxx })
transaction or transactions
: all built transactionsbuilder
: all instructions in transaction. e.g. builder.allInstructions, builder.AllTxDataextInfo
: transaction related publicKeys. (e.g: extInfo from raydium.cpmm.createPool includes poolId, programId...etc)
import { PoolFetchType } from '@raydium-io/raydium-sdk-v2'
const list = await raydium.api.fetchPoolByMints({
mint1: '4k3Dyjzvzp8eMZWUXbBCjEvwSkkk59S5iCNLY3QrkX6R', // required
mint2: 'EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v', // optional
type: PoolFetchType.All, // optional
sort: 'liquidity', // optional
order: 'desc', // optional
page: 1, // optional
})
await raydium.token.getTokenInfo('<Mint address>')
await raydium.account.fetchWalletTokenAccounts() // if need to force fetching token account, pass param { forceUpdate: true }
More api methods check here
- transactions were expired, set higher priority fees (computeBudgetConfig) to make it go through smoothly
- if you are testing in devnet, remember to replace programId to devnet one.
- currently api doesn't support devnet pool/farm data, please test on mainnet.
- only raydium.xxxx.getRpcPoolInfos support get devnet
rpc
pool info. - new created pool needs couple minutes to sync data to api, if you want to get info immediately, use raydium.xxxx.getRpcPoolInfos instead.
0x10001a9
: you might use https://openbook-tools.dexlab.space/market/create?network=devnet to create devnet market, and they used wrong devent program id, so please use createMarket.ts in demo to create marketlp amount is too less
: please provide more base/quote amount when create pool, if there's SOL/WSOL in your market, it's better provide more than 4 sol(4*10**9) in initial amount.