@baozi.bet/mcp-server 4.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (60) hide show
  1. package/README.md +294 -0
  2. package/dist/__tests__/full-test.d.ts +1 -0
  3. package/dist/__tests__/full-test.js +291 -0
  4. package/dist/builders/affiliate-transaction.d.ts +41 -0
  5. package/dist/builders/affiliate-transaction.js +123 -0
  6. package/dist/builders/bet-transaction.d.ts +70 -0
  7. package/dist/builders/bet-transaction.js +323 -0
  8. package/dist/builders/claim-transaction.d.ts +57 -0
  9. package/dist/builders/claim-transaction.js +196 -0
  10. package/dist/builders/creator-transaction.d.ts +49 -0
  11. package/dist/builders/creator-transaction.js +177 -0
  12. package/dist/builders/dispute-transaction.d.ts +81 -0
  13. package/dist/builders/dispute-transaction.js +215 -0
  14. package/dist/builders/index.d.ts +14 -0
  15. package/dist/builders/index.js +15 -0
  16. package/dist/builders/market-creation-tx.d.ts +65 -0
  17. package/dist/builders/market-creation-tx.js +362 -0
  18. package/dist/builders/market-management-transaction.d.ts +85 -0
  19. package/dist/builders/market-management-transaction.js +239 -0
  20. package/dist/builders/race-transaction.d.ts +67 -0
  21. package/dist/builders/race-transaction.js +242 -0
  22. package/dist/builders/resolution-transaction.d.ts +108 -0
  23. package/dist/builders/resolution-transaction.js +250 -0
  24. package/dist/builders/whitelist-transaction.d.ts +72 -0
  25. package/dist/builders/whitelist-transaction.js +179 -0
  26. package/dist/config.d.ts +138 -0
  27. package/dist/config.js +307 -0
  28. package/dist/handlers/agent-network.d.ts +81 -0
  29. package/dist/handlers/agent-network.js +332 -0
  30. package/dist/handlers/claims.d.ts +47 -0
  31. package/dist/handlers/claims.js +218 -0
  32. package/dist/handlers/market-creation.d.ts +154 -0
  33. package/dist/handlers/market-creation.js +290 -0
  34. package/dist/handlers/markets.d.ts +41 -0
  35. package/dist/handlers/markets.js +319 -0
  36. package/dist/handlers/positions.d.ts +40 -0
  37. package/dist/handlers/positions.js +244 -0
  38. package/dist/handlers/quote.d.ts +33 -0
  39. package/dist/handlers/quote.js +144 -0
  40. package/dist/handlers/race-markets.d.ts +54 -0
  41. package/dist/handlers/race-markets.js +308 -0
  42. package/dist/handlers/resolution.d.ts +43 -0
  43. package/dist/handlers/resolution.js +194 -0
  44. package/dist/index.d.ts +2 -0
  45. package/dist/index.js +109 -0
  46. package/dist/resources.d.ts +13 -0
  47. package/dist/resources.js +336 -0
  48. package/dist/tools.d.ts +3109 -0
  49. package/dist/tools.js +1956 -0
  50. package/dist/validation/bet-rules.d.ts +82 -0
  51. package/dist/validation/bet-rules.js +276 -0
  52. package/dist/validation/creation-rules.d.ts +69 -0
  53. package/dist/validation/creation-rules.js +302 -0
  54. package/dist/validation/index.d.ts +6 -0
  55. package/dist/validation/index.js +7 -0
  56. package/dist/validation/market-rules.d.ts +60 -0
  57. package/dist/validation/market-rules.js +237 -0
  58. package/dist/validation/parimutuel-rules.d.ts +117 -0
  59. package/dist/validation/parimutuel-rules.js +270 -0
  60. package/package.json +52 -0
