A Typescript SDK for interacting with the Dynamic Bonding Curve on Meteora.
npm install @meteora-ag/dynamic-bonding-curve-sdkA Typescript SDK for interacting with the Dynamic Bonding Curve on Meteora.
This SDK provides a set of tools and methods to interact with the Meteora Dynamic Bonding Curve. It enables developers to easily create and manage dynamic bonding curves, with support for custom configurations and fee structures.
``bash`
npm install @meteora-ag/dynamic-bonding-curve-sdkor
pnpm install @meteora-ag/dynamic-bonding-curve-sdkor
yarn add @meteora-ag/dynamic-bonding-curve-sdk
`typescript
import { Connection } from '@solana/web3.js'
import { DynamicBondingCurveClient } from '@meteora-ag/dynamic-bonding-curve-sdk'
const connection = new Connection('https://api.mainnet-beta.solana.com')
const client = new DynamicBondingCurveClient(connection, 'confirmed')
`
Refer to the docs for how to use the functions.
The generic flow of how Dynamic Bonding Curve works is as follows:
1. The partner creates a config key for the pool.
2. The creator creates a pool.
3. The pool is tradeable on the Dynamic Bonding Curve.
4. Meteora's migrator service migrates the pool to either DAMM V1 or DAMM V2 based on the config key once the quote reserve is more than or equals to the migration quote threshold.
5. The graduated pool is tradeable on either DAMM V1 or DAMM V2.
1. createDammV1MigrationMetadatacreateLocker
2. (if the token has locked vesting)migrateToDammV1
3. lockDammV1LpToken
4. (if creatorPermanentLockedLiquidityPercentage or partnerPermanentLockedLiquidityPercentage is >0)claimDammV1LpToken
5. (if creatorLiquidityPercentage or partnerLiquidityPercentage is >0)
1. createLocker (if the token has locked vesting)migrateToDammV2
2.
1. Run solana localnet validator
`bash`
cd packages/dynamic-bonding-curve
pnpm start-validator
2. Run the tests
`bash`
pnpm test
We have created a Manual Migrator UI that allows you to manually migrate a pool to either DAMM V1 or DAMM V2. Compatible with both Mainnet and Devnet pools.
- Mainnet-beta: dbcij3LWUppWqq96dh6gJWwBifmcGfLSB5D4DuSMaqN
- Devnet: dbcij3LWUppWqq96dh6gJWwBifmcGfLSB5D4DuSMaqN
Accessible via DAMM_V1_MIGRATION_FEE_ADDRESS[i] in the SDK.
- MigrationFeeOption.FixedBps25 == 0: 8f848CEy8eY6PhJ3VcemtBDzPPSD4Vq7aJczLZ3o8MmX
- MigrationFeeOption.FixedBps30 == 1: HBxB8Lf14Yj8pqeJ8C4qDb5ryHL7xwpuykz31BLNYr7S
- MigrationFeeOption.FixedBps100 == 2: 7v5vBdUQHTNeqk1HnduiXcgbvCyVEZ612HLmYkQoAkik
- MigrationFeeOption.FixedBps200 == 3: EkvP7d5yKxovj884d2DwmBQbrHUWRLGK6bympzrkXGja
- MigrationFeeOption.FixedBps400 == 4: 9EZYAJrcqNWNQzP2trzZesP7XKMHA1jEomHzbRsdX8R2
- MigrationFeeOption.FixedBps600 == 5: 8cdKo87jZU2R12KY1BUjjRPwyjgdNjLGqSGQyrDshhud
Accessible via DAMM_V2_MIGRATION_FEE_ADDRESS[i]` in the SDK.
- MigrationFeeOption.FixedBps25 == 0: 7F6dnUcRuyM2TwR8myT1dYypFXpPSxqwKNSFNkxyNESd
- MigrationFeeOption.FixedBps30 == 1: 2nHK1kju6XjphBLbNxpM5XRGFj7p9U8vvNzyZiha1z6k
- MigrationFeeOption.FixedBps100 == 2: Hv8Lmzmnju6m7kcokVKvwqz7QPmdX9XfKjJsXz8RXcjp
- MigrationFeeOption.FixedBps200 == 3: 2c4cYd4reUYVRAB9kUUkrq55VPyy2FNQ3FDL4o12JXmq
- MigrationFeeOption.FixedBps400 == 4: AkmQWebAwFvWk55wBoCr5D62C6VVDTzi84NJuD9H7cFD
- MigrationFeeOption.FixedBps600 == 5: DbCRBj8McvPYHJG1ukj8RE15h2dCNUdTAESG49XpQ44u
- MigrationFeeOption.Customizable == 6: A8gMrEPJkacWkcb3DGwtJwTe16HktSEfvwtuDh2MCtck