@zcomb/programs-sdk 1.3.0 → 1.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -841,8 +841,7 @@ export declare class AMMClient {
841
841
  * - Fetches current reserves and computes quote
842
842
  * - Calculates minOutput based on slippage tolerance
843
843
  * - Adds compute budget instruction (if includeCuBudget is true)
844
- * - Creates token accounts if they don't exist (if autoWrapUnwrap is true)
845
- * - Handles WSOL wrapping/unwrapping if needed (if autoWrapUnwrap is true)
844
+ * - Creates token accounts if they don't exist (if autoCreateTokenAccounts is true)
846
845
  */
847
846
  swapWithSlippage(trader: PublicKey, poolPda: PublicKey, swapAToB: boolean, inputAmount: BN | number, slippagePercent?: number, options?: AmmActionOptions): Promise<{
848
847
  builder: import("@coral-xyz/anchor/dist/cjs/program/namespace/methods").MethodsBuilder<Amm, {
@@ -151,7 +151,7 @@ class AMMClient {
151
151
  return postIxs.length > 0 ? builder.postInstructions(postIxs) : builder;
152
152
  }
153
153
  async swap(trader, poolPda, swapAToB, inputAmount, minOutputAmount, options) {
154
- const { autoWrapUnwrap = true, includeCuBudget = true, computeUnits } = options ?? {};
154
+ const { autoCreateTokenAccounts = true, includeCuBudget = true, computeUnits } = options ?? {};
155
155
  const pool = await this.fetchPool(poolPda);
156
156
  const [reserveA] = this.deriveReservePDA(poolPda, pool.mintA);
157
157
  const [reserveB] = this.deriveReservePDA(poolPda, pool.mintB);
@@ -159,40 +159,18 @@ class AMMClient {
159
159
  const traderAccountA = (0, spl_token_1.getAssociatedTokenAddressSync)(pool.mintA, trader);
160
160
  const traderAccountB = (0, spl_token_1.getAssociatedTokenAddressSync)(pool.mintB, trader);
161
161
  const preIxs = [];
162
- const postIxs = [];
163
162
  if (includeCuBudget) {
164
163
  preIxs.push(web3_js_1.ComputeBudgetProgram.setComputeUnitLimit({
165
164
  units: computeUnits ?? this.computeUnits,
166
165
  }));
167
166
  }
168
- const inputMint = swapAToB ? pool.mintA : pool.mintB;
169
- const outputMint = swapAToB ? pool.mintB : pool.mintA;
170
- const inputAta = swapAToB ? traderAccountA : traderAccountB;
171
- const outputAta = swapAToB ? traderAccountB : traderAccountA;
172
- if (autoWrapUnwrap) {
173
- // Create ATAs idempotently
167
+ if (autoCreateTokenAccounts) {
174
168
  preIxs.push((0, spl_token_1.createAssociatedTokenAccountIdempotentInstruction)(trader, traderAccountA, trader, pool.mintA), (0, spl_token_1.createAssociatedTokenAccountIdempotentInstruction)(trader, traderAccountB, trader, pool.mintB));
175
- // Wrap input SOL if needed
176
- if (inputMint.equals(spl_token_1.NATIVE_MINT)) {
177
- const input = typeof inputAmount === "number" ? new anchor_1.BN(inputAmount) : inputAmount;
178
- preIxs.push(web3_js_1.SystemProgram.transfer({
179
- fromPubkey: trader,
180
- toPubkey: inputAta,
181
- lamports: BigInt(input.toString()),
182
- }), (0, spl_token_1.createSyncNativeInstruction)(inputAta));
183
- }
184
- // Unwrap output SOL if needed
185
- if (outputMint.equals(spl_token_1.NATIVE_MINT)) {
186
- postIxs.push((0, spl_token_1.createCloseAccountInstruction)(outputAta, trader, trader));
187
- }
188
169
  }
189
170
  let builder = (0, instructions_1.swap)(this.program, trader, poolPda, reserveA, reserveB, feeVault, traderAccountA, traderAccountB, swapAToB, inputAmount, minOutputAmount);
190
171
  if (preIxs.length > 0) {
191
172
  builder = builder.preInstructions(preIxs);
192
173
  }
193
- if (postIxs.length > 0) {
194
- builder = builder.postInstructions(postIxs);
195
- }
196
174
  return builder;
197
175
  }
198
176
  async crankTwap(poolPda) {
@@ -210,11 +188,10 @@ class AMMClient {
210
188
  * - Fetches current reserves and computes quote
211
189
  * - Calculates minOutput based on slippage tolerance
212
190
  * - Adds compute budget instruction (if includeCuBudget is true)
213
- * - Creates token accounts if they don't exist (if autoWrapUnwrap is true)
214
- * - Handles WSOL wrapping/unwrapping if needed (if autoWrapUnwrap is true)
191
+ * - Creates token accounts if they don't exist (if autoCreateTokenAccounts is true)
215
192
  */
216
193
  async swapWithSlippage(trader, poolPda, swapAToB, inputAmount, slippagePercent = 0.5, options) {
217
- const { autoWrapUnwrap = true, includeCuBudget = true, computeUnits } = options ?? {};
194
+ const { autoCreateTokenAccounts = true, includeCuBudget = true, computeUnits } = options ?? {};
218
195
  const pool = await this.fetchPool(poolPda);
219
196
  const input = typeof inputAmount === "number" ? new anchor_1.BN(inputAmount) : inputAmount;
220
197
  // Get quote with slippage
@@ -228,38 +205,17 @@ class AMMClient {
228
205
  // Build base swap instruction
229
206
  let builder = (0, instructions_1.swap)(this.program, trader, poolPda, reserveA, reserveB, feeVault, traderAccountA, traderAccountB, swapAToB, input, quoteResult.minOutputAmount);
230
207
  const preIxs = [];
231
- const postIxs = [];
232
208
  if (includeCuBudget) {
233
209
  preIxs.push(web3_js_1.ComputeBudgetProgram.setComputeUnitLimit({
234
210
  units: computeUnits ?? this.computeUnits,
235
211
  }));
236
212
  }
237
- if (autoWrapUnwrap) {
213
+ if (autoCreateTokenAccounts) {
238
214
  preIxs.push((0, spl_token_1.createAssociatedTokenAccountIdempotentInstruction)(trader, traderAccountA, trader, pool.mintA), (0, spl_token_1.createAssociatedTokenAccountIdempotentInstruction)(trader, traderAccountB, trader, pool.mintB));
239
215
  }
240
- // Handle WSOL for input/output tokens
241
- const inputMint = swapAToB ? pool.mintA : pool.mintB;
242
- const outputMint = swapAToB ? pool.mintB : pool.mintA;
243
- const inputAta = swapAToB ? traderAccountA : traderAccountB;
244
- const outputAta = swapAToB ? traderAccountB : traderAccountA;
245
- if (autoWrapUnwrap && inputMint.equals(spl_token_1.NATIVE_MINT)) {
246
- // Wrap SOL before swap
247
- preIxs.push(web3_js_1.SystemProgram.transfer({
248
- fromPubkey: trader,
249
- toPubkey: inputAta,
250
- lamports: BigInt(input.toString()),
251
- }), (0, spl_token_1.createSyncNativeInstruction)(inputAta));
252
- }
253
- if (autoWrapUnwrap && outputMint.equals(spl_token_1.NATIVE_MINT)) {
254
- // Unwrap SOL after swap
255
- postIxs.push((0, spl_token_1.createCloseAccountInstruction)(outputAta, trader, trader));
256
- }
257
216
  if (preIxs.length > 0) {
258
217
  builder = builder.preInstructions(preIxs);
259
218
  }
260
- if (postIxs.length > 0) {
261
- builder = builder.postInstructions(postIxs);
262
- }
263
219
  return {
264
220
  builder,
265
221
  quote: quoteResult,
@@ -267,4 +223,4 @@ class AMMClient {
267
223
  }
268
224
  }
269
225
  exports.AMMClient = AMMClient;
270
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"client.js","sourceRoot":"","sources":["../../src/amm/client.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * High-level client for the AMM program.\n * Provides ergonomic methods for pool operations with automatic PDA derivation,\n * native SOL wrapping/unwrapping, and compute budget management.\n */\n\nimport { Program, AnchorProvider, BN } from \"@coral-xyz/anchor\";\nimport {\n  PublicKey,\n  ComputeBudgetProgram,\n  SystemProgram,\n  TransactionInstruction,\n} from \"@solana/web3.js\";\nimport {\n  getAccount,\n  getAssociatedTokenAddressSync,\n  getMint,\n  NATIVE_MINT,\n  createSyncNativeInstruction,\n  createCloseAccountInstruction,\n  createAssociatedTokenAccountIdempotentInstruction,\n} from \"@solana/spl-token\";\nimport { PROGRAM_ID } from \"./constants\";\nimport { Amm, PoolAccount, SwapQuote, AmmActionOptions } from \"./types\";\nimport {\n  derivePoolPDA,\n  deriveReservePDA,\n  deriveFeeVaultPDA,\n  fetchPoolAccount,\n  createSwapQuote,\n  calculateSpotPrice,\n  calculateTwap,\n} from \"./utils\";\nimport {\n  createPool as createPoolIx,\n  addLiquidity as addLiquidityIx,\n  removeLiquidity as removeLiquidityIx,\n  swap as swapIx,\n  crankTwap as crankTwapIx,\n  ceaseTrading as ceaseTradingIx,\n} from \"./instructions\";\n\nimport { AmmIDL } from \"../generated/idls\";\n\nconst DEFAULT_COMPUTE_UNITS = 300_000;\n\nexport class AMMClient {\n  public program: Program<Amm>;\n  public programId: PublicKey;\n  public computeUnits: number;\n\n  constructor(\n    provider: AnchorProvider,\n    programId?: PublicKey,\n    computeUnits?: number\n  ) {\n    this.programId = programId ?? PROGRAM_ID;\n    this.computeUnits = computeUnits ?? DEFAULT_COMPUTE_UNITS;\n    this.program = new Program(AmmIDL as Amm, provider);\n  }\n\n  /* PDA Helpers */\n\n  derivePoolPDA(\n    admin: PublicKey,\n    mintA: PublicKey,\n    mintB: PublicKey\n  ): [PublicKey, number] {\n    return derivePoolPDA(admin, mintA, mintB, this.programId);\n  }\n\n  deriveReservePDA(pool: PublicKey, mint: PublicKey): [PublicKey, number] {\n    return deriveReservePDA(pool, mint, this.programId);\n  }\n\n  deriveFeeVaultPDA(pool: PublicKey): [PublicKey, number] {\n    return deriveFeeVaultPDA(pool, this.programId);\n  }\n\n  /* State Fetching */\n\n  async fetchPool(poolPda: PublicKey): Promise<PoolAccount> {\n    return fetchPoolAccount(this.program, poolPda);\n  }\n\n  async fetchReserves(poolPda: PublicKey): Promise<{ reserveA: BN; reserveB: BN }> {\n    const pool = await this.fetchPool(poolPda);\n    const [reserveAPda] = this.deriveReservePDA(poolPda, pool.mintA);\n    const [reserveBPda] = this.deriveReservePDA(poolPda, pool.mintB);\n\n    const connection = this.program.provider.connection;\n\n    const [reserveAAccount, reserveBAccount] = await Promise.all([\n      getAccount(connection, reserveAPda),\n      getAccount(connection, reserveBPda),\n    ]);\n\n    return {\n      reserveA: new BN(reserveAAccount.amount.toString()),\n      reserveB: new BN(reserveBAccount.amount.toString()),\n    };\n  }\n\n  async fetchMintDecimals(poolPda: PublicKey): Promise<{ decimalsA: number; decimalsB: number }> {\n    const pool = await this.fetchPool(poolPda);\n    const connection = this.program.provider.connection;\n    const [mintA, mintB] = await Promise.all([\n      getMint(connection, pool.mintA),\n      getMint(connection, pool.mintB),\n    ]);\n    return { decimalsA: mintA.decimals, decimalsB: mintB.decimals };\n  }\n\n  async fetchSpotPrice(poolPda: PublicKey): Promise<BN> {\n    const { reserveA, reserveB } = await this.fetchReserves(poolPda);\n    const { decimalsA, decimalsB } = await this.fetchMintDecimals(poolPda);\n    return calculateSpotPrice(reserveA, reserveB, decimalsA, decimalsB);\n  }\n\n  async fetchTwap(poolPda: PublicKey): Promise<BN | null> {\n    const pool = await this.fetchPool(poolPda);\n    return calculateTwap(pool.oracle);\n  }\n\n  /* Quote */\n\n  async quote(\n    poolPda: PublicKey,\n    swapAToB: boolean,\n    inputAmount: BN | number,\n    slippagePercent: number = 0.5,\n  ): Promise<SwapQuote> {\n    const pool = await this.fetchPool(poolPda);\n    const { reserveA, reserveB } = await this.fetchReserves(poolPda);\n    const { decimalsA, decimalsB } = await this.fetchMintDecimals(poolPda);\n\n    const [reserveIn, reserveOut] = swapAToB\n      ? [reserveA, reserveB]\n      : [reserveB, reserveA];\n\n    const [decimalsIn, decimalsOut] = swapAToB\n      ? [decimalsA, decimalsB]\n      : [decimalsB, decimalsA];\n\n    return createSwapQuote(\n      inputAmount,\n      reserveIn,\n      reserveOut,\n      pool.fee,\n      decimalsIn,\n      decimalsOut,\n      swapAToB,\n      slippagePercent,\n    );\n  }\n\n  /* Instruction Builders */\n\n  createPool(\n    payer: PublicKey,\n    admin: PublicKey,\n    mintA: PublicKey,\n    mintB: PublicKey,\n    fee: number,\n    startingObservation: BN,\n    maxObservationDelta: BN,\n    warmupDuration: number,\n    liquidityProvider: PublicKey | null = null\n  ) {\n    const [poolPda] = this.derivePoolPDA(admin, mintA, mintB);\n    const [reserveA] = this.deriveReservePDA(poolPda, mintA);\n    const [reserveB] = this.deriveReservePDA(poolPda, mintB);\n    const [feeVault] = this.deriveFeeVaultPDA(poolPda);\n\n    const builder = createPoolIx(\n      this.program,\n      payer,\n      admin,\n      mintA,\n      mintB,\n      poolPda,\n      reserveA,\n      reserveB,\n      feeVault,\n      fee,\n      startingObservation,\n      maxObservationDelta,\n      warmupDuration,\n      liquidityProvider\n    );\n\n    return {\n      builder,\n      poolPda,\n      reserveA,\n      reserveB,\n      feeVault,\n    };\n  }\n\n  async addLiquidity(\n    depositor: PublicKey,\n    poolPda: PublicKey,\n    amountA: BN | number,\n    amountB: BN | number,\n    options?: AmmActionOptions\n  ) {\n    const { autoWrapUnwrap = true, includeCuBudget = true, computeUnits } = options ?? {};\n\n    const pool = await this.fetchPool(poolPda);\n    const [reserveA] = this.deriveReservePDA(poolPda, pool.mintA);\n    const [reserveB] = this.deriveReservePDA(poolPda, pool.mintB);\n    const depositorTokenAccA = getAssociatedTokenAddressSync(pool.mintA, depositor);\n    const depositorTokenAccB = getAssociatedTokenAddressSync(pool.mintB, depositor);\n\n    const preIxs: TransactionInstruction[] = [];\n\n    if (includeCuBudget) {\n      preIxs.push(\n        ComputeBudgetProgram.setComputeUnitLimit({\n          units: computeUnits ?? this.computeUnits,\n        })\n      );\n    }\n\n    if (autoWrapUnwrap && pool.mintA.equals(NATIVE_MINT)) {\n      const amountABN = typeof amountA === \"number\" ? new BN(amountA) : amountA;\n      preIxs.push(\n        createAssociatedTokenAccountIdempotentInstruction(\n          depositor,\n          depositorTokenAccA,\n          depositor,\n          pool.mintA\n        ),\n        SystemProgram.transfer({\n          fromPubkey: depositor,\n          toPubkey: depositorTokenAccA,\n          lamports: BigInt(amountABN.toString()),\n        }),\n        createSyncNativeInstruction(depositorTokenAccA)\n      );\n    }\n\n    if (autoWrapUnwrap && pool.mintB.equals(NATIVE_MINT)) {\n      const amountBBN = typeof amountB === \"number\" ? new BN(amountB) : amountB;\n      preIxs.push(\n        createAssociatedTokenAccountIdempotentInstruction(\n          depositor,\n          depositorTokenAccB,\n          depositor,\n          pool.mintB\n        ),\n        SystemProgram.transfer({\n          fromPubkey: depositor,\n          toPubkey: depositorTokenAccB,\n          lamports: BigInt(amountBBN.toString()),\n        }),\n        createSyncNativeInstruction(depositorTokenAccB)\n      );\n    }\n\n    let builder = addLiquidityIx(\n      this.program,\n      depositor,\n      poolPda,\n      reserveA,\n      reserveB,\n      depositorTokenAccA,\n      depositorTokenAccB,\n      amountA,\n      amountB\n    );\n\n    return preIxs.length > 0 ? builder.preInstructions(preIxs) : builder;\n  }\n\n  async removeLiquidity(\n    depositor: PublicKey,\n    poolPda: PublicKey,\n    amountA: BN | number,\n    amountB: BN | number,\n    options?: AmmActionOptions\n  ) {\n    const { autoWrapUnwrap = true, includeCuBudget = true, computeUnits } = options ?? {};\n\n    const pool = await this.fetchPool(poolPda);\n    const [reserveA] = this.deriveReservePDA(poolPda, pool.mintA);\n    const [reserveB] = this.deriveReservePDA(poolPda, pool.mintB);\n    const depositorTokenAccA = getAssociatedTokenAddressSync(pool.mintA, depositor);\n    const depositorTokenAccB = getAssociatedTokenAddressSync(pool.mintB, depositor);\n\n    let builder = removeLiquidityIx(\n      this.program,\n      depositor,\n      poolPda,\n      reserveA,\n      reserveB,\n      depositorTokenAccA,\n      depositorTokenAccB,\n      amountA,\n      amountB\n    );\n\n    if (includeCuBudget) {\n      builder = builder.preInstructions([\n        ComputeBudgetProgram.setComputeUnitLimit({\n          units: computeUnits ?? this.computeUnits,\n        }),\n      ]);\n    }\n\n    const postIxs: TransactionInstruction[] = [];\n\n    if (autoWrapUnwrap && pool.mintA.equals(NATIVE_MINT)) {\n      postIxs.push(createCloseAccountInstruction(depositorTokenAccA, depositor, depositor));\n    }\n\n    if (autoWrapUnwrap && pool.mintB.equals(NATIVE_MINT)) {\n      postIxs.push(createCloseAccountInstruction(depositorTokenAccB, depositor, depositor));\n    }\n\n    return postIxs.length > 0 ? builder.postInstructions(postIxs) : builder;\n  }\n\n  async swap(\n    trader: PublicKey,\n    poolPda: PublicKey,\n    swapAToB: boolean,\n    inputAmount: BN | number,\n    minOutputAmount: BN | number,\n    options?: AmmActionOptions\n  ) {\n    const { autoWrapUnwrap = true, includeCuBudget = true, computeUnits } = options ?? {};\n\n    const pool = await this.fetchPool(poolPda);\n    const [reserveA] = this.deriveReservePDA(poolPda, pool.mintA);\n    const [reserveB] = this.deriveReservePDA(poolPda, pool.mintB);\n    const [feeVault] = this.deriveFeeVaultPDA(poolPda);\n    const traderAccountA = getAssociatedTokenAddressSync(pool.mintA, trader);\n    const traderAccountB = getAssociatedTokenAddressSync(pool.mintB, trader);\n\n    const preIxs: TransactionInstruction[] = [];\n    const postIxs: TransactionInstruction[] = [];\n\n    if (includeCuBudget) {\n      preIxs.push(\n        ComputeBudgetProgram.setComputeUnitLimit({\n          units: computeUnits ?? this.computeUnits,\n        })\n      );\n    }\n\n    const inputMint = swapAToB ? pool.mintA : pool.mintB;\n    const outputMint = swapAToB ? pool.mintB : pool.mintA;\n    const inputAta = swapAToB ? traderAccountA : traderAccountB;\n    const outputAta = swapAToB ? traderAccountB : traderAccountA;\n\n    if (autoWrapUnwrap) {\n      // Create ATAs idempotently\n      preIxs.push(\n        createAssociatedTokenAccountIdempotentInstruction(\n          trader,\n          traderAccountA,\n          trader,\n          pool.mintA\n        ),\n        createAssociatedTokenAccountIdempotentInstruction(\n          trader,\n          traderAccountB,\n          trader,\n          pool.mintB\n        )\n      );\n\n      // Wrap input SOL if needed\n      if (inputMint.equals(NATIVE_MINT)) {\n        const input = typeof inputAmount === \"number\" ? new BN(inputAmount) : inputAmount;\n        preIxs.push(\n          SystemProgram.transfer({\n            fromPubkey: trader,\n            toPubkey: inputAta,\n            lamports: BigInt(input.toString()),\n          }),\n          createSyncNativeInstruction(inputAta)\n        );\n      }\n\n      // Unwrap output SOL if needed\n      if (outputMint.equals(NATIVE_MINT)) {\n        postIxs.push(createCloseAccountInstruction(outputAta, trader, trader));\n      }\n    }\n\n    let builder = swapIx(\n      this.program,\n      trader,\n      poolPda,\n      reserveA,\n      reserveB,\n      feeVault,\n      traderAccountA,\n      traderAccountB,\n      swapAToB,\n      inputAmount,\n      minOutputAmount\n    );\n\n    if (preIxs.length > 0) {\n      builder = builder.preInstructions(preIxs);\n    }\n    if (postIxs.length > 0) {\n      builder = builder.postInstructions(postIxs);\n    }\n\n    return builder;\n  }\n\n  async crankTwap(poolPda: PublicKey) {\n    const pool = await this.fetchPool(poolPda);\n    const [reserveA] = this.deriveReservePDA(poolPda, pool.mintA);\n    const [reserveB] = this.deriveReservePDA(poolPda, pool.mintB);\n\n    return crankTwapIx(this.program, poolPda, reserveA, reserveB);\n  }\n\n  ceaseTrading(admin: PublicKey, poolPda: PublicKey) {\n    return ceaseTradingIx(this.program, admin, poolPda);\n  }\n\n  /* High-Level Swap with Slippage */\n\n  /**\n   * High-level swap function that:\n   * - Fetches current reserves and computes quote\n   * - Calculates minOutput based on slippage tolerance\n   * - Adds compute budget instruction (if includeCuBudget is true)\n   * - Creates token accounts if they don't exist (if autoWrapUnwrap is true)\n   * - Handles WSOL wrapping/unwrapping if needed (if autoWrapUnwrap is true)\n   */\n  async swapWithSlippage(\n    trader: PublicKey,\n    poolPda: PublicKey,\n    swapAToB: boolean,\n    inputAmount: BN | number,\n    slippagePercent: number = 0.5,\n    options?: AmmActionOptions\n  ) {\n    const { autoWrapUnwrap = true, includeCuBudget = true, computeUnits } = options ?? {};\n\n    const pool = await this.fetchPool(poolPda);\n    const input = typeof inputAmount === \"number\" ? new BN(inputAmount) : inputAmount;\n\n    // Get quote with slippage\n    const quoteResult = await this.quote(poolPda, swapAToB, input, slippagePercent);\n\n    // Derive accounts\n    const [reserveA] = this.deriveReservePDA(poolPda, pool.mintA);\n    const [reserveB] = this.deriveReservePDA(poolPda, pool.mintB);\n    const [feeVault] = this.deriveFeeVaultPDA(poolPda);\n    const traderAccountA = getAssociatedTokenAddressSync(pool.mintA, trader);\n    const traderAccountB = getAssociatedTokenAddressSync(pool.mintB, trader);\n\n    // Build base swap instruction\n    let builder = swapIx(\n      this.program,\n      trader,\n      poolPda,\n      reserveA,\n      reserveB,\n      feeVault,\n      traderAccountA,\n      traderAccountB,\n      swapAToB,\n      input,\n      quoteResult.minOutputAmount\n    );\n\n    const preIxs: TransactionInstruction[] = [];\n    const postIxs: TransactionInstruction[] = [];\n\n    if (includeCuBudget) {\n      preIxs.push(\n        ComputeBudgetProgram.setComputeUnitLimit({\n          units: computeUnits ?? this.computeUnits,\n        })\n      );\n    }\n\n    if (autoWrapUnwrap) {\n      preIxs.push(\n        createAssociatedTokenAccountIdempotentInstruction(\n          trader,\n          traderAccountA,\n          trader,\n          pool.mintA\n        ),\n        createAssociatedTokenAccountIdempotentInstruction(\n          trader,\n          traderAccountB,\n          trader,\n          pool.mintB\n        )\n      );\n    }\n\n    // Handle WSOL for input/output tokens\n    const inputMint = swapAToB ? pool.mintA : pool.mintB;\n    const outputMint = swapAToB ? pool.mintB : pool.mintA;\n    const inputAta = swapAToB ? traderAccountA : traderAccountB;\n    const outputAta = swapAToB ? traderAccountB : traderAccountA;\n\n    if (autoWrapUnwrap && inputMint.equals(NATIVE_MINT)) {\n      // Wrap SOL before swap\n      preIxs.push(\n        SystemProgram.transfer({\n          fromPubkey: trader,\n          toPubkey: inputAta,\n          lamports: BigInt(input.toString()),\n        }),\n        createSyncNativeInstruction(inputAta)\n      );\n    }\n\n    if (autoWrapUnwrap && outputMint.equals(NATIVE_MINT)) {\n      // Unwrap SOL after swap\n      postIxs.push(createCloseAccountInstruction(outputAta, trader, trader));\n    }\n\n    if (preIxs.length > 0) {\n      builder = builder.preInstructions(preIxs);\n    }\n    if (postIxs.length > 0) {\n      builder = builder.postInstructions(postIxs);\n    }\n\n    return {\n      builder,\n      quote: quoteResult,\n    };\n  }\n}\n"]}
226
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"client.js","sourceRoot":"","sources":["../../src/amm/client.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * High-level client for the AMM program.\n * Provides ergonomic methods for pool operations with automatic PDA derivation,\n * native SOL wrapping/unwrapping, and compute budget management.\n */\n\nimport { Program, AnchorProvider, BN } from \"@coral-xyz/anchor\";\nimport {\n  PublicKey,\n  ComputeBudgetProgram,\n  SystemProgram,\n  TransactionInstruction,\n} from \"@solana/web3.js\";\nimport {\n  getAccount,\n  getAssociatedTokenAddressSync,\n  getMint,\n  NATIVE_MINT,\n  createSyncNativeInstruction,\n  createCloseAccountInstruction,\n  createAssociatedTokenAccountIdempotentInstruction,\n} from \"@solana/spl-token\";\nimport { PROGRAM_ID } from \"./constants\";\nimport { Amm, PoolAccount, SwapQuote, AmmActionOptions } from \"./types\";\nimport {\n  derivePoolPDA,\n  deriveReservePDA,\n  deriveFeeVaultPDA,\n  fetchPoolAccount,\n  createSwapQuote,\n  calculateSpotPrice,\n  calculateTwap,\n} from \"./utils\";\nimport {\n  createPool as createPoolIx,\n  addLiquidity as addLiquidityIx,\n  removeLiquidity as removeLiquidityIx,\n  swap as swapIx,\n  crankTwap as crankTwapIx,\n  ceaseTrading as ceaseTradingIx,\n} from \"./instructions\";\n\nimport { AmmIDL } from \"../generated/idls\";\n\nconst DEFAULT_COMPUTE_UNITS = 300_000;\n\nexport class AMMClient {\n  public program: Program<Amm>;\n  public programId: PublicKey;\n  public computeUnits: number;\n\n  constructor(\n    provider: AnchorProvider,\n    programId?: PublicKey,\n    computeUnits?: number\n  ) {\n    this.programId = programId ?? PROGRAM_ID;\n    this.computeUnits = computeUnits ?? DEFAULT_COMPUTE_UNITS;\n    this.program = new Program(AmmIDL as Amm, provider);\n  }\n\n  /* PDA Helpers */\n\n  derivePoolPDA(\n    admin: PublicKey,\n    mintA: PublicKey,\n    mintB: PublicKey\n  ): [PublicKey, number] {\n    return derivePoolPDA(admin, mintA, mintB, this.programId);\n  }\n\n  deriveReservePDA(pool: PublicKey, mint: PublicKey): [PublicKey, number] {\n    return deriveReservePDA(pool, mint, this.programId);\n  }\n\n  deriveFeeVaultPDA(pool: PublicKey): [PublicKey, number] {\n    return deriveFeeVaultPDA(pool, this.programId);\n  }\n\n  /* State Fetching */\n\n  async fetchPool(poolPda: PublicKey): Promise<PoolAccount> {\n    return fetchPoolAccount(this.program, poolPda);\n  }\n\n  async fetchReserves(poolPda: PublicKey): Promise<{ reserveA: BN; reserveB: BN }> {\n    const pool = await this.fetchPool(poolPda);\n    const [reserveAPda] = this.deriveReservePDA(poolPda, pool.mintA);\n    const [reserveBPda] = this.deriveReservePDA(poolPda, pool.mintB);\n\n    const connection = this.program.provider.connection;\n\n    const [reserveAAccount, reserveBAccount] = await Promise.all([\n      getAccount(connection, reserveAPda),\n      getAccount(connection, reserveBPda),\n    ]);\n\n    return {\n      reserveA: new BN(reserveAAccount.amount.toString()),\n      reserveB: new BN(reserveBAccount.amount.toString()),\n    };\n  }\n\n  async fetchMintDecimals(poolPda: PublicKey): Promise<{ decimalsA: number; decimalsB: number }> {\n    const pool = await this.fetchPool(poolPda);\n    const connection = this.program.provider.connection;\n    const [mintA, mintB] = await Promise.all([\n      getMint(connection, pool.mintA),\n      getMint(connection, pool.mintB),\n    ]);\n    return { decimalsA: mintA.decimals, decimalsB: mintB.decimals };\n  }\n\n  async fetchSpotPrice(poolPda: PublicKey): Promise<BN> {\n    const { reserveA, reserveB } = await this.fetchReserves(poolPda);\n    const { decimalsA, decimalsB } = await this.fetchMintDecimals(poolPda);\n    return calculateSpotPrice(reserveA, reserveB, decimalsA, decimalsB);\n  }\n\n  async fetchTwap(poolPda: PublicKey): Promise<BN | null> {\n    const pool = await this.fetchPool(poolPda);\n    return calculateTwap(pool.oracle);\n  }\n\n  /* Quote */\n\n  async quote(\n    poolPda: PublicKey,\n    swapAToB: boolean,\n    inputAmount: BN | number,\n    slippagePercent: number = 0.5,\n  ): Promise<SwapQuote> {\n    const pool = await this.fetchPool(poolPda);\n    const { reserveA, reserveB } = await this.fetchReserves(poolPda);\n    const { decimalsA, decimalsB } = await this.fetchMintDecimals(poolPda);\n\n    const [reserveIn, reserveOut] = swapAToB\n      ? [reserveA, reserveB]\n      : [reserveB, reserveA];\n\n    const [decimalsIn, decimalsOut] = swapAToB\n      ? [decimalsA, decimalsB]\n      : [decimalsB, decimalsA];\n\n    return createSwapQuote(\n      inputAmount,\n      reserveIn,\n      reserveOut,\n      pool.fee,\n      decimalsIn,\n      decimalsOut,\n      swapAToB,\n      slippagePercent,\n    );\n  }\n\n  /* Instruction Builders */\n\n  createPool(\n    payer: PublicKey,\n    admin: PublicKey,\n    mintA: PublicKey,\n    mintB: PublicKey,\n    fee: number,\n    startingObservation: BN,\n    maxObservationDelta: BN,\n    warmupDuration: number,\n    liquidityProvider: PublicKey | null = null\n  ) {\n    const [poolPda] = this.derivePoolPDA(admin, mintA, mintB);\n    const [reserveA] = this.deriveReservePDA(poolPda, mintA);\n    const [reserveB] = this.deriveReservePDA(poolPda, mintB);\n    const [feeVault] = this.deriveFeeVaultPDA(poolPda);\n\n    const builder = createPoolIx(\n      this.program,\n      payer,\n      admin,\n      mintA,\n      mintB,\n      poolPda,\n      reserveA,\n      reserveB,\n      feeVault,\n      fee,\n      startingObservation,\n      maxObservationDelta,\n      warmupDuration,\n      liquidityProvider\n    );\n\n    return {\n      builder,\n      poolPda,\n      reserveA,\n      reserveB,\n      feeVault,\n    };\n  }\n\n  async addLiquidity(\n    depositor: PublicKey,\n    poolPda: PublicKey,\n    amountA: BN | number,\n    amountB: BN | number,\n    options?: AmmActionOptions\n  ) {\n    const { autoWrapUnwrap = true, includeCuBudget = true, computeUnits } = options ?? {};\n\n    const pool = await this.fetchPool(poolPda);\n    const [reserveA] = this.deriveReservePDA(poolPda, pool.mintA);\n    const [reserveB] = this.deriveReservePDA(poolPda, pool.mintB);\n    const depositorTokenAccA = getAssociatedTokenAddressSync(pool.mintA, depositor);\n    const depositorTokenAccB = getAssociatedTokenAddressSync(pool.mintB, depositor);\n\n    const preIxs: TransactionInstruction[] = [];\n\n    if (includeCuBudget) {\n      preIxs.push(\n        ComputeBudgetProgram.setComputeUnitLimit({\n          units: computeUnits ?? this.computeUnits,\n        })\n      );\n    }\n\n    if (autoWrapUnwrap && pool.mintA.equals(NATIVE_MINT)) {\n      const amountABN = typeof amountA === \"number\" ? new BN(amountA) : amountA;\n      preIxs.push(\n        createAssociatedTokenAccountIdempotentInstruction(\n          depositor,\n          depositorTokenAccA,\n          depositor,\n          pool.mintA\n        ),\n        SystemProgram.transfer({\n          fromPubkey: depositor,\n          toPubkey: depositorTokenAccA,\n          lamports: BigInt(amountABN.toString()),\n        }),\n        createSyncNativeInstruction(depositorTokenAccA)\n      );\n    }\n\n    if (autoWrapUnwrap && pool.mintB.equals(NATIVE_MINT)) {\n      const amountBBN = typeof amountB === \"number\" ? new BN(amountB) : amountB;\n      preIxs.push(\n        createAssociatedTokenAccountIdempotentInstruction(\n          depositor,\n          depositorTokenAccB,\n          depositor,\n          pool.mintB\n        ),\n        SystemProgram.transfer({\n          fromPubkey: depositor,\n          toPubkey: depositorTokenAccB,\n          lamports: BigInt(amountBBN.toString()),\n        }),\n        createSyncNativeInstruction(depositorTokenAccB)\n      );\n    }\n\n    let builder = addLiquidityIx(\n      this.program,\n      depositor,\n      poolPda,\n      reserveA,\n      reserveB,\n      depositorTokenAccA,\n      depositorTokenAccB,\n      amountA,\n      amountB\n    );\n\n    return preIxs.length > 0 ? builder.preInstructions(preIxs) : builder;\n  }\n\n  async removeLiquidity(\n    depositor: PublicKey,\n    poolPda: PublicKey,\n    amountA: BN | number,\n    amountB: BN | number,\n    options?: AmmActionOptions\n  ) {\n    const { autoWrapUnwrap = true, includeCuBudget = true, computeUnits } = options ?? {};\n\n    const pool = await this.fetchPool(poolPda);\n    const [reserveA] = this.deriveReservePDA(poolPda, pool.mintA);\n    const [reserveB] = this.deriveReservePDA(poolPda, pool.mintB);\n    const depositorTokenAccA = getAssociatedTokenAddressSync(pool.mintA, depositor);\n    const depositorTokenAccB = getAssociatedTokenAddressSync(pool.mintB, depositor);\n\n    let builder = removeLiquidityIx(\n      this.program,\n      depositor,\n      poolPda,\n      reserveA,\n      reserveB,\n      depositorTokenAccA,\n      depositorTokenAccB,\n      amountA,\n      amountB\n    );\n\n    if (includeCuBudget) {\n      builder = builder.preInstructions([\n        ComputeBudgetProgram.setComputeUnitLimit({\n          units: computeUnits ?? this.computeUnits,\n        }),\n      ]);\n    }\n\n    const postIxs: TransactionInstruction[] = [];\n\n    if (autoWrapUnwrap && pool.mintA.equals(NATIVE_MINT)) {\n      postIxs.push(createCloseAccountInstruction(depositorTokenAccA, depositor, depositor));\n    }\n\n    if (autoWrapUnwrap && pool.mintB.equals(NATIVE_MINT)) {\n      postIxs.push(createCloseAccountInstruction(depositorTokenAccB, depositor, depositor));\n    }\n\n    return postIxs.length > 0 ? builder.postInstructions(postIxs) : builder;\n  }\n\n  async swap(\n    trader: PublicKey,\n    poolPda: PublicKey,\n    swapAToB: boolean,\n    inputAmount: BN | number,\n    minOutputAmount: BN | number,\n    options?: AmmActionOptions\n  ) {\n    const { autoCreateTokenAccounts = true, includeCuBudget = true, computeUnits } = options ?? {};\n\n    const pool = await this.fetchPool(poolPda);\n    const [reserveA] = this.deriveReservePDA(poolPda, pool.mintA);\n    const [reserveB] = this.deriveReservePDA(poolPda, pool.mintB);\n    const [feeVault] = this.deriveFeeVaultPDA(poolPda);\n    const traderAccountA = getAssociatedTokenAddressSync(pool.mintA, trader);\n    const traderAccountB = getAssociatedTokenAddressSync(pool.mintB, trader);\n\n    const preIxs: TransactionInstruction[] = [];\n\n    if (includeCuBudget) {\n      preIxs.push(\n        ComputeBudgetProgram.setComputeUnitLimit({\n          units: computeUnits ?? this.computeUnits,\n        })\n      );\n    }\n\n    if (autoCreateTokenAccounts) {\n      preIxs.push(\n        createAssociatedTokenAccountIdempotentInstruction(\n          trader,\n          traderAccountA,\n          trader,\n          pool.mintA\n        ),\n        createAssociatedTokenAccountIdempotentInstruction(\n          trader,\n          traderAccountB,\n          trader,\n          pool.mintB\n        )\n      );\n    }\n\n    let builder = swapIx(\n      this.program,\n      trader,\n      poolPda,\n      reserveA,\n      reserveB,\n      feeVault,\n      traderAccountA,\n      traderAccountB,\n      swapAToB,\n      inputAmount,\n      minOutputAmount\n    );\n\n    if (preIxs.length > 0) {\n      builder = builder.preInstructions(preIxs);\n    }\n\n    return builder;\n  }\n\n  async crankTwap(poolPda: PublicKey) {\n    const pool = await this.fetchPool(poolPda);\n    const [reserveA] = this.deriveReservePDA(poolPda, pool.mintA);\n    const [reserveB] = this.deriveReservePDA(poolPda, pool.mintB);\n\n    return crankTwapIx(this.program, poolPda, reserveA, reserveB);\n  }\n\n  ceaseTrading(admin: PublicKey, poolPda: PublicKey) {\n    return ceaseTradingIx(this.program, admin, poolPda);\n  }\n\n  /* High-Level Swap with Slippage */\n\n  /**\n   * High-level swap function that:\n   * - Fetches current reserves and computes quote\n   * - Calculates minOutput based on slippage tolerance\n   * - Adds compute budget instruction (if includeCuBudget is true)\n   * - Creates token accounts if they don't exist (if autoCreateTokenAccounts is true)\n   */\n  async swapWithSlippage(\n    trader: PublicKey,\n    poolPda: PublicKey,\n    swapAToB: boolean,\n    inputAmount: BN | number,\n    slippagePercent: number = 0.5,\n    options?: AmmActionOptions\n  ) {\n    const { autoCreateTokenAccounts = true, includeCuBudget = true, computeUnits } = options ?? {};\n\n    const pool = await this.fetchPool(poolPda);\n    const input = typeof inputAmount === \"number\" ? new BN(inputAmount) : inputAmount;\n\n    // Get quote with slippage\n    const quoteResult = await this.quote(poolPda, swapAToB, input, slippagePercent);\n\n    // Derive accounts\n    const [reserveA] = this.deriveReservePDA(poolPda, pool.mintA);\n    const [reserveB] = this.deriveReservePDA(poolPda, pool.mintB);\n    const [feeVault] = this.deriveFeeVaultPDA(poolPda);\n    const traderAccountA = getAssociatedTokenAddressSync(pool.mintA, trader);\n    const traderAccountB = getAssociatedTokenAddressSync(pool.mintB, trader);\n\n    // Build base swap instruction\n    let builder = swapIx(\n      this.program,\n      trader,\n      poolPda,\n      reserveA,\n      reserveB,\n      feeVault,\n      traderAccountA,\n      traderAccountB,\n      swapAToB,\n      input,\n      quoteResult.minOutputAmount\n    );\n\n    const preIxs: TransactionInstruction[] = [];\n\n    if (includeCuBudget) {\n      preIxs.push(\n        ComputeBudgetProgram.setComputeUnitLimit({\n          units: computeUnits ?? this.computeUnits,\n        })\n      );\n    }\n\n    if (autoCreateTokenAccounts) {\n      preIxs.push(\n        createAssociatedTokenAccountIdempotentInstruction(\n          trader,\n          traderAccountA,\n          trader,\n          pool.mintA\n        ),\n        createAssociatedTokenAccountIdempotentInstruction(\n          trader,\n          traderAccountB,\n          trader,\n          pool.mintB\n        )\n      );\n    }\n\n    if (preIxs.length > 0) {\n      builder = builder.preInstructions(preIxs);\n    }\n\n    return {\n      builder,\n      quote: quoteResult,\n    };\n  }\n}\n"]}
@@ -42,4 +42,5 @@ export type AMMEvent = {
42
42
  };
43
43
  export interface AmmActionOptions extends TxOptions {
44
44
  autoWrapUnwrap?: boolean;
45
+ autoCreateTokenAccounts?: boolean;
45
46
  }
package/dist/amm/types.js CHANGED
@@ -11,4 +11,4 @@ var PoolState;
11
11
  PoolState["Trading"] = "trading";
12
12
  PoolState["Finalized"] = "finalized";
13
13
  })(PoolState || (exports.PoolState = PoolState = {}));
14
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYW1tL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7O0dBR0c7OztBQXlCSCxXQUFXO0FBRVgsSUFBWSxTQUdYO0FBSEQsV0FBWSxTQUFTO0lBQ25CLGdDQUFtQixDQUFBO0lBQ25CLG9DQUF1QixDQUFBO0FBQ3pCLENBQUMsRUFIVyxTQUFTLHlCQUFULFNBQVMsUUFHcEIiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogVHlwZSBkZWZpbml0aW9ucyBmb3IgdGhlIEFNTSBwcm9ncmFtLlxuICogRXhwb3J0cyBJREwtZGVyaXZlZCB0eXBlcyBhbmQgU0RLLWZyaWVuZGx5IGVudW1zLlxuICovXG5cbmltcG9ydCB7IEJOLCBJZGxBY2NvdW50cywgSWRsRXZlbnRzLCBJZGxUeXBlcyB9IGZyb20gXCJAY29yYWwteHl6L2FuY2hvclwiO1xuaW1wb3J0IHsgVHhPcHRpb25zIH0gZnJvbSBcIi4uL3V0aWxzXCI7XG5cbi8qIElETCBUeXBlIFJlLWV4cG9ydCAqL1xuXG5leHBvcnQgeyBBbW0gfSBmcm9tIFwiLi4vZ2VuZXJhdGVkL3R5cGVzXCI7XG5pbXBvcnQgdHlwZSB7IEFtbSB9IGZyb20gXCIuLi9nZW5lcmF0ZWQvdHlwZXNcIjtcblxuLyogSURMLWRlcml2ZWQgVHlwZXMgKi9cblxuZXhwb3J0IHR5cGUgUG9vbEFjY291bnQgPSBJZGxBY2NvdW50czxBbW0+W1wicG9vbEFjY291bnRcIl07XG5leHBvcnQgdHlwZSBQb29sU3RhdGVSYXcgPSBJZGxUeXBlczxBbW0+W1wicG9vbFN0YXRlXCJdO1xuZXhwb3J0IHR5cGUgVHdhcE9yYWNsZSA9IElkbFR5cGVzPEFtbT5bXCJ0d2FwT3JhY2xlXCJdO1xuZXhwb3J0IHR5cGUgUG9vbEJ1bXBzID0gSWRsVHlwZXM8QW1tPltcInBvb2xCdW1wc1wiXTtcblxuLyogRXZlbnQgVHlwZXMgKi9cblxuZXhwb3J0IHR5cGUgUG9vbENyZWF0ZWRFdmVudCA9IElkbEV2ZW50czxBbW0+W1wicG9vbENyZWF0ZWRcIl07XG5leHBvcnQgdHlwZSBMaXF1aWRpdHlBZGRlZEV2ZW50ID0gSWRsRXZlbnRzPEFtbT5bXCJsaXF1aWRpdHlBZGRlZFwiXTtcbmV4cG9ydCB0eXBlIExpcXVpZGl0eVJlbW92ZWRFdmVudCA9IElkbEV2ZW50czxBbW0+W1wibGlxdWlkaXR5UmVtb3ZlZFwiXTtcbmV4cG9ydCB0eXBlIENvbmRTd2FwRXZlbnQgPSBJZGxFdmVudHM8QW1tPltcImNvbmRTd2FwXCJdO1xuZXhwb3J0IHR5cGUgVFdBUFVwZGF0ZUV2ZW50ID0gSWRsRXZlbnRzPEFtbT5bXCJ0d2FwVXBkYXRlXCJdO1xuXG4vKiBFbnVtcyAqL1xuXG5leHBvcnQgZW51bSBQb29sU3RhdGUge1xuICBUcmFkaW5nID0gXCJ0cmFkaW5nXCIsXG4gIEZpbmFsaXplZCA9IFwiZmluYWxpemVkXCIsXG59XG5cbi8qIFF1b3RlIFR5cGVzICovXG5cbmV4cG9ydCBpbnRlcmZhY2UgU3dhcFF1b3RlIHtcbiAgaW5wdXRBbW91bnQ6IEJOO1xuICBvdXRwdXRBbW91bnQ6IEJOO1xuICBtaW5PdXRwdXRBbW91bnQ6IEJOO1xuICBmZWVBbW91bnQ6IEJOO1xuICBwcmljZUltcGFjdDogbnVtYmVyO1xuICBzcG90UHJpY2VCZWZvcmU6IEJOO1xuICBzcG90UHJpY2VBZnRlcjogQk47XG59XG5cbi8qIEV2ZW50IFVuaW9uIFR5cGUgKi9cblxuZXhwb3J0IHR5cGUgQU1NRXZlbnQgPVxuICB8IHsgbmFtZTogXCJQb29sQ3JlYXRlZFwiOyBkYXRhOiBQb29sQ3JlYXRlZEV2ZW50IH1cbiAgfCB7IG5hbWU6IFwiTGlxdWlkaXR5QWRkZWRcIjsgZGF0YTogTGlxdWlkaXR5QWRkZWRFdmVudCB9XG4gIHwgeyBuYW1lOiBcIkxpcXVpZGl0eVJlbW92ZWRcIjsgZGF0YTogTGlxdWlkaXR5UmVtb3ZlZEV2ZW50IH1cbiAgfCB7IG5hbWU6IFwiQ29uZFN3YXBcIjsgZGF0YTogQ29uZFN3YXBFdmVudCB9XG4gIHwgeyBuYW1lOiBcIlRXQVBVcGRhdGVcIjsgZGF0YTogVFdBUFVwZGF0ZUV2ZW50IH07XG5cbi8qIE9wdGlvbnMgKi9cblxuZXhwb3J0IGludGVyZmFjZSBBbW1BY3Rpb25PcHRpb25zIGV4dGVuZHMgVHhPcHRpb25zIHtcbiAgYXV0b1dyYXBVbndyYXA/OiBib29sZWFuOyAvLyBBdXRvIHdyYXAvdW53cmFwIG5hdGl2ZSBTT0wgKGRlZmF1bHQ6IHRydWUpXG59XG4iXX0=
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYW1tL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7O0dBR0c7OztBQXlCSCxXQUFXO0FBRVgsSUFBWSxTQUdYO0FBSEQsV0FBWSxTQUFTO0lBQ25CLGdDQUFtQixDQUFBO0lBQ25CLG9DQUF1QixDQUFBO0FBQ3pCLENBQUMsRUFIVyxTQUFTLHlCQUFULFNBQVMsUUFHcEIiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogVHlwZSBkZWZpbml0aW9ucyBmb3IgdGhlIEFNTSBwcm9ncmFtLlxuICogRXhwb3J0cyBJREwtZGVyaXZlZCB0eXBlcyBhbmQgU0RLLWZyaWVuZGx5IGVudW1zLlxuICovXG5cbmltcG9ydCB7IEJOLCBJZGxBY2NvdW50cywgSWRsRXZlbnRzLCBJZGxUeXBlcyB9IGZyb20gXCJAY29yYWwteHl6L2FuY2hvclwiO1xuaW1wb3J0IHsgVHhPcHRpb25zIH0gZnJvbSBcIi4uL3V0aWxzXCI7XG5cbi8qIElETCBUeXBlIFJlLWV4cG9ydCAqL1xuXG5leHBvcnQgeyBBbW0gfSBmcm9tIFwiLi4vZ2VuZXJhdGVkL3R5cGVzXCI7XG5pbXBvcnQgdHlwZSB7IEFtbSB9IGZyb20gXCIuLi9nZW5lcmF0ZWQvdHlwZXNcIjtcblxuLyogSURMLWRlcml2ZWQgVHlwZXMgKi9cblxuZXhwb3J0IHR5cGUgUG9vbEFjY291bnQgPSBJZGxBY2NvdW50czxBbW0+W1wicG9vbEFjY291bnRcIl07XG5leHBvcnQgdHlwZSBQb29sU3RhdGVSYXcgPSBJZGxUeXBlczxBbW0+W1wicG9vbFN0YXRlXCJdO1xuZXhwb3J0IHR5cGUgVHdhcE9yYWNsZSA9IElkbFR5cGVzPEFtbT5bXCJ0d2FwT3JhY2xlXCJdO1xuZXhwb3J0IHR5cGUgUG9vbEJ1bXBzID0gSWRsVHlwZXM8QW1tPltcInBvb2xCdW1wc1wiXTtcblxuLyogRXZlbnQgVHlwZXMgKi9cblxuZXhwb3J0IHR5cGUgUG9vbENyZWF0ZWRFdmVudCA9IElkbEV2ZW50czxBbW0+W1wicG9vbENyZWF0ZWRcIl07XG5leHBvcnQgdHlwZSBMaXF1aWRpdHlBZGRlZEV2ZW50ID0gSWRsRXZlbnRzPEFtbT5bXCJsaXF1aWRpdHlBZGRlZFwiXTtcbmV4cG9ydCB0eXBlIExpcXVpZGl0eVJlbW92ZWRFdmVudCA9IElkbEV2ZW50czxBbW0+W1wibGlxdWlkaXR5UmVtb3ZlZFwiXTtcbmV4cG9ydCB0eXBlIENvbmRTd2FwRXZlbnQgPSBJZGxFdmVudHM8QW1tPltcImNvbmRTd2FwXCJdO1xuZXhwb3J0IHR5cGUgVFdBUFVwZGF0ZUV2ZW50ID0gSWRsRXZlbnRzPEFtbT5bXCJ0d2FwVXBkYXRlXCJdO1xuXG4vKiBFbnVtcyAqL1xuXG5leHBvcnQgZW51bSBQb29sU3RhdGUge1xuICBUcmFkaW5nID0gXCJ0cmFkaW5nXCIsXG4gIEZpbmFsaXplZCA9IFwiZmluYWxpemVkXCIsXG59XG5cbi8qIFF1b3RlIFR5cGVzICovXG5cbmV4cG9ydCBpbnRlcmZhY2UgU3dhcFF1b3RlIHtcbiAgaW5wdXRBbW91bnQ6IEJOO1xuICBvdXRwdXRBbW91bnQ6IEJOO1xuICBtaW5PdXRwdXRBbW91bnQ6IEJOO1xuICBmZWVBbW91bnQ6IEJOO1xuICBwcmljZUltcGFjdDogbnVtYmVyO1xuICBzcG90UHJpY2VCZWZvcmU6IEJOO1xuICBzcG90UHJpY2VBZnRlcjogQk47XG59XG5cbi8qIEV2ZW50IFVuaW9uIFR5cGUgKi9cblxuZXhwb3J0IHR5cGUgQU1NRXZlbnQgPVxuICB8IHsgbmFtZTogXCJQb29sQ3JlYXRlZFwiOyBkYXRhOiBQb29sQ3JlYXRlZEV2ZW50IH1cbiAgfCB7IG5hbWU6IFwiTGlxdWlkaXR5QWRkZWRcIjsgZGF0YTogTGlxdWlkaXR5QWRkZWRFdmVudCB9XG4gIHwgeyBuYW1lOiBcIkxpcXVpZGl0eVJlbW92ZWRcIjsgZGF0YTogTGlxdWlkaXR5UmVtb3ZlZEV2ZW50IH1cbiAgfCB7IG5hbWU6IFwiQ29uZFN3YXBcIjsgZGF0YTogQ29uZFN3YXBFdmVudCB9XG4gIHwgeyBuYW1lOiBcIlRXQVBVcGRhdGVcIjsgZGF0YTogVFdBUFVwZGF0ZUV2ZW50IH07XG5cbi8qIE9wdGlvbnMgKi9cblxuZXhwb3J0IGludGVyZmFjZSBBbW1BY3Rpb25PcHRpb25zIGV4dGVuZHMgVHhPcHRpb25zIHtcbiAgYXV0b1dyYXBVbndyYXA/OiBib29sZWFuOyAvLyBBdXRvIHdyYXAvdW53cmFwIG5hdGl2ZSBTT0wgKGRlZmF1bHQ6IHRydWUpIC0gZm9yIGxpcXVpZGl0eSBvcGVyYXRpb25zXG4gIGF1dG9DcmVhdGVUb2tlbkFjY291bnRzPzogYm9vbGVhbjsgLy8gQXV0byBjcmVhdGUgdG9rZW4gYWNjb3VudHMgKGRlZmF1bHQ6IHRydWUpIC0gZm9yIHN3YXBzXG59XG4iXX0=
@@ -420,6 +420,8 @@ class FutarchyClient {
420
420
  });
421
421
  await provider.connection.confirmTransaction(sig, "confirmed");
422
422
  // Extend ALT with addresses
423
+ // Use skipPreflight to avoid race condition where simulation sees stale state
424
+ // before previous extend has propagated (same pattern as CREATE above)
423
425
  const CHUNK_SIZE = 20;
424
426
  for (let i = 0; i < addresses.length; i += CHUNK_SIZE) {
425
427
  const chunk = addresses.slice(i, i + CHUNK_SIZE);
@@ -430,7 +432,13 @@ class FutarchyClient {
430
432
  addresses: chunk,
431
433
  });
432
434
  const extendTx = new web3_js_1.Transaction().add(extendIx);
433
- await provider.sendAndConfirm(extendTx);
435
+ extendTx.recentBlockhash = (await provider.connection.getLatestBlockhash()).blockhash;
436
+ extendTx.feePayer = creator;
437
+ const signedExtendTx = await provider.wallet.signTransaction(extendTx);
438
+ const extendSig = await provider.connection.sendRawTransaction(signedExtendTx.serialize(), {
439
+ skipPreflight: true,
440
+ });
441
+ await provider.connection.confirmTransaction(extendSig, "confirmed");
434
442
  }
435
443
  return { altAddress };
436
444
  }
@@ -570,6 +578,8 @@ class FutarchyClient {
570
578
  await provider.connection.confirmTransaction(sig, "confirmed");
571
579
  // Split addresses into chunks to avoid transaction size limits
572
580
  // Each address is 32 bytes, ~20 addresses per extend instruction is safe
581
+ // Use skipPreflight to avoid race condition where simulation sees stale state
582
+ // before previous extend has propagated (same pattern as CREATE above)
573
583
  const CHUNK_SIZE = 20;
574
584
  for (let i = 0; i < addresses.length; i += CHUNK_SIZE) {
575
585
  const chunk = addresses.slice(i, i + CHUNK_SIZE);
@@ -580,7 +590,13 @@ class FutarchyClient {
580
590
  addresses: chunk,
581
591
  });
582
592
  const extendTx = new web3_js_1.Transaction().add(extendIx);
583
- await provider.sendAndConfirm(extendTx);
593
+ extendTx.recentBlockhash = (await provider.connection.getLatestBlockhash()).blockhash;
594
+ extendTx.feePayer = creator;
595
+ const signedExtendTx = await provider.wallet.signTransaction(extendTx);
596
+ const extendSig = await provider.connection.sendRawTransaction(signedExtendTx.serialize(), {
597
+ skipPreflight: true,
598
+ });
599
+ await provider.connection.confirmTransaction(extendSig, "confirmed");
584
600
  }
585
601
  return { altAddress };
586
602
  }
@@ -669,4 +685,4 @@ class FutarchyClient {
669
685
  }
670
686
  }
671
687
  exports.FutarchyClient = FutarchyClient;
672
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"client.js","sourceRoot":"","sources":["../../src/futarchy/client.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * High-level client for the Futarchy program.\n * Handles account derivation, instruction building, and transaction composition.\n */\n\nimport { Program, AnchorProvider, BN } from \"@coral-xyz/anchor\";\nimport {\n  PublicKey,\n  ComputeBudgetProgram,\n  AddressLookupTableProgram,\n  AddressLookupTableAccount,\n  SystemProgram,\n  Transaction,\n  TransactionInstruction,\n  TransactionMessage,\n  VersionedTransaction,\n} from \"@solana/web3.js\";\nimport {\n  getAssociatedTokenAddressSync,\n  TOKEN_PROGRAM_ID,\n  ASSOCIATED_TOKEN_PROGRAM_ID,\n  createAssociatedTokenAccountIdempotentInstruction,\n} from \"@solana/spl-token\";\nimport { PROGRAM_ID, SQUADS_PROGRAM_ID } from \"./constants\";\nimport {\n  Futarchy,\n  DAOAccount,\n  ModeratorAccount,\n  ProposalAccount,\n  ProposalParams,\n  PoolType,\n} from \"./types\";\nimport {\n  deriveDAOPDA,\n  deriveModeratorPDA,\n  deriveProposalPDA,\n  deriveMintCreateKeyPDA,\n  fetchDAOAccount,\n  fetchModeratorAccount,\n  fetchProposalAccount,\n  parseProposalState,\n  isProposalExpired,\n  getTimeRemaining,\n} from \"./utils\";\nimport {\n  initializeModerator,\n  initializeProposal,\n  addOption,\n  launchProposal,\n  finalizeProposal,\n  redeemLiquidity,\n  addHistoricalProposal,\n  initializeParentDAO,\n  initializeChildDAO,\n  upgradeDAO,\n} from \"./instructions\";\nimport { TxOptions } from \"../utils\";\n\nimport { VaultClient, deriveVaultPDA, deriveConditionalMint, VaultType } from \"../vault\";\nimport { AMMClient, derivePoolPDA, deriveReservePDA, deriveFeeVaultPDA, FEE_AUTHORITY } from \"../amm\";\n\nimport { FutarchyIDL } from \"../generated/idls\";\nimport * as multisig from \"@sqds/multisig\";\n\nconst DEFAULT_COMPUTE_UNITS = 500_000;\n\nexport class FutarchyClient {\n  public program: Program<Futarchy>;\n  public programId: PublicKey;\n  public vault: VaultClient;\n  public amm: AMMClient;\n  private defaultComputeUnits: number;\n\n  constructor(provider: AnchorProvider, programId?: PublicKey, computeUnits?: number) {\n    this.programId = programId ?? PROGRAM_ID;\n    this.program = new Program(FutarchyIDL as Futarchy, provider);\n    this.vault = new VaultClient(provider);\n    this.amm = new AMMClient(provider);\n    this.defaultComputeUnits = computeUnits ?? DEFAULT_COMPUTE_UNITS;\n  }\n\n  /* PDA Helpers */\n\n  deriveDAOPDA(name: string): [PublicKey, number] {\n    return deriveDAOPDA(name, this.programId);\n  }\n\n  deriveModeratorPDA(name: string): [PublicKey, number] {\n    return deriveModeratorPDA(name, this.programId);\n  }\n\n  deriveProposalPDA(moderator: PublicKey, proposalId: number): [PublicKey, number] {\n    return deriveProposalPDA(moderator, proposalId, this.programId);\n  }\n\n  /* Fetchers */\n\n  async fetchDAO(daoPda: PublicKey): Promise<DAOAccount> {\n    return fetchDAOAccount(this.program, daoPda);\n  }\n\n  async fetchModerator(moderatorPda: PublicKey): Promise<ModeratorAccount> {\n    return fetchModeratorAccount(this.program, moderatorPda);\n  }\n\n  async fetchProposal(proposalPda: PublicKey): Promise<ProposalAccount> {\n    return fetchProposalAccount(this.program, proposalPda);\n  }\n\n  /* Proposal Helpers */\n\n  isProposalExpired(proposal: ProposalAccount): boolean {\n    return isProposalExpired(proposal);\n  }\n\n  getTimeRemaining(proposal: ProposalAccount): number {\n    return getTimeRemaining(proposal);\n  }\n\n  private getComputeUnits(options?: TxOptions): number {\n    return options?.computeUnits ?? this.defaultComputeUnits;\n  }\n\n  private maybeAddComputeBudget(options?: TxOptions): TransactionInstruction[] {\n    if (options?.includeCuBudget === false) {\n      return [];\n    }\n    return [ComputeBudgetProgram.setComputeUnitLimit({ units: this.getComputeUnits(options) })];\n  }\n\n  /* Instruction Builders */\n\n  async initializeModerator(\n    admin: PublicKey,\n    baseMint: PublicKey,\n    quoteMint: PublicKey,\n    name: string,\n    options?: TxOptions\n  ) {\n    const [moderatorPda] = this.deriveModeratorPDA(name);\n\n    const builder = initializeModerator(\n      this.program,\n      admin,\n      baseMint,\n      quoteMint,\n      moderatorPda,\n      name\n    ).preInstructions(this.maybeAddComputeBudget(options));\n\n    return { builder, moderatorPda, name };\n  }\n\n  async addHistoricalProposal(\n    admin: PublicKey,\n    moderatorPda: PublicKey,\n    numOptions: number,\n    winningIdx: number,\n    length: number,\n    createdAt: BN | number,\n    options?: TxOptions\n  ) {\n    const moderator = await this.fetchModerator(moderatorPda);\n    const proposalId = moderator.proposalIdCounter;\n    const [proposalPda] = this.deriveProposalPDA(moderatorPda, proposalId);\n\n    const builder = addHistoricalProposal(\n      this.program,\n      admin,\n      moderatorPda,\n      proposalPda,\n      numOptions,\n      winningIdx,\n      length,\n      createdAt\n    ).preInstructions(this.maybeAddComputeBudget(options));\n\n    return { builder, proposalPda, proposalId };\n  }\n\n  async initializeProposal(\n    creator: PublicKey,\n    moderatorPda: PublicKey,\n    proposalParams: ProposalParams,\n    metadata?: string,\n    options?: TxOptions\n  ) {\n    const moderator = await this.fetchModerator(moderatorPda);\n    const proposalId = moderator.proposalIdCounter;\n    const [proposalPda] = this.deriveProposalPDA(moderatorPda, proposalId);\n\n    // Derive vault PDA (proposal is the owner, nonce=proposalId)\n    const [vaultPda] = deriveVaultPDA(proposalPda, proposalId, this.vault.programId);\n\n    // Derive conditional mints for initial 2 options\n    const [condBaseMint0] = deriveConditionalMint(vaultPda, VaultType.Base, 0, this.vault.programId);\n    const [condBaseMint1] = deriveConditionalMint(vaultPda, VaultType.Base, 1, this.vault.programId);\n    const [condQuoteMint0] = deriveConditionalMint(vaultPda, VaultType.Quote, 0, this.vault.programId);\n    const [condQuoteMint1] = deriveConditionalMint(vaultPda, VaultType.Quote, 1, this.vault.programId);\n\n    // Derive pool PDAs for initial 2 options (proposal is admin, mintA=condQuote, mintB=condBase)\n    const [pool0] = derivePoolPDA(proposalPda, condQuoteMint0, condBaseMint0, this.amm.programId);\n    const [pool1] = derivePoolPDA(proposalPda, condQuoteMint1, condBaseMint1, this.amm.programId);\n\n    // Derive reserves and fee vaults\n    const [reserveA0] = deriveReservePDA(pool0, condQuoteMint0, this.amm.programId);\n    const [reserveB0] = deriveReservePDA(pool0, condBaseMint0, this.amm.programId);\n    const [feeVault0] = deriveFeeVaultPDA(pool0, this.amm.programId);\n    const [reserveA1] = deriveReservePDA(pool1, condQuoteMint1, this.amm.programId);\n    const [reserveB1] = deriveReservePDA(pool1, condBaseMint1, this.amm.programId);\n    const [feeVault1] = deriveFeeVaultPDA(pool1, this.amm.programId);\n\n    // Vault token accounts\n    const baseTokenAcc = getAssociatedTokenAddressSync(moderator.baseMint, vaultPda, true);\n    const quoteTokenAcc = getAssociatedTokenAddressSync(moderator.quoteMint, vaultPda, true);\n\n    // Build remaining accounts in expected order (see initialize_proposal.rs)\n    const remainingAccounts = [\n      { pubkey: moderator.baseMint, isSigner: false, isWritable: false },      // 0: base_mint\n      { pubkey: moderator.quoteMint, isSigner: false, isWritable: false },     // 1: quote_mint\n      { pubkey: vaultPda, isSigner: false, isWritable: true },                 // 2: vault\n      { pubkey: baseTokenAcc, isSigner: false, isWritable: true },             // 3: base_token_acc\n      { pubkey: quoteTokenAcc, isSigner: false, isWritable: true },            // 4: quote_token_acc\n      { pubkey: condBaseMint0, isSigner: false, isWritable: true },            // 5: cond_base_mint_0\n      { pubkey: condBaseMint1, isSigner: false, isWritable: true },            // 6: cond_base_mint_1\n      { pubkey: condQuoteMint0, isSigner: false, isWritable: true },           // 7: cond_quote_mint_0\n      { pubkey: condQuoteMint1, isSigner: false, isWritable: true },           // 8: cond_quote_mint_1\n      { pubkey: pool0, isSigner: false, isWritable: true },                    // 9: pool_0\n      { pubkey: reserveA0, isSigner: false, isWritable: true },                // 10: reserve_a_0\n      { pubkey: reserveB0, isSigner: false, isWritable: true },                // 11: reserve_b_0\n      { pubkey: FEE_AUTHORITY, isSigner: false, isWritable: false },           // 12: fee_authority\n      { pubkey: feeVault0, isSigner: false, isWritable: true },                // 13: fee_vault_0\n      { pubkey: pool1, isSigner: false, isWritable: true },                    // 14: pool_1\n      { pubkey: reserveA1, isSigner: false, isWritable: true },                // 15: reserve_a_1\n      { pubkey: reserveB1, isSigner: false, isWritable: true },                // 16: reserve_b_1\n      { pubkey: feeVault1, isSigner: false, isWritable: true },                // 17: fee_vault_1\n    ];\n\n    const builder = initializeProposal(\n      this.program,\n      creator,\n      moderatorPda,\n      proposalPda,\n      proposalParams,\n      metadata ?? null,\n      remainingAccounts\n    ).preInstructions(this.maybeAddComputeBudget(options));\n\n    return {\n      builder,\n      proposalPda,\n      proposalId,\n      vaultPda,\n      pools: [pool0, pool1],\n      condBaseMints: [condBaseMint0, condBaseMint1],\n      condQuoteMints: [condQuoteMint0, condQuoteMint1],\n    };\n  }\n\n  async addOption(creator: PublicKey, proposalPda: PublicKey, options?: TxOptions) {\n    const proposal = await this.fetchProposal(proposalPda);\n    const optionIndex = proposal.numOptions;\n\n    // Derive new conditional mints\n    const [condBaseMint] = deriveConditionalMint(proposal.vault, VaultType.Base, optionIndex, this.vault.programId);\n    const [condQuoteMint] = deriveConditionalMint(proposal.vault, VaultType.Quote, optionIndex, this.vault.programId);\n\n    // Derive pool PDA\n    const [pool] = derivePoolPDA(proposalPda, condQuoteMint, condBaseMint, this.amm.programId);\n    const [reserveA] = deriveReservePDA(pool, condQuoteMint, this.amm.programId);\n    const [reserveB] = deriveReservePDA(pool, condBaseMint, this.amm.programId);\n    const [feeVault] = deriveFeeVaultPDA(pool, this.amm.programId);\n\n    // Build remaining accounts (see add_option.rs)\n    const remainingAccounts = [\n      { pubkey: proposal.vault, isSigner: false, isWritable: true },           // 0: vault\n      { pubkey: condBaseMint, isSigner: false, isWritable: true },             // 1: cond_base_mint\n      { pubkey: condQuoteMint, isSigner: false, isWritable: true },            // 2: cond_quote_mint\n      { pubkey: pool, isSigner: false, isWritable: true },                     // 3: pool\n      { pubkey: reserveA, isSigner: false, isWritable: true },                 // 4: reserve_a\n      { pubkey: reserveB, isSigner: false, isWritable: true },                 // 5: reserve_b\n      { pubkey: FEE_AUTHORITY, isSigner: false, isWritable: false },           // 6: fee_authority\n      { pubkey: feeVault, isSigner: false, isWritable: true },                 // 7: fee_vault\n    ];\n\n    const builder = addOption(this.program, creator, proposalPda, remainingAccounts)\n      .preInstructions(this.maybeAddComputeBudget(options));\n\n    return { builder, optionIndex, pool, condBaseMint, condQuoteMint };\n  }\n\n  async launchProposal(\n    creator: PublicKey,\n    proposalPda: PublicKey,\n    baseAmount: BN | number,\n    quoteAmount: BN | number,\n    options?: TxOptions\n  ) {\n    const proposal = await this.fetchProposal(proposalPda);\n    const vault = await this.vault.fetchVault(proposal.vault);\n    const numOptions = proposal.numOptions;\n\n    // Slice arrays to numOptions (fixed-size arrays from Rust include empty slots)\n    const condBaseMints = vault.condBaseMints.slice(0, numOptions);\n    const condQuoteMints = vault.condQuoteMints.slice(0, numOptions);\n\n    // Pre-create conditional ATAs for 3+ options to avoid exceeding the\n    // 64 instruction trace limit. Each ATA creation via vault deposit adds\n    // 5 inner instructions; with 4 options that's 40 extra instructions.\n    const shouldEnsureATAs = options?.ensureATAs ?? (numOptions >= 3);\n    if (shouldEnsureATAs) {\n      await this._createConditionalATAs(creator, condBaseMints, condQuoteMints);\n    }\n    const pools = proposal.pools.slice(0, numOptions);\n\n    // Derive all user conditional token ATAs\n    const userCondBaseATAs = condBaseMints.map((m) => getAssociatedTokenAddressSync(m, creator));\n    const userCondQuoteATAs = condQuoteMints.map((m) => getAssociatedTokenAddressSync(m, creator));\n\n    // Derive reserve accounts for each pool\n    const reservesA: PublicKey[] = [];\n    const reservesB: PublicKey[] = [];\n    for (let i = 0; i < numOptions; i++) {\n      const [resA] = deriveReservePDA(pools[i], condQuoteMints[i], this.amm.programId);\n      const [resB] = deriveReservePDA(pools[i], condBaseMints[i], this.amm.programId);\n      reservesA.push(resA);\n      reservesB.push(resB);\n    }\n\n    // Build remaining accounts (see launch_proposal.rs)\n    // Layout: 6 fixed + 7*N variable\n    const remainingAccounts: { pubkey: PublicKey; isSigner: boolean; isWritable: boolean }[] = [\n      { pubkey: vault.baseMint.address, isSigner: false, isWritable: false },                              // 0: base_mint\n      { pubkey: vault.quoteMint.address, isSigner: false, isWritable: false },                             // 1: quote_mint\n      { pubkey: getAssociatedTokenAddressSync(vault.baseMint.address, proposal.vault, true), isSigner: false, isWritable: true },   // 2: vault_base_ata\n      { pubkey: getAssociatedTokenAddressSync(vault.quoteMint.address, proposal.vault, true), isSigner: false, isWritable: true },  // 3: vault_quote_ata\n      { pubkey: getAssociatedTokenAddressSync(vault.baseMint.address, creator), isSigner: false, isWritable: true },  // 4: user_base_ata\n      { pubkey: getAssociatedTokenAddressSync(vault.quoteMint.address, creator), isSigner: false, isWritable: true }, // 5: user_quote_ata\n    ];\n\n    // 6..6+N: cond_base_mints\n    for (const mint of condBaseMints) {\n      remainingAccounts.push({ pubkey: mint, isSigner: false, isWritable: true });\n    }\n    // 6+N..6+2N: cond_quote_mints\n    for (const mint of condQuoteMints) {\n      remainingAccounts.push({ pubkey: mint, isSigner: false, isWritable: true });\n    }\n    // 6+2N..6+3N: user_cond_base_atas\n    for (const ata of userCondBaseATAs) {\n      remainingAccounts.push({ pubkey: ata, isSigner: false, isWritable: true });\n    }\n    // 6+3N..6+4N: user_cond_quote_atas\n    for (const ata of userCondQuoteATAs) {\n      remainingAccounts.push({ pubkey: ata, isSigner: false, isWritable: true });\n    }\n    // 6+4N..6+5N: pools\n    for (const pool of pools) {\n      remainingAccounts.push({ pubkey: pool, isSigner: false, isWritable: true });\n    }\n    // 6+5N..6+6N: reserves_a\n    for (const res of reservesA) {\n      remainingAccounts.push({ pubkey: res, isSigner: false, isWritable: true });\n    }\n    // 6+6N..6+7N: reserves_b\n    for (const res of reservesB) {\n      remainingAccounts.push({ pubkey: res, isSigner: false, isWritable: true });\n    }\n\n    const builder = launchProposal(\n      this.program,\n      creator,\n      proposalPda,\n      proposal.vault,\n      baseAmount,\n      quoteAmount,\n      remainingAccounts\n    ).preInstructions(this.maybeAddComputeBudget(options));\n\n    return { builder };\n  }\n\n  /**\n   * Pre-creates all conditional token ATAs for a user before launching a proposal.\n   *\n   * This is REQUIRED for proposals with 3+ options to avoid exceeding Solana's\n   * max instruction trace length limit (64 instructions). The vault's deposit CPI\n   * creates ATAs on-the-fly, each requiring 5 inner instructions. For 4 options:\n   * 8 ATAs × 5 = 40 extra instructions, pushing the total over 64.\n   *\n   * Pre-creating ATAs eliminates this overhead, reducing the trace to ~32 instructions.\n   *\n   * @param creator - The user who will receive conditional tokens\n   * @param proposalPda - The proposal PDA (must be initialized but not launched)\n   * @returns Transaction signature\n   */\n  async ensureConditionalATAs(\n    creator: PublicKey,\n    proposalPda: PublicKey,\n  ): Promise<string> {\n    const proposal = await this.fetchProposal(proposalPda);\n    const vault = await this.vault.fetchVault(proposal.vault);\n    const condBaseMints = vault.condBaseMints.slice(0, proposal.numOptions);\n    const condQuoteMints = vault.condQuoteMints.slice(0, proposal.numOptions);\n    return this._createConditionalATAs(creator, condBaseMints, condQuoteMints);\n  }\n\n  /**\n   * Internal helper to create conditional ATAs given mint arrays.\n   * Used by both ensureConditionalATAs and launchProposal to avoid redundant fetches.\n   */\n  private async _createConditionalATAs(\n    creator: PublicKey,\n    condBaseMints: PublicKey[],\n    condQuoteMints: PublicKey[],\n  ): Promise<string> {\n    const provider = this.program.provider as AnchorProvider;\n\n    // Build ATA creation instructions (idempotent - won't fail if exists)\n    const instructions: TransactionInstruction[] = [];\n    for (let i = 0; i < condBaseMints.length; i++) {\n      const userCondBaseAta = getAssociatedTokenAddressSync(condBaseMints[i], creator);\n      const userCondQuoteAta = getAssociatedTokenAddressSync(condQuoteMints[i], creator);\n\n      instructions.push(\n        createAssociatedTokenAccountIdempotentInstruction(\n          creator,\n          userCondBaseAta,\n          creator,\n          condBaseMints[i]\n        ),\n        createAssociatedTokenAccountIdempotentInstruction(\n          creator,\n          userCondQuoteAta,\n          creator,\n          condQuoteMints[i]\n        )\n      );\n    }\n\n    // Send transaction\n    const tx = new Transaction().add(...instructions);\n    return provider.sendAndConfirm(tx);\n  }\n\n  async finalizeProposal(signer: PublicKey, proposalPda: PublicKey, options?: TxOptions) {\n    const proposal = await this.fetchProposal(proposalPda);\n    const vault = await this.vault.fetchVault(proposal.vault);\n    const numOptions = proposal.numOptions;\n\n    // Build remaining accounts (3 per pool: pool, reserve_a, reserve_b)\n    const remainingAccounts: { pubkey: PublicKey; isSigner: boolean; isWritable: boolean }[] = [];\n\n    for (let i = 0; i < numOptions; i++) {\n      const pool = proposal.pools[i];\n      const [reserveA] = deriveReservePDA(pool, vault.condQuoteMints[i], this.amm.programId);\n      const [reserveB] = deriveReservePDA(pool, vault.condBaseMints[i], this.amm.programId);\n\n      remainingAccounts.push({ pubkey: pool, isSigner: false, isWritable: true });\n      remainingAccounts.push({ pubkey: reserveA, isSigner: false, isWritable: false });\n      remainingAccounts.push({ pubkey: reserveB, isSigner: false, isWritable: false });\n    }\n\n    const builder = finalizeProposal(\n      this.program,\n      signer,\n      proposalPda,\n      proposal.vault,\n      remainingAccounts\n    ).preInstructions(this.maybeAddComputeBudget(options));\n\n    return { builder };\n  }\n\n  async redeemLiquidity(creator: PublicKey, proposalPda: PublicKey, options?: TxOptions) {\n    const proposal = await this.fetchProposal(proposalPda);\n    const vault = await this.vault.fetchVault(proposal.vault);\n    const numOptions = proposal.numOptions;\n\n    const { winningIdx } = parseProposalState(proposal.state);\n    if (winningIdx === null) {\n      throw new Error(\"Proposal not finalized\");\n    }\n    const winningPool = proposal.pools[winningIdx];\n\n    // Derive winning pool reserves\n    const [reserveA] = deriveReservePDA(winningPool, vault.condQuoteMints[winningIdx], this.amm.programId);\n    const [reserveB] = deriveReservePDA(winningPool, vault.condBaseMints[winningIdx], this.amm.programId);\n\n    // User's winning conditional token ATAs\n    const creatorCondQuoteAta = getAssociatedTokenAddressSync(vault.condQuoteMints[winningIdx], creator);\n    const creatorCondBaseAta = getAssociatedTokenAddressSync(vault.condBaseMints[winningIdx], creator);\n\n    // Build remaining accounts (see redeem_liquidity.rs)\n    const remainingAccounts: { pubkey: PublicKey; isSigner: boolean; isWritable: boolean }[] = [\n      // remove_liquidity accounts (0-3)\n      { pubkey: reserveA, isSigner: false, isWritable: true },\n      { pubkey: reserveB, isSigner: false, isWritable: true },\n      { pubkey: creatorCondQuoteAta, isSigner: false, isWritable: true },\n      { pubkey: creatorCondBaseAta, isSigner: false, isWritable: true },\n\n      // redeem_winnings base fixed accounts (4-6)\n      { pubkey: vault.baseMint.address, isSigner: false, isWritable: false },\n      { pubkey: getAssociatedTokenAddressSync(vault.baseMint.address, proposal.vault, true), isSigner: false, isWritable: true },\n      { pubkey: getAssociatedTokenAddressSync(vault.baseMint.address, creator), isSigner: false, isWritable: true },\n    ];\n\n    // redeem_winnings base remaining (7..7+2N): [cond_base_mint_i, user_cond_base_ata_i]\n    for (let i = 0; i < numOptions; i++) {\n      remainingAccounts.push({ pubkey: vault.condBaseMints[i], isSigner: false, isWritable: true });\n      remainingAccounts.push({ pubkey: getAssociatedTokenAddressSync(vault.condBaseMints[i], creator), isSigner: false, isWritable: true });\n    }\n\n    // redeem_winnings quote fixed accounts\n    remainingAccounts.push({ pubkey: vault.quoteMint.address, isSigner: false, isWritable: false });\n    remainingAccounts.push({ pubkey: getAssociatedTokenAddressSync(vault.quoteMint.address, proposal.vault, true), isSigner: false, isWritable: true });\n    remainingAccounts.push({ pubkey: getAssociatedTokenAddressSync(vault.quoteMint.address, creator), isSigner: false, isWritable: true });\n\n    // redeem_winnings quote remaining: [cond_quote_mint_i, user_cond_quote_ata_i]\n    for (let i = 0; i < numOptions; i++) {\n      remainingAccounts.push({ pubkey: vault.condQuoteMints[i], isSigner: false, isWritable: true });\n      remainingAccounts.push({ pubkey: getAssociatedTokenAddressSync(vault.condQuoteMints[i], creator), isSigner: false, isWritable: true });\n    }\n\n    const builder = redeemLiquidity(\n      this.program,\n      creator,\n      proposalPda,\n      proposal.vault,\n      winningPool,\n      remainingAccounts\n    ).preInstructions(this.maybeAddComputeBudget(options));\n\n    return { builder, numOptions };\n  }\n\n  /**\n   * Creates an Address Lookup Table for redemption operations.\n   * Required for proposals with 3+ options to avoid exceeding transaction size limits.\n   *\n   * @param creator - The user redeeming (creator of proposal or liquidity provider)\n   * @param proposalPda - The proposal PDA\n   * @returns ALT address\n   */\n  async createRedemptionALT(\n    creator: PublicKey,\n    proposalPda: PublicKey,\n  ): Promise<{ altAddress: PublicKey }> {\n    const provider = this.program.provider as AnchorProvider;\n    const proposal = await this.fetchProposal(proposalPda);\n    const vault = await this.vault.fetchVault(proposal.vault);\n    const numOptions = proposal.numOptions;\n\n    const { winningIdx } = parseProposalState(proposal.state);\n    if (winningIdx === null) {\n      throw new Error(\"Proposal not finalized\");\n    }\n\n    const addresses: PublicKey[] = [\n      // Programs\n      this.programId,\n      this.vault.programId,\n      this.amm.programId,\n      SystemProgram.programId,\n      TOKEN_PROGRAM_ID,\n      ASSOCIATED_TOKEN_PROGRAM_ID,\n      // Core accounts\n      proposalPda,\n      proposal.vault,\n      proposal.moderator,\n      vault.baseMint.address,\n      vault.quoteMint.address,\n      // Winning pool and reserves\n      proposal.pools[winningIdx],\n      // Vault token accounts\n      getAssociatedTokenAddressSync(vault.baseMint.address, proposal.vault, true),\n      getAssociatedTokenAddressSync(vault.quoteMint.address, proposal.vault, true),\n      // Creator's base/quote ATAs\n      getAssociatedTokenAddressSync(vault.baseMint.address, creator),\n      getAssociatedTokenAddressSync(vault.quoteMint.address, creator),\n    ];\n\n    // Winning pool reserves\n    const [reserveA] = deriveReservePDA(proposal.pools[winningIdx], vault.condQuoteMints[winningIdx], this.amm.programId);\n    const [reserveB] = deriveReservePDA(proposal.pools[winningIdx], vault.condBaseMints[winningIdx], this.amm.programId);\n    addresses.push(reserveA, reserveB);\n\n    // Per-option accounts (conditional mints and user ATAs)\n    for (let i = 0; i < numOptions; i++) {\n      addresses.push(\n        vault.condBaseMints[i],\n        vault.condQuoteMints[i],\n        getAssociatedTokenAddressSync(vault.condBaseMints[i], creator),\n        getAssociatedTokenAddressSync(vault.condQuoteMints[i], creator),\n      );\n    }\n\n    // Get recent slot for ALT creation\n    const slot = await provider.connection.getSlot(\"finalized\");\n\n    const [createIx, altAddress] = AddressLookupTableProgram.createLookupTable({\n      authority: creator,\n      payer: creator,\n      recentSlot: slot,\n    });\n\n    // Create ALT\n    const createTx = new Transaction().add(createIx);\n    createTx.recentBlockhash = (await provider.connection.getLatestBlockhash()).blockhash;\n    createTx.feePayer = creator;\n    const signedTx = await provider.wallet.signTransaction(createTx);\n    const sig = await provider.connection.sendRawTransaction(signedTx.serialize(), {\n      skipPreflight: true,\n    });\n    await provider.connection.confirmTransaction(sig, \"confirmed\");\n\n    // Extend ALT with addresses\n    const CHUNK_SIZE = 20;\n    for (let i = 0; i < addresses.length; i += CHUNK_SIZE) {\n      const chunk = addresses.slice(i, i + CHUNK_SIZE);\n      const extendIx = AddressLookupTableProgram.extendLookupTable({\n        payer: creator,\n        authority: creator,\n        lookupTable: altAddress,\n        addresses: chunk,\n      });\n      const extendTx = new Transaction().add(extendIx);\n      await provider.sendAndConfirm(extendTx);\n    }\n\n    return { altAddress };\n  }\n\n  /**\n   * Builds a versioned transaction for redeeming liquidity with ALT.\n   * Required for proposals with 3+ options to avoid exceeding transaction size limits.\n   *\n   * @param creator - The user redeeming\n   * @param proposalPda - The proposal PDA\n   * @param altAddress - Optional ALT address (will be created if not provided for 3+ options)\n   * @returns Unsigned versioned transaction, ALT address, and number of options\n   */\n  async redeemLiquidityVersioned(\n    creator: PublicKey,\n    proposalPda: PublicKey,\n    altAddress?: PublicKey,\n  ): Promise<{ versionedTx: VersionedTransaction; altAddress: PublicKey; numOptions: number }> {\n    const provider = this.program.provider as AnchorProvider;\n    const { builder, numOptions } = await this.redeemLiquidity(creator, proposalPda);\n\n    // Create ALT if not provided and needed\n    let altPubkey = altAddress;\n    let verifiedALT: AddressLookupTableAccount | null = null;\n\n    if (!altPubkey && numOptions >= 3) {\n      console.log(`  Creating redemption ALT for ${numOptions} options...`);\n      const result = await this.createRedemptionALT(creator, proposalPda);\n      altPubkey = result.altAddress;\n      console.log(`  ✓ Redemption ALT created: ${altPubkey.toBase58()}`);\n\n      // Wait for ALT to be fully available with all addresses\n      // Use longer delays after extending to ensure propagation\n      console.log(`  Waiting for ALT propagation...`);\n      const expectedAddresses = 18 + (numOptions * 4); // Base accounts + per-option accounts\n      let attempts = 0;\n\n      // Initial delay after extension\n      await new Promise(resolve => setTimeout(resolve, 2000));\n\n      while (attempts < 30) {\n        const altAccount = await provider.connection.getAddressLookupTable(altPubkey, {\n          commitment: 'confirmed',\n        });\n        if (altAccount.value) {\n          const addressCount = altAccount.value.state.addresses.length;\n          console.log(`  Attempt ${attempts + 1}: ALT has ${addressCount}/${expectedAddresses} addresses`);\n          if (addressCount >= expectedAddresses) {\n            verifiedALT = altAccount.value;\n            console.log(`  ✓ ALT verified with ${addressCount} addresses`);\n            break;\n          }\n        }\n        await new Promise(resolve => setTimeout(resolve, 1000));\n        attempts++;\n      }\n\n      if (!verifiedALT) {\n        throw new Error(`ALT failed to populate with expected ${expectedAddresses} addresses after ${attempts} attempts`);\n      }\n    }\n\n    if (!altPubkey) {\n      throw new Error(\"ALT address required for multi-option redemption\");\n    }\n\n    // Fetch ALT if we don't have it verified already\n    if (!verifiedALT) {\n      verifiedALT = await this.fetchALT(altPubkey);\n    }\n\n    // Build instruction\n    const instruction = await builder.instruction();\n    const computeBudgetIx = ComputeBudgetProgram.setComputeUnitLimit({ units: 500_000 });\n\n    // Get fresh blockhash\n    const { blockhash } = await provider.connection.getLatestBlockhash();\n\n    // Build versioned transaction using the verified ALT (no re-fetch)\n    const versionedTx = this.buildVersionedTxWithALT(\n      creator,\n      [computeBudgetIx, instruction],\n      verifiedALT,\n      blockhash,\n    );\n\n    // Return the versioned transaction for the caller to sign and send\n    // This allows the caller to use their own signing mechanism (e.g., keypair.sign)\n    return { versionedTx, altAddress: altPubkey, numOptions };\n  }\n\n  /**\n   * Helper to send a signed versioned transaction.\n   */\n  async sendVersionedTransaction(\n    signedTx: VersionedTransaction,\n  ): Promise<string> {\n    const provider = this.program.provider as AnchorProvider;\n    const signature = await provider.connection.sendTransaction(signedTx, {\n      skipPreflight: false,\n      preflightCommitment: 'confirmed',\n    });\n    await provider.connection.confirmTransaction(signature, 'confirmed');\n    return signature;\n  }\n\n  /* Address Lookup Table */\n\n  async createProposalALT(\n    creator: PublicKey,\n    moderatorPda: PublicKey,\n    numOptions: number = 2,\n  ): Promise<{ altAddress: PublicKey }> {\n    const provider = this.program.provider as AnchorProvider;\n    const moderator = await this.fetchModerator(moderatorPda);\n    const proposalId = moderator.proposalIdCounter;\n    const [proposalPda] = this.deriveProposalPDA(moderatorPda, proposalId);\n    const [vaultPda] = deriveVaultPDA(proposalPda, proposalId, this.vault.programId);\n\n    const addresses: PublicKey[] = [\n      // Programs\n      this.programId,\n      this.vault.programId,\n      this.amm.programId,\n      SystemProgram.programId,\n      TOKEN_PROGRAM_ID,\n      ASSOCIATED_TOKEN_PROGRAM_ID,\n      // Core accounts\n      moderatorPda,\n      proposalPda,\n      vaultPda,\n      moderator.baseMint,\n      moderator.quoteMint,\n      FEE_AUTHORITY,\n      // Vault token accounts\n      getAssociatedTokenAddressSync(moderator.baseMint, vaultPda, true),\n      getAssociatedTokenAddressSync(moderator.quoteMint, vaultPda, true),\n      // Creator's base/quote ATAs\n      getAssociatedTokenAddressSync(moderator.baseMint, creator),\n      getAssociatedTokenAddressSync(moderator.quoteMint, creator),\n    ];\n\n    // Per-option accounts\n    for (let i = 0; i < numOptions; i++) {\n      const [condBaseMint] = deriveConditionalMint(vaultPda, VaultType.Base, i, this.vault.programId);\n      const [condQuoteMint] = deriveConditionalMint(vaultPda, VaultType.Quote, i, this.vault.programId);\n      const [pool] = derivePoolPDA(proposalPda, condQuoteMint, condBaseMint, this.amm.programId);\n      const [reserveA] = deriveReservePDA(pool, condQuoteMint, this.amm.programId);\n      const [reserveB] = deriveReservePDA(pool, condBaseMint, this.amm.programId);\n      const [feeVault] = deriveFeeVaultPDA(pool, this.amm.programId);\n\n      addresses.push(\n        condBaseMint,\n        condQuoteMint,\n        pool,\n        reserveA,\n        reserveB,\n        feeVault,\n        // Creator's conditional token ATAs\n        getAssociatedTokenAddressSync(condBaseMint, creator),\n        getAssociatedTokenAddressSync(condQuoteMint, creator),\n      );\n    }\n\n    // Get the most recent slot using \"finalized\" commitment for stability\n    const slot = await provider.connection.getSlot(\"finalized\");\n\n    const [createIx, altAddress] = AddressLookupTableProgram.createLookupTable({\n      authority: creator,\n      payer: creator,\n      recentSlot: slot,\n    });\n\n    // Send create transaction immediately, skip preflight to avoid slot timing issues\n    const createTx = new Transaction().add(createIx);\n    createTx.recentBlockhash = (await provider.connection.getLatestBlockhash()).blockhash;\n    createTx.feePayer = creator;\n    const signedTx = await provider.wallet.signTransaction(createTx);\n    const sig = await provider.connection.sendRawTransaction(signedTx.serialize(), {\n      skipPreflight: true,\n    });\n    await provider.connection.confirmTransaction(sig, \"confirmed\");\n\n    // Split addresses into chunks to avoid transaction size limits\n    // Each address is 32 bytes, ~20 addresses per extend instruction is safe\n    const CHUNK_SIZE = 20;\n    for (let i = 0; i < addresses.length; i += CHUNK_SIZE) {\n      const chunk = addresses.slice(i, i + CHUNK_SIZE);\n      const extendIx = AddressLookupTableProgram.extendLookupTable({\n        payer: creator,\n        authority: creator,\n        lookupTable: altAddress,\n        addresses: chunk,\n      });\n      const extendTx = new Transaction().add(extendIx);\n      await provider.sendAndConfirm(extendTx);\n    }\n\n    return { altAddress };\n  }\n\n  async fetchALT(altAddress: PublicKey): Promise<AddressLookupTableAccount> {\n    const alt = await this.program.provider.connection.getAddressLookupTable(altAddress);\n    if (!alt.value) {\n      throw new Error(\"ALT not found\");\n    }\n    return alt.value;\n  }\n\n  async buildVersionedTx(\n    payer: PublicKey,\n    instructions: TransactionInstruction[],\n    altAddress: PublicKey,\n  ): Promise<VersionedTransaction> {\n    const provider = this.program.provider as AnchorProvider;\n    const alt = await this.fetchALT(altAddress);\n    const { blockhash } = await provider.connection.getLatestBlockhash();\n    return this.buildVersionedTxWithALT(payer, instructions, alt, blockhash);\n  }\n\n  buildVersionedTxWithALT(\n    payer: PublicKey,\n    instructions: TransactionInstruction[],\n    alt: AddressLookupTableAccount,\n    blockhash: string,\n  ): VersionedTransaction {\n    const message = new TransactionMessage({\n      payerKey: payer,\n      recentBlockhash: blockhash,\n      instructions,\n    }).compileToV0Message([alt]);\n\n    return new VersionedTransaction(message);\n  }\n\n  /* DAO Methods */\n\n  deriveMintCreateKeyPDA(daoPda: PublicKey, name: string): [PublicKey, number] {\n    return deriveMintCreateKeyPDA(daoPda, name, this.programId);\n  }\n\n  private async fetchSquadsProgramConfig() {\n    const [programConfigPda] = multisig.getProgramConfigPda({\n      programId: SQUADS_PROGRAM_ID,\n    });\n    const programConfig = await multisig.accounts.ProgramConfig.fromAccountAddress(\n      this.program.provider.connection,\n      programConfigPda\n    );\n    return {\n      programConfig: programConfigPda,\n      programConfigTreasury: programConfig.treasury,\n    };\n  }\n\n  private deriveMultisigPda(createKey: PublicKey): PublicKey {\n    const [multisigPda] = multisig.getMultisigPda({\n      createKey,\n      programId: SQUADS_PROGRAM_ID,\n    });\n    return multisigPda;\n  }\n\n  async initializeParentDAO(\n    admin: PublicKey,\n    parentAdmin: PublicKey,\n    name: string,\n    baseMint: PublicKey,\n    quoteMint: PublicKey,\n    treasuryCosigner: PublicKey,\n    pool: PublicKey,\n    poolType: PoolType,\n    options?: TxOptions\n  ) {\n    const [daoPda] = this.deriveDAOPDA(name);\n    const [moderatorPda] = this.deriveModeratorPDA(name);\n    const [mintCreateKeyPda] = this.deriveMintCreateKeyPDA(daoPda, name);\n\n    // Derive Squads accounts (single RPC call)\n    const squadsConfig = await this.fetchSquadsProgramConfig();\n    const treasuryMultisigPda = this.deriveMultisigPda(daoPda);\n    const mintMultisigPda = this.deriveMultisigPda(mintCreateKeyPda);\n\n    const builder = initializeParentDAO(\n      this.program,\n      admin,\n      parentAdmin,\n      daoPda,\n      moderatorPda,\n      baseMint,\n      quoteMint,\n      squadsConfig.programConfig,\n      squadsConfig.programConfigTreasury,\n      treasuryMultisigPda,\n      mintMultisigPda,\n      mintCreateKeyPda,\n      SQUADS_PROGRAM_ID,\n      name,\n      treasuryCosigner,\n      pool,\n      poolType\n    ).preInstructions(this.maybeAddComputeBudget(options));\n\n    return {\n      builder,\n      daoPda,\n      moderatorPda,\n      treasuryMultisig: treasuryMultisigPda,\n      mintMultisig: mintMultisigPda,\n    };\n  }\n\n  async initializeChildDAO(\n    admin: PublicKey,\n    parentAdmin: PublicKey,\n    parentDaoName: string,\n    name: string,\n    tokenMint: PublicKey,\n    treasuryCosigner: PublicKey,\n    options?: TxOptions\n  ) {\n    const [daoPda] = this.deriveDAOPDA(name);\n    const [parentDaoPda] = this.deriveDAOPDA(parentDaoName);\n    const [mintCreateKeyPda] = this.deriveMintCreateKeyPDA(daoPda, name);\n\n    // Derive Squads accounts (single RPC call)\n    const squadsConfig = await this.fetchSquadsProgramConfig();\n    const treasuryMultisigPda = this.deriveMultisigPda(daoPda);\n    const mintMultisigPda = this.deriveMultisigPda(mintCreateKeyPda);\n\n    const builder = initializeChildDAO(\n      this.program,\n      admin,\n      parentAdmin,\n      daoPda,\n      parentDaoPda,\n      tokenMint,\n      squadsConfig.programConfig,\n      squadsConfig.programConfigTreasury,\n      treasuryMultisigPda,\n      mintMultisigPda,\n      mintCreateKeyPda,\n      SQUADS_PROGRAM_ID,\n      name,\n      treasuryCosigner\n    ).preInstructions(this.maybeAddComputeBudget(options));\n\n    return {\n      builder,\n      daoPda,\n      parentDaoPda,\n      treasuryMultisig: treasuryMultisigPda,\n      mintMultisig: mintMultisigPda,\n    };\n  }\n\n  async upgradeDAO(\n    admin: PublicKey,\n    parentAdmin: PublicKey,\n    daoName: string,\n    parentDaoName: string,\n    baseMint: PublicKey,\n    quoteMint: PublicKey,\n    pool: PublicKey,\n    poolType: PoolType,\n    options?: TxOptions\n  ) {\n    const [daoPda] = this.deriveDAOPDA(daoName);\n    const [parentDaoPda] = this.deriveDAOPDA(parentDaoName);\n    const [moderatorPda] = this.deriveModeratorPDA(daoName);\n\n    const builder = upgradeDAO(\n      this.program,\n      admin,\n      parentAdmin,\n      daoPda,\n      parentDaoPda,\n      moderatorPda,\n      baseMint,\n      quoteMint,\n      pool,\n      poolType\n    ).preInstructions(this.maybeAddComputeBudget(options));\n\n    return { builder, daoPda, moderatorPda };\n  }\n}\n"]}
688
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"client.js","sourceRoot":"","sources":["../../src/futarchy/client.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * High-level client for the Futarchy program.\n * Handles account derivation, instruction building, and transaction composition.\n */\n\nimport { Program, AnchorProvider, BN } from \"@coral-xyz/anchor\";\nimport {\n  PublicKey,\n  ComputeBudgetProgram,\n  AddressLookupTableProgram,\n  AddressLookupTableAccount,\n  SystemProgram,\n  Transaction,\n  TransactionInstruction,\n  TransactionMessage,\n  VersionedTransaction,\n} from \"@solana/web3.js\";\nimport {\n  getAssociatedTokenAddressSync,\n  TOKEN_PROGRAM_ID,\n  ASSOCIATED_TOKEN_PROGRAM_ID,\n  createAssociatedTokenAccountIdempotentInstruction,\n} from \"@solana/spl-token\";\nimport { PROGRAM_ID, SQUADS_PROGRAM_ID } from \"./constants\";\nimport {\n  Futarchy,\n  DAOAccount,\n  ModeratorAccount,\n  ProposalAccount,\n  ProposalParams,\n  PoolType,\n} from \"./types\";\nimport {\n  deriveDAOPDA,\n  deriveModeratorPDA,\n  deriveProposalPDA,\n  deriveMintCreateKeyPDA,\n  fetchDAOAccount,\n  fetchModeratorAccount,\n  fetchProposalAccount,\n  parseProposalState,\n  isProposalExpired,\n  getTimeRemaining,\n} from \"./utils\";\nimport {\n  initializeModerator,\n  initializeProposal,\n  addOption,\n  launchProposal,\n  finalizeProposal,\n  redeemLiquidity,\n  addHistoricalProposal,\n  initializeParentDAO,\n  initializeChildDAO,\n  upgradeDAO,\n} from \"./instructions\";\nimport { TxOptions } from \"../utils\";\n\nimport { VaultClient, deriveVaultPDA, deriveConditionalMint, VaultType } from \"../vault\";\nimport { AMMClient, derivePoolPDA, deriveReservePDA, deriveFeeVaultPDA, FEE_AUTHORITY } from \"../amm\";\n\nimport { FutarchyIDL } from \"../generated/idls\";\nimport * as multisig from \"@sqds/multisig\";\n\nconst DEFAULT_COMPUTE_UNITS = 500_000;\n\nexport class FutarchyClient {\n  public program: Program<Futarchy>;\n  public programId: PublicKey;\n  public vault: VaultClient;\n  public amm: AMMClient;\n  private defaultComputeUnits: number;\n\n  constructor(provider: AnchorProvider, programId?: PublicKey, computeUnits?: number) {\n    this.programId = programId ?? PROGRAM_ID;\n    this.program = new Program(FutarchyIDL as Futarchy, provider);\n    this.vault = new VaultClient(provider);\n    this.amm = new AMMClient(provider);\n    this.defaultComputeUnits = computeUnits ?? DEFAULT_COMPUTE_UNITS;\n  }\n\n  /* PDA Helpers */\n\n  deriveDAOPDA(name: string): [PublicKey, number] {\n    return deriveDAOPDA(name, this.programId);\n  }\n\n  deriveModeratorPDA(name: string): [PublicKey, number] {\n    return deriveModeratorPDA(name, this.programId);\n  }\n\n  deriveProposalPDA(moderator: PublicKey, proposalId: number): [PublicKey, number] {\n    return deriveProposalPDA(moderator, proposalId, this.programId);\n  }\n\n  /* Fetchers */\n\n  async fetchDAO(daoPda: PublicKey): Promise<DAOAccount> {\n    return fetchDAOAccount(this.program, daoPda);\n  }\n\n  async fetchModerator(moderatorPda: PublicKey): Promise<ModeratorAccount> {\n    return fetchModeratorAccount(this.program, moderatorPda);\n  }\n\n  async fetchProposal(proposalPda: PublicKey): Promise<ProposalAccount> {\n    return fetchProposalAccount(this.program, proposalPda);\n  }\n\n  /* Proposal Helpers */\n\n  isProposalExpired(proposal: ProposalAccount): boolean {\n    return isProposalExpired(proposal);\n  }\n\n  getTimeRemaining(proposal: ProposalAccount): number {\n    return getTimeRemaining(proposal);\n  }\n\n  private getComputeUnits(options?: TxOptions): number {\n    return options?.computeUnits ?? this.defaultComputeUnits;\n  }\n\n  private maybeAddComputeBudget(options?: TxOptions): TransactionInstruction[] {\n    if (options?.includeCuBudget === false) {\n      return [];\n    }\n    return [ComputeBudgetProgram.setComputeUnitLimit({ units: this.getComputeUnits(options) })];\n  }\n\n  /* Instruction Builders */\n\n  async initializeModerator(\n    admin: PublicKey,\n    baseMint: PublicKey,\n    quoteMint: PublicKey,\n    name: string,\n    options?: TxOptions\n  ) {\n    const [moderatorPda] = this.deriveModeratorPDA(name);\n\n    const builder = initializeModerator(\n      this.program,\n      admin,\n      baseMint,\n      quoteMint,\n      moderatorPda,\n      name\n    ).preInstructions(this.maybeAddComputeBudget(options));\n\n    return { builder, moderatorPda, name };\n  }\n\n  async addHistoricalProposal(\n    admin: PublicKey,\n    moderatorPda: PublicKey,\n    numOptions: number,\n    winningIdx: number,\n    length: number,\n    createdAt: BN | number,\n    options?: TxOptions\n  ) {\n    const moderator = await this.fetchModerator(moderatorPda);\n    const proposalId = moderator.proposalIdCounter;\n    const [proposalPda] = this.deriveProposalPDA(moderatorPda, proposalId);\n\n    const builder = addHistoricalProposal(\n      this.program,\n      admin,\n      moderatorPda,\n      proposalPda,\n      numOptions,\n      winningIdx,\n      length,\n      createdAt\n    ).preInstructions(this.maybeAddComputeBudget(options));\n\n    return { builder, proposalPda, proposalId };\n  }\n\n  async initializeProposal(\n    creator: PublicKey,\n    moderatorPda: PublicKey,\n    proposalParams: ProposalParams,\n    metadata?: string,\n    options?: TxOptions\n  ) {\n    const moderator = await this.fetchModerator(moderatorPda);\n    const proposalId = moderator.proposalIdCounter;\n    const [proposalPda] = this.deriveProposalPDA(moderatorPda, proposalId);\n\n    // Derive vault PDA (proposal is the owner, nonce=proposalId)\n    const [vaultPda] = deriveVaultPDA(proposalPda, proposalId, this.vault.programId);\n\n    // Derive conditional mints for initial 2 options\n    const [condBaseMint0] = deriveConditionalMint(vaultPda, VaultType.Base, 0, this.vault.programId);\n    const [condBaseMint1] = deriveConditionalMint(vaultPda, VaultType.Base, 1, this.vault.programId);\n    const [condQuoteMint0] = deriveConditionalMint(vaultPda, VaultType.Quote, 0, this.vault.programId);\n    const [condQuoteMint1] = deriveConditionalMint(vaultPda, VaultType.Quote, 1, this.vault.programId);\n\n    // Derive pool PDAs for initial 2 options (proposal is admin, mintA=condQuote, mintB=condBase)\n    const [pool0] = derivePoolPDA(proposalPda, condQuoteMint0, condBaseMint0, this.amm.programId);\n    const [pool1] = derivePoolPDA(proposalPda, condQuoteMint1, condBaseMint1, this.amm.programId);\n\n    // Derive reserves and fee vaults\n    const [reserveA0] = deriveReservePDA(pool0, condQuoteMint0, this.amm.programId);\n    const [reserveB0] = deriveReservePDA(pool0, condBaseMint0, this.amm.programId);\n    const [feeVault0] = deriveFeeVaultPDA(pool0, this.amm.programId);\n    const [reserveA1] = deriveReservePDA(pool1, condQuoteMint1, this.amm.programId);\n    const [reserveB1] = deriveReservePDA(pool1, condBaseMint1, this.amm.programId);\n    const [feeVault1] = deriveFeeVaultPDA(pool1, this.amm.programId);\n\n    // Vault token accounts\n    const baseTokenAcc = getAssociatedTokenAddressSync(moderator.baseMint, vaultPda, true);\n    const quoteTokenAcc = getAssociatedTokenAddressSync(moderator.quoteMint, vaultPda, true);\n\n    // Build remaining accounts in expected order (see initialize_proposal.rs)\n    const remainingAccounts = [\n      { pubkey: moderator.baseMint, isSigner: false, isWritable: false },      // 0: base_mint\n      { pubkey: moderator.quoteMint, isSigner: false, isWritable: false },     // 1: quote_mint\n      { pubkey: vaultPda, isSigner: false, isWritable: true },                 // 2: vault\n      { pubkey: baseTokenAcc, isSigner: false, isWritable: true },             // 3: base_token_acc\n      { pubkey: quoteTokenAcc, isSigner: false, isWritable: true },            // 4: quote_token_acc\n      { pubkey: condBaseMint0, isSigner: false, isWritable: true },            // 5: cond_base_mint_0\n      { pubkey: condBaseMint1, isSigner: false, isWritable: true },            // 6: cond_base_mint_1\n      { pubkey: condQuoteMint0, isSigner: false, isWritable: true },           // 7: cond_quote_mint_0\n      { pubkey: condQuoteMint1, isSigner: false, isWritable: true },           // 8: cond_quote_mint_1\n      { pubkey: pool0, isSigner: false, isWritable: true },                    // 9: pool_0\n      { pubkey: reserveA0, isSigner: false, isWritable: true },                // 10: reserve_a_0\n      { pubkey: reserveB0, isSigner: false, isWritable: true },                // 11: reserve_b_0\n      { pubkey: FEE_AUTHORITY, isSigner: false, isWritable: false },           // 12: fee_authority\n      { pubkey: feeVault0, isSigner: false, isWritable: true },                // 13: fee_vault_0\n      { pubkey: pool1, isSigner: false, isWritable: true },                    // 14: pool_1\n      { pubkey: reserveA1, isSigner: false, isWritable: true },                // 15: reserve_a_1\n      { pubkey: reserveB1, isSigner: false, isWritable: true },                // 16: reserve_b_1\n      { pubkey: feeVault1, isSigner: false, isWritable: true },                // 17: fee_vault_1\n    ];\n\n    const builder = initializeProposal(\n      this.program,\n      creator,\n      moderatorPda,\n      proposalPda,\n      proposalParams,\n      metadata ?? null,\n      remainingAccounts\n    ).preInstructions(this.maybeAddComputeBudget(options));\n\n    return {\n      builder,\n      proposalPda,\n      proposalId,\n      vaultPda,\n      pools: [pool0, pool1],\n      condBaseMints: [condBaseMint0, condBaseMint1],\n      condQuoteMints: [condQuoteMint0, condQuoteMint1],\n    };\n  }\n\n  async addOption(creator: PublicKey, proposalPda: PublicKey, options?: TxOptions) {\n    const proposal = await this.fetchProposal(proposalPda);\n    const optionIndex = proposal.numOptions;\n\n    // Derive new conditional mints\n    const [condBaseMint] = deriveConditionalMint(proposal.vault, VaultType.Base, optionIndex, this.vault.programId);\n    const [condQuoteMint] = deriveConditionalMint(proposal.vault, VaultType.Quote, optionIndex, this.vault.programId);\n\n    // Derive pool PDA\n    const [pool] = derivePoolPDA(proposalPda, condQuoteMint, condBaseMint, this.amm.programId);\n    const [reserveA] = deriveReservePDA(pool, condQuoteMint, this.amm.programId);\n    const [reserveB] = deriveReservePDA(pool, condBaseMint, this.amm.programId);\n    const [feeVault] = deriveFeeVaultPDA(pool, this.amm.programId);\n\n    // Build remaining accounts (see add_option.rs)\n    const remainingAccounts = [\n      { pubkey: proposal.vault, isSigner: false, isWritable: true },           // 0: vault\n      { pubkey: condBaseMint, isSigner: false, isWritable: true },             // 1: cond_base_mint\n      { pubkey: condQuoteMint, isSigner: false, isWritable: true },            // 2: cond_quote_mint\n      { pubkey: pool, isSigner: false, isWritable: true },                     // 3: pool\n      { pubkey: reserveA, isSigner: false, isWritable: true },                 // 4: reserve_a\n      { pubkey: reserveB, isSigner: false, isWritable: true },                 // 5: reserve_b\n      { pubkey: FEE_AUTHORITY, isSigner: false, isWritable: false },           // 6: fee_authority\n      { pubkey: feeVault, isSigner: false, isWritable: true },                 // 7: fee_vault\n    ];\n\n    const builder = addOption(this.program, creator, proposalPda, remainingAccounts)\n      .preInstructions(this.maybeAddComputeBudget(options));\n\n    return { builder, optionIndex, pool, condBaseMint, condQuoteMint };\n  }\n\n  async launchProposal(\n    creator: PublicKey,\n    proposalPda: PublicKey,\n    baseAmount: BN | number,\n    quoteAmount: BN | number,\n    options?: TxOptions\n  ) {\n    const proposal = await this.fetchProposal(proposalPda);\n    const vault = await this.vault.fetchVault(proposal.vault);\n    const numOptions = proposal.numOptions;\n\n    // Slice arrays to numOptions (fixed-size arrays from Rust include empty slots)\n    const condBaseMints = vault.condBaseMints.slice(0, numOptions);\n    const condQuoteMints = vault.condQuoteMints.slice(0, numOptions);\n\n    // Pre-create conditional ATAs for 3+ options to avoid exceeding the\n    // 64 instruction trace limit. Each ATA creation via vault deposit adds\n    // 5 inner instructions; with 4 options that's 40 extra instructions.\n    const shouldEnsureATAs = options?.ensureATAs ?? (numOptions >= 3);\n    if (shouldEnsureATAs) {\n      await this._createConditionalATAs(creator, condBaseMints, condQuoteMints);\n    }\n    const pools = proposal.pools.slice(0, numOptions);\n\n    // Derive all user conditional token ATAs\n    const userCondBaseATAs = condBaseMints.map((m) => getAssociatedTokenAddressSync(m, creator));\n    const userCondQuoteATAs = condQuoteMints.map((m) => getAssociatedTokenAddressSync(m, creator));\n\n    // Derive reserve accounts for each pool\n    const reservesA: PublicKey[] = [];\n    const reservesB: PublicKey[] = [];\n    for (let i = 0; i < numOptions; i++) {\n      const [resA] = deriveReservePDA(pools[i], condQuoteMints[i], this.amm.programId);\n      const [resB] = deriveReservePDA(pools[i], condBaseMints[i], this.amm.programId);\n      reservesA.push(resA);\n      reservesB.push(resB);\n    }\n\n    // Build remaining accounts (see launch_proposal.rs)\n    // Layout: 6 fixed + 7*N variable\n    const remainingAccounts: { pubkey: PublicKey; isSigner: boolean; isWritable: boolean }[] = [\n      { pubkey: vault.baseMint.address, isSigner: false, isWritable: false },                              // 0: base_mint\n      { pubkey: vault.quoteMint.address, isSigner: false, isWritable: false },                             // 1: quote_mint\n      { pubkey: getAssociatedTokenAddressSync(vault.baseMint.address, proposal.vault, true), isSigner: false, isWritable: true },   // 2: vault_base_ata\n      { pubkey: getAssociatedTokenAddressSync(vault.quoteMint.address, proposal.vault, true), isSigner: false, isWritable: true },  // 3: vault_quote_ata\n      { pubkey: getAssociatedTokenAddressSync(vault.baseMint.address, creator), isSigner: false, isWritable: true },  // 4: user_base_ata\n      { pubkey: getAssociatedTokenAddressSync(vault.quoteMint.address, creator), isSigner: false, isWritable: true }, // 5: user_quote_ata\n    ];\n\n    // 6..6+N: cond_base_mints\n    for (const mint of condBaseMints) {\n      remainingAccounts.push({ pubkey: mint, isSigner: false, isWritable: true });\n    }\n    // 6+N..6+2N: cond_quote_mints\n    for (const mint of condQuoteMints) {\n      remainingAccounts.push({ pubkey: mint, isSigner: false, isWritable: true });\n    }\n    // 6+2N..6+3N: user_cond_base_atas\n    for (const ata of userCondBaseATAs) {\n      remainingAccounts.push({ pubkey: ata, isSigner: false, isWritable: true });\n    }\n    // 6+3N..6+4N: user_cond_quote_atas\n    for (const ata of userCondQuoteATAs) {\n      remainingAccounts.push({ pubkey: ata, isSigner: false, isWritable: true });\n    }\n    // 6+4N..6+5N: pools\n    for (const pool of pools) {\n      remainingAccounts.push({ pubkey: pool, isSigner: false, isWritable: true });\n    }\n    // 6+5N..6+6N: reserves_a\n    for (const res of reservesA) {\n      remainingAccounts.push({ pubkey: res, isSigner: false, isWritable: true });\n    }\n    // 6+6N..6+7N: reserves_b\n    for (const res of reservesB) {\n      remainingAccounts.push({ pubkey: res, isSigner: false, isWritable: true });\n    }\n\n    const builder = launchProposal(\n      this.program,\n      creator,\n      proposalPda,\n      proposal.vault,\n      baseAmount,\n      quoteAmount,\n      remainingAccounts\n    ).preInstructions(this.maybeAddComputeBudget(options));\n\n    return { builder };\n  }\n\n  /**\n   * Pre-creates all conditional token ATAs for a user before launching a proposal.\n   *\n   * This is REQUIRED for proposals with 3+ options to avoid exceeding Solana's\n   * max instruction trace length limit (64 instructions). The vault's deposit CPI\n   * creates ATAs on-the-fly, each requiring 5 inner instructions. For 4 options:\n   * 8 ATAs × 5 = 40 extra instructions, pushing the total over 64.\n   *\n   * Pre-creating ATAs eliminates this overhead, reducing the trace to ~32 instructions.\n   *\n   * @param creator - The user who will receive conditional tokens\n   * @param proposalPda - The proposal PDA (must be initialized but not launched)\n   * @returns Transaction signature\n   */\n  async ensureConditionalATAs(\n    creator: PublicKey,\n    proposalPda: PublicKey,\n  ): Promise<string> {\n    const proposal = await this.fetchProposal(proposalPda);\n    const vault = await this.vault.fetchVault(proposal.vault);\n    const condBaseMints = vault.condBaseMints.slice(0, proposal.numOptions);\n    const condQuoteMints = vault.condQuoteMints.slice(0, proposal.numOptions);\n    return this._createConditionalATAs(creator, condBaseMints, condQuoteMints);\n  }\n\n  /**\n   * Internal helper to create conditional ATAs given mint arrays.\n   * Used by both ensureConditionalATAs and launchProposal to avoid redundant fetches.\n   */\n  private async _createConditionalATAs(\n    creator: PublicKey,\n    condBaseMints: PublicKey[],\n    condQuoteMints: PublicKey[],\n  ): Promise<string> {\n    const provider = this.program.provider as AnchorProvider;\n\n    // Build ATA creation instructions (idempotent - won't fail if exists)\n    const instructions: TransactionInstruction[] = [];\n    for (let i = 0; i < condBaseMints.length; i++) {\n      const userCondBaseAta = getAssociatedTokenAddressSync(condBaseMints[i], creator);\n      const userCondQuoteAta = getAssociatedTokenAddressSync(condQuoteMints[i], creator);\n\n      instructions.push(\n        createAssociatedTokenAccountIdempotentInstruction(\n          creator,\n          userCondBaseAta,\n          creator,\n          condBaseMints[i]\n        ),\n        createAssociatedTokenAccountIdempotentInstruction(\n          creator,\n          userCondQuoteAta,\n          creator,\n          condQuoteMints[i]\n        )\n      );\n    }\n\n    // Send transaction\n    const tx = new Transaction().add(...instructions);\n    return provider.sendAndConfirm(tx);\n  }\n\n  async finalizeProposal(signer: PublicKey, proposalPda: PublicKey, options?: TxOptions) {\n    const proposal = await this.fetchProposal(proposalPda);\n    const vault = await this.vault.fetchVault(proposal.vault);\n    const numOptions = proposal.numOptions;\n\n    // Build remaining accounts (3 per pool: pool, reserve_a, reserve_b)\n    const remainingAccounts: { pubkey: PublicKey; isSigner: boolean; isWritable: boolean }[] = [];\n\n    for (let i = 0; i < numOptions; i++) {\n      const pool = proposal.pools[i];\n      const [reserveA] = deriveReservePDA(pool, vault.condQuoteMints[i], this.amm.programId);\n      const [reserveB] = deriveReservePDA(pool, vault.condBaseMints[i], this.amm.programId);\n\n      remainingAccounts.push({ pubkey: pool, isSigner: false, isWritable: true });\n      remainingAccounts.push({ pubkey: reserveA, isSigner: false, isWritable: false });\n      remainingAccounts.push({ pubkey: reserveB, isSigner: false, isWritable: false });\n    }\n\n    const builder = finalizeProposal(\n      this.program,\n      signer,\n      proposalPda,\n      proposal.vault,\n      remainingAccounts\n    ).preInstructions(this.maybeAddComputeBudget(options));\n\n    return { builder };\n  }\n\n  async redeemLiquidity(creator: PublicKey, proposalPda: PublicKey, options?: TxOptions) {\n    const proposal = await this.fetchProposal(proposalPda);\n    const vault = await this.vault.fetchVault(proposal.vault);\n    const numOptions = proposal.numOptions;\n\n    const { winningIdx } = parseProposalState(proposal.state);\n    if (winningIdx === null) {\n      throw new Error(\"Proposal not finalized\");\n    }\n    const winningPool = proposal.pools[winningIdx];\n\n    // Derive winning pool reserves\n    const [reserveA] = deriveReservePDA(winningPool, vault.condQuoteMints[winningIdx], this.amm.programId);\n    const [reserveB] = deriveReservePDA(winningPool, vault.condBaseMints[winningIdx], this.amm.programId);\n\n    // User's winning conditional token ATAs\n    const creatorCondQuoteAta = getAssociatedTokenAddressSync(vault.condQuoteMints[winningIdx], creator);\n    const creatorCondBaseAta = getAssociatedTokenAddressSync(vault.condBaseMints[winningIdx], creator);\n\n    // Build remaining accounts (see redeem_liquidity.rs)\n    const remainingAccounts: { pubkey: PublicKey; isSigner: boolean; isWritable: boolean }[] = [\n      // remove_liquidity accounts (0-3)\n      { pubkey: reserveA, isSigner: false, isWritable: true },\n      { pubkey: reserveB, isSigner: false, isWritable: true },\n      { pubkey: creatorCondQuoteAta, isSigner: false, isWritable: true },\n      { pubkey: creatorCondBaseAta, isSigner: false, isWritable: true },\n\n      // redeem_winnings base fixed accounts (4-6)\n      { pubkey: vault.baseMint.address, isSigner: false, isWritable: false },\n      { pubkey: getAssociatedTokenAddressSync(vault.baseMint.address, proposal.vault, true), isSigner: false, isWritable: true },\n      { pubkey: getAssociatedTokenAddressSync(vault.baseMint.address, creator), isSigner: false, isWritable: true },\n    ];\n\n    // redeem_winnings base remaining (7..7+2N): [cond_base_mint_i, user_cond_base_ata_i]\n    for (let i = 0; i < numOptions; i++) {\n      remainingAccounts.push({ pubkey: vault.condBaseMints[i], isSigner: false, isWritable: true });\n      remainingAccounts.push({ pubkey: getAssociatedTokenAddressSync(vault.condBaseMints[i], creator), isSigner: false, isWritable: true });\n    }\n\n    // redeem_winnings quote fixed accounts\n    remainingAccounts.push({ pubkey: vault.quoteMint.address, isSigner: false, isWritable: false });\n    remainingAccounts.push({ pubkey: getAssociatedTokenAddressSync(vault.quoteMint.address, proposal.vault, true), isSigner: false, isWritable: true });\n    remainingAccounts.push({ pubkey: getAssociatedTokenAddressSync(vault.quoteMint.address, creator), isSigner: false, isWritable: true });\n\n    // redeem_winnings quote remaining: [cond_quote_mint_i, user_cond_quote_ata_i]\n    for (let i = 0; i < numOptions; i++) {\n      remainingAccounts.push({ pubkey: vault.condQuoteMints[i], isSigner: false, isWritable: true });\n      remainingAccounts.push({ pubkey: getAssociatedTokenAddressSync(vault.condQuoteMints[i], creator), isSigner: false, isWritable: true });\n    }\n\n    const builder = redeemLiquidity(\n      this.program,\n      creator,\n      proposalPda,\n      proposal.vault,\n      winningPool,\n      remainingAccounts\n    ).preInstructions(this.maybeAddComputeBudget(options));\n\n    return { builder, numOptions };\n  }\n\n  /**\n   * Creates an Address Lookup Table for redemption operations.\n   * Required for proposals with 3+ options to avoid exceeding transaction size limits.\n   *\n   * @param creator - The user redeeming (creator of proposal or liquidity provider)\n   * @param proposalPda - The proposal PDA\n   * @returns ALT address\n   */\n  async createRedemptionALT(\n    creator: PublicKey,\n    proposalPda: PublicKey,\n  ): Promise<{ altAddress: PublicKey }> {\n    const provider = this.program.provider as AnchorProvider;\n    const proposal = await this.fetchProposal(proposalPda);\n    const vault = await this.vault.fetchVault(proposal.vault);\n    const numOptions = proposal.numOptions;\n\n    const { winningIdx } = parseProposalState(proposal.state);\n    if (winningIdx === null) {\n      throw new Error(\"Proposal not finalized\");\n    }\n\n    const addresses: PublicKey[] = [\n      // Programs\n      this.programId,\n      this.vault.programId,\n      this.amm.programId,\n      SystemProgram.programId,\n      TOKEN_PROGRAM_ID,\n      ASSOCIATED_TOKEN_PROGRAM_ID,\n      // Core accounts\n      proposalPda,\n      proposal.vault,\n      proposal.moderator,\n      vault.baseMint.address,\n      vault.quoteMint.address,\n      // Winning pool and reserves\n      proposal.pools[winningIdx],\n      // Vault token accounts\n      getAssociatedTokenAddressSync(vault.baseMint.address, proposal.vault, true),\n      getAssociatedTokenAddressSync(vault.quoteMint.address, proposal.vault, true),\n      // Creator's base/quote ATAs\n      getAssociatedTokenAddressSync(vault.baseMint.address, creator),\n      getAssociatedTokenAddressSync(vault.quoteMint.address, creator),\n    ];\n\n    // Winning pool reserves\n    const [reserveA] = deriveReservePDA(proposal.pools[winningIdx], vault.condQuoteMints[winningIdx], this.amm.programId);\n    const [reserveB] = deriveReservePDA(proposal.pools[winningIdx], vault.condBaseMints[winningIdx], this.amm.programId);\n    addresses.push(reserveA, reserveB);\n\n    // Per-option accounts (conditional mints and user ATAs)\n    for (let i = 0; i < numOptions; i++) {\n      addresses.push(\n        vault.condBaseMints[i],\n        vault.condQuoteMints[i],\n        getAssociatedTokenAddressSync(vault.condBaseMints[i], creator),\n        getAssociatedTokenAddressSync(vault.condQuoteMints[i], creator),\n      );\n    }\n\n    // Get recent slot for ALT creation\n    const slot = await provider.connection.getSlot(\"finalized\");\n\n    const [createIx, altAddress] = AddressLookupTableProgram.createLookupTable({\n      authority: creator,\n      payer: creator,\n      recentSlot: slot,\n    });\n\n    // Create ALT\n    const createTx = new Transaction().add(createIx);\n    createTx.recentBlockhash = (await provider.connection.getLatestBlockhash()).blockhash;\n    createTx.feePayer = creator;\n    const signedTx = await provider.wallet.signTransaction(createTx);\n    const sig = await provider.connection.sendRawTransaction(signedTx.serialize(), {\n      skipPreflight: true,\n    });\n    await provider.connection.confirmTransaction(sig, \"confirmed\");\n\n    // Extend ALT with addresses\n    // Use skipPreflight to avoid race condition where simulation sees stale state\n    // before previous extend has propagated (same pattern as CREATE above)\n    const CHUNK_SIZE = 20;\n    for (let i = 0; i < addresses.length; i += CHUNK_SIZE) {\n      const chunk = addresses.slice(i, i + CHUNK_SIZE);\n      const extendIx = AddressLookupTableProgram.extendLookupTable({\n        payer: creator,\n        authority: creator,\n        lookupTable: altAddress,\n        addresses: chunk,\n      });\n      const extendTx = new Transaction().add(extendIx);\n      extendTx.recentBlockhash = (await provider.connection.getLatestBlockhash()).blockhash;\n      extendTx.feePayer = creator;\n      const signedExtendTx = await provider.wallet.signTransaction(extendTx);\n      const extendSig = await provider.connection.sendRawTransaction(signedExtendTx.serialize(), {\n        skipPreflight: true,\n      });\n      await provider.connection.confirmTransaction(extendSig, \"confirmed\");\n    }\n\n    return { altAddress };\n  }\n\n  /**\n   * Builds a versioned transaction for redeeming liquidity with ALT.\n   * Required for proposals with 3+ options to avoid exceeding transaction size limits.\n   *\n   * @param creator - The user redeeming\n   * @param proposalPda - The proposal PDA\n   * @param altAddress - Optional ALT address (will be created if not provided for 3+ options)\n   * @returns Unsigned versioned transaction, ALT address, and number of options\n   */\n  async redeemLiquidityVersioned(\n    creator: PublicKey,\n    proposalPda: PublicKey,\n    altAddress?: PublicKey,\n  ): Promise<{ versionedTx: VersionedTransaction; altAddress: PublicKey; numOptions: number }> {\n    const provider = this.program.provider as AnchorProvider;\n    const { builder, numOptions } = await this.redeemLiquidity(creator, proposalPda);\n\n    // Create ALT if not provided and needed\n    let altPubkey = altAddress;\n    let verifiedALT: AddressLookupTableAccount | null = null;\n\n    if (!altPubkey && numOptions >= 3) {\n      console.log(`  Creating redemption ALT for ${numOptions} options...`);\n      const result = await this.createRedemptionALT(creator, proposalPda);\n      altPubkey = result.altAddress;\n      console.log(`  ✓ Redemption ALT created: ${altPubkey.toBase58()}`);\n\n      // Wait for ALT to be fully available with all addresses\n      // Use longer delays after extending to ensure propagation\n      console.log(`  Waiting for ALT propagation...`);\n      const expectedAddresses = 18 + (numOptions * 4); // Base accounts + per-option accounts\n      let attempts = 0;\n\n      // Initial delay after extension\n      await new Promise(resolve => setTimeout(resolve, 2000));\n\n      while (attempts < 30) {\n        const altAccount = await provider.connection.getAddressLookupTable(altPubkey, {\n          commitment: 'confirmed',\n        });\n        if (altAccount.value) {\n          const addressCount = altAccount.value.state.addresses.length;\n          console.log(`  Attempt ${attempts + 1}: ALT has ${addressCount}/${expectedAddresses} addresses`);\n          if (addressCount >= expectedAddresses) {\n            verifiedALT = altAccount.value;\n            console.log(`  ✓ ALT verified with ${addressCount} addresses`);\n            break;\n          }\n        }\n        await new Promise(resolve => setTimeout(resolve, 1000));\n        attempts++;\n      }\n\n      if (!verifiedALT) {\n        throw new Error(`ALT failed to populate with expected ${expectedAddresses} addresses after ${attempts} attempts`);\n      }\n    }\n\n    if (!altPubkey) {\n      throw new Error(\"ALT address required for multi-option redemption\");\n    }\n\n    // Fetch ALT if we don't have it verified already\n    if (!verifiedALT) {\n      verifiedALT = await this.fetchALT(altPubkey);\n    }\n\n    // Build instruction\n    const instruction = await builder.instruction();\n    const computeBudgetIx = ComputeBudgetProgram.setComputeUnitLimit({ units: 500_000 });\n\n    // Get fresh blockhash\n    const { blockhash } = await provider.connection.getLatestBlockhash();\n\n    // Build versioned transaction using the verified ALT (no re-fetch)\n    const versionedTx = this.buildVersionedTxWithALT(\n      creator,\n      [computeBudgetIx, instruction],\n      verifiedALT,\n      blockhash,\n    );\n\n    // Return the versioned transaction for the caller to sign and send\n    // This allows the caller to use their own signing mechanism (e.g., keypair.sign)\n    return { versionedTx, altAddress: altPubkey, numOptions };\n  }\n\n  /**\n   * Helper to send a signed versioned transaction.\n   */\n  async sendVersionedTransaction(\n    signedTx: VersionedTransaction,\n  ): Promise<string> {\n    const provider = this.program.provider as AnchorProvider;\n    const signature = await provider.connection.sendTransaction(signedTx, {\n      skipPreflight: false,\n      preflightCommitment: 'confirmed',\n    });\n    await provider.connection.confirmTransaction(signature, 'confirmed');\n    return signature;\n  }\n\n  /* Address Lookup Table */\n\n  async createProposalALT(\n    creator: PublicKey,\n    moderatorPda: PublicKey,\n    numOptions: number = 2,\n  ): Promise<{ altAddress: PublicKey }> {\n    const provider = this.program.provider as AnchorProvider;\n    const moderator = await this.fetchModerator(moderatorPda);\n    const proposalId = moderator.proposalIdCounter;\n    const [proposalPda] = this.deriveProposalPDA(moderatorPda, proposalId);\n    const [vaultPda] = deriveVaultPDA(proposalPda, proposalId, this.vault.programId);\n\n    const addresses: PublicKey[] = [\n      // Programs\n      this.programId,\n      this.vault.programId,\n      this.amm.programId,\n      SystemProgram.programId,\n      TOKEN_PROGRAM_ID,\n      ASSOCIATED_TOKEN_PROGRAM_ID,\n      // Core accounts\n      moderatorPda,\n      proposalPda,\n      vaultPda,\n      moderator.baseMint,\n      moderator.quoteMint,\n      FEE_AUTHORITY,\n      // Vault token accounts\n      getAssociatedTokenAddressSync(moderator.baseMint, vaultPda, true),\n      getAssociatedTokenAddressSync(moderator.quoteMint, vaultPda, true),\n      // Creator's base/quote ATAs\n      getAssociatedTokenAddressSync(moderator.baseMint, creator),\n      getAssociatedTokenAddressSync(moderator.quoteMint, creator),\n    ];\n\n    // Per-option accounts\n    for (let i = 0; i < numOptions; i++) {\n      const [condBaseMint] = deriveConditionalMint(vaultPda, VaultType.Base, i, this.vault.programId);\n      const [condQuoteMint] = deriveConditionalMint(vaultPda, VaultType.Quote, i, this.vault.programId);\n      const [pool] = derivePoolPDA(proposalPda, condQuoteMint, condBaseMint, this.amm.programId);\n      const [reserveA] = deriveReservePDA(pool, condQuoteMint, this.amm.programId);\n      const [reserveB] = deriveReservePDA(pool, condBaseMint, this.amm.programId);\n      const [feeVault] = deriveFeeVaultPDA(pool, this.amm.programId);\n\n      addresses.push(\n        condBaseMint,\n        condQuoteMint,\n        pool,\n        reserveA,\n        reserveB,\n        feeVault,\n        // Creator's conditional token ATAs\n        getAssociatedTokenAddressSync(condBaseMint, creator),\n        getAssociatedTokenAddressSync(condQuoteMint, creator),\n      );\n    }\n\n    // Get the most recent slot using \"finalized\" commitment for stability\n    const slot = await provider.connection.getSlot(\"finalized\");\n\n    const [createIx, altAddress] = AddressLookupTableProgram.createLookupTable({\n      authority: creator,\n      payer: creator,\n      recentSlot: slot,\n    });\n\n    // Send create transaction immediately, skip preflight to avoid slot timing issues\n    const createTx = new Transaction().add(createIx);\n    createTx.recentBlockhash = (await provider.connection.getLatestBlockhash()).blockhash;\n    createTx.feePayer = creator;\n    const signedTx = await provider.wallet.signTransaction(createTx);\n    const sig = await provider.connection.sendRawTransaction(signedTx.serialize(), {\n      skipPreflight: true,\n    });\n    await provider.connection.confirmTransaction(sig, \"confirmed\");\n\n    // Split addresses into chunks to avoid transaction size limits\n    // Each address is 32 bytes, ~20 addresses per extend instruction is safe\n    // Use skipPreflight to avoid race condition where simulation sees stale state\n    // before previous extend has propagated (same pattern as CREATE above)\n    const CHUNK_SIZE = 20;\n    for (let i = 0; i < addresses.length; i += CHUNK_SIZE) {\n      const chunk = addresses.slice(i, i + CHUNK_SIZE);\n      const extendIx = AddressLookupTableProgram.extendLookupTable({\n        payer: creator,\n        authority: creator,\n        lookupTable: altAddress,\n        addresses: chunk,\n      });\n      const extendTx = new Transaction().add(extendIx);\n      extendTx.recentBlockhash = (await provider.connection.getLatestBlockhash()).blockhash;\n      extendTx.feePayer = creator;\n      const signedExtendTx = await provider.wallet.signTransaction(extendTx);\n      const extendSig = await provider.connection.sendRawTransaction(signedExtendTx.serialize(), {\n        skipPreflight: true,\n      });\n      await provider.connection.confirmTransaction(extendSig, \"confirmed\");\n    }\n\n    return { altAddress };\n  }\n\n  async fetchALT(altAddress: PublicKey): Promise<AddressLookupTableAccount> {\n    const alt = await this.program.provider.connection.getAddressLookupTable(altAddress);\n    if (!alt.value) {\n      throw new Error(\"ALT not found\");\n    }\n    return alt.value;\n  }\n\n  async buildVersionedTx(\n    payer: PublicKey,\n    instructions: TransactionInstruction[],\n    altAddress: PublicKey,\n  ): Promise<VersionedTransaction> {\n    const provider = this.program.provider as AnchorProvider;\n    const alt = await this.fetchALT(altAddress);\n    const { blockhash } = await provider.connection.getLatestBlockhash();\n    return this.buildVersionedTxWithALT(payer, instructions, alt, blockhash);\n  }\n\n  buildVersionedTxWithALT(\n    payer: PublicKey,\n    instructions: TransactionInstruction[],\n    alt: AddressLookupTableAccount,\n    blockhash: string,\n  ): VersionedTransaction {\n    const message = new TransactionMessage({\n      payerKey: payer,\n      recentBlockhash: blockhash,\n      instructions,\n    }).compileToV0Message([alt]);\n\n    return new VersionedTransaction(message);\n  }\n\n  /* DAO Methods */\n\n  deriveMintCreateKeyPDA(daoPda: PublicKey, name: string): [PublicKey, number] {\n    return deriveMintCreateKeyPDA(daoPda, name, this.programId);\n  }\n\n  private async fetchSquadsProgramConfig() {\n    const [programConfigPda] = multisig.getProgramConfigPda({\n      programId: SQUADS_PROGRAM_ID,\n    });\n    const programConfig = await multisig.accounts.ProgramConfig.fromAccountAddress(\n      this.program.provider.connection,\n      programConfigPda\n    );\n    return {\n      programConfig: programConfigPda,\n      programConfigTreasury: programConfig.treasury,\n    };\n  }\n\n  private deriveMultisigPda(createKey: PublicKey): PublicKey {\n    const [multisigPda] = multisig.getMultisigPda({\n      createKey,\n      programId: SQUADS_PROGRAM_ID,\n    });\n    return multisigPda;\n  }\n\n  async initializeParentDAO(\n    admin: PublicKey,\n    parentAdmin: PublicKey,\n    name: string,\n    baseMint: PublicKey,\n    quoteMint: PublicKey,\n    treasuryCosigner: PublicKey,\n    pool: PublicKey,\n    poolType: PoolType,\n    options?: TxOptions\n  ) {\n    const [daoPda] = this.deriveDAOPDA(name);\n    const [moderatorPda] = this.deriveModeratorPDA(name);\n    const [mintCreateKeyPda] = this.deriveMintCreateKeyPDA(daoPda, name);\n\n    // Derive Squads accounts (single RPC call)\n    const squadsConfig = await this.fetchSquadsProgramConfig();\n    const treasuryMultisigPda = this.deriveMultisigPda(daoPda);\n    const mintMultisigPda = this.deriveMultisigPda(mintCreateKeyPda);\n\n    const builder = initializeParentDAO(\n      this.program,\n      admin,\n      parentAdmin,\n      daoPda,\n      moderatorPda,\n      baseMint,\n      quoteMint,\n      squadsConfig.programConfig,\n      squadsConfig.programConfigTreasury,\n      treasuryMultisigPda,\n      mintMultisigPda,\n      mintCreateKeyPda,\n      SQUADS_PROGRAM_ID,\n      name,\n      treasuryCosigner,\n      pool,\n      poolType\n    ).preInstructions(this.maybeAddComputeBudget(options));\n\n    return {\n      builder,\n      daoPda,\n      moderatorPda,\n      treasuryMultisig: treasuryMultisigPda,\n      mintMultisig: mintMultisigPda,\n    };\n  }\n\n  async initializeChildDAO(\n    admin: PublicKey,\n    parentAdmin: PublicKey,\n    parentDaoName: string,\n    name: string,\n    tokenMint: PublicKey,\n    treasuryCosigner: PublicKey,\n    options?: TxOptions\n  ) {\n    const [daoPda] = this.deriveDAOPDA(name);\n    const [parentDaoPda] = this.deriveDAOPDA(parentDaoName);\n    const [mintCreateKeyPda] = this.deriveMintCreateKeyPDA(daoPda, name);\n\n    // Derive Squads accounts (single RPC call)\n    const squadsConfig = await this.fetchSquadsProgramConfig();\n    const treasuryMultisigPda = this.deriveMultisigPda(daoPda);\n    const mintMultisigPda = this.deriveMultisigPda(mintCreateKeyPda);\n\n    const builder = initializeChildDAO(\n      this.program,\n      admin,\n      parentAdmin,\n      daoPda,\n      parentDaoPda,\n      tokenMint,\n      squadsConfig.programConfig,\n      squadsConfig.programConfigTreasury,\n      treasuryMultisigPda,\n      mintMultisigPda,\n      mintCreateKeyPda,\n      SQUADS_PROGRAM_ID,\n      name,\n      treasuryCosigner\n    ).preInstructions(this.maybeAddComputeBudget(options));\n\n    return {\n      builder,\n      daoPda,\n      parentDaoPda,\n      treasuryMultisig: treasuryMultisigPda,\n      mintMultisig: mintMultisigPda,\n    };\n  }\n\n  async upgradeDAO(\n    admin: PublicKey,\n    parentAdmin: PublicKey,\n    daoName: string,\n    parentDaoName: string,\n    baseMint: PublicKey,\n    quoteMint: PublicKey,\n    pool: PublicKey,\n    poolType: PoolType,\n    options?: TxOptions\n  ) {\n    const [daoPda] = this.deriveDAOPDA(daoName);\n    const [parentDaoPda] = this.deriveDAOPDA(parentDaoName);\n    const [moderatorPda] = this.deriveModeratorPDA(daoName);\n\n    const builder = upgradeDAO(\n      this.program,\n      admin,\n      parentAdmin,\n      daoPda,\n      parentDaoPda,\n      moderatorPda,\n      baseMint,\n      quoteMint,\n      pool,\n      poolType\n    ).preInstructions(this.maybeAddComputeBudget(options));\n\n    return { builder, daoPda, moderatorPda };\n  }\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@zcomb/programs-sdk",
3
- "version": "1.3.0",
3
+ "version": "1.5.0",
4
4
  "description": "SDK for ZCombinator Programs",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
package/src/amm/client.ts CHANGED
@@ -330,7 +330,7 @@ export class AMMClient {
330
330
  minOutputAmount: BN | number,
331
331
  options?: AmmActionOptions
332
332
  ) {
333
- const { autoWrapUnwrap = true, includeCuBudget = true, computeUnits } = options ?? {};
333
+ const { autoCreateTokenAccounts = true, includeCuBudget = true, computeUnits } = options ?? {};
334
334
 
335
335
  const pool = await this.fetchPool(poolPda);
336
336
  const [reserveA] = this.deriveReservePDA(poolPda, pool.mintA);
@@ -340,7 +340,6 @@ export class AMMClient {
340
340
  const traderAccountB = getAssociatedTokenAddressSync(pool.mintB, trader);
341
341
 
342
342
  const preIxs: TransactionInstruction[] = [];
343
- const postIxs: TransactionInstruction[] = [];
344
343
 
345
344
  if (includeCuBudget) {
346
345
  preIxs.push(
@@ -350,13 +349,7 @@ export class AMMClient {
350
349
  );
351
350
  }
352
351
 
353
- const inputMint = swapAToB ? pool.mintA : pool.mintB;
354
- const outputMint = swapAToB ? pool.mintB : pool.mintA;
355
- const inputAta = swapAToB ? traderAccountA : traderAccountB;
356
- const outputAta = swapAToB ? traderAccountB : traderAccountA;
357
-
358
- if (autoWrapUnwrap) {
359
- // Create ATAs idempotently
352
+ if (autoCreateTokenAccounts) {
360
353
  preIxs.push(
361
354
  createAssociatedTokenAccountIdempotentInstruction(
362
355
  trader,
@@ -371,24 +364,6 @@ export class AMMClient {
371
364
  pool.mintB
372
365
  )
373
366
  );
374
-
375
- // Wrap input SOL if needed
376
- if (inputMint.equals(NATIVE_MINT)) {
377
- const input = typeof inputAmount === "number" ? new BN(inputAmount) : inputAmount;
378
- preIxs.push(
379
- SystemProgram.transfer({
380
- fromPubkey: trader,
381
- toPubkey: inputAta,
382
- lamports: BigInt(input.toString()),
383
- }),
384
- createSyncNativeInstruction(inputAta)
385
- );
386
- }
387
-
388
- // Unwrap output SOL if needed
389
- if (outputMint.equals(NATIVE_MINT)) {
390
- postIxs.push(createCloseAccountInstruction(outputAta, trader, trader));
391
- }
392
367
  }
393
368
 
394
369
  let builder = swapIx(
@@ -408,9 +383,6 @@ export class AMMClient {
408
383
  if (preIxs.length > 0) {
409
384
  builder = builder.preInstructions(preIxs);
410
385
  }
411
- if (postIxs.length > 0) {
412
- builder = builder.postInstructions(postIxs);
413
- }
414
386
 
415
387
  return builder;
416
388
  }
@@ -434,8 +406,7 @@ export class AMMClient {
434
406
  * - Fetches current reserves and computes quote
435
407
  * - Calculates minOutput based on slippage tolerance
436
408
  * - Adds compute budget instruction (if includeCuBudget is true)
437
- * - Creates token accounts if they don't exist (if autoWrapUnwrap is true)
438
- * - Handles WSOL wrapping/unwrapping if needed (if autoWrapUnwrap is true)
409
+ * - Creates token accounts if they don't exist (if autoCreateTokenAccounts is true)
439
410
  */
440
411
  async swapWithSlippage(
441
412
  trader: PublicKey,
@@ -445,7 +416,7 @@ export class AMMClient {
445
416
  slippagePercent: number = 0.5,
446
417
  options?: AmmActionOptions
447
418
  ) {
448
- const { autoWrapUnwrap = true, includeCuBudget = true, computeUnits } = options ?? {};
419
+ const { autoCreateTokenAccounts = true, includeCuBudget = true, computeUnits } = options ?? {};
449
420
 
450
421
  const pool = await this.fetchPool(poolPda);
451
422
  const input = typeof inputAmount === "number" ? new BN(inputAmount) : inputAmount;
@@ -476,7 +447,6 @@ export class AMMClient {
476
447
  );
477
448
 
478
449
  const preIxs: TransactionInstruction[] = [];
479
- const postIxs: TransactionInstruction[] = [];
480
450
 
481
451
  if (includeCuBudget) {
482
452
  preIxs.push(
@@ -486,7 +456,7 @@ export class AMMClient {
486
456
  );
487
457
  }
488
458
 
489
- if (autoWrapUnwrap) {
459
+ if (autoCreateTokenAccounts) {
490
460
  preIxs.push(
491
461
  createAssociatedTokenAccountIdempotentInstruction(
492
462
  trader,
@@ -503,35 +473,9 @@ export class AMMClient {
503
473
  );
504
474
  }
505
475
 
506
- // Handle WSOL for input/output tokens
507
- const inputMint = swapAToB ? pool.mintA : pool.mintB;
508
- const outputMint = swapAToB ? pool.mintB : pool.mintA;
509
- const inputAta = swapAToB ? traderAccountA : traderAccountB;
510
- const outputAta = swapAToB ? traderAccountB : traderAccountA;
511
-
512
- if (autoWrapUnwrap && inputMint.equals(NATIVE_MINT)) {
513
- // Wrap SOL before swap
514
- preIxs.push(
515
- SystemProgram.transfer({
516
- fromPubkey: trader,
517
- toPubkey: inputAta,
518
- lamports: BigInt(input.toString()),
519
- }),
520
- createSyncNativeInstruction(inputAta)
521
- );
522
- }
523
-
524
- if (autoWrapUnwrap && outputMint.equals(NATIVE_MINT)) {
525
- // Unwrap SOL after swap
526
- postIxs.push(createCloseAccountInstruction(outputAta, trader, trader));
527
- }
528
-
529
476
  if (preIxs.length > 0) {
530
477
  builder = builder.preInstructions(preIxs);
531
478
  }
532
- if (postIxs.length > 0) {
533
- builder = builder.postInstructions(postIxs);
534
- }
535
479
 
536
480
  return {
537
481
  builder,
package/src/amm/types.ts CHANGED
@@ -57,5 +57,6 @@ export type AMMEvent =
57
57
  /* Options */
58
58
 
59
59
  export interface AmmActionOptions extends TxOptions {
60
- autoWrapUnwrap?: boolean; // Auto wrap/unwrap native SOL (default: true)
60
+ autoWrapUnwrap?: boolean; // Auto wrap/unwrap native SOL (default: true) - for liquidity operations
61
+ autoCreateTokenAccounts?: boolean; // Auto create token accounts (default: true) - for swaps
61
62
  }
@@ -615,6 +615,8 @@ export class FutarchyClient {
615
615
  await provider.connection.confirmTransaction(sig, "confirmed");
616
616
 
617
617
  // Extend ALT with addresses
618
+ // Use skipPreflight to avoid race condition where simulation sees stale state
619
+ // before previous extend has propagated (same pattern as CREATE above)
618
620
  const CHUNK_SIZE = 20;
619
621
  for (let i = 0; i < addresses.length; i += CHUNK_SIZE) {
620
622
  const chunk = addresses.slice(i, i + CHUNK_SIZE);
@@ -625,7 +627,13 @@ export class FutarchyClient {
625
627
  addresses: chunk,
626
628
  });
627
629
  const extendTx = new Transaction().add(extendIx);
628
- await provider.sendAndConfirm(extendTx);
630
+ extendTx.recentBlockhash = (await provider.connection.getLatestBlockhash()).blockhash;
631
+ extendTx.feePayer = creator;
632
+ const signedExtendTx = await provider.wallet.signTransaction(extendTx);
633
+ const extendSig = await provider.connection.sendRawTransaction(signedExtendTx.serialize(), {
634
+ skipPreflight: true,
635
+ });
636
+ await provider.connection.confirmTransaction(extendSig, "confirmed");
629
637
  }
630
638
 
631
639
  return { altAddress };
@@ -812,6 +820,8 @@ export class FutarchyClient {
812
820
 
813
821
  // Split addresses into chunks to avoid transaction size limits
814
822
  // Each address is 32 bytes, ~20 addresses per extend instruction is safe
823
+ // Use skipPreflight to avoid race condition where simulation sees stale state
824
+ // before previous extend has propagated (same pattern as CREATE above)
815
825
  const CHUNK_SIZE = 20;
816
826
  for (let i = 0; i < addresses.length; i += CHUNK_SIZE) {
817
827
  const chunk = addresses.slice(i, i + CHUNK_SIZE);
@@ -822,7 +832,13 @@ export class FutarchyClient {
822
832
  addresses: chunk,
823
833
  });
824
834
  const extendTx = new Transaction().add(extendIx);
825
- await provider.sendAndConfirm(extendTx);
835
+ extendTx.recentBlockhash = (await provider.connection.getLatestBlockhash()).blockhash;
836
+ extendTx.feePayer = creator;
837
+ const signedExtendTx = await provider.wallet.signTransaction(extendTx);
838
+ const extendSig = await provider.connection.sendRawTransaction(signedExtendTx.serialize(), {
839
+ skipPreflight: true,
840
+ });
841
+ await provider.connection.confirmTransaction(extendSig, "confirmed");
826
842
  }
827
843
 
828
844
  return { altAddress };