drama-pm-client 0.4.13 → 0.4.14
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.
- package/dist/index.d.ts +6 -0
- package/dist/index.js +46 -43
- package/package.json +1 -1
package/dist/index.d.ts
CHANGED
|
@@ -15,6 +15,12 @@ export interface PriorityFeeOptions {
|
|
|
15
15
|
/** Maximum compute units for the transaction (default: 200,000 for normal txs, 400,000 for complex ones) */
|
|
16
16
|
computeUnitLimit?: number;
|
|
17
17
|
}
|
|
18
|
+
/**
|
|
19
|
+
* Default priority fee options used when caller does not provide priorityFeeOptions.
|
|
20
|
+
* computeUnitPrice: 100,000 micro-lamports/CU — suitable for most network conditions.
|
|
21
|
+
* computeUnitLimit is not set here; each method applies its own default.
|
|
22
|
+
*/
|
|
23
|
+
export declare const DEFAULT_PRIORITY_FEE: PriorityFeeOptions;
|
|
18
24
|
export interface CreateMarketParams {
|
|
19
25
|
admin: PublicKey;
|
|
20
26
|
marketId: number | BN;
|
package/dist/index.js
CHANGED
|
@@ -6,6 +6,14 @@ import { IDL } from "./idl.js";
|
|
|
6
6
|
import { getGlobalConfigPda, getMarketPda, getMarketPdas, getVaultPda, NO_MINT_SEED, VAULT_SEED, YES_MINT_SEED } from "./utils.js";
|
|
7
7
|
export * from "./utils.js";
|
|
8
8
|
export { IDL };
|
|
9
|
+
/**
|
|
10
|
+
* Default priority fee options used when caller does not provide priorityFeeOptions.
|
|
11
|
+
* computeUnitPrice: 100,000 micro-lamports/CU — suitable for most network conditions.
|
|
12
|
+
* computeUnitLimit is not set here; each method applies its own default.
|
|
13
|
+
*/
|
|
14
|
+
export const DEFAULT_PRIORITY_FEE = {
|
|
15
|
+
computeUnitPrice: 100000,
|
|
16
|
+
};
|
|
9
17
|
export class DramaPmClient {
|
|
10
18
|
constructor(connection, wallet, programId) {
|
|
11
19
|
this.connection = connection;
|
|
@@ -212,19 +220,17 @@ export class DramaPmClient {
|
|
|
212
220
|
*/
|
|
213
221
|
async buildCreateMarketTx(params, priorityFeeOptions) {
|
|
214
222
|
const tx = new Transaction();
|
|
215
|
-
// Add priority fee instructions if
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
223
|
+
// Add priority fee instructions (use default if not provided)
|
|
224
|
+
const feeOpts = priorityFeeOptions ?? DEFAULT_PRIORITY_FEE;
|
|
225
|
+
// Set compute unit limit (createMarket is a complex tx, default to 400k)
|
|
226
|
+
const computeUnitLimit = feeOpts.computeUnitLimit ?? 400000;
|
|
227
|
+
tx.add(ComputeBudgetProgram.setComputeUnitLimit({
|
|
228
|
+
units: computeUnitLimit,
|
|
229
|
+
}));
|
|
230
|
+
if (feeOpts.computeUnitPrice !== undefined && feeOpts.computeUnitPrice > 0) {
|
|
231
|
+
tx.add(ComputeBudgetProgram.setComputeUnitPrice({
|
|
232
|
+
microLamports: feeOpts.computeUnitPrice,
|
|
221
233
|
}));
|
|
222
|
-
// Set compute unit price if specified
|
|
223
|
-
if (priorityFeeOptions.computeUnitPrice !== undefined && priorityFeeOptions.computeUnitPrice > 0) {
|
|
224
|
-
tx.add(ComputeBudgetProgram.setComputeUnitPrice({
|
|
225
|
-
microLamports: priorityFeeOptions.computeUnitPrice,
|
|
226
|
-
}));
|
|
227
|
-
}
|
|
228
234
|
}
|
|
229
235
|
const ix = await this.createMarket(params);
|
|
230
236
|
tx.add(ix);
|
|
@@ -765,17 +771,16 @@ export class DramaPmClient {
|
|
|
765
771
|
// allowOwnerOffCurve for multisig/PDA fee recipients
|
|
766
772
|
const feeRecipientToken = getAssociatedTokenAddressSync(marketInfo.bettingToken, feeRecipientAddress, true);
|
|
767
773
|
const tx = new Transaction();
|
|
768
|
-
// Add priority fee instructions if
|
|
769
|
-
|
|
770
|
-
|
|
771
|
-
|
|
772
|
-
|
|
774
|
+
// Add priority fee instructions (use default if not provided)
|
|
775
|
+
const feeOpts = priorityFeeOptions ?? DEFAULT_PRIORITY_FEE;
|
|
776
|
+
const computeUnitLimit = feeOpts.computeUnitLimit ?? 400000;
|
|
777
|
+
tx.add(ComputeBudgetProgram.setComputeUnitLimit({
|
|
778
|
+
units: computeUnitLimit,
|
|
779
|
+
}));
|
|
780
|
+
if (feeOpts.computeUnitPrice !== undefined && feeOpts.computeUnitPrice > 0) {
|
|
781
|
+
tx.add(ComputeBudgetProgram.setComputeUnitPrice({
|
|
782
|
+
microLamports: feeOpts.computeUnitPrice,
|
|
773
783
|
}));
|
|
774
|
-
if (priorityFeeOptions.computeUnitPrice !== undefined && priorityFeeOptions.computeUnitPrice > 0) {
|
|
775
|
-
tx.add(ComputeBudgetProgram.setComputeUnitPrice({
|
|
776
|
-
microLamports: priorityFeeOptions.computeUnitPrice,
|
|
777
|
-
}));
|
|
778
|
-
}
|
|
779
784
|
}
|
|
780
785
|
// Check if fee recipient token account exists and create if needed
|
|
781
786
|
const feeRecipientAtaExists = await this.ataExists(feeRecipientToken);
|
|
@@ -830,17 +835,16 @@ export class DramaPmClient {
|
|
|
830
835
|
// allowOwnerOffCurve for multisig/PDA fee recipients
|
|
831
836
|
const feeRecipientToken = getAssociatedTokenAddressSync(marketInfo.bettingToken, feeRecipientAddress, true);
|
|
832
837
|
const tx = new Transaction();
|
|
833
|
-
// Add priority fee instructions if
|
|
834
|
-
|
|
835
|
-
|
|
836
|
-
|
|
837
|
-
|
|
838
|
+
// Add priority fee instructions (use default if not provided)
|
|
839
|
+
const feeOpts = priorityFeeOptions ?? DEFAULT_PRIORITY_FEE;
|
|
840
|
+
const computeUnitLimit = feeOpts.computeUnitLimit ?? 400000;
|
|
841
|
+
tx.add(ComputeBudgetProgram.setComputeUnitLimit({
|
|
842
|
+
units: computeUnitLimit,
|
|
843
|
+
}));
|
|
844
|
+
if (feeOpts.computeUnitPrice !== undefined && feeOpts.computeUnitPrice > 0) {
|
|
845
|
+
tx.add(ComputeBudgetProgram.setComputeUnitPrice({
|
|
846
|
+
microLamports: feeOpts.computeUnitPrice,
|
|
838
847
|
}));
|
|
839
|
-
if (priorityFeeOptions.computeUnitPrice !== undefined && priorityFeeOptions.computeUnitPrice > 0) {
|
|
840
|
-
tx.add(ComputeBudgetProgram.setComputeUnitPrice({
|
|
841
|
-
microLamports: priorityFeeOptions.computeUnitPrice,
|
|
842
|
-
}));
|
|
843
|
-
}
|
|
844
848
|
}
|
|
845
849
|
// Check if fee recipient token account exists and create if needed
|
|
846
850
|
const feeRecipientAtaExists = await this.ataExists(feeRecipientToken);
|
|
@@ -1046,17 +1050,16 @@ export class DramaPmClient {
|
|
|
1046
1050
|
async buildClaimBurnMarketTx(params, priorityFeeOptions) {
|
|
1047
1051
|
const { user, market } = params;
|
|
1048
1052
|
const tx = new Transaction();
|
|
1049
|
-
// Add priority fee instructions if
|
|
1050
|
-
|
|
1051
|
-
|
|
1052
|
-
|
|
1053
|
-
|
|
1053
|
+
// Add priority fee instructions (use default if not provided)
|
|
1054
|
+
const feeOpts = priorityFeeOptions ?? DEFAULT_PRIORITY_FEE;
|
|
1055
|
+
const computeUnitLimit = feeOpts.computeUnitLimit ?? 400000;
|
|
1056
|
+
tx.add(ComputeBudgetProgram.setComputeUnitLimit({
|
|
1057
|
+
units: computeUnitLimit,
|
|
1058
|
+
}));
|
|
1059
|
+
if (feeOpts.computeUnitPrice !== undefined && feeOpts.computeUnitPrice > 0) {
|
|
1060
|
+
tx.add(ComputeBudgetProgram.setComputeUnitPrice({
|
|
1061
|
+
microLamports: feeOpts.computeUnitPrice,
|
|
1054
1062
|
}));
|
|
1055
|
-
if (priorityFeeOptions.computeUnitPrice !== undefined && priorityFeeOptions.computeUnitPrice > 0) {
|
|
1056
|
-
tx.add(ComputeBudgetProgram.setComputeUnitPrice({
|
|
1057
|
-
microLamports: priorityFeeOptions.computeUnitPrice,
|
|
1058
|
-
}));
|
|
1059
|
-
}
|
|
1060
1063
|
}
|
|
1061
1064
|
// Derive PDAs
|
|
1062
1065
|
const yesMint = PublicKey.findProgramAddressSync([Buffer.from(YES_MINT_SEED), market.toBuffer()], this.program.programId)[0];
|
|
@@ -1254,4 +1257,4 @@ export class DramaPmClient {
|
|
|
1254
1257
|
}
|
|
1255
1258
|
}
|
|
1256
1259
|
}
|
|
1257
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ASSOCIATED_TOKEN_PROGRAM_ID,\n  createTransferInstruction,\n  getAccount,\n  getAssociatedTokenAddressSync,\n  TOKEN_2022_PROGRAM_ID,\n  TOKEN_PROGRAM_ID\n} from \"@solana/spl-token\";\n\nimport { Program as AnchorProgram, AnchorProvider, Idl, Program, Wallet } from \"@coral-xyz/anchor\";\n\nimport BN from \"bn.js\";\n\nimport {\n  ComputeBudgetProgram,\n  Connection,\n  Keypair,\n  PublicKey,\n  SystemProgram,\n  Transaction,\n  TransactionInstruction\n} from \"@solana/web3.js\";\nimport { IDL } from \"./idl.js\";\nimport { DramaPm } from \"./types.js\";\nimport {\n  getGlobalConfigPda,\n  getMarketPda,\n  getMarketPdas,\n  getVaultPda,\n  NO_MINT_SEED,\n  VAULT_SEED,\n  YES_MINT_SEED\n} from \"./utils.js\";\n\nexport * from \"./utils.js\";\nexport { DramaPm, IDL };\n\nexport type Outcome = \"Yes\" | \"No\";\n\n/**\n * Priority fee options for accelerating transaction confirmation\n */\nexport interface PriorityFeeOptions {\n  /** Price per compute unit in micro-lamports (1 SOL = 1e9 lamports = 1e15 micro-lamports) */\n  computeUnitPrice?: number;\n  /** Maximum compute units for the transaction (default: 200,000 for normal txs, 400,000 for complex ones) */\n  computeUnitLimit?: number;\n}\n\nexport interface CreateMarketParams {\n  admin: PublicKey;\n  marketId: number | BN;\n  yesPrice: number | BN;\n  noPrice: number | BN;\n  endTime: number | BN;\n  bettingToken: PublicKey;\n}\n\nexport interface PlaceBetParams {\n  user: PublicKey;\n  market: PublicKey; // Market PDA address\n  amount: number | BN;\n  outcome: Outcome;\n  bettingToken: PublicKey;\n  feeRecipient?: PublicKey; // Fee recipient address (optional, will fetch from config if not provided)\n  feeRecipientToken?: PublicKey | null; // Fee recipient token account (optional, used internally by buildPlaceBetTx)\n  createAta?: boolean; // Whether to create ATA instruction automatically\n}\n\nexport interface UpdateFeeConfigParams {\n  authority: PublicKey; // Can be authority or authorized admin\n  newFeeBps: number; // Fee in basis points (1 bps = 0.01%, max 2000 = 20%)\n  newFeeRecipient: PublicKey;\n  newFeeClaimBps: number; // Fee for claiming rewards in basis points\n}\n\nexport interface ClaimRewardsParams {\n  user: PublicKey;\n  market: PublicKey; // Market PDA address\n  bettingToken: PublicKey;\n  winningOutcome: Outcome;\n  sharesToClaim: number | BN; // Amount of shares to claim (0 = claim all)\n  closeAccount?: boolean; // Whether to close the outcome token account after claiming all shares (default: false)\n  feeRecipient?: PublicKey; // Fee recipient address (optional, will fetch from config if not provided)\n}\n\nexport interface BatchClaimParams {\n  user: PublicKey;\n  claims: Array<{\n    market: PublicKey;\n    bettingToken: PublicKey;\n    winningOutcome: Outcome;\n    sharesToClaim?: number | BN; // Amount of shares to claim (0 or undefined = claim all)\n    closeAccount?: boolean; // Whether to close the outcome token account after claiming all shares\n  }>;\n}\n\nexport interface RefundParams {\n  user: PublicKey;\n  market: PublicKey; // Market PDA address\n  bettingToken: PublicKey;\n  outcome: Outcome;\n  tokenAmount?: number | BN; // Amount of shares to refund. 0 or undefined means refund all shares.\n  closeAccount?: boolean; // Whether to close the outcome token account after refunding all shares (default: false)\n}\n\n/**\n * Parameters for refundV2 - refunding both Yes and No positions in one transaction.\n * Use this when a user has bet on both outcomes and wants to refund everything at once.\n */\nexport interface RefundV2Params {\n  user: PublicKey;\n  market: PublicKey; // Market PDA address\n  bettingToken: PublicKey;\n  yesTokenAmount?: number | BN; // Amount of Yes shares to refund. 0 or undefined means refund all.\n  noTokenAmount?: number | BN;  // Amount of No shares to refund. 0 or undefined means refund all.\n  closeYesAccount?: boolean; // Whether to close the Yes outcome token account (default: true)\n  closeNoAccount?: boolean;  // Whether to close the No outcome token account (default: true)\n}\n\n/**\n * Parameters for claim_burn_market instruction\n * Combines claiming rewards (if won) and burning tokens (if lost) in one call.\n * Always closes token accounts to reclaim rent.\n */\nexport interface ClaimBurnMarketParams {\n  user: PublicKey;\n  market: PublicKey; // Market PDA address\n  bettingToken: PublicKey;\n}\n\nexport interface UserMarketHoldParams {\n  user: PublicKey;\n  market: PublicKey; // Market PDA address\n}\n\nexport interface UserMarketHoldResult {\n  yesMint: PublicKey;\n  noMint: PublicKey;\n  yesTokenBalance: string; // Balance as string to preserve precision\n  noTokenBalance: string;  // Balance as string to preserve precision\n  hasYesTokenAccount: boolean;\n  hasNoTokenAccount: boolean;\n}\n\n/**\n * Parameters for placeBetV2 - combines user bet and bonus account bet in one transaction\n * Requires both user and bonusAccount to sign the transaction\n */\nexport interface PlaceBetV2Params {\n  user: PublicKey;              // User's public key (signer)\n  bonusAccount: PublicKey;      // Bonus account public key (signer)\n  market: PublicKey;            // Market PDA address\n  userAmount: number | BN;      // Amount user pays\n  bonusAmount: number | BN;     // Amount bonus account pays\n  outcome: Outcome;             // Outcome to bet on (Yes/No)\n  bettingToken: PublicKey;      // Betting token mint\n  feeRecipient?: PublicKey;     // Fee recipient address (optional)\n  createAta?: boolean;          // Whether to create ATA instruction automatically\n}\n\n/**\n * Result from buildPlaceBetV2Tx containing both the transaction and its serialized form\n * for split signing workflow (frontend user sign + backend bonus sign)\n */\nexport interface PlaceBetV2Result {\n  transaction: Transaction;     // Transaction object for local signing (testing)\n  requiredSigners: PublicKey[]; // List of required signers [user, bonusAccount]\n}\n\nexport class DramaPmClient {\n  program: Program<DramaPm>;\n  provider: AnchorProvider;\n  connection: Connection;\n\n  constructor(connection: Connection, wallet?: Wallet, programId?: PublicKey) {\n    this.connection = connection;\n    \n    // Create a default wallet if none provided\n    const defaultKeypair = Keypair.generate();\n    const defaultWallet: Wallet = {\n      publicKey: defaultKeypair.publicKey,\n      signTransaction: async (tx) => tx,\n      signAllTransactions: async (txs) => txs,\n      payer: defaultKeypair,\n    };\n    \n    this.provider = new AnchorProvider(\n      connection,\n      wallet || defaultWallet,\n      { commitment: \"confirmed\" }\n    );\n    \n    // Use custom programId if provided, otherwise use the default from IDL\n    const finalProgramId = programId || new PublicKey(IDL.address);\n    \n    // Create a new IDL with the custom programId\n    const customIdl = { ...IDL, address: finalProgramId.toBase58() };\n    \n    this.program = new AnchorProgram(customIdl as Idl, this.provider) as unknown as Program<DramaPm>;\n  }\n\n  /**\n   * Get the current program ID\n   */\n  getProgramId(): PublicKey {\n    return this.program.programId;\n  }\n\n  /**\n   * Set a new program ID and reinitialize the program instance\n   * Useful when redeploying the program to a new address\n   */\n  setProgramId(programId: PublicKey): void {\n    const customIdl = { ...IDL, address: programId.toBase58() };\n    this.program = new AnchorProgram(customIdl as Idl, this.provider) as unknown as Program<DramaPm>;\n  }\n\n  /**\n   * Check if an associated token account exists\n   */\n  async ataExists(ata: PublicKey): Promise<boolean> {\n    try {\n      await getAccount(this.connection, ata);\n      return true;\n    } catch {\n      return false;\n    }\n  }\n\n  /**\n   * Create an instruction to initialize an associated token account\n   * @param tokenProgram - Token program ID (TOKEN_PROGRAM_ID for betting token, TOKEN_2022_PROGRAM_ID for outcome tokens)\n   */\n  createAtaInstruction(\n    payer: PublicKey,\n    owner: PublicKey,\n    mint: PublicKey,\n    tokenProgram: PublicKey = TOKEN_PROGRAM_ID\n  ): TransactionInstruction {\n    const ata = getAssociatedTokenAddressSync(mint, owner, true, tokenProgram);\n    \n    // Use CreateIdempotent instruction (opcode 1) to support PDAs and idempotency\n    const keys = [\n      { pubkey: payer, isSigner: true, isWritable: true },\n      { pubkey: ata, isSigner: false, isWritable: true },\n      { pubkey: owner, isSigner: false, isWritable: false },\n      { pubkey: mint, isSigner: false, isWritable: false },\n      { pubkey: SystemProgram.programId, isSigner: false, isWritable: false },\n      { pubkey: tokenProgram, isSigner: false, isWritable: false },\n    ];\n\n    return new TransactionInstruction({\n      keys,\n      programId: ASSOCIATED_TOKEN_PROGRAM_ID,\n      data: Buffer.from([1]),\n    });\n  }\n\n  /**\n   * Initialize global configuration (Authority only)\n   */\n  async initializeConfig(authority: PublicKey): Promise<TransactionInstruction> {\n    const globalConfig = getGlobalConfigPda(this.program.programId);\n    return await this.program.methods\n      .initializeConfig()\n      .accountsPartial({\n        globalConfig,\n        authority: authority,\n        systemProgram: SystemProgram.programId,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to initialize config\n   */\n  async buildInitializeConfigTx(authority: PublicKey): Promise<Transaction> {\n    const ix = await this.initializeConfig(authority);\n    return new Transaction().add(ix);\n  }\n\n  /**\n   * Migrate GlobalConfig to new version with fee_claim_bps field (Authority only)\n   * Should be called once after program upgrade\n   */\n  async migrateConfig(authority: PublicKey): Promise<TransactionInstruction> {\n    const globalConfig = getGlobalConfigPda(this.program.programId);\n    return await this.program.methods\n      .migrateConfig()\n      .accountsPartial({\n        globalConfig,\n        authority: authority,\n        systemProgram: SystemProgram.programId,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to migrate config\n   */\n  async buildMigrateConfigTx(authority: PublicKey): Promise<Transaction> {\n    const ix = await this.migrateConfig(authority);\n    return new Transaction().add(ix);\n  }\n\n  /**\n   * Update authorized admin (Authority only)\n   */\n  async addAdmin(newAdmin: PublicKey): Promise<TransactionInstruction> {\n    const globalConfig = getGlobalConfigPda(this.program.programId);\n\n    return await this.program.methods\n      .addAdmin(newAdmin)\n      .accountsPartial({\n        globalConfig,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to update admin\n   */\n  async buildAddAdminTx(newAdmin: PublicKey): Promise<Transaction> {\n    const ix = await this.addAdmin(newAdmin);\n    return new Transaction().add(ix);\n  }\n\n  /**\n   * Remove authorized admin (Authority only)\n   */\n  async removeAdmin(adminToRemove: PublicKey): Promise<TransactionInstruction> {\n    const globalConfig = getGlobalConfigPda(this.program.programId);\n\n    return await this.program.methods\n      .removeAdmin(adminToRemove)\n      .accountsPartial({\n        globalConfig,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to remove admin\n   */\n  async buildRemoveAdminTx(adminToRemove: PublicKey): Promise<Transaction> {\n    const ix = await this.removeAdmin(adminToRemove);\n    return new Transaction().add(ix);\n  }\n\n  /**\n   * Update fee configuration (Authority or authorized admin)\n   */\n  async updateFeeConfig(params: UpdateFeeConfigParams): Promise<TransactionInstruction> {\n    const globalConfig = getGlobalConfigPda(this.program.programId);\n\n    return await this.program.methods\n      .updateFeeConfig(params.newFeeBps, params.newFeeRecipient, params.newFeeClaimBps)\n      .accountsPartial({\n        globalConfig: globalConfig,\n        authority: params.authority,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to update fee config\n   */\n  async buildUpdateFeeConfigTx(params: UpdateFeeConfigParams): Promise<Transaction> {\n    const ix = await this.updateFeeConfig(params);\n    return new Transaction().add(ix);\n  }\n\n  /**\n   * Create a new prediction market instruction\n   */\n  async createMarket(params: CreateMarketParams): Promise<TransactionInstruction> {\n    const { admin, marketId, yesPrice, noPrice, endTime, bettingToken } = params;\n    \n    const marketIdBn = new BN(marketId);\n    const yesPriceBn = new BN(yesPrice);\n    const noPriceBn = new BN(noPrice);\n    const endTimeBn = new BN(endTime);\n\n    const pdas = getMarketPdas(this.program.programId, admin, marketIdBn);\n    const globalConfig = getGlobalConfigPda(this.program.programId);\n\n    return await this.program.methods\n      .createMarket({\n          marketId: marketIdBn,\n          yesPrice: yesPriceBn,\n          noPrice: noPriceBn,\n          endTime: endTimeBn,\n        })\n        .accountsPartial({\n          globalConfig,\n          market: pdas.market,\n          yesMint: pdas.yesMint,\n          noMint: pdas.noMint,\n          bettingToken: bettingToken,\n          vault: pdas.vault,\n          admin: admin,\n          tokenProgram: TOKEN_PROGRAM_ID,\n          systemProgram: SystemProgram.programId,\n        })\n        .instruction();\n  }\n\n  /**\n   * Build a complete transaction to create a market\n   * @param params - Market creation parameters\n   * @param priorityFeeOptions - Optional priority fee settings to accelerate transaction confirmation\n   * @param priorityFeeOptions.computeUnitPrice - Price per compute unit in micro-lamports (e.g., 1000 = 0.000001 SOL per CU)\n   * @param priorityFeeOptions.computeUnitLimit - Max compute units (default: 400,000 for createMarket due to multiple PDA inits)\n   */\n  async buildCreateMarketTx(\n    params: CreateMarketParams,\n    priorityFeeOptions?: PriorityFeeOptions\n  ): Promise<Transaction> {\n    const tx = new Transaction();\n\n    // Add priority fee instructions if specified\n    if (priorityFeeOptions) {\n      // Set compute unit limit (createMarket is a complex tx, default to 400k)\n      const computeUnitLimit = priorityFeeOptions.computeUnitLimit ?? 400_000;\n      tx.add(\n        ComputeBudgetProgram.setComputeUnitLimit({\n          units: computeUnitLimit,\n        })\n      );\n\n      // Set compute unit price if specified\n      if (priorityFeeOptions.computeUnitPrice !== undefined && priorityFeeOptions.computeUnitPrice > 0) {\n        tx.add(\n          ComputeBudgetProgram.setComputeUnitPrice({\n            microLamports: priorityFeeOptions.computeUnitPrice,\n          })\n        );\n      }\n    }\n\n    const ix = await this.createMarket(params);\n    tx.add(ix);\n    \n    return tx;\n  }\n\n  /**\n   * Place a bet instruction (without ATA creation)\n   */\n  async placeBet(params: PlaceBetParams): Promise<TransactionInstruction> {\n    const { user, market, amount, outcome, bettingToken, feeRecipientToken } = params;\n    \n    const amountBn = new BN(amount);\n    const outcomeEnum = outcome === \"Yes\" ? { yes: {} } : { no: {} };\n\n    // Get global config for fee info\n    const globalConfig = getGlobalConfigPda(this.program.programId);\n\n    // Derive PDAs from market address\n    const yesMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(YES_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    const noMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(NO_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    const vault = PublicKey.findProgramAddressSync(\n      [Buffer.from(VAULT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n\n    const userBettingToken = getAssociatedTokenAddressSync(bettingToken, user);\n    \n    // Determine which outcome token the user will receive\n    // Outcome tokens (Yes/No) use Token-2022 program\n    const targetMint = outcome === \"Yes\" ? yesMint : noMint;\n    const userOutcomeToken = getAssociatedTokenAddressSync(targetMint, user, false, TOKEN_2022_PROGRAM_ID);\n\n    return await this.program.methods\n      .placeBet({\n        buyOutcome: outcomeEnum,\n        amount: amountBn,\n      })\n      .accountsPartial({\n        globalConfig,\n        market,\n        yesMint,\n        noMint,\n        vault,\n        feeRecipientToken: feeRecipientToken || null,\n        userOutcomeToken,\n        userBettingToken,\n        user,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to place a bet (with optional ATA creation for both outcome token and fee recipient)\n   */\n  async buildPlaceBetTx(params: PlaceBetParams): Promise<Transaction> {\n    const { user, market, outcome, bettingToken, createAta = true } = params;\n    \n    const tx = new Transaction();\n    \n    // Fetch config to check fee_bps\n    const configAccount = await this.getGlobalConfigAccount();\n    \n    // Derive mint PDAs from market address\n    const yesMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(YES_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    const noMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(NO_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    \n    // Outcome tokens (Yes/No) use Token-2022 program\n    const targetMint = outcome === \"Yes\" ? yesMint : noMint;\n    const userOutcomeToken = getAssociatedTokenAddressSync(targetMint, user, false, TOKEN_2022_PROGRAM_ID);\n\n    // Check if user outcome ATA exists and create if needed\n    if (createAta) {\n      const exists = await this.ataExists(userOutcomeToken);\n      if (!exists) {\n        const createAtaIx = this.createAtaInstruction(user, user, targetMint, TOKEN_2022_PROGRAM_ID);\n        tx.add(createAtaIx);\n      }\n    }\n\n    // Handle fee recipient token account if fee_bps > 0\n    let feeRecipientToken: PublicKey | null = null;\n    if (configAccount.feeBps > 0) {\n      const feeRecipientAddress = params.feeRecipient || configAccount.feeRecipient;\n      feeRecipientToken = getAssociatedTokenAddressSync(bettingToken, feeRecipientAddress);\n      \n      // Check if fee recipient ATA exists and create if needed\n      const feeAtaExists = await this.ataExists(feeRecipientToken);\n      if (!feeAtaExists) {\n        const createFeeAtaIx = this.createAtaInstruction(user, feeRecipientAddress, bettingToken);\n        tx.add(createFeeAtaIx);\n      }\n    }\n\n    const placeBetIx = await this.placeBet({\n      ...params,\n      feeRecipientToken,\n    });\n    tx.add(placeBetIx);\n\n    return tx;\n  }\n\n  /**\n   * Build a transaction to place bets from both user and bonus account in one transaction.\n   * This transaction requires two signers: user and bonusAccount.\n   * \n   * Use case: User pays part of the bet, bonus account (backend) pays the rest.\n   * Example: User bets 10U total, user pays 8U, bonus account pays 2U.\n   * \n   * Both bets are placed on the same outcome, but outcome tokens go to each account respectively.\n   */\n  async buildPlaceBetV2Tx(params: PlaceBetV2Params): Promise<PlaceBetV2Result> {\n    const { \n      user, \n      bonusAccount, \n      market, \n      userAmount, \n      bonusAmount, \n      outcome, \n      bettingToken, \n      createAta = true \n    } = params;\n    \n    const tx = new Transaction();\n    \n    // Fetch config to check fee_bps\n    const configAccount = await this.getGlobalConfigAccount();\n    \n    // Derive mint PDAs from market address\n    const yesMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(YES_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    const noMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(NO_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    \n    // Outcome tokens (Yes/No) use Token-2022 program\n    const targetMint = outcome === \"Yes\" ? yesMint : noMint;\n    \n    // User's outcome token account\n    const userOutcomeToken = getAssociatedTokenAddressSync(targetMint, user, false, TOKEN_2022_PROGRAM_ID);\n    \n    // Bonus account's outcome token account\n    const bonusOutcomeToken = getAssociatedTokenAddressSync(targetMint, bonusAccount, false, TOKEN_2022_PROGRAM_ID);\n\n    // Create ATAs if needed\n    if (createAta) {\n      // Check if user outcome ATA exists and create if needed\n      const userAtaExists = await this.ataExists(userOutcomeToken);\n      if (!userAtaExists) {\n        const createUserAtaIx = this.createAtaInstruction(user, user, targetMint, TOKEN_2022_PROGRAM_ID);\n        tx.add(createUserAtaIx);\n      }\n      \n      // Check if bonus account outcome ATA exists and create if needed\n      const bonusAtaExists = await this.ataExists(bonusOutcomeToken);\n      if (!bonusAtaExists) {\n        // User pays for creating the bonus account's ATA\n        const createBonusAtaIx = this.createAtaInstruction(user, bonusAccount, targetMint, TOKEN_2022_PROGRAM_ID);\n        tx.add(createBonusAtaIx);\n      }\n    }\n\n    // Handle fee recipient token account if fee_bps > 0\n    let feeRecipientToken: PublicKey | null = null;\n    if (configAccount.feeBps > 0) {\n      const feeRecipientAddress = params.feeRecipient || configAccount.feeRecipient;\n      feeRecipientToken = getAssociatedTokenAddressSync(bettingToken, feeRecipientAddress);\n      \n      // Check if fee recipient ATA exists and create if needed\n      const feeAtaExists = await this.ataExists(feeRecipientToken);\n      if (!feeAtaExists) {\n        const createFeeAtaIx = this.createAtaInstruction(user, feeRecipientAddress, bettingToken);\n        tx.add(createFeeAtaIx);\n      }\n    }\n\n    // Create user's placeBet instruction\n    const userBetIx = await this.placeBet({\n      user,\n      market,\n      amount: userAmount,\n      outcome,\n      bettingToken,\n      feeRecipientToken,\n    });\n    tx.add(userBetIx);\n\n    // Create bonus account's placeBet instruction\n    const bonusBetIx = await this.placeBet({\n      user: bonusAccount,\n      market,\n      amount: bonusAmount,\n      outcome,\n      bettingToken,\n      feeRecipientToken,\n    });\n    tx.add(bonusBetIx);\n    return {\n      transaction: tx,\n      requiredSigners: [user, bonusAccount],\n    };\n  }\n\n  /**\n   * Deserialize a base64 encoded transaction\n   * Use this on frontend to decode the transaction received from backend\n   */\n  static deserializeTransaction(serializedTx: string): Transaction {\n    const buffer = Buffer.from(serializedTx, 'base64');\n    return Transaction.from(buffer);\n  }\n\n  /**\n   * Sign a partially signed transaction with the bonus account (backend side)\n   * \n   * @param userSignedTxBase64 - Base64 encoded transaction that has been signed by user\n   * @param bonusAccountKeypair - The bonus account keypair for signing\n   * @returns The fully signed transaction ready for submission\n   */\n  static signWithKeyPair(userSignedTxBase64: string, keyPair: Keypair): Transaction {\n    const buffer = Buffer.from(userSignedTxBase64, 'base64');\n    const tx = Transaction.from(buffer);\n    tx.partialSign(keyPair);\n    return tx;\n  }\n\n  // async transfer()\n\n  /**\n   * Build a transaction to withdraw bonus (transfer USDT from bonus account to user)\n   * This transaction requires the bonus account to sign.\n   * \n   * @param bonusAccount - The bonus account public key (signer, source of funds)\n   * @param user - The user's public key (destination)\n   * @param tokenMint - The token mint address (e.g., USDT)\n   * @param amount - Amount to transfer (in token's smallest unit, e.g., 1_000_000 for 1 USDT with 6 decimals)\n   * @param createAta - Whether to create the user's ATA if it doesn't exist (default: true)\n   * @returns Transaction ready for signing\n   */\n  async buildWithdrawBonusTx(params: {\n    bonusAccount: PublicKey;\n    user: PublicKey;\n    tokenMint: PublicKey;\n    amount: number | BN;\n    createAta?: boolean;\n  }): Promise<Transaction> {\n    const { bonusAccount, user, tokenMint, amount, createAta = true } = params;\n    const amountBn = new BN(amount);\n    \n    const tx = new Transaction();\n    \n    // Get ATA addresses for both accounts\n    const bonusTokenAccount = getAssociatedTokenAddressSync(tokenMint, bonusAccount);\n    const userTokenAccount = getAssociatedTokenAddressSync(tokenMint, user);\n    \n    // Create user's ATA if needed\n    if (createAta) {\n      const userAtaExists = await this.ataExists(userTokenAccount);\n      if (!userAtaExists) {\n        const createUserAtaIx = this.createAtaInstruction(bonusAccount, user, tokenMint);\n        tx.add(createUserAtaIx);\n      }\n    }\n    \n    // Create transfer instruction\n    const transferIx = createTransferInstruction(\n      bonusTokenAccount,  // source\n      userTokenAccount,   // destination\n      bonusAccount,       // owner (signer)\n      BigInt(amountBn.toString()),  // amount\n      [],                 // multiSigners (empty for single signer)\n      TOKEN_PROGRAM_ID    // program id\n    );\n    tx.add(transferIx);\n    \n    return tx;\n  }\n\n  /**\n   * Build and return a transaction for withdrawing bonus with serialization info\n   * Useful for split signing workflow where user/admin builds tx and bonus account signs\n   * \n   * @returns Object containing transaction and required signers\n   */\n  async buildWithdrawBonusTxWithInfo(params: {\n    bonusAccount: PublicKey;\n    user: PublicKey;\n    tokenMint: PublicKey;\n    amount: number | BN;\n    createAta?: boolean;\n  }): Promise<{ transaction: Transaction; requiredSigners: PublicKey[] }> {\n    const tx = await this.buildWithdrawBonusTx(params);\n    return {\n      transaction: tx,\n      requiredSigners: [params.bonusAccount],\n    };\n  }\n\n  /**\n   * Claim rewards after market resolution\n   */\n  async claimRewards(params: ClaimRewardsParams): Promise<TransactionInstruction> {\n    const { user, market, bettingToken, winningOutcome } = params;\n\n    // Derive mint PDAs from market address\n    const yesMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(YES_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    const noMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(NO_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n\n    // Derive vault PDA\n    const vault = PublicKey.findProgramAddressSync(\n      [Buffer.from(VAULT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n\n    const userBettingToken = getAssociatedTokenAddressSync(bettingToken, user);\n    // Outcome tokens (Yes/No) use Token-2022 program\n    const targetMint = winningOutcome === \"Yes\" ? yesMint : noMint;\n    const userOutcomeToken = getAssociatedTokenAddressSync(targetMint, user, false, TOKEN_2022_PROGRAM_ID);\n    const sharesToClaimBn = new BN(params.sharesToClaim);\n    const closeAccount = params.closeAccount ?? true;\n    return await this.program.methods\n      .claimRewards({\n        tokenAmount: sharesToClaimBn,\n        closeAccount,\n      })\n      .accountsPartial({\n        market,\n        yesMint,\n        noMint,\n        vault,\n        userOutcomeToken,\n        userBettingToken,\n        user,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to claim rewards\n   */\n  async buildClaimRewardsTx(params: ClaimRewardsParams): Promise<Transaction> {\n    const { user, market, bettingToken, winningOutcome } = params;\n    const tx = new Transaction();\n\n    // Derive mint PDAs from market address\n    const yesMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(YES_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n\n    const noMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(NO_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n\n    // Derive vault PDA\n    const vault = PublicKey.findProgramAddressSync(\n      [Buffer.from(VAULT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n\n    const userBettingToken = getAssociatedTokenAddressSync(bettingToken, user);\n    // Outcome tokens (Yes/No) use Token-2022 program\n    const targetMint = winningOutcome === \"Yes\" ? yesMint : noMint;\n    const userOutcomeToken = getAssociatedTokenAddressSync(targetMint, user, false, TOKEN_2022_PROGRAM_ID);\n    const sharesToClaimBn = new BN(params.sharesToClaim);\n    const closeAccount = params.closeAccount ?? true;\n\n    const ix = await this.program.methods\n      .claimRewards({\n        tokenAmount: sharesToClaimBn,\n        closeAccount,\n      })\n      .accountsPartial({\n        market,\n        yesMint,\n        noMint,\n        vault,\n        userOutcomeToken,\n        userBettingToken,\n        user,\n      })\n      .instruction();\n    \n    tx.add(ix);\n    return tx;\n  }\n\n  /**\n   * Build instructions to claim rewards from multiple markets\n   * Returns an array of instructions that can be batched into transactions\n   */\n  async batchClaimRewards(params: BatchClaimParams): Promise<TransactionInstruction[]> {\n    const { user, claims } = params;\n    const instructions: TransactionInstruction[] = [];\n\n    for (const claim of claims) {\n      const ix = await this.claimRewards({\n        user,\n        market: claim.market,\n        bettingToken: claim.bettingToken,\n        winningOutcome: claim.winningOutcome,\n        sharesToClaim: claim.sharesToClaim ?? 0,\n        closeAccount: claim.closeAccount ?? true,\n      });\n      instructions.push(ix);\n    }\n\n    return instructions;\n  }\n\n  /**\n   * Build transactions to claim rewards from multiple markets\n   * Automatically splits into multiple transactions if needed (max 5 claims per tx to avoid size limits)\n   * @param params - Batch claim parameters\n   * @param maxClaimsPerTx - Maximum claims per transaction (default: 5)\n   * @returns Array of transactions\n   */\n  async buildBatchClaimRewardsTx(\n    params: BatchClaimParams,\n    maxClaimsPerTx: number = 5\n  ): Promise<Transaction[]> {\n    const instructions = await this.batchClaimRewards(params);\n    const transactions: Transaction[] = [];\n\n    // Split instructions into chunks\n    for (let i = 0; i < instructions.length; i += maxClaimsPerTx) {\n      const chunk = instructions.slice(i, i + maxClaimsPerTx);\n      const tx = new Transaction();\n      chunk.forEach(ix => tx.add(ix));\n      transactions.push(tx);\n    }\n\n    return transactions;\n  }\n\n  /**\n   * Refund bets if market is refunded\n   * @param params.tokenAmount - Amount of shares to refund. 0 or undefined means refund all shares.\n   *                             This allows users to partially refund their position across multiple transactions.\n   */\n  async refund(params: RefundParams): Promise<TransactionInstruction> {\n    const { user, market, bettingToken, outcome, tokenAmount, closeAccount = true } = params;\n    \n    const outcomeEnum = outcome === \"Yes\" ? { yes: {} } : { no: {} };\n    \n    // Convert tokenAmount to BN (0 means refund all)\n    const tokenAmountBn = new BN(tokenAmount ?? 0);\n    \n    // Derive mint PDAs from market address\n    const yesMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(YES_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    const noMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(NO_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n\n    // Derive vault PDA\n    const vault = PublicKey.findProgramAddressSync(\n      [Buffer.from(VAULT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n\n    const userBettingToken = getAssociatedTokenAddressSync(bettingToken, user);\n    // Outcome tokens (Yes/No) use Token-2022 program\n    const targetMint = outcome === \"Yes\" ? yesMint : noMint;\n    const userOutcomeToken = getAssociatedTokenAddressSync(targetMint, user, false, TOKEN_2022_PROGRAM_ID);\n\n    return await this.program.methods\n      .refund({\n        outcome: outcomeEnum,\n        tokenAmount: tokenAmountBn,\n        closeAccount,\n      })\n      .accountsPartial({\n        market: market,\n        yesMint: yesMint,\n        noMint: noMint,\n        vault: vault,\n        userOutcomeToken: userOutcomeToken,\n        userBettingToken: userBettingToken,\n        tokenProgram: TOKEN_PROGRAM_ID,\n        token2022Program: TOKEN_2022_PROGRAM_ID,\n        user: user,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to refund\n   */\n  async buildRefundTx(params: RefundParams): Promise<Transaction> {\n    const ix = await this.refund(params);\n    return new Transaction().add(ix);\n  }\n\n  /**\n   * Refund both Yes and No positions in a single transaction.\n   * \n   * Use this method when a user has bet on both Yes and No outcomes and needs to \n   * refund all positions after the market has been resolved as \"Refunded\" (None).\n   * \n   * This method automatically:\n   * - Checks if the user has Yes tokens and/or No tokens\n   * - Only includes refund instructions for outcomes the user actually holds\n   * - Closes the token accounts after refunding (by default)\n   * \n   * @param params - RefundV2Params\n   * @param params.user - User's public key (signer)\n   * @param params.market - Market PDA address\n   * @param params.bettingToken - Betting token mint (e.g., USDC)\n   * @param params.yesTokenAmount - Optional. Amount of Yes tokens to refund. 0 or undefined = refund all.\n   * @param params.noTokenAmount - Optional. Amount of No tokens to refund. 0 or undefined = refund all.\n   * @param params.closeYesAccount - Optional. Whether to close the Yes token account after refund. Default: true\n   * @param params.closeNoAccount - Optional. Whether to close the No token account after refund. Default: true\n   * \n   * @returns Transaction containing refund instructions for both outcomes (if applicable)\n   * \n   * @example\n   * ```typescript\n   * // Basic usage: Refund all Yes and No tokens\n   * const tx = await client.buildRefundV2Tx({\n   *   user: userPublicKey,\n   *   market: marketPda,\n   *   bettingToken: usdcMint,\n   * });\n   * \n   * // Sign and send\n   * tx.recentBlockhash = (await connection.getLatestBlockhash()).blockhash;\n   * tx.feePayer = userPublicKey;\n   * await wallet.signTransaction(tx);\n   * await connection.sendRawTransaction(tx.serialize());\n   * ```\n   * \n   * @example\n   * ```typescript\n   * // Keep token accounts open (don't close them)\n   * const tx = await client.buildRefundV2Tx({\n   *   user: userPublicKey,\n   *   market: marketPda,\n   *   bettingToken: usdcMint,\n   *   closeYesAccount: false, // Keep Yes token account open\n   *   closeNoAccount: false,  // Keep No token account open\n   * });\n   * ```\n   * \n   * @remarks\n   * - The market must be in \"Refunded\" status for this method to work\n   * - If the user only has tokens on one side, only that side will be refunded\n   * - The returned transaction will be empty if the user has no tokens on either side\n   */\n  async buildRefundV2Tx(params: RefundV2Params): Promise<Transaction> {\n    const { \n      user, \n      market, \n      bettingToken,\n      yesTokenAmount,\n      noTokenAmount,\n      closeYesAccount = true,\n      closeNoAccount = true \n    } = params;\n    \n    const tx = new Transaction();\n    \n    // Derive mint PDAs from market address\n    const yesMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(YES_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    const noMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(NO_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    \n    // Get user's outcome token accounts\n    const userYesToken = getAssociatedTokenAddressSync(yesMint, user, false, TOKEN_2022_PROGRAM_ID);\n    const userNoToken = getAssociatedTokenAddressSync(noMint, user, false, TOKEN_2022_PROGRAM_ID);\n    \n    // Check if user has Yes tokens\n    let hasYesTokens = false;\n    let yesBalance = 0;\n    try {\n      const yesAccount = await this.connection.getTokenAccountBalance(userYesToken);\n      yesBalance = Number(yesAccount.value.amount);\n      hasYesTokens = yesBalance > 0;\n    } catch {\n      // Account doesn't exist or has no balance\n    }\n    \n    // Check if user has No tokens\n    let hasNoTokens = false;\n    let noBalance = 0;\n    try {\n      const noAccount = await this.connection.getTokenAccountBalance(userNoToken);\n      noBalance = Number(noAccount.value.amount);\n      hasNoTokens = noBalance > 0;\n    } catch {\n      // Account doesn't exist or has no balance\n    }\n    \n    // Add Yes refund instruction if user has Yes tokens\n    if (hasYesTokens) {\n      const yesRefundIx = await this.refund({\n        user,\n        market,\n        bettingToken,\n        outcome: \"Yes\",\n        tokenAmount: 0,\n        closeAccount: closeYesAccount,\n      });\n      tx.add(yesRefundIx);\n    }\n    \n    // Add No refund instruction if user has No tokens\n    if (hasNoTokens) {\n      const noRefundIx = await this.refund({\n        user,\n        market,\n        bettingToken,\n        outcome: \"No\",\n        tokenAmount: 0,\n        closeAccount: closeNoAccount,\n      });\n      tx.add(noRefundIx);\n    }\n    \n    return tx;\n  }\n\n  /**\n   * Resolve a market (Admin only)\n   */\n  async resolveMarketByID(\n    admin: PublicKey,\n    marketId: number | BN,\n    winningOutcome: \"Yes\" | \"No\" | null,\n    feeRecipient?: PublicKey\n  ): Promise<TransactionInstruction> {\n    const marketIdBn = new BN(marketId);\n    const marketPda = getMarketPda(this.program.programId, admin, marketIdBn);\n    const globalConfig = getGlobalConfigPda(this.program.programId);\n\n    let outcomeEnum: any = null;\n    if (winningOutcome === \"Yes\") {\n      outcomeEnum = { yes: {} };\n    } else if (winningOutcome === \"No\") {\n      outcomeEnum = { no: {} };\n    }\n\n    // Get market info to determine betting token\n    const marketInfo = await this.getMarketInfo(marketPda);\n    // fee recipient address\n    const feeRecipientAddress = feeRecipient || (await this.getGlobalConfigAccount()).feeRecipient;\n    // fee recipient token account (allowOwnerOffCurve for multisig/PDA)\n    const feeRecipientToken = getAssociatedTokenAddressSync(marketInfo.bettingToken, feeRecipientAddress, true);\n\n    // Derive vault PDA\n    const vault = PublicKey.findProgramAddressSync(\n      [Buffer.from(VAULT_SEED), marketPda.toBuffer()],\n      this.program.programId\n    )[0];\n\n    return await this.program.methods\n      .resolveMarket(outcomeEnum)\n      .accountsPartial({\n        globalConfig,\n        market: marketPda,\n        vault,\n        feeRecipient: feeRecipientToken,\n        admin,\n        tokenProgram: TOKEN_PROGRAM_ID,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to resolve a market\n   * @param priorityFeeOptions - Optional priority fee settings to accelerate transaction confirmation\n   */\n  async buildResolveMarketTxByID(\n    admin: PublicKey,\n    marketId: number | BN,\n    winningOutcome: \"Yes\" | \"No\" | null,\n    feeRecipient?: PublicKey,\n    priorityFeeOptions?: PriorityFeeOptions\n  ): Promise<Transaction> {\n    const marketIdBn = new BN(marketId);\n    const marketPda = getMarketPda(this.program.programId, admin, marketIdBn);\n    const marketInfo = await this.getMarketInfo(marketPda);\n    const globalConfigAccount = await this.getGlobalConfigAccount();\n    const feeRecipientAddress = feeRecipient || globalConfigAccount.feeRecipient;\n    // allowOwnerOffCurve for multisig/PDA fee recipients\n    const feeRecipientToken = getAssociatedTokenAddressSync(marketInfo.bettingToken, feeRecipientAddress, true);\n\n    const tx = new Transaction();\n\n    // Add priority fee instructions if specified\n    if (priorityFeeOptions) {\n      const computeUnitLimit = priorityFeeOptions.computeUnitLimit ?? 200_000;\n      tx.add(\n        ComputeBudgetProgram.setComputeUnitLimit({\n          units: computeUnitLimit,\n        })\n      );\n      if (priorityFeeOptions.computeUnitPrice !== undefined && priorityFeeOptions.computeUnitPrice > 0) {\n        tx.add(\n          ComputeBudgetProgram.setComputeUnitPrice({\n            microLamports: priorityFeeOptions.computeUnitPrice,\n          })\n        );\n      }\n    }\n\n    // Check if fee recipient token account exists and create if needed\n    const feeRecipientAtaExists = await this.ataExists(feeRecipientToken);\n    if (!feeRecipientAtaExists) {\n      const createFeeRecipientAtaIx = this.createAtaInstruction(admin, feeRecipientAddress, marketInfo.bettingToken);\n      tx.add(createFeeRecipientAtaIx);\n    }\n\n    // Add resolve market instruction\n    const resolveMarketIx = await this.resolveMarketByID(admin, marketId, winningOutcome, feeRecipient);\n    tx.add(resolveMarketIx);\n\n    return tx;\n  }\n\n  /**\n   * Resolve a market (Admin only)\n   */\n  async resolveMarket(\n    admin: PublicKey,\n    market: PublicKey,\n    winningOutcome: \"Yes\" | \"No\" | null,\n    feeRecipient?: PublicKey\n  ): Promise<TransactionInstruction> {\n    const globalConfig = getGlobalConfigPda(this.program.programId);\n\n    let outcomeEnum: any = null;\n    if (winningOutcome === \"Yes\") {\n      outcomeEnum = { yes: {} };\n    } else if (winningOutcome === \"No\") {\n      outcomeEnum = { no: {} };\n    }\n\n    // Get market info to determine betting token\n    const marketInfo = await this.getMarketInfo(market);\n    const feeRecipientAddress = feeRecipient || (await this.getGlobalConfigAccount()).feeRecipient;\n    // allowOwnerOffCurve for multisig/PDA fee recipients\n    const feeRecipientToken = getAssociatedTokenAddressSync(marketInfo.bettingToken, feeRecipientAddress, true);\n\n    // Derive vault PDA\n    const vault = PublicKey.findProgramAddressSync(\n      [Buffer.from(VAULT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n\n    return await this.program.methods\n      .resolveMarket(outcomeEnum)\n      .accountsPartial({\n        globalConfig,\n        market: market,\n        vault,\n        feeRecipient: feeRecipientToken,\n        admin,\n        tokenProgram: TOKEN_PROGRAM_ID,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to resolve a market\n   * @param priorityFeeOptions - Optional priority fee settings to accelerate transaction confirmation\n   */\n  async buildResolveMarketTx(\n    admin: PublicKey,\n    market: PublicKey,\n    winningOutcome: \"Yes\" | \"No\" | null,\n    feeRecipient?: PublicKey,\n    priorityFeeOptions?: PriorityFeeOptions\n  ): Promise<Transaction> {\n    const marketInfo = await this.getMarketInfo(market);\n    const globalConfigAccount = await this.getGlobalConfigAccount();\n    const feeRecipientAddress = feeRecipient || globalConfigAccount.feeRecipient;\n    // allowOwnerOffCurve for multisig/PDA fee recipients\n    const feeRecipientToken = getAssociatedTokenAddressSync(marketInfo.bettingToken, feeRecipientAddress, true);\n\n    const tx = new Transaction();\n\n    // Add priority fee instructions if specified\n    if (priorityFeeOptions) {\n      const computeUnitLimit = priorityFeeOptions.computeUnitLimit ?? 200_000;\n      tx.add(\n        ComputeBudgetProgram.setComputeUnitLimit({\n          units: computeUnitLimit,\n        })\n      );\n      if (priorityFeeOptions.computeUnitPrice !== undefined && priorityFeeOptions.computeUnitPrice > 0) {\n        tx.add(\n          ComputeBudgetProgram.setComputeUnitPrice({\n            microLamports: priorityFeeOptions.computeUnitPrice,\n          })\n        );\n      }\n    }\n\n    // Check if fee recipient token account exists and create if needed\n    const feeRecipientAtaExists = await this.ataExists(feeRecipientToken);\n    if (!feeRecipientAtaExists) {\n      const createFeeRecipientAtaIx = this.createAtaInstruction(admin, feeRecipientAddress, marketInfo.bettingToken);\n      tx.add(createFeeRecipientAtaIx);\n    }\n\n    // Add resolve market instruction\n    const resolveMarketIx = await this.resolveMarket(admin, market, winningOutcome, feeRecipient);\n    tx.add(resolveMarketIx);\n\n    return tx;\n  }\n\n  /**\n   * Close a market (Admin only)\n   */\n  async closeMarket(\n    admin: PublicKey,\n    market: PublicKey\n  ): Promise<TransactionInstruction> {\n    return await this.program.methods\n      .closeMarket()\n      .accountsPartial({\n        market: market,\n        admin: admin,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to close a market\n   */\n  async buildCloseMarketTx(\n    admin: PublicKey,\n    market: PublicKey\n  ): Promise<Transaction> {\n    const ix = await this.closeMarket(admin, market);\n    return new Transaction().add(ix);\n  }\n\n  /**\n   * Close a market (Admin only)\n   */\n  async closeMarketByID(\n    admin: PublicKey,\n    marketId: number | BN\n  ): Promise<TransactionInstruction> {\n    const marketIdBn = new BN(marketId);\n    const marketPda = getMarketPda(this.program.programId, admin, marketIdBn);\n\n    return await this.program.methods\n      .closeMarket()\n      .accountsPartial({\n        market: marketPda,\n        admin: admin,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to close a market\n   */\n  async buildCloseMarketTxByID(\n    admin: PublicKey,\n    marketId: number | BN\n  ): Promise<Transaction> {\n    const ix = await this.closeMarketByID(admin, marketId);\n    return new Transaction().add(ix);\n  }\n\n  /**\n   * Close market account and reclaim rent (Admin only)\n   * Can only be called after market is resolved and all rewards claimed\n   */\n  async closeMarketAccount(\n    admin: PublicKey,\n    market: PublicKey\n  ): Promise<TransactionInstruction> {\n    // Derive PDAs\n    const yesMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(YES_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    const noMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(NO_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    const vault = PublicKey.findProgramAddressSync(\n      [Buffer.from(VAULT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n\n    return await this.program.methods\n      .closeMarketAccount()\n      .accountsPartial({\n        market,\n        yesMint,\n        noMint,\n        vault,\n        admin,\n        tokenProgram: TOKEN_PROGRAM_ID,\n        token2022Program: TOKEN_2022_PROGRAM_ID,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to close market account\n   */\n  async buildCloseMarketAccountTx(\n    admin: PublicKey,\n    market: PublicKey\n  ): Promise<Transaction> {\n    const ix = await this.closeMarketAccount(admin, market);\n    return new Transaction().add(ix);\n  }\n\n  /**\n   * Burn worthless tokens from the losing side of a resolved market.\n   * This allows users to clean up their losing tokens so the market account can be closed.\n   * @param user - The user who holds losing tokens\n   * @param market - The market PDA\n   * @param losingOutcome - The outcome that lost (the side to burn)\n   * @param tokenAmount - Amount to burn (0 = burn all)\n   * @param closeAccount - Whether to close the losing token account after burning all tokens (default: false)\n   */\n  async burnMarketTokens(\n    user: PublicKey,\n    market: PublicKey,\n    losingOutcome: Outcome,\n    tokenAmount: number | BN = 0,\n    closeAccount: boolean = false\n  ): Promise<TransactionInstruction> {\n    // Derive PDAs\n    const yesMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(YES_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    const noMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(NO_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n\n    // The losing mint is the side that lost\n    const losingMint = losingOutcome === \"Yes\" ? yesMint : noMint;\n    const userLosingToken = getAssociatedTokenAddressSync(losingMint, user, false, TOKEN_2022_PROGRAM_ID);\n\n    return await this.program.methods\n      .burnMarketTokens({\n        tokenAmount: new BN(tokenAmount),\n        closeAccount,\n      })\n      .accountsPartial({\n        market,\n        yesMint,\n        noMint,\n        losingMint,\n        userLosingToken,\n        user,\n        token2022Program: TOKEN_2022_PROGRAM_ID,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to burn market tokens\n   * @param closeAccount - Whether to close the losing token account after burning all tokens (default: false)\n   */\n  async buildBurnMarketTokensTx(\n    user: PublicKey,\n    market: PublicKey,\n    losingOutcome: Outcome,\n    tokenAmount: number | BN = 0,\n    closeAccount: boolean = true\n  ): Promise<Transaction> {\n    const ix = await this.burnMarketTokens(user, market, losingOutcome, tokenAmount, closeAccount);\n    return new Transaction().add(ix);\n  }\n\n  /**\n   * Get user's token balance for a specific market\n   * Returns the balance of both Yes and No tokens\n   * @param params - UserMarketHoldParams containing user and market addresses\n   * @returns UserMarketHoldResult with yes and no token balances\n   */\n  async getUserMarketTokenBalance(\n    params: UserMarketHoldParams\n  ): Promise<UserMarketHoldResult> {\n    const { user, market } = params;\n    \n    // Derive PDAs\n    const yesMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(YES_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    const noMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(NO_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n\n    // Get user token accounts\n    const userYesToken = getAssociatedTokenAddressSync(yesMint, user, false, TOKEN_2022_PROGRAM_ID);\n    const userNoToken = getAssociatedTokenAddressSync(noMint, user, false, TOKEN_2022_PROGRAM_ID);\n\n    // Check Yes token balance\n    let yesBalance = \"0\";\n    let hasYesAccount = false;\n    try {\n      const yesAccount = await getAccount(this.connection, userYesToken, undefined, TOKEN_2022_PROGRAM_ID);\n      yesBalance = yesAccount.amount.toString();\n      hasYesAccount = true;\n    } catch {\n      // Account doesn't exist or has no balance\n    }\n\n    // Check No token balance\n    let noBalance = \"0\";\n    let hasNoAccount = false;\n    try {\n      const noAccount = await getAccount(this.connection, userNoToken, undefined, TOKEN_2022_PROGRAM_ID);\n      noBalance = noAccount.amount.toString();\n      hasNoAccount = true;\n    } catch {\n      // Account doesn't exist or has no balance\n    }\n\n    return {\n      yesMint,\n      noMint,\n      yesTokenBalance: yesBalance,\n      noTokenBalance: noBalance,\n      hasYesTokenAccount: hasYesAccount,\n      hasNoTokenAccount: hasNoAccount,\n    };\n  }\n\n  /**\n   * Claim rewards if won, or burn tokens if lost, with optional account closure.\n   * This instruction combines claim_rewards and burn_market_tokens logic into a single call.\n   * \n   * @param params - ClaimBurnMarketParams\n   * @param userYesToken - User's YES token account (optional, pass null if user has no YES tokens)\n   * @param userNoToken - User's NO token account (optional, pass null if user has no NO tokens)\n   */\n  async claimBurnMarket(\n    params: ClaimBurnMarketParams,\n    userYesToken: PublicKey | null,\n    userNoToken: PublicKey | null\n  ): Promise<TransactionInstruction> {\n    const { user, market, bettingToken } = params;\n\n    // Derive PDAs\n    const yesMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(YES_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    const noMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(NO_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    const vault = PublicKey.findProgramAddressSync(\n      [Buffer.from(VAULT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n\n    const userBettingToken = getAssociatedTokenAddressSync(bettingToken, user);\n\n    return await this.program.methods\n      .claimBurnMarket()\n      .accountsPartial({\n        market,\n        yesMint,\n        noMint,\n        vault,\n        userYesToken: userYesToken,\n        userNoToken: userNoToken,\n        userBettingToken,\n        user,\n        tokenProgram: TOKEN_PROGRAM_ID,\n        token2022Program: TOKEN_2022_PROGRAM_ID,\n      })\n      .instruction();\n  }\n\n\n  /**\n   * Build a complete transaction to claim rewards (if won) or burn tokens (if lost)\n   * Automatically creates user outcome token accounts based on user's holdings\n   * @param priorityFeeOptions - Optional priority fee settings to accelerate transaction confirmation\n   */\n  async buildClaimBurnMarketTx(\n    params: ClaimBurnMarketParams,\n    priorityFeeOptions?: PriorityFeeOptions\n  ): Promise<Transaction> {\n    const { user, market } = params;\n    const tx = new Transaction();\n\n    // Add priority fee instructions if specified\n    if (priorityFeeOptions) {\n      const computeUnitLimit = priorityFeeOptions.computeUnitLimit ?? 200_000;\n      tx.add(\n        ComputeBudgetProgram.setComputeUnitLimit({\n          units: computeUnitLimit,\n        })\n      );\n      if (priorityFeeOptions.computeUnitPrice !== undefined && priorityFeeOptions.computeUnitPrice > 0) {\n        tx.add(\n          ComputeBudgetProgram.setComputeUnitPrice({\n            microLamports: priorityFeeOptions.computeUnitPrice,\n          })\n        );\n      }\n    }\n\n    // Derive PDAs\n    const yesMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(YES_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    const noMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(NO_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n\n    // Get user token accounts\n    const userYesToken = getAssociatedTokenAddressSync(yesMint, user, false, TOKEN_2022_PROGRAM_ID);\n    const userNoToken = getAssociatedTokenAddressSync(noMint, user, false, TOKEN_2022_PROGRAM_ID);\n\n    // Check which accounts exist and have tokens\n    let hasYesTokens = false;\n    let hasNoTokens = false;\n\n    try {\n      const yesAccount = await getAccount(this.connection, userYesToken, undefined, TOKEN_2022_PROGRAM_ID);\n      hasYesTokens = yesAccount.amount > 0n;\n    } catch {\n      // Account doesn't exist\n    }\n\n    try {\n      const noAccount = await getAccount(this.connection, userNoToken, undefined, TOKEN_2022_PROGRAM_ID);\n      hasNoTokens = noAccount.amount > 0n;\n    } catch {\n      // Account doesn't exist\n    }\n\n    // Build instruction with appropriate accounts\n    const ix = await this.claimBurnMarket(\n      params,\n      hasYesTokens ? userYesToken : null,\n      hasNoTokens ? userNoToken : null\n    );\n    tx.add(ix);\n\n    return tx;\n  }\n  \n  /**\n   * Fetch global config account data\n   */\n  async getGlobalConfigAccount() {\n    const globalConfig = getGlobalConfigPda(this.program.programId);\n    return await this.program.account.globalConfig.fetch(globalConfig);\n  }\n\n\n  /**\n   * Fetch market account data\n   */\n  async getMarketAccount(admin: PublicKey, marketId: number | BN) {\n    const marketIdBn = new BN(marketId);\n    const marketPda = getMarketPda(this.program.programId, admin, marketIdBn);\n    return await this.program.account.market.fetch(marketPda);\n  }\n\n  async getMarketInfo(marketPda: PublicKey) {\n    const marketAccount = await this.program.account.market.fetch(marketPda);\n    return marketAccount;\n  }\n\n  /**\n   * Fetch vault account data\n   */\n  async getVaultAccount(marketPda: PublicKey) {\n    const vaultPda = getVaultPda(this.program.programId, marketPda);\n    return await getAccount(this.connection, vaultPda);\n  }\n\n/**\n   * 获取特定代币 (Mint) 的持有者数量\n   * 自动兼容经典 Token Program 和 Token-2022 Program\n   * \n   * @param mint - 代币 Mint 的公钥\n   * @param tokenProgram - 可选：明确指定代币程序 ID。如果不提供，将自动通过查询 Mint 账户信息来确定\n   * @returns 余额大于 0 的唯一持有者数量\n   */\nasync getTokenHolderCount(\n  mint: PublicKey,\n  tokenProgram?: PublicKey | string\n): Promise<number> {\n  try {\n    // 1. 确定 Token 程序 ID\n    let programId: PublicKey;\n    if (!tokenProgram) {\n      const mintInfo = await this.connection.getAccountInfo(mint);\n      if (!mintInfo) throw new Error(`Mint 账户不存在: ${mint.toBase58()}`);\n      \n      // 增加校验：只有 Token 或 Token-2022 程序拥有的账户才是合法的 Mint\n      if (!mintInfo.owner.equals(TOKEN_PROGRAM_ID) && !mintInfo.owner.equals(TOKEN_2022_PROGRAM_ID)) {\n        throw new Error(`地址 ${mint.toBase58()} 不是一个有效的代币 Mint (Owner 为 ${mintInfo.owner.toBase58()})`);\n      }\n      programId = mintInfo.owner;\n    } else {\n      programId = typeof tokenProgram === 'string' ? new PublicKey(tokenProgram) : tokenProgram;\n    }\n\n    // 2. 构造过滤器\n    const filters: any[] = [\n      {\n        memcmp: {\n          offset: 0, // Mint 地址始终在代币账户数据的偏移量 0 处\n          bytes: mint.toBase58(),\n        },\n      },\n    ];\n\n    // 只有经典 Token Program (Tokenkeg...) 账户大小固定为 165 字节\n    // Token-2022 (TokenzQd...) 账户因为可能包含 Extensions，大小是可变的，因此不使用 dataSize 过滤\n    if (programId.equals(TOKEN_PROGRAM_ID)) {\n      filters.unshift({ dataSize: 165 });\n    }\n\n    // 3. 执行 getProgramAccounts 查询\n    const accounts = await this.connection.getProgramAccounts(programId, {\n      filters,\n    });\n\n    // 4. 过滤出余额 > 0 的账户\n    // 无论哪个程序，余额 (Amount) 都在偏移量 64 处的 8 字节 (u64)\n    const holdersWithBalance = accounts.filter((account) => {\n      const data = account.account.data;\n      const amount = data.readBigUInt64LE(64);\n      return amount > 0n;\n    });\n\n    return holdersWithBalance.length;\n  } catch (error) {\n    console.error(`获取 Mint ${mint.toBase58()} 的持有者数量失败:`, error);\n    throw error;\n  }\n}\n\n    /**\n   * 获取综合的市场回收状态（包含链上数据）\n   * 该方法查询所有必要信息，以判断市场是否可以安全地回收租金\n   * \n   * @param marketPda - 市场的 PDA 公钥\n   * @param options - 配置选项\n   * @param options.skipHolderCount - 是否跳过昂贵的持有人数查询（默认为 false）。\n   *                                  如果只需判断是否满足合约关闭条件，建议设为 true 以提升性能。\n   * @returns 包含所有相关数据的市场回收状态\n   */\n    async getMarketReclaimStatus(\n      marketPda: PublicKey,\n      options: { skipHolderCount?: boolean } = {}\n    ): Promise<{\n      yesMint: PublicKey;\n      noMint: PublicKey;\n      vault: PublicKey;\n      yesSupply: number;\n      noSupply: number;\n      yesHolderCount: number;\n      noHolderCount: number;\n      vaultBalance: bigint;\n      canCloseOnChain: boolean;\n      blockers: string[];\n    }> {\n      const skipHolderCount = options.skipHolderCount ?? false;\n  \n      try {\n        // 1. 获取市场基础信息 (包含 totalYesSupply 和 totalNoSupply)\n        const marketInfo = await this.getMarketInfo(marketPda);\n        \n        // 2. 派生相关的 PDA 地址\n        const yesMint = PublicKey.findProgramAddressSync(\n          [Buffer.from(YES_MINT_SEED), marketPda.toBuffer()],\n          this.program.programId\n        )[0];\n        \n        const noMint = PublicKey.findProgramAddressSync(\n          [Buffer.from(NO_MINT_SEED), marketPda.toBuffer()],\n          this.program.programId\n        )[0];\n        \n        const vault = PublicKey.findProgramAddressSync(\n          [Buffer.from(VAULT_SEED), marketPda.toBuffer()],\n          this.program.programId\n        )[0];\n  \n        // 3. 并行查询链上详细数据\n        // 始终查询 vault 余额，根据选项决定是否查询 holder 数量\n        const queries: Promise<any>[] = [this.getVaultAccount(marketPda)];\n        \n        if (!skipHolderCount) {\n          // getTokenHolderCount 现在内部会自动识别 Token 程序类型\n          queries.push(this.getTokenHolderCount(yesMint));\n          queries.push(this.getTokenHolderCount(noMint));\n        }\n  \n        const results = await Promise.all(queries);\n        const vaultAccount = results[0];\n        const yesHolderCount = skipHolderCount ? 0 : results[1];\n        const noHolderCount = skipHolderCount ? 0 : results[2];\n  \n        // 4. 提取关键指标\n        const yesSupply = Number(marketInfo.totalYesSupply);\n        const noSupply = Number(marketInfo.totalNoSupply);\n        const vaultBalance = vaultAccount.amount;\n  \n        // 5. 判断是否满足链上关闭条件（遵循合约逻辑）\n        const blockers: string[] = [];\n        \n        // 核心检查：获胜方代币供应量必须为 0\n        if (marketInfo.winningOutcome !== null) {\n          const winningSupply = marketInfo.winningOutcome.yes !== undefined ? yesSupply : noSupply;\n          if (winningSupply > 0) {\n            blockers.push(`获胜方仍有 ${winningSupply} 个代币未领取/销毁`);\n          }\n        }\n        \n        // 核心检查：Vault 余额必须几乎为 0\n        const DUST_THRESHOLD = 100n;\n        if (vaultBalance >= DUST_THRESHOLD) {\n          blockers.push(`Vault 余额为 ${vaultBalance}（超过容差阈值: ${DUST_THRESHOLD}）`);\n        }\n        \n        // 如果未跳过 Holder 检查，则添加 Holder 相关的 blocker\n        if (!skipHolderCount) {\n          if (yesHolderCount > 0) {\n            blockers.push(`仍有 ${yesHolderCount} 个用户持有 Yes 代币账户`);\n          }\n          if (noHolderCount > 0) {\n            blockers.push(`仍有 ${noHolderCount} 个用户持有 No 代币账户`);\n          }\n        }\n  \n        // 如果 Supply > 0，通常也不建议关闭\n        if (yesSupply > 0) {\n          blockers.push(`Yes 代币总供应量不为 0: ${yesSupply}`);\n        }\n        if (noSupply > 0) {\n          blockers.push(`No 代币总供应量不为 0: ${noSupply}`);\n        }\n  \n        const canCloseOnChain = blockers.length === 0;\n  \n        return {\n          yesMint,\n          noMint,\n          vault,\n          yesSupply,\n          noSupply,\n          yesHolderCount,\n          noHolderCount,\n          vaultBalance,\n          canCloseOnChain,\n          blockers,\n        };\n      } catch (error) {\n        console.error(`获取市场 ${marketPda.toBase58()} 的回收状态失败:`, error);\n        throw error;\n      }\n    }\n}\n"]}
|
|
1260
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ASSOCIATED_TOKEN_PROGRAM_ID,\n  createTransferInstruction,\n  getAccount,\n  getAssociatedTokenAddressSync,\n  TOKEN_2022_PROGRAM_ID,\n  TOKEN_PROGRAM_ID\n} from \"@solana/spl-token\";\n\nimport { Program as AnchorProgram, AnchorProvider, Idl, Program, Wallet } from \"@coral-xyz/anchor\";\n\nimport BN from \"bn.js\";\n\nimport {\n  ComputeBudgetProgram,\n  Connection,\n  Keypair,\n  PublicKey,\n  SystemProgram,\n  Transaction,\n  TransactionInstruction\n} from \"@solana/web3.js\";\nimport { IDL } from \"./idl.js\";\nimport { DramaPm } from \"./types.js\";\nimport {\n  getGlobalConfigPda,\n  getMarketPda,\n  getMarketPdas,\n  getVaultPda,\n  NO_MINT_SEED,\n  VAULT_SEED,\n  YES_MINT_SEED\n} from \"./utils.js\";\n\nexport * from \"./utils.js\";\nexport { DramaPm, IDL };\n\nexport type Outcome = \"Yes\" | \"No\";\n\n/**\n * Priority fee options for accelerating transaction confirmation\n */\nexport interface PriorityFeeOptions {\n  /** Price per compute unit in micro-lamports (1 SOL = 1e9 lamports = 1e15 micro-lamports) */\n  computeUnitPrice?: number;\n  /** Maximum compute units for the transaction (default: 200,000 for normal txs, 400,000 for complex ones) */\n  computeUnitLimit?: number;\n}\n\n/**\n * Default priority fee options used when caller does not provide priorityFeeOptions.\n * computeUnitPrice: 100,000 micro-lamports/CU — suitable for most network conditions.\n * computeUnitLimit is not set here; each method applies its own default.\n */\nexport const DEFAULT_PRIORITY_FEE: PriorityFeeOptions = {\n  computeUnitPrice: 100_000,\n};\n\nexport interface CreateMarketParams {\n  admin: PublicKey;\n  marketId: number | BN;\n  yesPrice: number | BN;\n  noPrice: number | BN;\n  endTime: number | BN;\n  bettingToken: PublicKey;\n}\n\nexport interface PlaceBetParams {\n  user: PublicKey;\n  market: PublicKey; // Market PDA address\n  amount: number | BN;\n  outcome: Outcome;\n  bettingToken: PublicKey;\n  feeRecipient?: PublicKey; // Fee recipient address (optional, will fetch from config if not provided)\n  feeRecipientToken?: PublicKey | null; // Fee recipient token account (optional, used internally by buildPlaceBetTx)\n  createAta?: boolean; // Whether to create ATA instruction automatically\n}\n\nexport interface UpdateFeeConfigParams {\n  authority: PublicKey; // Can be authority or authorized admin\n  newFeeBps: number; // Fee in basis points (1 bps = 0.01%, max 2000 = 20%)\n  newFeeRecipient: PublicKey;\n  newFeeClaimBps: number; // Fee for claiming rewards in basis points\n}\n\nexport interface ClaimRewardsParams {\n  user: PublicKey;\n  market: PublicKey; // Market PDA address\n  bettingToken: PublicKey;\n  winningOutcome: Outcome;\n  sharesToClaim: number | BN; // Amount of shares to claim (0 = claim all)\n  closeAccount?: boolean; // Whether to close the outcome token account after claiming all shares (default: false)\n  feeRecipient?: PublicKey; // Fee recipient address (optional, will fetch from config if not provided)\n}\n\nexport interface BatchClaimParams {\n  user: PublicKey;\n  claims: Array<{\n    market: PublicKey;\n    bettingToken: PublicKey;\n    winningOutcome: Outcome;\n    sharesToClaim?: number | BN; // Amount of shares to claim (0 or undefined = claim all)\n    closeAccount?: boolean; // Whether to close the outcome token account after claiming all shares\n  }>;\n}\n\nexport interface RefundParams {\n  user: PublicKey;\n  market: PublicKey; // Market PDA address\n  bettingToken: PublicKey;\n  outcome: Outcome;\n  tokenAmount?: number | BN; // Amount of shares to refund. 0 or undefined means refund all shares.\n  closeAccount?: boolean; // Whether to close the outcome token account after refunding all shares (default: false)\n}\n\n/**\n * Parameters for refundV2 - refunding both Yes and No positions in one transaction.\n * Use this when a user has bet on both outcomes and wants to refund everything at once.\n */\nexport interface RefundV2Params {\n  user: PublicKey;\n  market: PublicKey; // Market PDA address\n  bettingToken: PublicKey;\n  yesTokenAmount?: number | BN; // Amount of Yes shares to refund. 0 or undefined means refund all.\n  noTokenAmount?: number | BN;  // Amount of No shares to refund. 0 or undefined means refund all.\n  closeYesAccount?: boolean; // Whether to close the Yes outcome token account (default: true)\n  closeNoAccount?: boolean;  // Whether to close the No outcome token account (default: true)\n}\n\n/**\n * Parameters for claim_burn_market instruction\n * Combines claiming rewards (if won) and burning tokens (if lost) in one call.\n * Always closes token accounts to reclaim rent.\n */\nexport interface ClaimBurnMarketParams {\n  user: PublicKey;\n  market: PublicKey; // Market PDA address\n  bettingToken: PublicKey;\n}\n\nexport interface UserMarketHoldParams {\n  user: PublicKey;\n  market: PublicKey; // Market PDA address\n}\n\nexport interface UserMarketHoldResult {\n  yesMint: PublicKey;\n  noMint: PublicKey;\n  yesTokenBalance: string; // Balance as string to preserve precision\n  noTokenBalance: string;  // Balance as string to preserve precision\n  hasYesTokenAccount: boolean;\n  hasNoTokenAccount: boolean;\n}\n\n/**\n * Parameters for placeBetV2 - combines user bet and bonus account bet in one transaction\n * Requires both user and bonusAccount to sign the transaction\n */\nexport interface PlaceBetV2Params {\n  user: PublicKey;              // User's public key (signer)\n  bonusAccount: PublicKey;      // Bonus account public key (signer)\n  market: PublicKey;            // Market PDA address\n  userAmount: number | BN;      // Amount user pays\n  bonusAmount: number | BN;     // Amount bonus account pays\n  outcome: Outcome;             // Outcome to bet on (Yes/No)\n  bettingToken: PublicKey;      // Betting token mint\n  feeRecipient?: PublicKey;     // Fee recipient address (optional)\n  createAta?: boolean;          // Whether to create ATA instruction automatically\n}\n\n/**\n * Result from buildPlaceBetV2Tx containing both the transaction and its serialized form\n * for split signing workflow (frontend user sign + backend bonus sign)\n */\nexport interface PlaceBetV2Result {\n  transaction: Transaction;     // Transaction object for local signing (testing)\n  requiredSigners: PublicKey[]; // List of required signers [user, bonusAccount]\n}\n\nexport class DramaPmClient {\n  program: Program<DramaPm>;\n  provider: AnchorProvider;\n  connection: Connection;\n\n  constructor(connection: Connection, wallet?: Wallet, programId?: PublicKey) {\n    this.connection = connection;\n    \n    // Create a default wallet if none provided\n    const defaultKeypair = Keypair.generate();\n    const defaultWallet: Wallet = {\n      publicKey: defaultKeypair.publicKey,\n      signTransaction: async (tx) => tx,\n      signAllTransactions: async (txs) => txs,\n      payer: defaultKeypair,\n    };\n    \n    this.provider = new AnchorProvider(\n      connection,\n      wallet || defaultWallet,\n      { commitment: \"confirmed\" }\n    );\n    \n    // Use custom programId if provided, otherwise use the default from IDL\n    const finalProgramId = programId || new PublicKey(IDL.address);\n    \n    // Create a new IDL with the custom programId\n    const customIdl = { ...IDL, address: finalProgramId.toBase58() };\n    \n    this.program = new AnchorProgram(customIdl as Idl, this.provider) as unknown as Program<DramaPm>;\n  }\n\n  /**\n   * Get the current program ID\n   */\n  getProgramId(): PublicKey {\n    return this.program.programId;\n  }\n\n  /**\n   * Set a new program ID and reinitialize the program instance\n   * Useful when redeploying the program to a new address\n   */\n  setProgramId(programId: PublicKey): void {\n    const customIdl = { ...IDL, address: programId.toBase58() };\n    this.program = new AnchorProgram(customIdl as Idl, this.provider) as unknown as Program<DramaPm>;\n  }\n\n  /**\n   * Check if an associated token account exists\n   */\n  async ataExists(ata: PublicKey): Promise<boolean> {\n    try {\n      await getAccount(this.connection, ata);\n      return true;\n    } catch {\n      return false;\n    }\n  }\n\n  /**\n   * Create an instruction to initialize an associated token account\n   * @param tokenProgram - Token program ID (TOKEN_PROGRAM_ID for betting token, TOKEN_2022_PROGRAM_ID for outcome tokens)\n   */\n  createAtaInstruction(\n    payer: PublicKey,\n    owner: PublicKey,\n    mint: PublicKey,\n    tokenProgram: PublicKey = TOKEN_PROGRAM_ID\n  ): TransactionInstruction {\n    const ata = getAssociatedTokenAddressSync(mint, owner, true, tokenProgram);\n    \n    // Use CreateIdempotent instruction (opcode 1) to support PDAs and idempotency\n    const keys = [\n      { pubkey: payer, isSigner: true, isWritable: true },\n      { pubkey: ata, isSigner: false, isWritable: true },\n      { pubkey: owner, isSigner: false, isWritable: false },\n      { pubkey: mint, isSigner: false, isWritable: false },\n      { pubkey: SystemProgram.programId, isSigner: false, isWritable: false },\n      { pubkey: tokenProgram, isSigner: false, isWritable: false },\n    ];\n\n    return new TransactionInstruction({\n      keys,\n      programId: ASSOCIATED_TOKEN_PROGRAM_ID,\n      data: Buffer.from([1]),\n    });\n  }\n\n  /**\n   * Initialize global configuration (Authority only)\n   */\n  async initializeConfig(authority: PublicKey): Promise<TransactionInstruction> {\n    const globalConfig = getGlobalConfigPda(this.program.programId);\n    return await this.program.methods\n      .initializeConfig()\n      .accountsPartial({\n        globalConfig,\n        authority: authority,\n        systemProgram: SystemProgram.programId,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to initialize config\n   */\n  async buildInitializeConfigTx(authority: PublicKey): Promise<Transaction> {\n    const ix = await this.initializeConfig(authority);\n    return new Transaction().add(ix);\n  }\n\n  /**\n   * Migrate GlobalConfig to new version with fee_claim_bps field (Authority only)\n   * Should be called once after program upgrade\n   */\n  async migrateConfig(authority: PublicKey): Promise<TransactionInstruction> {\n    const globalConfig = getGlobalConfigPda(this.program.programId);\n    return await this.program.methods\n      .migrateConfig()\n      .accountsPartial({\n        globalConfig,\n        authority: authority,\n        systemProgram: SystemProgram.programId,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to migrate config\n   */\n  async buildMigrateConfigTx(authority: PublicKey): Promise<Transaction> {\n    const ix = await this.migrateConfig(authority);\n    return new Transaction().add(ix);\n  }\n\n  /**\n   * Update authorized admin (Authority only)\n   */\n  async addAdmin(newAdmin: PublicKey): Promise<TransactionInstruction> {\n    const globalConfig = getGlobalConfigPda(this.program.programId);\n\n    return await this.program.methods\n      .addAdmin(newAdmin)\n      .accountsPartial({\n        globalConfig,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to update admin\n   */\n  async buildAddAdminTx(newAdmin: PublicKey): Promise<Transaction> {\n    const ix = await this.addAdmin(newAdmin);\n    return new Transaction().add(ix);\n  }\n\n  /**\n   * Remove authorized admin (Authority only)\n   */\n  async removeAdmin(adminToRemove: PublicKey): Promise<TransactionInstruction> {\n    const globalConfig = getGlobalConfigPda(this.program.programId);\n\n    return await this.program.methods\n      .removeAdmin(adminToRemove)\n      .accountsPartial({\n        globalConfig,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to remove admin\n   */\n  async buildRemoveAdminTx(adminToRemove: PublicKey): Promise<Transaction> {\n    const ix = await this.removeAdmin(adminToRemove);\n    return new Transaction().add(ix);\n  }\n\n  /**\n   * Update fee configuration (Authority or authorized admin)\n   */\n  async updateFeeConfig(params: UpdateFeeConfigParams): Promise<TransactionInstruction> {\n    const globalConfig = getGlobalConfigPda(this.program.programId);\n\n    return await this.program.methods\n      .updateFeeConfig(params.newFeeBps, params.newFeeRecipient, params.newFeeClaimBps)\n      .accountsPartial({\n        globalConfig: globalConfig,\n        authority: params.authority,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to update fee config\n   */\n  async buildUpdateFeeConfigTx(params: UpdateFeeConfigParams): Promise<Transaction> {\n    const ix = await this.updateFeeConfig(params);\n    return new Transaction().add(ix);\n  }\n\n  /**\n   * Create a new prediction market instruction\n   */\n  async createMarket(params: CreateMarketParams): Promise<TransactionInstruction> {\n    const { admin, marketId, yesPrice, noPrice, endTime, bettingToken } = params;\n    \n    const marketIdBn = new BN(marketId);\n    const yesPriceBn = new BN(yesPrice);\n    const noPriceBn = new BN(noPrice);\n    const endTimeBn = new BN(endTime);\n\n    const pdas = getMarketPdas(this.program.programId, admin, marketIdBn);\n    const globalConfig = getGlobalConfigPda(this.program.programId);\n\n    return await this.program.methods\n      .createMarket({\n          marketId: marketIdBn,\n          yesPrice: yesPriceBn,\n          noPrice: noPriceBn,\n          endTime: endTimeBn,\n        })\n        .accountsPartial({\n          globalConfig,\n          market: pdas.market,\n          yesMint: pdas.yesMint,\n          noMint: pdas.noMint,\n          bettingToken: bettingToken,\n          vault: pdas.vault,\n          admin: admin,\n          tokenProgram: TOKEN_PROGRAM_ID,\n          systemProgram: SystemProgram.programId,\n        })\n        .instruction();\n  }\n\n  /**\n   * Build a complete transaction to create a market\n   * @param params - Market creation parameters\n   * @param priorityFeeOptions - Optional priority fee settings to accelerate transaction confirmation\n   * @param priorityFeeOptions.computeUnitPrice - Price per compute unit in micro-lamports (e.g., 1000 = 0.000001 SOL per CU)\n   * @param priorityFeeOptions.computeUnitLimit - Max compute units (default: 400,000 for createMarket due to multiple PDA inits)\n   */\n  async buildCreateMarketTx(\n    params: CreateMarketParams,\n    priorityFeeOptions?: PriorityFeeOptions\n  ): Promise<Transaction> {\n    const tx = new Transaction();\n\n    // Add priority fee instructions (use default if not provided)\n    const feeOpts = priorityFeeOptions ?? DEFAULT_PRIORITY_FEE;\n    // Set compute unit limit (createMarket is a complex tx, default to 400k)\n    const computeUnitLimit = feeOpts.computeUnitLimit ?? 400_000;\n    tx.add(\n      ComputeBudgetProgram.setComputeUnitLimit({\n        units: computeUnitLimit,\n      })\n    );\n    if (feeOpts.computeUnitPrice !== undefined && feeOpts.computeUnitPrice > 0) {\n      tx.add(\n        ComputeBudgetProgram.setComputeUnitPrice({\n          microLamports: feeOpts.computeUnitPrice,\n        })\n      );\n    }\n\n    const ix = await this.createMarket(params);\n    tx.add(ix);\n    \n    return tx;\n  }\n\n  /**\n   * Place a bet instruction (without ATA creation)\n   */\n  async placeBet(params: PlaceBetParams): Promise<TransactionInstruction> {\n    const { user, market, amount, outcome, bettingToken, feeRecipientToken } = params;\n    \n    const amountBn = new BN(amount);\n    const outcomeEnum = outcome === \"Yes\" ? { yes: {} } : { no: {} };\n\n    // Get global config for fee info\n    const globalConfig = getGlobalConfigPda(this.program.programId);\n\n    // Derive PDAs from market address\n    const yesMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(YES_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    const noMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(NO_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    const vault = PublicKey.findProgramAddressSync(\n      [Buffer.from(VAULT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n\n    const userBettingToken = getAssociatedTokenAddressSync(bettingToken, user);\n    \n    // Determine which outcome token the user will receive\n    // Outcome tokens (Yes/No) use Token-2022 program\n    const targetMint = outcome === \"Yes\" ? yesMint : noMint;\n    const userOutcomeToken = getAssociatedTokenAddressSync(targetMint, user, false, TOKEN_2022_PROGRAM_ID);\n\n    return await this.program.methods\n      .placeBet({\n        buyOutcome: outcomeEnum,\n        amount: amountBn,\n      })\n      .accountsPartial({\n        globalConfig,\n        market,\n        yesMint,\n        noMint,\n        vault,\n        feeRecipientToken: feeRecipientToken || null,\n        userOutcomeToken,\n        userBettingToken,\n        user,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to place a bet (with optional ATA creation for both outcome token and fee recipient)\n   */\n  async buildPlaceBetTx(params: PlaceBetParams): Promise<Transaction> {\n    const { user, market, outcome, bettingToken, createAta = true } = params;\n    \n    const tx = new Transaction();\n    \n    // Fetch config to check fee_bps\n    const configAccount = await this.getGlobalConfigAccount();\n    \n    // Derive mint PDAs from market address\n    const yesMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(YES_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    const noMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(NO_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    \n    // Outcome tokens (Yes/No) use Token-2022 program\n    const targetMint = outcome === \"Yes\" ? yesMint : noMint;\n    const userOutcomeToken = getAssociatedTokenAddressSync(targetMint, user, false, TOKEN_2022_PROGRAM_ID);\n\n    // Check if user outcome ATA exists and create if needed\n    if (createAta) {\n      const exists = await this.ataExists(userOutcomeToken);\n      if (!exists) {\n        const createAtaIx = this.createAtaInstruction(user, user, targetMint, TOKEN_2022_PROGRAM_ID);\n        tx.add(createAtaIx);\n      }\n    }\n\n    // Handle fee recipient token account if fee_bps > 0\n    let feeRecipientToken: PublicKey | null = null;\n    if (configAccount.feeBps > 0) {\n      const feeRecipientAddress = params.feeRecipient || configAccount.feeRecipient;\n      feeRecipientToken = getAssociatedTokenAddressSync(bettingToken, feeRecipientAddress);\n      \n      // Check if fee recipient ATA exists and create if needed\n      const feeAtaExists = await this.ataExists(feeRecipientToken);\n      if (!feeAtaExists) {\n        const createFeeAtaIx = this.createAtaInstruction(user, feeRecipientAddress, bettingToken);\n        tx.add(createFeeAtaIx);\n      }\n    }\n\n    const placeBetIx = await this.placeBet({\n      ...params,\n      feeRecipientToken,\n    });\n    tx.add(placeBetIx);\n\n    return tx;\n  }\n\n  /**\n   * Build a transaction to place bets from both user and bonus account in one transaction.\n   * This transaction requires two signers: user and bonusAccount.\n   * \n   * Use case: User pays part of the bet, bonus account (backend) pays the rest.\n   * Example: User bets 10U total, user pays 8U, bonus account pays 2U.\n   * \n   * Both bets are placed on the same outcome, but outcome tokens go to each account respectively.\n   */\n  async buildPlaceBetV2Tx(params: PlaceBetV2Params): Promise<PlaceBetV2Result> {\n    const { \n      user, \n      bonusAccount, \n      market, \n      userAmount, \n      bonusAmount, \n      outcome, \n      bettingToken, \n      createAta = true \n    } = params;\n    \n    const tx = new Transaction();\n    \n    // Fetch config to check fee_bps\n    const configAccount = await this.getGlobalConfigAccount();\n    \n    // Derive mint PDAs from market address\n    const yesMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(YES_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    const noMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(NO_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    \n    // Outcome tokens (Yes/No) use Token-2022 program\n    const targetMint = outcome === \"Yes\" ? yesMint : noMint;\n    \n    // User's outcome token account\n    const userOutcomeToken = getAssociatedTokenAddressSync(targetMint, user, false, TOKEN_2022_PROGRAM_ID);\n    \n    // Bonus account's outcome token account\n    const bonusOutcomeToken = getAssociatedTokenAddressSync(targetMint, bonusAccount, false, TOKEN_2022_PROGRAM_ID);\n\n    // Create ATAs if needed\n    if (createAta) {\n      // Check if user outcome ATA exists and create if needed\n      const userAtaExists = await this.ataExists(userOutcomeToken);\n      if (!userAtaExists) {\n        const createUserAtaIx = this.createAtaInstruction(user, user, targetMint, TOKEN_2022_PROGRAM_ID);\n        tx.add(createUserAtaIx);\n      }\n      \n      // Check if bonus account outcome ATA exists and create if needed\n      const bonusAtaExists = await this.ataExists(bonusOutcomeToken);\n      if (!bonusAtaExists) {\n        // User pays for creating the bonus account's ATA\n        const createBonusAtaIx = this.createAtaInstruction(user, bonusAccount, targetMint, TOKEN_2022_PROGRAM_ID);\n        tx.add(createBonusAtaIx);\n      }\n    }\n\n    // Handle fee recipient token account if fee_bps > 0\n    let feeRecipientToken: PublicKey | null = null;\n    if (configAccount.feeBps > 0) {\n      const feeRecipientAddress = params.feeRecipient || configAccount.feeRecipient;\n      feeRecipientToken = getAssociatedTokenAddressSync(bettingToken, feeRecipientAddress);\n      \n      // Check if fee recipient ATA exists and create if needed\n      const feeAtaExists = await this.ataExists(feeRecipientToken);\n      if (!feeAtaExists) {\n        const createFeeAtaIx = this.createAtaInstruction(user, feeRecipientAddress, bettingToken);\n        tx.add(createFeeAtaIx);\n      }\n    }\n\n    // Create user's placeBet instruction\n    const userBetIx = await this.placeBet({\n      user,\n      market,\n      amount: userAmount,\n      outcome,\n      bettingToken,\n      feeRecipientToken,\n    });\n    tx.add(userBetIx);\n\n    // Create bonus account's placeBet instruction\n    const bonusBetIx = await this.placeBet({\n      user: bonusAccount,\n      market,\n      amount: bonusAmount,\n      outcome,\n      bettingToken,\n      feeRecipientToken,\n    });\n    tx.add(bonusBetIx);\n    return {\n      transaction: tx,\n      requiredSigners: [user, bonusAccount],\n    };\n  }\n\n  /**\n   * Deserialize a base64 encoded transaction\n   * Use this on frontend to decode the transaction received from backend\n   */\n  static deserializeTransaction(serializedTx: string): Transaction {\n    const buffer = Buffer.from(serializedTx, 'base64');\n    return Transaction.from(buffer);\n  }\n\n  /**\n   * Sign a partially signed transaction with the bonus account (backend side)\n   * \n   * @param userSignedTxBase64 - Base64 encoded transaction that has been signed by user\n   * @param bonusAccountKeypair - The bonus account keypair for signing\n   * @returns The fully signed transaction ready for submission\n   */\n  static signWithKeyPair(userSignedTxBase64: string, keyPair: Keypair): Transaction {\n    const buffer = Buffer.from(userSignedTxBase64, 'base64');\n    const tx = Transaction.from(buffer);\n    tx.partialSign(keyPair);\n    return tx;\n  }\n\n  // async transfer()\n\n  /**\n   * Build a transaction to withdraw bonus (transfer USDT from bonus account to user)\n   * This transaction requires the bonus account to sign.\n   * \n   * @param bonusAccount - The bonus account public key (signer, source of funds)\n   * @param user - The user's public key (destination)\n   * @param tokenMint - The token mint address (e.g., USDT)\n   * @param amount - Amount to transfer (in token's smallest unit, e.g., 1_000_000 for 1 USDT with 6 decimals)\n   * @param createAta - Whether to create the user's ATA if it doesn't exist (default: true)\n   * @returns Transaction ready for signing\n   */\n  async buildWithdrawBonusTx(params: {\n    bonusAccount: PublicKey;\n    user: PublicKey;\n    tokenMint: PublicKey;\n    amount: number | BN;\n    createAta?: boolean;\n  }): Promise<Transaction> {\n    const { bonusAccount, user, tokenMint, amount, createAta = true } = params;\n    const amountBn = new BN(amount);\n    \n    const tx = new Transaction();\n    \n    // Get ATA addresses for both accounts\n    const bonusTokenAccount = getAssociatedTokenAddressSync(tokenMint, bonusAccount);\n    const userTokenAccount = getAssociatedTokenAddressSync(tokenMint, user);\n    \n    // Create user's ATA if needed\n    if (createAta) {\n      const userAtaExists = await this.ataExists(userTokenAccount);\n      if (!userAtaExists) {\n        const createUserAtaIx = this.createAtaInstruction(bonusAccount, user, tokenMint);\n        tx.add(createUserAtaIx);\n      }\n    }\n    \n    // Create transfer instruction\n    const transferIx = createTransferInstruction(\n      bonusTokenAccount,  // source\n      userTokenAccount,   // destination\n      bonusAccount,       // owner (signer)\n      BigInt(amountBn.toString()),  // amount\n      [],                 // multiSigners (empty for single signer)\n      TOKEN_PROGRAM_ID    // program id\n    );\n    tx.add(transferIx);\n    \n    return tx;\n  }\n\n  /**\n   * Build and return a transaction for withdrawing bonus with serialization info\n   * Useful for split signing workflow where user/admin builds tx and bonus account signs\n   * \n   * @returns Object containing transaction and required signers\n   */\n  async buildWithdrawBonusTxWithInfo(params: {\n    bonusAccount: PublicKey;\n    user: PublicKey;\n    tokenMint: PublicKey;\n    amount: number | BN;\n    createAta?: boolean;\n  }): Promise<{ transaction: Transaction; requiredSigners: PublicKey[] }> {\n    const tx = await this.buildWithdrawBonusTx(params);\n    return {\n      transaction: tx,\n      requiredSigners: [params.bonusAccount],\n    };\n  }\n\n  /**\n   * Claim rewards after market resolution\n   */\n  async claimRewards(params: ClaimRewardsParams): Promise<TransactionInstruction> {\n    const { user, market, bettingToken, winningOutcome } = params;\n\n    // Derive mint PDAs from market address\n    const yesMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(YES_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    const noMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(NO_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n\n    // Derive vault PDA\n    const vault = PublicKey.findProgramAddressSync(\n      [Buffer.from(VAULT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n\n    const userBettingToken = getAssociatedTokenAddressSync(bettingToken, user);\n    // Outcome tokens (Yes/No) use Token-2022 program\n    const targetMint = winningOutcome === \"Yes\" ? yesMint : noMint;\n    const userOutcomeToken = getAssociatedTokenAddressSync(targetMint, user, false, TOKEN_2022_PROGRAM_ID);\n    const sharesToClaimBn = new BN(params.sharesToClaim);\n    const closeAccount = params.closeAccount ?? true;\n    return await this.program.methods\n      .claimRewards({\n        tokenAmount: sharesToClaimBn,\n        closeAccount,\n      })\n      .accountsPartial({\n        market,\n        yesMint,\n        noMint,\n        vault,\n        userOutcomeToken,\n        userBettingToken,\n        user,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to claim rewards\n   */\n  async buildClaimRewardsTx(params: ClaimRewardsParams): Promise<Transaction> {\n    const { user, market, bettingToken, winningOutcome } = params;\n    const tx = new Transaction();\n\n    // Derive mint PDAs from market address\n    const yesMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(YES_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n\n    const noMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(NO_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n\n    // Derive vault PDA\n    const vault = PublicKey.findProgramAddressSync(\n      [Buffer.from(VAULT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n\n    const userBettingToken = getAssociatedTokenAddressSync(bettingToken, user);\n    // Outcome tokens (Yes/No) use Token-2022 program\n    const targetMint = winningOutcome === \"Yes\" ? yesMint : noMint;\n    const userOutcomeToken = getAssociatedTokenAddressSync(targetMint, user, false, TOKEN_2022_PROGRAM_ID);\n    const sharesToClaimBn = new BN(params.sharesToClaim);\n    const closeAccount = params.closeAccount ?? true;\n\n    const ix = await this.program.methods\n      .claimRewards({\n        tokenAmount: sharesToClaimBn,\n        closeAccount,\n      })\n      .accountsPartial({\n        market,\n        yesMint,\n        noMint,\n        vault,\n        userOutcomeToken,\n        userBettingToken,\n        user,\n      })\n      .instruction();\n    \n    tx.add(ix);\n    return tx;\n  }\n\n  /**\n   * Build instructions to claim rewards from multiple markets\n   * Returns an array of instructions that can be batched into transactions\n   */\n  async batchClaimRewards(params: BatchClaimParams): Promise<TransactionInstruction[]> {\n    const { user, claims } = params;\n    const instructions: TransactionInstruction[] = [];\n\n    for (const claim of claims) {\n      const ix = await this.claimRewards({\n        user,\n        market: claim.market,\n        bettingToken: claim.bettingToken,\n        winningOutcome: claim.winningOutcome,\n        sharesToClaim: claim.sharesToClaim ?? 0,\n        closeAccount: claim.closeAccount ?? true,\n      });\n      instructions.push(ix);\n    }\n\n    return instructions;\n  }\n\n  /**\n   * Build transactions to claim rewards from multiple markets\n   * Automatically splits into multiple transactions if needed (max 5 claims per tx to avoid size limits)\n   * @param params - Batch claim parameters\n   * @param maxClaimsPerTx - Maximum claims per transaction (default: 5)\n   * @returns Array of transactions\n   */\n  async buildBatchClaimRewardsTx(\n    params: BatchClaimParams,\n    maxClaimsPerTx: number = 5\n  ): Promise<Transaction[]> {\n    const instructions = await this.batchClaimRewards(params);\n    const transactions: Transaction[] = [];\n\n    // Split instructions into chunks\n    for (let i = 0; i < instructions.length; i += maxClaimsPerTx) {\n      const chunk = instructions.slice(i, i + maxClaimsPerTx);\n      const tx = new Transaction();\n      chunk.forEach(ix => tx.add(ix));\n      transactions.push(tx);\n    }\n\n    return transactions;\n  }\n\n  /**\n   * Refund bets if market is refunded\n   * @param params.tokenAmount - Amount of shares to refund. 0 or undefined means refund all shares.\n   *                             This allows users to partially refund their position across multiple transactions.\n   */\n  async refund(params: RefundParams): Promise<TransactionInstruction> {\n    const { user, market, bettingToken, outcome, tokenAmount, closeAccount = true } = params;\n    \n    const outcomeEnum = outcome === \"Yes\" ? { yes: {} } : { no: {} };\n    \n    // Convert tokenAmount to BN (0 means refund all)\n    const tokenAmountBn = new BN(tokenAmount ?? 0);\n    \n    // Derive mint PDAs from market address\n    const yesMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(YES_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    const noMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(NO_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n\n    // Derive vault PDA\n    const vault = PublicKey.findProgramAddressSync(\n      [Buffer.from(VAULT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n\n    const userBettingToken = getAssociatedTokenAddressSync(bettingToken, user);\n    // Outcome tokens (Yes/No) use Token-2022 program\n    const targetMint = outcome === \"Yes\" ? yesMint : noMint;\n    const userOutcomeToken = getAssociatedTokenAddressSync(targetMint, user, false, TOKEN_2022_PROGRAM_ID);\n\n    return await this.program.methods\n      .refund({\n        outcome: outcomeEnum,\n        tokenAmount: tokenAmountBn,\n        closeAccount,\n      })\n      .accountsPartial({\n        market: market,\n        yesMint: yesMint,\n        noMint: noMint,\n        vault: vault,\n        userOutcomeToken: userOutcomeToken,\n        userBettingToken: userBettingToken,\n        tokenProgram: TOKEN_PROGRAM_ID,\n        token2022Program: TOKEN_2022_PROGRAM_ID,\n        user: user,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to refund\n   */\n  async buildRefundTx(params: RefundParams): Promise<Transaction> {\n    const ix = await this.refund(params);\n    return new Transaction().add(ix);\n  }\n\n  /**\n   * Refund both Yes and No positions in a single transaction.\n   * \n   * Use this method when a user has bet on both Yes and No outcomes and needs to \n   * refund all positions after the market has been resolved as \"Refunded\" (None).\n   * \n   * This method automatically:\n   * - Checks if the user has Yes tokens and/or No tokens\n   * - Only includes refund instructions for outcomes the user actually holds\n   * - Closes the token accounts after refunding (by default)\n   * \n   * @param params - RefundV2Params\n   * @param params.user - User's public key (signer)\n   * @param params.market - Market PDA address\n   * @param params.bettingToken - Betting token mint (e.g., USDC)\n   * @param params.yesTokenAmount - Optional. Amount of Yes tokens to refund. 0 or undefined = refund all.\n   * @param params.noTokenAmount - Optional. Amount of No tokens to refund. 0 or undefined = refund all.\n   * @param params.closeYesAccount - Optional. Whether to close the Yes token account after refund. Default: true\n   * @param params.closeNoAccount - Optional. Whether to close the No token account after refund. Default: true\n   * \n   * @returns Transaction containing refund instructions for both outcomes (if applicable)\n   * \n   * @example\n   * ```typescript\n   * // Basic usage: Refund all Yes and No tokens\n   * const tx = await client.buildRefundV2Tx({\n   *   user: userPublicKey,\n   *   market: marketPda,\n   *   bettingToken: usdcMint,\n   * });\n   * \n   * // Sign and send\n   * tx.recentBlockhash = (await connection.getLatestBlockhash()).blockhash;\n   * tx.feePayer = userPublicKey;\n   * await wallet.signTransaction(tx);\n   * await connection.sendRawTransaction(tx.serialize());\n   * ```\n   * \n   * @example\n   * ```typescript\n   * // Keep token accounts open (don't close them)\n   * const tx = await client.buildRefundV2Tx({\n   *   user: userPublicKey,\n   *   market: marketPda,\n   *   bettingToken: usdcMint,\n   *   closeYesAccount: false, // Keep Yes token account open\n   *   closeNoAccount: false,  // Keep No token account open\n   * });\n   * ```\n   * \n   * @remarks\n   * - The market must be in \"Refunded\" status for this method to work\n   * - If the user only has tokens on one side, only that side will be refunded\n   * - The returned transaction will be empty if the user has no tokens on either side\n   */\n  async buildRefundV2Tx(params: RefundV2Params): Promise<Transaction> {\n    const { \n      user, \n      market, \n      bettingToken,\n      yesTokenAmount,\n      noTokenAmount,\n      closeYesAccount = true,\n      closeNoAccount = true \n    } = params;\n    \n    const tx = new Transaction();\n    \n    // Derive mint PDAs from market address\n    const yesMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(YES_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    const noMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(NO_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    \n    // Get user's outcome token accounts\n    const userYesToken = getAssociatedTokenAddressSync(yesMint, user, false, TOKEN_2022_PROGRAM_ID);\n    const userNoToken = getAssociatedTokenAddressSync(noMint, user, false, TOKEN_2022_PROGRAM_ID);\n    \n    // Check if user has Yes tokens\n    let hasYesTokens = false;\n    let yesBalance = 0;\n    try {\n      const yesAccount = await this.connection.getTokenAccountBalance(userYesToken);\n      yesBalance = Number(yesAccount.value.amount);\n      hasYesTokens = yesBalance > 0;\n    } catch {\n      // Account doesn't exist or has no balance\n    }\n    \n    // Check if user has No tokens\n    let hasNoTokens = false;\n    let noBalance = 0;\n    try {\n      const noAccount = await this.connection.getTokenAccountBalance(userNoToken);\n      noBalance = Number(noAccount.value.amount);\n      hasNoTokens = noBalance > 0;\n    } catch {\n      // Account doesn't exist or has no balance\n    }\n    \n    // Add Yes refund instruction if user has Yes tokens\n    if (hasYesTokens) {\n      const yesRefundIx = await this.refund({\n        user,\n        market,\n        bettingToken,\n        outcome: \"Yes\",\n        tokenAmount: 0,\n        closeAccount: closeYesAccount,\n      });\n      tx.add(yesRefundIx);\n    }\n    \n    // Add No refund instruction if user has No tokens\n    if (hasNoTokens) {\n      const noRefundIx = await this.refund({\n        user,\n        market,\n        bettingToken,\n        outcome: \"No\",\n        tokenAmount: 0,\n        closeAccount: closeNoAccount,\n      });\n      tx.add(noRefundIx);\n    }\n    \n    return tx;\n  }\n\n  /**\n   * Resolve a market (Admin only)\n   */\n  async resolveMarketByID(\n    admin: PublicKey,\n    marketId: number | BN,\n    winningOutcome: \"Yes\" | \"No\" | null,\n    feeRecipient?: PublicKey\n  ): Promise<TransactionInstruction> {\n    const marketIdBn = new BN(marketId);\n    const marketPda = getMarketPda(this.program.programId, admin, marketIdBn);\n    const globalConfig = getGlobalConfigPda(this.program.programId);\n\n    let outcomeEnum: any = null;\n    if (winningOutcome === \"Yes\") {\n      outcomeEnum = { yes: {} };\n    } else if (winningOutcome === \"No\") {\n      outcomeEnum = { no: {} };\n    }\n\n    // Get market info to determine betting token\n    const marketInfo = await this.getMarketInfo(marketPda);\n    // fee recipient address\n    const feeRecipientAddress = feeRecipient || (await this.getGlobalConfigAccount()).feeRecipient;\n    // fee recipient token account (allowOwnerOffCurve for multisig/PDA)\n    const feeRecipientToken = getAssociatedTokenAddressSync(marketInfo.bettingToken, feeRecipientAddress, true);\n\n    // Derive vault PDA\n    const vault = PublicKey.findProgramAddressSync(\n      [Buffer.from(VAULT_SEED), marketPda.toBuffer()],\n      this.program.programId\n    )[0];\n\n    return await this.program.methods\n      .resolveMarket(outcomeEnum)\n      .accountsPartial({\n        globalConfig,\n        market: marketPda,\n        vault,\n        feeRecipient: feeRecipientToken,\n        admin,\n        tokenProgram: TOKEN_PROGRAM_ID,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to resolve a market\n   * @param priorityFeeOptions - Optional priority fee settings to accelerate transaction confirmation\n   */\n  async buildResolveMarketTxByID(\n    admin: PublicKey,\n    marketId: number | BN,\n    winningOutcome: \"Yes\" | \"No\" | null,\n    feeRecipient?: PublicKey,\n    priorityFeeOptions?: PriorityFeeOptions\n  ): Promise<Transaction> {\n    const marketIdBn = new BN(marketId);\n    const marketPda = getMarketPda(this.program.programId, admin, marketIdBn);\n    const marketInfo = await this.getMarketInfo(marketPda);\n    const globalConfigAccount = await this.getGlobalConfigAccount();\n    const feeRecipientAddress = feeRecipient || globalConfigAccount.feeRecipient;\n    // allowOwnerOffCurve for multisig/PDA fee recipients\n    const feeRecipientToken = getAssociatedTokenAddressSync(marketInfo.bettingToken, feeRecipientAddress, true);\n\n    const tx = new Transaction();\n\n    // Add priority fee instructions (use default if not provided)\n    const feeOpts = priorityFeeOptions ?? DEFAULT_PRIORITY_FEE;\n    const computeUnitLimit = feeOpts.computeUnitLimit ?? 400_000;\n    tx.add(\n      ComputeBudgetProgram.setComputeUnitLimit({\n        units: computeUnitLimit,\n      })\n    );\n    if (feeOpts.computeUnitPrice !== undefined && feeOpts.computeUnitPrice > 0) {\n      tx.add(\n        ComputeBudgetProgram.setComputeUnitPrice({\n          microLamports: feeOpts.computeUnitPrice,\n        })\n      );\n    }\n\n    // Check if fee recipient token account exists and create if needed\n    const feeRecipientAtaExists = await this.ataExists(feeRecipientToken);\n    if (!feeRecipientAtaExists) {\n      const createFeeRecipientAtaIx = this.createAtaInstruction(admin, feeRecipientAddress, marketInfo.bettingToken);\n      tx.add(createFeeRecipientAtaIx);\n    }\n\n    // Add resolve market instruction\n    const resolveMarketIx = await this.resolveMarketByID(admin, marketId, winningOutcome, feeRecipient);\n    tx.add(resolveMarketIx);\n\n    return tx;\n  }\n\n  /**\n   * Resolve a market (Admin only)\n   */\n  async resolveMarket(\n    admin: PublicKey,\n    market: PublicKey,\n    winningOutcome: \"Yes\" | \"No\" | null,\n    feeRecipient?: PublicKey\n  ): Promise<TransactionInstruction> {\n    const globalConfig = getGlobalConfigPda(this.program.programId);\n\n    let outcomeEnum: any = null;\n    if (winningOutcome === \"Yes\") {\n      outcomeEnum = { yes: {} };\n    } else if (winningOutcome === \"No\") {\n      outcomeEnum = { no: {} };\n    }\n\n    // Get market info to determine betting token\n    const marketInfo = await this.getMarketInfo(market);\n    const feeRecipientAddress = feeRecipient || (await this.getGlobalConfigAccount()).feeRecipient;\n    // allowOwnerOffCurve for multisig/PDA fee recipients\n    const feeRecipientToken = getAssociatedTokenAddressSync(marketInfo.bettingToken, feeRecipientAddress, true);\n\n    // Derive vault PDA\n    const vault = PublicKey.findProgramAddressSync(\n      [Buffer.from(VAULT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n\n    return await this.program.methods\n      .resolveMarket(outcomeEnum)\n      .accountsPartial({\n        globalConfig,\n        market: market,\n        vault,\n        feeRecipient: feeRecipientToken,\n        admin,\n        tokenProgram: TOKEN_PROGRAM_ID,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to resolve a market\n   * @param priorityFeeOptions - Optional priority fee settings to accelerate transaction confirmation\n   */\n  async buildResolveMarketTx(\n    admin: PublicKey,\n    market: PublicKey,\n    winningOutcome: \"Yes\" | \"No\" | null,\n    feeRecipient?: PublicKey,\n    priorityFeeOptions?: PriorityFeeOptions\n  ): Promise<Transaction> {\n    const marketInfo = await this.getMarketInfo(market);\n    const globalConfigAccount = await this.getGlobalConfigAccount();\n    const feeRecipientAddress = feeRecipient || globalConfigAccount.feeRecipient;\n    // allowOwnerOffCurve for multisig/PDA fee recipients\n    const feeRecipientToken = getAssociatedTokenAddressSync(marketInfo.bettingToken, feeRecipientAddress, true);\n\n    const tx = new Transaction();\n\n    // Add priority fee instructions (use default if not provided)\n    const feeOpts = priorityFeeOptions ?? DEFAULT_PRIORITY_FEE;\n    const computeUnitLimit = feeOpts.computeUnitLimit ?? 400_000;\n    tx.add(\n      ComputeBudgetProgram.setComputeUnitLimit({\n        units: computeUnitLimit,\n      })\n    );\n    if (feeOpts.computeUnitPrice !== undefined && feeOpts.computeUnitPrice > 0) {\n      tx.add(\n        ComputeBudgetProgram.setComputeUnitPrice({\n          microLamports: feeOpts.computeUnitPrice,\n        })\n      );\n    }\n\n    // Check if fee recipient token account exists and create if needed\n    const feeRecipientAtaExists = await this.ataExists(feeRecipientToken);\n    if (!feeRecipientAtaExists) {\n      const createFeeRecipientAtaIx = this.createAtaInstruction(admin, feeRecipientAddress, marketInfo.bettingToken);\n      tx.add(createFeeRecipientAtaIx);\n    }\n\n    // Add resolve market instruction\n    const resolveMarketIx = await this.resolveMarket(admin, market, winningOutcome, feeRecipient);\n    tx.add(resolveMarketIx);\n\n    return tx;\n  }\n\n  /**\n   * Close a market (Admin only)\n   */\n  async closeMarket(\n    admin: PublicKey,\n    market: PublicKey\n  ): Promise<TransactionInstruction> {\n    return await this.program.methods\n      .closeMarket()\n      .accountsPartial({\n        market: market,\n        admin: admin,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to close a market\n   */\n  async buildCloseMarketTx(\n    admin: PublicKey,\n    market: PublicKey\n  ): Promise<Transaction> {\n    const ix = await this.closeMarket(admin, market);\n    return new Transaction().add(ix);\n  }\n\n  /**\n   * Close a market (Admin only)\n   */\n  async closeMarketByID(\n    admin: PublicKey,\n    marketId: number | BN\n  ): Promise<TransactionInstruction> {\n    const marketIdBn = new BN(marketId);\n    const marketPda = getMarketPda(this.program.programId, admin, marketIdBn);\n\n    return await this.program.methods\n      .closeMarket()\n      .accountsPartial({\n        market: marketPda,\n        admin: admin,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to close a market\n   */\n  async buildCloseMarketTxByID(\n    admin: PublicKey,\n    marketId: number | BN\n  ): Promise<Transaction> {\n    const ix = await this.closeMarketByID(admin, marketId);\n    return new Transaction().add(ix);\n  }\n\n  /**\n   * Close market account and reclaim rent (Admin only)\n   * Can only be called after market is resolved and all rewards claimed\n   */\n  async closeMarketAccount(\n    admin: PublicKey,\n    market: PublicKey\n  ): Promise<TransactionInstruction> {\n    // Derive PDAs\n    const yesMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(YES_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    const noMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(NO_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    const vault = PublicKey.findProgramAddressSync(\n      [Buffer.from(VAULT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n\n    return await this.program.methods\n      .closeMarketAccount()\n      .accountsPartial({\n        market,\n        yesMint,\n        noMint,\n        vault,\n        admin,\n        tokenProgram: TOKEN_PROGRAM_ID,\n        token2022Program: TOKEN_2022_PROGRAM_ID,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to close market account\n   */\n  async buildCloseMarketAccountTx(\n    admin: PublicKey,\n    market: PublicKey\n  ): Promise<Transaction> {\n    const ix = await this.closeMarketAccount(admin, market);\n    return new Transaction().add(ix);\n  }\n\n  /**\n   * Burn worthless tokens from the losing side of a resolved market.\n   * This allows users to clean up their losing tokens so the market account can be closed.\n   * @param user - The user who holds losing tokens\n   * @param market - The market PDA\n   * @param losingOutcome - The outcome that lost (the side to burn)\n   * @param tokenAmount - Amount to burn (0 = burn all)\n   * @param closeAccount - Whether to close the losing token account after burning all tokens (default: false)\n   */\n  async burnMarketTokens(\n    user: PublicKey,\n    market: PublicKey,\n    losingOutcome: Outcome,\n    tokenAmount: number | BN = 0,\n    closeAccount: boolean = false\n  ): Promise<TransactionInstruction> {\n    // Derive PDAs\n    const yesMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(YES_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    const noMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(NO_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n\n    // The losing mint is the side that lost\n    const losingMint = losingOutcome === \"Yes\" ? yesMint : noMint;\n    const userLosingToken = getAssociatedTokenAddressSync(losingMint, user, false, TOKEN_2022_PROGRAM_ID);\n\n    return await this.program.methods\n      .burnMarketTokens({\n        tokenAmount: new BN(tokenAmount),\n        closeAccount,\n      })\n      .accountsPartial({\n        market,\n        yesMint,\n        noMint,\n        losingMint,\n        userLosingToken,\n        user,\n        token2022Program: TOKEN_2022_PROGRAM_ID,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to burn market tokens\n   * @param closeAccount - Whether to close the losing token account after burning all tokens (default: false)\n   */\n  async buildBurnMarketTokensTx(\n    user: PublicKey,\n    market: PublicKey,\n    losingOutcome: Outcome,\n    tokenAmount: number | BN = 0,\n    closeAccount: boolean = true\n  ): Promise<Transaction> {\n    const ix = await this.burnMarketTokens(user, market, losingOutcome, tokenAmount, closeAccount);\n    return new Transaction().add(ix);\n  }\n\n  /**\n   * Get user's token balance for a specific market\n   * Returns the balance of both Yes and No tokens\n   * @param params - UserMarketHoldParams containing user and market addresses\n   * @returns UserMarketHoldResult with yes and no token balances\n   */\n  async getUserMarketTokenBalance(\n    params: UserMarketHoldParams\n  ): Promise<UserMarketHoldResult> {\n    const { user, market } = params;\n    \n    // Derive PDAs\n    const yesMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(YES_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    const noMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(NO_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n\n    // Get user token accounts\n    const userYesToken = getAssociatedTokenAddressSync(yesMint, user, false, TOKEN_2022_PROGRAM_ID);\n    const userNoToken = getAssociatedTokenAddressSync(noMint, user, false, TOKEN_2022_PROGRAM_ID);\n\n    // Check Yes token balance\n    let yesBalance = \"0\";\n    let hasYesAccount = false;\n    try {\n      const yesAccount = await getAccount(this.connection, userYesToken, undefined, TOKEN_2022_PROGRAM_ID);\n      yesBalance = yesAccount.amount.toString();\n      hasYesAccount = true;\n    } catch {\n      // Account doesn't exist or has no balance\n    }\n\n    // Check No token balance\n    let noBalance = \"0\";\n    let hasNoAccount = false;\n    try {\n      const noAccount = await getAccount(this.connection, userNoToken, undefined, TOKEN_2022_PROGRAM_ID);\n      noBalance = noAccount.amount.toString();\n      hasNoAccount = true;\n    } catch {\n      // Account doesn't exist or has no balance\n    }\n\n    return {\n      yesMint,\n      noMint,\n      yesTokenBalance: yesBalance,\n      noTokenBalance: noBalance,\n      hasYesTokenAccount: hasYesAccount,\n      hasNoTokenAccount: hasNoAccount,\n    };\n  }\n\n  /**\n   * Claim rewards if won, or burn tokens if lost, with optional account closure.\n   * This instruction combines claim_rewards and burn_market_tokens logic into a single call.\n   * \n   * @param params - ClaimBurnMarketParams\n   * @param userYesToken - User's YES token account (optional, pass null if user has no YES tokens)\n   * @param userNoToken - User's NO token account (optional, pass null if user has no NO tokens)\n   */\n  async claimBurnMarket(\n    params: ClaimBurnMarketParams,\n    userYesToken: PublicKey | null,\n    userNoToken: PublicKey | null\n  ): Promise<TransactionInstruction> {\n    const { user, market, bettingToken } = params;\n\n    // Derive PDAs\n    const yesMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(YES_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    const noMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(NO_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    const vault = PublicKey.findProgramAddressSync(\n      [Buffer.from(VAULT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n\n    const userBettingToken = getAssociatedTokenAddressSync(bettingToken, user);\n\n    return await this.program.methods\n      .claimBurnMarket()\n      .accountsPartial({\n        market,\n        yesMint,\n        noMint,\n        vault,\n        userYesToken: userYesToken,\n        userNoToken: userNoToken,\n        userBettingToken,\n        user,\n        tokenProgram: TOKEN_PROGRAM_ID,\n        token2022Program: TOKEN_2022_PROGRAM_ID,\n      })\n      .instruction();\n  }\n\n\n  /**\n   * Build a complete transaction to claim rewards (if won) or burn tokens (if lost)\n   * Automatically creates user outcome token accounts based on user's holdings\n   * @param priorityFeeOptions - Optional priority fee settings to accelerate transaction confirmation\n   */\n  async buildClaimBurnMarketTx(\n    params: ClaimBurnMarketParams,\n    priorityFeeOptions?: PriorityFeeOptions\n  ): Promise<Transaction> {\n    const { user, market } = params;\n    const tx = new Transaction();\n\n    // Add priority fee instructions (use default if not provided)\n    const feeOpts = priorityFeeOptions ?? DEFAULT_PRIORITY_FEE;\n    const computeUnitLimit = feeOpts.computeUnitLimit ?? 400_000;\n    tx.add(\n      ComputeBudgetProgram.setComputeUnitLimit({\n        units: computeUnitLimit,\n      })\n    );\n    if (feeOpts.computeUnitPrice !== undefined && feeOpts.computeUnitPrice > 0) {\n      tx.add(\n        ComputeBudgetProgram.setComputeUnitPrice({\n          microLamports: feeOpts.computeUnitPrice,\n        })\n      );\n    }\n\n    // Derive PDAs\n    const yesMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(YES_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n    const noMint = PublicKey.findProgramAddressSync(\n      [Buffer.from(NO_MINT_SEED), market.toBuffer()],\n      this.program.programId\n    )[0];\n\n    // Get user token accounts\n    const userYesToken = getAssociatedTokenAddressSync(yesMint, user, false, TOKEN_2022_PROGRAM_ID);\n    const userNoToken = getAssociatedTokenAddressSync(noMint, user, false, TOKEN_2022_PROGRAM_ID);\n\n    // Check which accounts exist and have tokens\n    let hasYesTokens = false;\n    let hasNoTokens = false;\n\n    try {\n      const yesAccount = await getAccount(this.connection, userYesToken, undefined, TOKEN_2022_PROGRAM_ID);\n      hasYesTokens = yesAccount.amount > 0n;\n    } catch {\n      // Account doesn't exist\n    }\n\n    try {\n      const noAccount = await getAccount(this.connection, userNoToken, undefined, TOKEN_2022_PROGRAM_ID);\n      hasNoTokens = noAccount.amount > 0n;\n    } catch {\n      // Account doesn't exist\n    }\n\n    // Build instruction with appropriate accounts\n    const ix = await this.claimBurnMarket(\n      params,\n      hasYesTokens ? userYesToken : null,\n      hasNoTokens ? userNoToken : null\n    );\n    tx.add(ix);\n\n    return tx;\n  }\n  \n  /**\n   * Fetch global config account data\n   */\n  async getGlobalConfigAccount() {\n    const globalConfig = getGlobalConfigPda(this.program.programId);\n    return await this.program.account.globalConfig.fetch(globalConfig);\n  }\n\n\n  /**\n   * Fetch market account data\n   */\n  async getMarketAccount(admin: PublicKey, marketId: number | BN) {\n    const marketIdBn = new BN(marketId);\n    const marketPda = getMarketPda(this.program.programId, admin, marketIdBn);\n    return await this.program.account.market.fetch(marketPda);\n  }\n\n  async getMarketInfo(marketPda: PublicKey) {\n    const marketAccount = await this.program.account.market.fetch(marketPda);\n    return marketAccount;\n  }\n\n  /**\n   * Fetch vault account data\n   */\n  async getVaultAccount(marketPda: PublicKey) {\n    const vaultPda = getVaultPda(this.program.programId, marketPda);\n    return await getAccount(this.connection, vaultPda);\n  }\n\n/**\n   * 获取特定代币 (Mint) 的持有者数量\n   * 自动兼容经典 Token Program 和 Token-2022 Program\n   * \n   * @param mint - 代币 Mint 的公钥\n   * @param tokenProgram - 可选：明确指定代币程序 ID。如果不提供，将自动通过查询 Mint 账户信息来确定\n   * @returns 余额大于 0 的唯一持有者数量\n   */\nasync getTokenHolderCount(\n  mint: PublicKey,\n  tokenProgram?: PublicKey | string\n): Promise<number> {\n  try {\n    // 1. 确定 Token 程序 ID\n    let programId: PublicKey;\n    if (!tokenProgram) {\n      const mintInfo = await this.connection.getAccountInfo(mint);\n      if (!mintInfo) throw new Error(`Mint 账户不存在: ${mint.toBase58()}`);\n      \n      // 增加校验：只有 Token 或 Token-2022 程序拥有的账户才是合法的 Mint\n      if (!mintInfo.owner.equals(TOKEN_PROGRAM_ID) && !mintInfo.owner.equals(TOKEN_2022_PROGRAM_ID)) {\n        throw new Error(`地址 ${mint.toBase58()} 不是一个有效的代币 Mint (Owner 为 ${mintInfo.owner.toBase58()})`);\n      }\n      programId = mintInfo.owner;\n    } else {\n      programId = typeof tokenProgram === 'string' ? new PublicKey(tokenProgram) : tokenProgram;\n    }\n\n    // 2. 构造过滤器\n    const filters: any[] = [\n      {\n        memcmp: {\n          offset: 0, // Mint 地址始终在代币账户数据的偏移量 0 处\n          bytes: mint.toBase58(),\n        },\n      },\n    ];\n\n    // 只有经典 Token Program (Tokenkeg...) 账户大小固定为 165 字节\n    // Token-2022 (TokenzQd...) 账户因为可能包含 Extensions，大小是可变的，因此不使用 dataSize 过滤\n    if (programId.equals(TOKEN_PROGRAM_ID)) {\n      filters.unshift({ dataSize: 165 });\n    }\n\n    // 3. 执行 getProgramAccounts 查询\n    const accounts = await this.connection.getProgramAccounts(programId, {\n      filters,\n    });\n\n    // 4. 过滤出余额 > 0 的账户\n    // 无论哪个程序，余额 (Amount) 都在偏移量 64 处的 8 字节 (u64)\n    const holdersWithBalance = accounts.filter((account) => {\n      const data = account.account.data;\n      const amount = data.readBigUInt64LE(64);\n      return amount > 0n;\n    });\n\n    return holdersWithBalance.length;\n  } catch (error) {\n    console.error(`获取 Mint ${mint.toBase58()} 的持有者数量失败:`, error);\n    throw error;\n  }\n}\n\n    /**\n   * 获取综合的市场回收状态（包含链上数据）\n   * 该方法查询所有必要信息，以判断市场是否可以安全地回收租金\n   * \n   * @param marketPda - 市场的 PDA 公钥\n   * @param options - 配置选项\n   * @param options.skipHolderCount - 是否跳过昂贵的持有人数查询（默认为 false）。\n   *                                  如果只需判断是否满足合约关闭条件，建议设为 true 以提升性能。\n   * @returns 包含所有相关数据的市场回收状态\n   */\n    async getMarketReclaimStatus(\n      marketPda: PublicKey,\n      options: { skipHolderCount?: boolean } = {}\n    ): Promise<{\n      yesMint: PublicKey;\n      noMint: PublicKey;\n      vault: PublicKey;\n      yesSupply: number;\n      noSupply: number;\n      yesHolderCount: number;\n      noHolderCount: number;\n      vaultBalance: bigint;\n      canCloseOnChain: boolean;\n      blockers: string[];\n    }> {\n      const skipHolderCount = options.skipHolderCount ?? false;\n  \n      try {\n        // 1. 获取市场基础信息 (包含 totalYesSupply 和 totalNoSupply)\n        const marketInfo = await this.getMarketInfo(marketPda);\n        \n        // 2. 派生相关的 PDA 地址\n        const yesMint = PublicKey.findProgramAddressSync(\n          [Buffer.from(YES_MINT_SEED), marketPda.toBuffer()],\n          this.program.programId\n        )[0];\n        \n        const noMint = PublicKey.findProgramAddressSync(\n          [Buffer.from(NO_MINT_SEED), marketPda.toBuffer()],\n          this.program.programId\n        )[0];\n        \n        const vault = PublicKey.findProgramAddressSync(\n          [Buffer.from(VAULT_SEED), marketPda.toBuffer()],\n          this.program.programId\n        )[0];\n  \n        // 3. 并行查询链上详细数据\n        // 始终查询 vault 余额，根据选项决定是否查询 holder 数量\n        const queries: Promise<any>[] = [this.getVaultAccount(marketPda)];\n        \n        if (!skipHolderCount) {\n          // getTokenHolderCount 现在内部会自动识别 Token 程序类型\n          queries.push(this.getTokenHolderCount(yesMint));\n          queries.push(this.getTokenHolderCount(noMint));\n        }\n  \n        const results = await Promise.all(queries);\n        const vaultAccount = results[0];\n        const yesHolderCount = skipHolderCount ? 0 : results[1];\n        const noHolderCount = skipHolderCount ? 0 : results[2];\n  \n        // 4. 提取关键指标\n        const yesSupply = Number(marketInfo.totalYesSupply);\n        const noSupply = Number(marketInfo.totalNoSupply);\n        const vaultBalance = vaultAccount.amount;\n  \n        // 5. 判断是否满足链上关闭条件（遵循合约逻辑）\n        const blockers: string[] = [];\n        \n        // 核心检查：获胜方代币供应量必须为 0\n        if (marketInfo.winningOutcome !== null) {\n          const winningSupply = marketInfo.winningOutcome.yes !== undefined ? yesSupply : noSupply;\n          if (winningSupply > 0) {\n            blockers.push(`获胜方仍有 ${winningSupply} 个代币未领取/销毁`);\n          }\n        }\n        \n        // 核心检查：Vault 余额必须几乎为 0\n        const DUST_THRESHOLD = 100n;\n        if (vaultBalance >= DUST_THRESHOLD) {\n          blockers.push(`Vault 余额为 ${vaultBalance}（超过容差阈值: ${DUST_THRESHOLD}）`);\n        }\n        \n        // 如果未跳过 Holder 检查，则添加 Holder 相关的 blocker\n        if (!skipHolderCount) {\n          if (yesHolderCount > 0) {\n            blockers.push(`仍有 ${yesHolderCount} 个用户持有 Yes 代币账户`);\n          }\n          if (noHolderCount > 0) {\n            blockers.push(`仍有 ${noHolderCount} 个用户持有 No 代币账户`);\n          }\n        }\n  \n        // 如果 Supply > 0，通常也不建议关闭\n        if (yesSupply > 0) {\n          blockers.push(`Yes 代币总供应量不为 0: ${yesSupply}`);\n        }\n        if (noSupply > 0) {\n          blockers.push(`No 代币总供应量不为 0: ${noSupply}`);\n        }\n  \n        const canCloseOnChain = blockers.length === 0;\n  \n        return {\n          yesMint,\n          noMint,\n          vault,\n          yesSupply,\n          noSupply,\n          yesHolderCount,\n          noHolderCount,\n          vaultBalance,\n          canCloseOnChain,\n          blockers,\n        };\n      } catch (error) {\n        console.error(`获取市场 ${marketPda.toBase58()} 的回收状态失败:`, error);\n        throw error;\n      }\n    }\n}\n"]}
|