@@ -0,0 +1,362 @@
1
+ /**
2
+ * Market Creation Transaction Builders
3
+ *
4
+ * Builds unsigned transactions for:
5
+ * - create_lab_market_sol (community markets)
6
+ * - create_private_table_sol (invite-only markets)
7
+ * - create_race_market_sol (multi-outcome markets)
8
+ *
9
+ * FIXED: Jan 2026 - Corrected discriminators, offsets, and instruction formats
10
+ */
11
+ import { Connection, PublicKey, Transaction, TransactionInstruction, SystemProgram, } from '@solana/web3.js';
12
+ import { PROGRAM_ID, CONFIG_PDA, SOL_TREASURY_PDA, SEEDS, RPC_ENDPOINT, } from '../config.js';
13
+ // =============================================================================
14
+ // INSTRUCTION DISCRIMINATORS (sha256("global:<name>")[0..8])
15
+ // =============================================================================
16
+ const CREATE_LAB_MARKET_SOL_DISCRIMINATOR = Buffer.from([35, 159, 50, 67, 31, 134, 199, 157]);
17
+ const CREATE_PRIVATE_TABLE_SOL_DISCRIMINATOR = Buffer.from([242, 241, 183, 108, 35, 183, 38, 241]);
18
+ const CREATE_RACE_MARKET_SOL_DISCRIMINATOR = Buffer.from([94, 237, 40, 47, 63, 233, 25, 67]);
19
+ // =============================================================================
20
+ // GLOBAL CONFIG OFFSETS (calculated from IDL struct layout)
21
+ // =============================================================================
22
+ // GlobalConfig struct layout:
23
+ // discriminator (8) + admin (32) + treasury (32) + guardian (32) +
24
+ // _reserved_usdc_mint (32) + _reserved_creation_fee_usdc (8) + creation_fee_sol (8) +
25
+ // _reserved_market_bond_usdc (8) + market_bond_sol (8) + platform_fee_bps (2) + market_count (8)
26
+ const MARKET_COUNT_OFFSET = 8 + 32 + 32 + 32 + 32 + 8 + 8 + 8 + 8 + 2; // = 170
27
+ // =============================================================================
28
+ // PDA DERIVATION
29
+ // =============================================================================
30
+ function deriveMarketPda(marketId) {
31
+ const marketIdBuffer = Buffer.alloc(8);
32
+ marketIdBuffer.writeBigUInt64LE(marketId);
33
+ return PublicKey.findProgramAddressSync([SEEDS.MARKET, marketIdBuffer], PROGRAM_ID);
34
+ }
35
+ function deriveRaceMarketPda(marketId) {
36
+ const marketIdBuffer = Buffer.alloc(8);
37
+ marketIdBuffer.writeBigUInt64LE(marketId);
38
+ return PublicKey.findProgramAddressSync([SEEDS.RACE, marketIdBuffer], PROGRAM_ID);
39
+ }
40
+ function deriveWhitelistPda(marketId) {
41
+ const marketIdBuffer = Buffer.alloc(8);
42
+ marketIdBuffer.writeBigUInt64LE(marketId);
43
+ return PublicKey.findProgramAddressSync([SEEDS.WHITELIST, marketIdBuffer], PROGRAM_ID);
44
+ }
45
+ function deriveCreatorProfilePda(creator) {
46
+ return PublicKey.findProgramAddressSync([Buffer.from('creator_profile'), creator.toBuffer()], PROGRAM_ID);
47
+ }
48
+ // =============================================================================
49
+ // GET MARKET COUNT FROM CONFIG
50
+ // =============================================================================
51
+ export async function getNextMarketId(connection) {
52
+ const conn = connection || new Connection(RPC_ENDPOINT, 'confirmed');
53
+ try {
54
+ const configAccount = await conn.getAccountInfo(CONFIG_PDA);
55
+ if (!configAccount) {
56
+ throw new Error('GlobalConfig not found');
57
+ }
58
+ const data = configAccount.data;
59
+ // market_count at offset 170 (verified against on-chain data)
60
+ const marketCount = data.readBigUInt64LE(MARKET_COUNT_OFFSET);
61
+ // Both regular and race markets use the SAME counter
62
+ // The program uses the CURRENT value (not +1) for PDA derivation
63
+ return {
64
+ marketId: marketCount,
65
+ raceMarketId: marketCount,
66
+ };
67
+ }
68
+ catch (err) {
69
+ // If we can't read config, return safe defaults
70
+ return { marketId: 0n, raceMarketId: 0n };
71
+ }
72
+ }
73
+ // =============================================================================
74
+ // BUILD CREATE LAB MARKET TRANSACTION
75
+ // =============================================================================
76
+ export async function buildCreateLabMarketTransaction(params, connection) {
77
+ const conn = connection || new Connection(RPC_ENDPOINT, 'confirmed');
78
+ const creatorPubkey = new PublicKey(params.creatorWallet);
79
+ // Get current market count for PDA derivation
80
+ const { marketId } = await getNextMarketId(conn);
81
+ const [marketPda] = deriveMarketPda(marketId);
82
+ const [creatorProfilePda] = deriveCreatorProfilePda(creatorPubkey);
83
+ // Check if creator profile exists
84
+ const creatorProfileInfo = await conn.getAccountInfo(creatorProfilePda);
85
+ const hasCreatorProfile = creatorProfileInfo !== null;
86
+ // Set defaults
87
+ const closingTime = BigInt(Math.floor(params.closingTime.getTime() / 1000));
88
+ const resolutionBuffer = BigInt(params.resolutionBuffer ?? 43200); // 12 hours
89
+ const autoStopBuffer = BigInt(params.autoStopBuffer ?? 300); // 5 minutes
90
+ const resolutionMode = params.resolutionMode ?? 1; // CouncilOracle by default
91
+ // For CouncilOracle, creator is default council member
92
+ const council = params.council?.map(p => new PublicKey(p)) ??
93
+ (resolutionMode === 1 ? [creatorPubkey] : []);
94
+ const councilThreshold = params.councilThreshold ?? (council.length > 0 ? 1 : 0);
95
+ // Encode instruction data:
96
+ // discriminator (8) + question (4+len) + closing_time (8) + resolution_buffer (8) +
97
+ // auto_stop_buffer (8) + resolution_mode (1) + council (4+n*32) + council_threshold (1)
98
+ const questionBytes = Buffer.from(params.question, 'utf8');
99
+ const size = 8 + 4 + questionBytes.length + 8 + 8 + 8 + 1 + 4 + (council.length * 32) + 1;
100
+ const data = Buffer.alloc(size);
101
+ let offset = 0;
102
+ CREATE_LAB_MARKET_SOL_DISCRIMINATOR.copy(data, offset);
103
+ offset += 8;
104
+ data.writeUInt32LE(questionBytes.length, offset);
105
+ offset += 4;
106
+ questionBytes.copy(data, offset);
107
+ offset += questionBytes.length;
108
+ data.writeBigInt64LE(closingTime, offset);
109
+ offset += 8;
110
+ data.writeBigInt64LE(resolutionBuffer, offset);
111
+ offset += 8;
112
+ data.writeBigInt64LE(autoStopBuffer, offset);
113
+ offset += 8;
114
+ data.writeUInt8(resolutionMode, offset);
115
+ offset += 1;
116
+ data.writeUInt32LE(council.length, offset);
117
+ offset += 4;
118
+ for (const member of council) {
119
+ member.toBuffer().copy(data, offset);
120
+ offset += 32;
121
+ }
122
+ data.writeUInt8(councilThreshold, offset);
123
+ // Accounts from IDL:
124
+ // config (PDA), market (PDA), treasury, creator (signer), creator_profile (optional), system_program
125
+ const keys = [
126
+ { pubkey: CONFIG_PDA, isSigner: false, isWritable: true },
127
+ { pubkey: marketPda, isSigner: false, isWritable: true },
128
+ { pubkey: SOL_TREASURY_PDA, isSigner: false, isWritable: true },
129
+ { pubkey: creatorPubkey, isSigner: true, isWritable: true },
130
+ // For optional accounts, pass PROGRAM_ID as placeholder if not present
131
+ { pubkey: hasCreatorProfile ? creatorProfilePda : PROGRAM_ID, isSigner: false, isWritable: hasCreatorProfile },
132
+ { pubkey: SystemProgram.programId, isSigner: false, isWritable: false },
133
+ ];
134
+ const instruction = new TransactionInstruction({
135
+ programId: PROGRAM_ID,
136
+ keys,
137
+ data,
138
+ });
139
+ const transaction = new Transaction();
140
+ transaction.add(instruction);
141
+ const { blockhash } = await conn.getLatestBlockhash('finalized');
142
+ transaction.recentBlockhash = blockhash;
143
+ transaction.feePayer = creatorPubkey;
144
+ const serializedTx = transaction.serialize({
145
+ requireAllSignatures: false,
146
+ verifySignatures: false,
147
+ }).toString('base64');
148
+ return {
149
+ transaction,
150
+ serializedTx,
151
+ marketPda: marketPda.toBase58(),
152
+ marketId,
153
+ };
154
+ }
155
+ // =============================================================================
156
+ // BUILD CREATE PRIVATE MARKET TRANSACTION
157
+ // =============================================================================
158
+ export async function buildCreatePrivateMarketTransaction(params, connection) {
159
+ const conn = connection || new Connection(RPC_ENDPOINT, 'confirmed');
160
+ const creatorPubkey = new PublicKey(params.creatorWallet);
161
+ const { marketId } = await getNextMarketId(conn);
162
+ const [marketPda] = deriveMarketPda(marketId);
163
+ const [whitelistPda] = deriveWhitelistPda(marketId);
164
+ const [creatorProfilePda] = deriveCreatorProfilePda(creatorPubkey);
165
+ const creatorProfileInfo = await conn.getAccountInfo(creatorProfilePda);
166
+ const hasCreatorProfile = creatorProfileInfo !== null;
167
+ const closingTime = BigInt(Math.floor(params.closingTime.getTime() / 1000));
168
+ const resolutionBuffer = BigInt(params.resolutionBuffer ?? 43200);
169
+ const autoStopBuffer = BigInt(params.autoStopBuffer ?? 300);
170
+ const resolutionMode = params.resolutionMode ?? 0; // HostOracle for private
171
+ const council = params.council?.map(p => new PublicKey(p)) ?? [];
172
+ const councilThreshold = params.councilThreshold ?? 0;
173
+ // Same instruction format as Lab market
174
+ const questionBytes = Buffer.from(params.question, 'utf8');
175
+ const size = 8 + 4 + questionBytes.length + 8 + 8 + 8 + 1 + 4 + (council.length * 32) + 1;
176
+ const data = Buffer.alloc(size);
177
+ let offset = 0;
178
+ CREATE_PRIVATE_TABLE_SOL_DISCRIMINATOR.copy(data, offset);
179
+ offset += 8;
180
+ data.writeUInt32LE(questionBytes.length, offset);
181
+ offset += 4;
182
+ questionBytes.copy(data, offset);
183
+ offset += questionBytes.length;
184
+ data.writeBigInt64LE(closingTime, offset);
185
+ offset += 8;
186
+ data.writeBigInt64LE(resolutionBuffer, offset);
187
+ offset += 8;
188
+ data.writeBigInt64LE(autoStopBuffer, offset);
189
+ offset += 8;
190
+ data.writeUInt8(resolutionMode, offset);
191
+ offset += 1;
192
+ data.writeUInt32LE(council.length, offset);
193
+ offset += 4;
194
+ for (const member of council) {
195
+ member.toBuffer().copy(data, offset);
196
+ offset += 32;
197
+ }
198
+ data.writeUInt8(councilThreshold, offset);
199
+ // Private market accounts include whitelist PDA
200
+ const keys = [
201
+ { pubkey: CONFIG_PDA, isSigner: false, isWritable: true },
202
+ { pubkey: marketPda, isSigner: false, isWritable: true },
203
+ { pubkey: whitelistPda, isSigner: false, isWritable: true },
204
+ { pubkey: SOL_TREASURY_PDA, isSigner: false, isWritable: true },
205
+ { pubkey: creatorPubkey, isSigner: true, isWritable: true },
206
+ { pubkey: hasCreatorProfile ? creatorProfilePda : PROGRAM_ID, isSigner: false, isWritable: hasCreatorProfile },
207
+ { pubkey: SystemProgram.programId, isSigner: false, isWritable: false },
208
+ ];
209
+ const instruction = new TransactionInstruction({
210
+ programId: PROGRAM_ID,
211
+ keys,
212
+ data,
213
+ });
214
+ const transaction = new Transaction();
215
+ transaction.add(instruction);
216
+ const { blockhash } = await conn.getLatestBlockhash('finalized');
217
+ transaction.recentBlockhash = blockhash;
218
+ transaction.feePayer = creatorPubkey;
219
+ const serializedTx = transaction.serialize({
220
+ requireAllSignatures: false,
221
+ verifySignatures: false,
222
+ }).toString('base64');
223
+ return {
224
+ transaction,
225
+ serializedTx,
226
+ marketPda: marketPda.toBase58(),
227
+ marketId,
228
+ };
229
+ }
230
+ // =============================================================================
231
+ // BUILD CREATE RACE MARKET TRANSACTION
232
+ // =============================================================================
233
+ export async function buildCreateRaceMarketTransaction(params, connection) {
234
+ const conn = connection || new Connection(RPC_ENDPOINT, 'confirmed');
235
+ const creatorPubkey = new PublicKey(params.creatorWallet);
236
+ const { raceMarketId } = await getNextMarketId(conn);
237
+ const [raceMarketPda] = deriveRaceMarketPda(raceMarketId);
238
+ const [creatorProfilePda] = deriveCreatorProfilePda(creatorPubkey);
239
+ const creatorProfileInfo = await conn.getAccountInfo(creatorProfilePda);
240
+ const hasCreatorProfile = creatorProfileInfo !== null;
241
+ const closingTime = BigInt(Math.floor(params.closingTime.getTime() / 1000));
242
+ const resolutionBuffer = BigInt(params.resolutionBuffer ?? 43200);
243
+ const autoStopBuffer = BigInt(params.autoStopBuffer ?? 300);
244
+ const layer = params.layer ?? 1; // Lab by default
245
+ const resolutionMode = params.resolutionMode ?? 1; // CouncilOracle
246
+ const accessGate = params.accessGate ?? 0; // Public
247
+ // Council is Option<Vec<Pubkey>> - encode as 1 (Some) + vec or 0 (None)
248
+ const hasCouncil = params.council && params.council.length > 0;
249
+ const council = hasCouncil ? params.council.map(p => new PublicKey(p)) : [];
250
+ // council_threshold is Option<u8>
251
+ const hasThreshold = params.councilThreshold !== undefined;
252
+ const councilThreshold = params.councilThreshold ?? 0;
253
+ // Encode instruction data:
254
+ // discriminator (8) + question (4+len) + outcome_labels (4 + n*(4+len)) +
255
+ // closing_time (8) + resolution_buffer (8) + auto_stop_buffer (8) +
256
+ // layer (1) + resolution_mode (1) + access_gate (1) +
257
+ // council (1 + 4 + n*32 or just 1) + council_threshold (1 + 1 or just 1)
258
+ const questionBytes = Buffer.from(params.question, 'utf8');
259
+ const outcomeBuffers = params.outcomes.map(o => Buffer.from(o, 'utf8'));
260
+ let outcomesSize = 4; // vec length
261
+ for (const buf of outcomeBuffers) {
262
+ outcomesSize += 4 + buf.length;
263
+ }
264
+ const councilSize = hasCouncil ? (1 + 4 + council.length * 32) : 1;
265
+ const thresholdSize = hasThreshold ? 2 : 1;
266
+ const size = 8 + 4 + questionBytes.length + outcomesSize + 8 + 8 + 8 + 1 + 1 + 1 + councilSize + thresholdSize;
267
+ const data = Buffer.alloc(size);
268
+ let offset = 0;
269
+ CREATE_RACE_MARKET_SOL_DISCRIMINATOR.copy(data, offset);
270
+ offset += 8;
271
+ data.writeUInt32LE(questionBytes.length, offset);
272
+ offset += 4;
273
+ questionBytes.copy(data, offset);
274
+ offset += questionBytes.length;
275
+ data.writeUInt32LE(params.outcomes.length, offset);
276
+ offset += 4;
277
+ for (const buf of outcomeBuffers) {
278
+ data.writeUInt32LE(buf.length, offset);
279
+ offset += 4;
280
+ buf.copy(data, offset);
281
+ offset += buf.length;
282
+ }
283
+ data.writeBigInt64LE(closingTime, offset);
284
+ offset += 8;
285
+ data.writeBigInt64LE(resolutionBuffer, offset);
286
+ offset += 8;
287
+ data.writeBigInt64LE(autoStopBuffer, offset);
288
+ offset += 8;
289
+ data.writeUInt8(layer, offset);
290
+ offset += 1;
291
+ data.writeUInt8(resolutionMode, offset);
292
+ offset += 1;
293
+ data.writeUInt8(accessGate, offset);
294
+ offset += 1;
295
+ // Option<Vec<Pubkey>> - 1 (Some) + vec or 0 (None)
296
+ if (hasCouncil) {
297
+ data.writeUInt8(1, offset);
298
+ offset += 1;
299
+ data.writeUInt32LE(council.length, offset);
300
+ offset += 4;
301
+ for (const member of council) {
302
+ member.toBuffer().copy(data, offset);
303
+ offset += 32;
304
+ }
305
+ }
306
+ else {
307
+ data.writeUInt8(0, offset);
308
+ offset += 1;
309
+ }
310
+ // Option<u8> - 1 (Some) + value or 0 (None)
311
+ if (hasThreshold) {
312
+ data.writeUInt8(1, offset);
313
+ offset += 1;
314
+ data.writeUInt8(councilThreshold, offset);
315
+ offset += 1;
316
+ }
317
+ else {
318
+ data.writeUInt8(0, offset);
319
+ offset += 1;
320
+ }
321
+ // Accounts: config, race_market, creator_profile (optional), treasury, creator, system_program
322
+ const keys = [
323
+ { pubkey: CONFIG_PDA, isSigner: false, isWritable: true },
324
+ { pubkey: raceMarketPda, isSigner: false, isWritable: true },
325
+ { pubkey: hasCreatorProfile ? creatorProfilePda : PROGRAM_ID, isSigner: false, isWritable: hasCreatorProfile },
326
+ { pubkey: SOL_TREASURY_PDA, isSigner: false, isWritable: true },
327
+ { pubkey: creatorPubkey, isSigner: true, isWritable: true },
328
+ { pubkey: SystemProgram.programId, isSigner: false, isWritable: false },
329
+ ];
330
+ const instruction = new TransactionInstruction({
331
+ programId: PROGRAM_ID,
332
+ keys,
333
+ data,
334
+ });
335
+ const transaction = new Transaction();
336
+ transaction.add(instruction);
337
+ const { blockhash } = await conn.getLatestBlockhash('finalized');
338
+ transaction.recentBlockhash = blockhash;
339
+ transaction.feePayer = creatorPubkey;
340
+ const serializedTx = transaction.serialize({
341
+ requireAllSignatures: false,
342
+ verifySignatures: false,
343
+ }).toString('base64');
344
+ return {
345
+ transaction,
346
+ serializedTx,
347
+ marketPda: raceMarketPda.toBase58(),
348
+ marketId: raceMarketId,
349
+ };
350
+ }
351
+ // =============================================================================
352
+ // HELPER: DERIVE PDA PREVIEW
353
+ // =============================================================================
354
+ export function previewMarketPda(marketId) {
355
+ const [pda, bump] = deriveMarketPda(marketId);
356
+ return { marketPda: pda.toBase58(), bump };
357
+ }
358
+ export function previewRaceMarketPda(marketId) {
359
+ const [pda, bump] = deriveRaceMarketPda(marketId);
360
+ return { raceMarketPda: pda.toBase58(), bump };
361
+ }
362
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"market-creation-tx.js","sourceRoot":"","sources":["../../src/builders/market-creation-tx.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Market Creation Transaction Builders\n *\n * Builds unsigned transactions for:\n * - create_lab_market_sol (community markets)\n * - create_private_table_sol (invite-only markets)\n * - create_race_market_sol (multi-outcome markets)\n *\n * FIXED: Jan 2026 - Corrected discriminators, offsets, and instruction formats\n */\nimport {\n  Connection,\n  PublicKey,\n  Transaction,\n  TransactionInstruction,\n  SystemProgram,\n} from '@solana/web3.js';\nimport {\n  PROGRAM_ID,\n  CONFIG_PDA,\n  SOL_TREASURY_PDA,\n  SEEDS,\n  RPC_ENDPOINT,\n} from '../config.js';\n\n// =============================================================================\n// INSTRUCTION DISCRIMINATORS (sha256(\"global:<name>\")[0..8])\n// =============================================================================\n\nconst CREATE_LAB_MARKET_SOL_DISCRIMINATOR = Buffer.from([35, 159, 50, 67, 31, 134, 199, 157]);\nconst CREATE_PRIVATE_TABLE_SOL_DISCRIMINATOR = Buffer.from([242, 241, 183, 108, 35, 183, 38, 241]);\nconst CREATE_RACE_MARKET_SOL_DISCRIMINATOR = Buffer.from([94, 237, 40, 47, 63, 233, 25, 67]);\n\n// =============================================================================\n// GLOBAL CONFIG OFFSETS (calculated from IDL struct layout)\n// =============================================================================\n\n// GlobalConfig struct layout:\n// discriminator (8) + admin (32) + treasury (32) + guardian (32) +\n// _reserved_usdc_mint (32) + _reserved_creation_fee_usdc (8) + creation_fee_sol (8) +\n// _reserved_market_bond_usdc (8) + market_bond_sol (8) + platform_fee_bps (2) + market_count (8)\nconst MARKET_COUNT_OFFSET = 8 + 32 + 32 + 32 + 32 + 8 + 8 + 8 + 8 + 2; // = 170\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\nexport interface CreateMarketResult {\n  transaction: Transaction;\n  serializedTx: string;\n  marketPda: string;\n  marketId: bigint;\n}\n\nexport interface CreateLabMarketParams {\n  question: string;\n  closingTime: Date;\n  resolutionBuffer?: number;    // seconds after closing before resolution (default: 43200 = 12h)\n  autoStopBuffer?: number;      // seconds before closing to stop betting (default: 300 = 5min)\n  resolutionMode?: number;      // 0=HostOracle, 1=CouncilOracle (default: 1)\n  council?: string[];           // council member pubkeys (required if resolutionMode=1)\n  councilThreshold?: number;    // votes needed (required if resolutionMode=1)\n  creatorWallet: string;\n}\n\nexport interface CreatePrivateMarketParams {\n  question: string;\n  closingTime: Date;\n  resolutionBuffer?: number;\n  autoStopBuffer?: number;\n  resolutionMode?: number;\n  council?: string[];\n  councilThreshold?: number;\n  creatorWallet: string;\n}\n\nexport interface CreateRaceMarketParams {\n  question: string;\n  outcomes: string[];           // 2-10 outcome labels\n  closingTime: Date;\n  resolutionBuffer?: number;\n  autoStopBuffer?: number;\n  layer?: number;               // 1=Lab, 2=Private (default: 1)\n  resolutionMode?: number;      // 0=HostOracle, 1=CouncilOracle\n  accessGate?: number;          // 0=Public, 1=Whitelist\n  council?: string[];\n  councilThreshold?: number;\n  creatorWallet: string;\n}\n\n// =============================================================================\n// PDA DERIVATION\n// =============================================================================\n\nfunction deriveMarketPda(marketId: bigint): [PublicKey, number] {\n  const marketIdBuffer = Buffer.alloc(8);\n  marketIdBuffer.writeBigUInt64LE(marketId);\n  return PublicKey.findProgramAddressSync(\n    [SEEDS.MARKET, marketIdBuffer],\n    PROGRAM_ID\n  );\n}\n\nfunction deriveRaceMarketPda(marketId: bigint): [PublicKey, number] {\n  const marketIdBuffer = Buffer.alloc(8);\n  marketIdBuffer.writeBigUInt64LE(marketId);\n  return PublicKey.findProgramAddressSync(\n    [SEEDS.RACE, marketIdBuffer],\n    PROGRAM_ID\n  );\n}\n\nfunction deriveWhitelistPda(marketId: bigint): [PublicKey, number] {\n  const marketIdBuffer = Buffer.alloc(8);\n  marketIdBuffer.writeBigUInt64LE(marketId);\n  return PublicKey.findProgramAddressSync(\n    [SEEDS.WHITELIST, marketIdBuffer],\n    PROGRAM_ID\n  );\n}\n\nfunction deriveCreatorProfilePda(creator: PublicKey): [PublicKey, number] {\n  return PublicKey.findProgramAddressSync(\n    [Buffer.from('creator_profile'), creator.toBuffer()],\n    PROGRAM_ID\n  );\n}\n\n// =============================================================================\n// GET MARKET COUNT FROM CONFIG\n// =============================================================================\n\nexport async function getNextMarketId(\n  connection?: Connection\n): Promise<{ marketId: bigint; raceMarketId: bigint }> {\n  const conn = connection || new Connection(RPC_ENDPOINT, 'confirmed');\n\n  try {\n    const configAccount = await conn.getAccountInfo(CONFIG_PDA);\n    if (!configAccount) {\n      throw new Error('GlobalConfig not found');\n    }\n\n    const data = configAccount.data;\n    // market_count at offset 170 (verified against on-chain data)\n    const marketCount = data.readBigUInt64LE(MARKET_COUNT_OFFSET);\n\n    // Both regular and race markets use the SAME counter\n    // The program uses the CURRENT value (not +1) for PDA derivation\n    return {\n      marketId: marketCount,\n      raceMarketId: marketCount,\n    };\n  } catch (err) {\n    // If we can't read config, return safe defaults\n    return { marketId: 0n, raceMarketId: 0n };\n  }\n}\n\n// =============================================================================\n// BUILD CREATE LAB MARKET TRANSACTION\n// =============================================================================\n\nexport async function buildCreateLabMarketTransaction(\n  params: CreateLabMarketParams,\n  connection?: Connection\n): Promise<CreateMarketResult> {\n  const conn = connection || new Connection(RPC_ENDPOINT, 'confirmed');\n  const creatorPubkey = new PublicKey(params.creatorWallet);\n\n  // Get current market count for PDA derivation\n  const { marketId } = await getNextMarketId(conn);\n  const [marketPda] = deriveMarketPda(marketId);\n  const [creatorProfilePda] = deriveCreatorProfilePda(creatorPubkey);\n\n  // Check if creator profile exists\n  const creatorProfileInfo = await conn.getAccountInfo(creatorProfilePda);\n  const hasCreatorProfile = creatorProfileInfo !== null;\n\n  // Set defaults\n  const closingTime = BigInt(Math.floor(params.closingTime.getTime() / 1000));\n  const resolutionBuffer = BigInt(params.resolutionBuffer ?? 43200); // 12 hours\n  const autoStopBuffer = BigInt(params.autoStopBuffer ?? 300); // 5 minutes\n  const resolutionMode = params.resolutionMode ?? 1; // CouncilOracle by default\n\n  // For CouncilOracle, creator is default council member\n  const council = params.council?.map(p => new PublicKey(p)) ??\n    (resolutionMode === 1 ? [creatorPubkey] : []);\n  const councilThreshold = params.councilThreshold ?? (council.length > 0 ? 1 : 0);\n\n  // Encode instruction data:\n  // discriminator (8) + question (4+len) + closing_time (8) + resolution_buffer (8) +\n  // auto_stop_buffer (8) + resolution_mode (1) + council (4+n*32) + council_threshold (1)\n  const questionBytes = Buffer.from(params.question, 'utf8');\n  const size = 8 + 4 + questionBytes.length + 8 + 8 + 8 + 1 + 4 + (council.length * 32) + 1;\n\n  const data = Buffer.alloc(size);\n  let offset = 0;\n\n  CREATE_LAB_MARKET_SOL_DISCRIMINATOR.copy(data, offset); offset += 8;\n  data.writeUInt32LE(questionBytes.length, offset); offset += 4;\n  questionBytes.copy(data, offset); offset += questionBytes.length;\n  data.writeBigInt64LE(closingTime, offset); offset += 8;\n  data.writeBigInt64LE(resolutionBuffer, offset); offset += 8;\n  data.writeBigInt64LE(autoStopBuffer, offset); offset += 8;\n  data.writeUInt8(resolutionMode, offset); offset += 1;\n  data.writeUInt32LE(council.length, offset); offset += 4;\n  for (const member of council) {\n    member.toBuffer().copy(data, offset); offset += 32;\n  }\n  data.writeUInt8(councilThreshold, offset);\n\n  // Accounts from IDL:\n  // config (PDA), market (PDA), treasury, creator (signer), creator_profile (optional), system_program\n  const keys = [\n    { pubkey: CONFIG_PDA, isSigner: false, isWritable: true },\n    { pubkey: marketPda, isSigner: false, isWritable: true },\n    { pubkey: SOL_TREASURY_PDA, isSigner: false, isWritable: true },\n    { pubkey: creatorPubkey, isSigner: true, isWritable: true },\n    // For optional accounts, pass PROGRAM_ID as placeholder if not present\n    { pubkey: hasCreatorProfile ? creatorProfilePda : PROGRAM_ID, isSigner: false, isWritable: hasCreatorProfile },\n    { pubkey: SystemProgram.programId, isSigner: false, isWritable: false },\n  ];\n\n  const instruction = new TransactionInstruction({\n    programId: PROGRAM_ID,\n    keys,\n    data,\n  });\n\n  const transaction = new Transaction();\n  transaction.add(instruction);\n\n  const { blockhash } = await conn.getLatestBlockhash('finalized');\n  transaction.recentBlockhash = blockhash;\n  transaction.feePayer = creatorPubkey;\n\n  const serializedTx = transaction.serialize({\n    requireAllSignatures: false,\n    verifySignatures: false,\n  }).toString('base64');\n\n  return {\n    transaction,\n    serializedTx,\n    marketPda: marketPda.toBase58(),\n    marketId,\n  };\n}\n\n// =============================================================================\n// BUILD CREATE PRIVATE MARKET TRANSACTION\n// =============================================================================\n\nexport async function buildCreatePrivateMarketTransaction(\n  params: CreatePrivateMarketParams,\n  connection?: Connection\n): Promise<CreateMarketResult> {\n  const conn = connection || new Connection(RPC_ENDPOINT, 'confirmed');\n  const creatorPubkey = new PublicKey(params.creatorWallet);\n\n  const { marketId } = await getNextMarketId(conn);\n  const [marketPda] = deriveMarketPda(marketId);\n  const [whitelistPda] = deriveWhitelistPda(marketId);\n  const [creatorProfilePda] = deriveCreatorProfilePda(creatorPubkey);\n\n  const creatorProfileInfo = await conn.getAccountInfo(creatorProfilePda);\n  const hasCreatorProfile = creatorProfileInfo !== null;\n\n  const closingTime = BigInt(Math.floor(params.closingTime.getTime() / 1000));\n  const resolutionBuffer = BigInt(params.resolutionBuffer ?? 43200);\n  const autoStopBuffer = BigInt(params.autoStopBuffer ?? 300);\n  const resolutionMode = params.resolutionMode ?? 0; // HostOracle for private\n\n  const council = params.council?.map(p => new PublicKey(p)) ?? [];\n  const councilThreshold = params.councilThreshold ?? 0;\n\n  // Same instruction format as Lab market\n  const questionBytes = Buffer.from(params.question, 'utf8');\n  const size = 8 + 4 + questionBytes.length + 8 + 8 + 8 + 1 + 4 + (council.length * 32) + 1;\n\n  const data = Buffer.alloc(size);\n  let offset = 0;\n\n  CREATE_PRIVATE_TABLE_SOL_DISCRIMINATOR.copy(data, offset); offset += 8;\n  data.writeUInt32LE(questionBytes.length, offset); offset += 4;\n  questionBytes.copy(data, offset); offset += questionBytes.length;\n  data.writeBigInt64LE(closingTime, offset); offset += 8;\n  data.writeBigInt64LE(resolutionBuffer, offset); offset += 8;\n  data.writeBigInt64LE(autoStopBuffer, offset); offset += 8;\n  data.writeUInt8(resolutionMode, offset); offset += 1;\n  data.writeUInt32LE(council.length, offset); offset += 4;\n  for (const member of council) {\n    member.toBuffer().copy(data, offset); offset += 32;\n  }\n  data.writeUInt8(councilThreshold, offset);\n\n  // Private market accounts include whitelist PDA\n  const keys = [\n    { pubkey: CONFIG_PDA, isSigner: false, isWritable: true },\n    { pubkey: marketPda, isSigner: false, isWritable: true },\n    { pubkey: whitelistPda, isSigner: false, isWritable: true },\n    { pubkey: SOL_TREASURY_PDA, isSigner: false, isWritable: true },\n    { pubkey: creatorPubkey, isSigner: true, isWritable: true },\n    { pubkey: hasCreatorProfile ? creatorProfilePda : PROGRAM_ID, isSigner: false, isWritable: hasCreatorProfile },\n    { pubkey: SystemProgram.programId, isSigner: false, isWritable: false },\n  ];\n\n  const instruction = new TransactionInstruction({\n    programId: PROGRAM_ID,\n    keys,\n    data,\n  });\n\n  const transaction = new Transaction();\n  transaction.add(instruction);\n\n  const { blockhash } = await conn.getLatestBlockhash('finalized');\n  transaction.recentBlockhash = blockhash;\n  transaction.feePayer = creatorPubkey;\n\n  const serializedTx = transaction.serialize({\n    requireAllSignatures: false,\n    verifySignatures: false,\n  }).toString('base64');\n\n  return {\n    transaction,\n    serializedTx,\n    marketPda: marketPda.toBase58(),\n    marketId,\n  };\n}\n\n// =============================================================================\n// BUILD CREATE RACE MARKET TRANSACTION\n// =============================================================================\n\nexport async function buildCreateRaceMarketTransaction(\n  params: CreateRaceMarketParams,\n  connection?: Connection\n): Promise<CreateMarketResult> {\n  const conn = connection || new Connection(RPC_ENDPOINT, 'confirmed');\n  const creatorPubkey = new PublicKey(params.creatorWallet);\n\n  const { raceMarketId } = await getNextMarketId(conn);\n  const [raceMarketPda] = deriveRaceMarketPda(raceMarketId);\n  const [creatorProfilePda] = deriveCreatorProfilePda(creatorPubkey);\n\n  const creatorProfileInfo = await conn.getAccountInfo(creatorProfilePda);\n  const hasCreatorProfile = creatorProfileInfo !== null;\n\n  const closingTime = BigInt(Math.floor(params.closingTime.getTime() / 1000));\n  const resolutionBuffer = BigInt(params.resolutionBuffer ?? 43200);\n  const autoStopBuffer = BigInt(params.autoStopBuffer ?? 300);\n  const layer = params.layer ?? 1; // Lab by default\n  const resolutionMode = params.resolutionMode ?? 1; // CouncilOracle\n  const accessGate = params.accessGate ?? 0; // Public\n\n  // Council is Option<Vec<Pubkey>> - encode as 1 (Some) + vec or 0 (None)\n  const hasCouncil = params.council && params.council.length > 0;\n  const council = hasCouncil ? params.council!.map(p => new PublicKey(p)) : [];\n\n  // council_threshold is Option<u8>\n  const hasThreshold = params.councilThreshold !== undefined;\n  const councilThreshold = params.councilThreshold ?? 0;\n\n  // Encode instruction data:\n  // discriminator (8) + question (4+len) + outcome_labels (4 + n*(4+len)) +\n  // closing_time (8) + resolution_buffer (8) + auto_stop_buffer (8) +\n  // layer (1) + resolution_mode (1) + access_gate (1) +\n  // council (1 + 4 + n*32 or just 1) + council_threshold (1 + 1 or just 1)\n\n  const questionBytes = Buffer.from(params.question, 'utf8');\n  const outcomeBuffers = params.outcomes.map(o => Buffer.from(o, 'utf8'));\n\n  let outcomesSize = 4; // vec length\n  for (const buf of outcomeBuffers) {\n    outcomesSize += 4 + buf.length;\n  }\n\n  const councilSize = hasCouncil ? (1 + 4 + council.length * 32) : 1;\n  const thresholdSize = hasThreshold ? 2 : 1;\n\n  const size = 8 + 4 + questionBytes.length + outcomesSize + 8 + 8 + 8 + 1 + 1 + 1 + councilSize + thresholdSize;\n  const data = Buffer.alloc(size);\n  let offset = 0;\n\n  CREATE_RACE_MARKET_SOL_DISCRIMINATOR.copy(data, offset); offset += 8;\n\n  data.writeUInt32LE(questionBytes.length, offset); offset += 4;\n  questionBytes.copy(data, offset); offset += questionBytes.length;\n\n  data.writeUInt32LE(params.outcomes.length, offset); offset += 4;\n  for (const buf of outcomeBuffers) {\n    data.writeUInt32LE(buf.length, offset); offset += 4;\n    buf.copy(data, offset); offset += buf.length;\n  }\n\n  data.writeBigInt64LE(closingTime, offset); offset += 8;\n  data.writeBigInt64LE(resolutionBuffer, offset); offset += 8;\n  data.writeBigInt64LE(autoStopBuffer, offset); offset += 8;\n\n  data.writeUInt8(layer, offset); offset += 1;\n  data.writeUInt8(resolutionMode, offset); offset += 1;\n  data.writeUInt8(accessGate, offset); offset += 1;\n\n  // Option<Vec<Pubkey>> - 1 (Some) + vec or 0 (None)\n  if (hasCouncil) {\n    data.writeUInt8(1, offset); offset += 1;\n    data.writeUInt32LE(council.length, offset); offset += 4;\n    for (const member of council) {\n      member.toBuffer().copy(data, offset); offset += 32;\n    }\n  } else {\n    data.writeUInt8(0, offset); offset += 1;\n  }\n\n  // Option<u8> - 1 (Some) + value or 0 (None)\n  if (hasThreshold) {\n    data.writeUInt8(1, offset); offset += 1;\n    data.writeUInt8(councilThreshold, offset); offset += 1;\n  } else {\n    data.writeUInt8(0, offset); offset += 1;\n  }\n\n  // Accounts: config, race_market, creator_profile (optional), treasury, creator, system_program\n  const keys = [\n    { pubkey: CONFIG_PDA, isSigner: false, isWritable: true },\n    { pubkey: raceMarketPda, isSigner: false, isWritable: true },\n    { pubkey: hasCreatorProfile ? creatorProfilePda : PROGRAM_ID, isSigner: false, isWritable: hasCreatorProfile },\n    { pubkey: SOL_TREASURY_PDA, isSigner: false, isWritable: true },\n    { pubkey: creatorPubkey, isSigner: true, isWritable: true },\n    { pubkey: SystemProgram.programId, isSigner: false, isWritable: false },\n  ];\n\n  const instruction = new TransactionInstruction({\n    programId: PROGRAM_ID,\n    keys,\n    data,\n  });\n\n  const transaction = new Transaction();\n  transaction.add(instruction);\n\n  const { blockhash } = await conn.getLatestBlockhash('finalized');\n  transaction.recentBlockhash = blockhash;\n  transaction.feePayer = creatorPubkey;\n\n  const serializedTx = transaction.serialize({\n    requireAllSignatures: false,\n    verifySignatures: false,\n  }).toString('base64');\n\n  return {\n    transaction,\n    serializedTx,\n    marketPda: raceMarketPda.toBase58(),\n    marketId: raceMarketId,\n  };\n}\n\n// =============================================================================\n// HELPER: DERIVE PDA PREVIEW\n// =============================================================================\n\nexport function previewMarketPda(marketId: bigint): {\n  marketPda: string;\n  bump: number;\n} {\n  const [pda, bump] = deriveMarketPda(marketId);\n  return { marketPda: pda.toBase58(), bump };\n}\n\nexport function previewRaceMarketPda(marketId: bigint): {\n  raceMarketPda: string;\n  bump: number;\n} {\n  const [pda, bump] = deriveRaceMarketPda(marketId);\n  return { raceMarketPda: pda.toBase58(), bump };\n}\n"]}
@@ -0,0 +1,85 @@
1
+ /**
2
+ * Market Management Transaction Builders
3
+ *
4
+ * Builds unsigned transactions for:
5
+ * - Closing markets (stopping betting)
6
+ * - Extending market deadlines
7
+ */
8
+ import { Connection, Transaction } from '@solana/web3.js';
9
+ /**
10
+ * Build close_market transaction
11
+ * Stops betting on a market (usually done by creator before resolution)
12
+ */
13
+ export declare function buildCloseMarketTransaction(params: {
14
+ marketPda: string;
15
+ callerWallet: string;
16
+ connection?: Connection;
17
+ }): Promise<{
18
+ transaction: Transaction;
19
+ serializedTx: string;
20
+ }>;
21
+ /**
22
+ * Build extend_market transaction
23
+ * Extends the closing time and/or resolution time
24
+ */
25
+ export declare function buildExtendMarketTransaction(params: {
26
+ marketPda: string;
27
+ newClosingTime: number;
28
+ newResolutionTime?: number;
29
+ callerWallet: string;
30
+ connection?: Connection;
31
+ }): Promise<{
32
+ transaction: Transaction;
33
+ serializedTx: string;
34
+ }>;
35
+ /**
36
+ * Build close_race_market transaction
37
+ */
38
+ export declare function buildCloseRaceMarketTransaction(params: {
39
+ raceMarketPda: string;
40
+ callerWallet: string;
41
+ connection?: Connection;
42
+ }): Promise<{
43
+ transaction: Transaction;
44
+ serializedTx: string;
45
+ }>;
46
+ /**
47
+ * Build extend_race_market transaction
48
+ */
49
+ export declare function buildExtendRaceMarketTransaction(params: {
50
+ raceMarketPda: string;
51
+ newClosingTime: number;
52
+ newResolutionTime?: number;
53
+ callerWallet: string;
54
+ connection?: Connection;
55
+ }): Promise<{
56
+ transaction: Transaction;
57
+ serializedTx: string;
58
+ }>;
59
+ /**
60
+ * Build cancel_market transaction
61
+ * Cancels a market and allows all bettors to claim refunds.
62
+ * Only callable by admin or creator (depending on market status).
63
+ */
64
+ export declare function buildCancelMarketTransaction(params: {
65
+ marketPda: string;
66
+ reason: string;
67
+ authorityWallet: string;
68
+ connection?: Connection;
69
+ }): Promise<{
70
+ transaction: Transaction;
71
+ serializedTx: string;
72
+ }>;
73
+ /**
74
+ * Build cancel_race transaction
75
+ * Cancels a race market and allows all bettors to claim refunds.
76
+ */
77
+ export declare function buildCancelRaceTransaction(params: {
78
+ raceMarketPda: string;
79
+ reason: string;
80
+ authorityWallet: string;
81
+ connection?: Connection;
82
+ }): Promise<{
83
+ transaction: Transaction;
84
+ serializedTx: string;
85
+ }>;