@1upmonster/duel 0.1.8 → 0.2.1

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 (181) hide show
  1. package/dist/admin.d.ts +20 -42
  2. package/dist/admin.js +82 -117
  3. package/dist/encryption.js +1 -2
  4. package/dist/generated/duel/accounts/index.d.ts +10 -0
  5. package/dist/generated/duel/accounts/index.js +11 -0
  6. package/dist/generated/duel/accounts/matchTicket.d.ts +38 -0
  7. package/dist/generated/duel/accounts/matchTicket.js +45 -0
  8. package/dist/generated/duel/accounts/queue.d.ts +42 -0
  9. package/dist/generated/duel/accounts/queue.js +45 -0
  10. package/dist/generated/duel/accounts/tenant.d.ts +41 -0
  11. package/dist/generated/duel/accounts/tenant.js +44 -0
  12. package/dist/generated/duel/errors/duel.d.ts +33 -0
  13. package/dist/generated/duel/errors/duel.js +37 -0
  14. package/dist/generated/duel/errors/index.d.ts +8 -0
  15. package/dist/generated/duel/errors/index.js +9 -0
  16. package/dist/generated/duel/index.d.ts +12 -0
  17. package/dist/generated/duel/index.js +13 -0
  18. package/dist/generated/duel/instructions/cancelTicket.d.ts +45 -0
  19. package/dist/generated/duel/instructions/cancelTicket.js +56 -0
  20. package/dist/generated/duel/instructions/closeTicket.d.ts +45 -0
  21. package/dist/generated/duel/instructions/closeTicket.js +56 -0
  22. package/dist/generated/duel/instructions/commitTickets.d.ts +39 -0
  23. package/dist/generated/duel/instructions/commitTickets.js +50 -0
  24. package/dist/generated/duel/instructions/createTicket.d.ts +48 -0
  25. package/dist/generated/duel/instructions/createTicket.js +63 -0
  26. package/dist/generated/duel/instructions/delegateQueue.d.ts +69 -0
  27. package/dist/generated/duel/instructions/delegateQueue.js +90 -0
  28. package/dist/generated/duel/instructions/delegateTicket.d.ts +69 -0
  29. package/dist/generated/duel/instructions/delegateTicket.js +90 -0
  30. package/dist/generated/duel/instructions/flushMatches.d.ts +37 -0
  31. package/dist/generated/duel/instructions/flushMatches.js +43 -0
  32. package/dist/generated/duel/instructions/index.d.ts +18 -0
  33. package/dist/generated/duel/instructions/index.js +19 -0
  34. package/dist/generated/duel/instructions/initializeQueue.d.ts +48 -0
  35. package/dist/generated/duel/instructions/initializeQueue.js +63 -0
  36. package/dist/generated/duel/instructions/initializeTenant.d.ts +70 -0
  37. package/dist/generated/duel/instructions/initializeTenant.js +67 -0
  38. package/dist/generated/duel/instructions/joinQueue.d.ts +51 -0
  39. package/dist/generated/duel/instructions/joinQueue.js +56 -0
  40. package/dist/generated/duel/instructions/processUndelegation.d.ts +43 -0
  41. package/dist/generated/duel/instructions/processUndelegation.js +49 -0
  42. package/dist/generated/duel/programs/duel.d.ts +88 -0
  43. package/dist/generated/duel/programs/duel.js +138 -0
  44. package/dist/generated/duel/programs/index.d.ts +8 -0
  45. package/dist/generated/duel/programs/index.js +9 -0
  46. package/dist/generated/duel/types/accountType.d.ts +25 -0
  47. package/dist/generated/duel/types/accountType.js +25 -0
  48. package/dist/generated/duel/types/index.d.ts +13 -0
  49. package/dist/generated/duel/types/index.js +14 -0
  50. package/dist/generated/duel/types/matchEntry.d.ts +23 -0
  51. package/dist/generated/duel/types/matchEntry.js +18 -0
  52. package/dist/generated/duel/types/matchFound.d.ts +23 -0
  53. package/dist/generated/duel/types/matchFound.js +18 -0
  54. package/dist/generated/duel/types/pendingMatch.d.ts +21 -0
  55. package/dist/generated/duel/types/pendingMatch.js +18 -0
  56. package/dist/generated/duel/types/queueEntry.d.ts +19 -0
  57. package/dist/generated/duel/types/queueEntry.js +18 -0
  58. package/dist/generated/duel/types/ticketStatus.d.ts +40 -0
  59. package/dist/generated/duel/types/ticketStatus.js +25 -0
  60. package/dist/generated/rps-game/accounts/gameSession.d.ts +40 -0
  61. package/dist/generated/rps-game/accounts/gameSession.js +45 -0
  62. package/dist/generated/rps-game/accounts/index.d.ts +9 -0
  63. package/dist/generated/rps-game/accounts/index.js +10 -0
  64. package/dist/generated/rps-game/accounts/playerProfile.d.ts +36 -0
  65. package/dist/generated/rps-game/accounts/playerProfile.js +47 -0
  66. package/dist/generated/rps-game/errors/index.d.ts +8 -0
  67. package/dist/generated/rps-game/errors/index.js +9 -0
  68. package/dist/generated/rps-game/errors/rpsGame.d.ts +25 -0
  69. package/dist/generated/rps-game/errors/rpsGame.js +29 -0
  70. package/dist/generated/rps-game/index.d.ts +12 -0
  71. package/dist/generated/rps-game/index.js +13 -0
  72. package/dist/generated/rps-game/instructions/closePlayer.d.ts +45 -0
  73. package/dist/generated/rps-game/instructions/closePlayer.js +56 -0
  74. package/dist/generated/rps-game/instructions/delegatePda.d.ts +69 -0
  75. package/dist/generated/rps-game/instructions/delegatePda.js +90 -0
  76. package/dist/generated/rps-game/instructions/index.d.ts +16 -0
  77. package/dist/generated/rps-game/instructions/index.js +17 -0
  78. package/dist/generated/rps-game/instructions/initializePlayer.d.ts +48 -0
  79. package/dist/generated/rps-game/instructions/initializePlayer.js +63 -0
  80. package/dist/generated/rps-game/instructions/makeChoice.d.ts +44 -0
  81. package/dist/generated/rps-game/instructions/makeChoice.js +46 -0
  82. package/dist/generated/rps-game/instructions/onMatchFound.d.ts +43 -0
  83. package/dist/generated/rps-game/instructions/onMatchFound.js +45 -0
  84. package/dist/generated/rps-game/instructions/persistResults.d.ts +43 -0
  85. package/dist/generated/rps-game/instructions/persistResults.js +50 -0
  86. package/dist/generated/rps-game/instructions/processUndelegation.d.ts +43 -0
  87. package/dist/generated/rps-game/instructions/processUndelegation.js +49 -0
  88. package/dist/generated/rps-game/instructions/startGame.d.ts +54 -0
  89. package/dist/generated/rps-game/instructions/startGame.js +67 -0
  90. package/dist/generated/rps-game/instructions/startGameWithTicket.d.ts +57 -0
  91. package/dist/generated/rps-game/instructions/startGameWithTicket.js +67 -0
  92. package/dist/generated/rps-game/programs/index.d.ts +8 -0
  93. package/dist/generated/rps-game/programs/index.js +9 -0
  94. package/dist/generated/rps-game/programs/rpsGame.d.ts +78 -0
  95. package/dist/generated/rps-game/programs/rpsGame.js +118 -0
  96. package/dist/generated/rps-game/types/accountType.d.ts +34 -0
  97. package/dist/generated/rps-game/types/accountType.js +25 -0
  98. package/dist/generated/rps-game/types/choice.d.ts +17 -0
  99. package/dist/generated/rps-game/types/choice.js +25 -0
  100. package/dist/generated/rps-game/types/gameResult.d.ts +26 -0
  101. package/dist/generated/rps-game/types/gameResult.js +25 -0
  102. package/dist/generated/rps-game/types/index.d.ts +10 -0
  103. package/dist/generated/rps-game/types/index.js +11 -0
  104. package/dist/index.d.ts +2 -1
  105. package/dist/index.js +3 -2
  106. package/dist/player.d.ts +21 -48
  107. package/dist/player.js +61 -140
  108. package/dist/tee.d.ts +14 -0
  109. package/dist/tee.js +62 -0
  110. package/dist/transaction.d.ts +11 -0
  111. package/dist/transaction.js +50 -0
  112. package/dist/utils.d.ts +4 -4
  113. package/dist/utils.js +23 -8
  114. package/package.json +3 -6
  115. package/src/admin.ts +129 -163
  116. package/src/duel.json +66 -2
  117. package/src/encryption.ts +0 -3
  118. package/src/generated/duel/accounts/index.ts +11 -0
  119. package/src/generated/duel/accounts/matchTicket.ts +77 -0
  120. package/src/generated/duel/accounts/queue.ts +77 -0
  121. package/src/generated/duel/accounts/tenant.ts +76 -0
  122. package/src/generated/duel/errors/duel.ts +48 -0
  123. package/src/generated/duel/errors/index.ts +9 -0
  124. package/src/generated/duel/index.ts +13 -0
  125. package/src/generated/duel/instructions/cancelTicket.ts +100 -0
  126. package/src/generated/duel/instructions/closeTicket.ts +100 -0
  127. package/src/generated/duel/instructions/commitTickets.ts +84 -0
  128. package/src/generated/duel/instructions/createTicket.ts +109 -0
  129. package/src/generated/duel/instructions/delegateQueue.ts +157 -0
  130. package/src/generated/duel/instructions/delegateTicket.ts +157 -0
  131. package/src/generated/duel/instructions/flushMatches.ts +76 -0
  132. package/src/generated/duel/instructions/index.ts +19 -0
  133. package/src/generated/duel/instructions/initializeQueue.ts +109 -0
  134. package/src/generated/duel/instructions/initializeTenant.ts +126 -0
  135. package/src/generated/duel/instructions/joinQueue.ts +106 -0
  136. package/src/generated/duel/instructions/processUndelegation.ts +86 -0
  137. package/src/generated/duel/programs/duel.ts +104 -0
  138. package/src/generated/duel/programs/index.ts +9 -0
  139. package/src/generated/duel/types/accountType.ts +36 -0
  140. package/src/generated/duel/types/index.ts +14 -0
  141. package/src/generated/duel/types/matchEntry.ts +25 -0
  142. package/src/generated/duel/types/matchFound.ts +25 -0
  143. package/src/generated/duel/types/pendingMatch.ts +25 -0
  144. package/src/generated/duel/types/queueEntry.ts +25 -0
  145. package/src/generated/duel/types/ticketStatus.ts +38 -0
  146. package/src/generated/rps-game/accounts/gameSession.ts +77 -0
  147. package/src/generated/rps-game/accounts/index.ts +10 -0
  148. package/src/generated/rps-game/accounts/playerProfile.ts +80 -0
  149. package/src/generated/rps-game/errors/index.ts +9 -0
  150. package/src/generated/rps-game/errors/rpsGame.ts +40 -0
  151. package/src/generated/rps-game/index.ts +13 -0
  152. package/src/generated/rps-game/instructions/closePlayer.ts +100 -0
  153. package/src/generated/rps-game/instructions/delegatePda.ts +157 -0
  154. package/src/generated/rps-game/instructions/index.ts +17 -0
  155. package/src/generated/rps-game/instructions/initializePlayer.ts +109 -0
  156. package/src/generated/rps-game/instructions/makeChoice.ts +84 -0
  157. package/src/generated/rps-game/instructions/onMatchFound.ts +79 -0
  158. package/src/generated/rps-game/instructions/persistResults.ts +88 -0
  159. package/src/generated/rps-game/instructions/processUndelegation.ts +86 -0
  160. package/src/generated/rps-game/instructions/startGame.ts +118 -0
  161. package/src/generated/rps-game/instructions/startGameWithTicket.ts +121 -0
  162. package/src/generated/rps-game/programs/index.ts +9 -0
  163. package/src/generated/rps-game/programs/rpsGame.ts +95 -0
  164. package/src/generated/rps-game/types/accountType.ts +36 -0
  165. package/src/generated/rps-game/types/choice.ts +25 -0
  166. package/src/generated/rps-game/types/gameResult.ts +37 -0
  167. package/src/generated/rps-game/types/index.ts +11 -0
  168. package/src/index.ts +2 -1
  169. package/src/player.ts +96 -192
  170. package/src/rps_game.json +991 -0
  171. package/src/tee.ts +79 -0
  172. package/src/transaction.ts +90 -0
  173. package/src/utils.ts +35 -20
  174. package/tsconfig.json +2 -2
  175. package/dist/client.d.ts +0 -54
  176. package/dist/client.js +0 -265
  177. package/dist/duel.json +0 -1207
  178. package/dist/private_matchmaking.json +0 -534
  179. package/dist/types.d.ts +0 -635
  180. package/dist/types.js +0 -2
  181. package/src/types.ts +0 -300
package/dist/admin.d.ts CHANGED
@@ -1,49 +1,27 @@
1
- import * as anchor from "@coral-xyz/anchor";
2
- import * as web3 from "@solana/web3.js";
3
- import type { Duel } from "./types.js";
4
- export type EloDataType = 'u8' | 'u16' | 'u32' | 'u64';
1
+ import { type Address, type TransactionSigner, type Rpc, type SolanaRpcApi } from "@solana/kit";
2
+ export type EloDataType = "u8" | "u16" | "u32" | "u64";
5
3
  export interface InitializeTenantOptions {
6
- authority?: web3.PublicKey;
7
- eloWindow?: number;
4
+ authority?: Address;
5
+ eloWindow?: bigint;
8
6
  eloOffset?: number;
9
7
  eloDataType?: EloDataType;
10
- callbackProgramId?: web3.PublicKey | null;
8
+ callbackProgramId?: Address | null;
11
9
  callbackDiscriminator?: number[] | null;
12
10
  }
13
11
  export declare class MatchmakingAdmin {
14
- program: anchor.Program<Duel>;
15
- provider: anchor.AnchorProvider;
16
- constructor(provider: anchor.AnchorProvider, programId: web3.PublicKey | string);
17
- getQueuePda(authority: web3.PublicKey): web3.PublicKey;
18
- getTenantPda(authority: web3.PublicKey): web3.PublicKey;
19
- getTicketPda(player: web3.PublicKey, tenant: web3.PublicKey): web3.PublicKey;
20
- /**
21
- * Fetch Queue account data
22
- */
23
- getQueue(queuePda: web3.PublicKey): Promise<any>;
24
- /**
25
- * Fetch Tenant account data
26
- */
27
- getTenant(tenantPda: web3.PublicKey): Promise<any>;
28
- /**
29
- * Initialize a Tenant (with optional callback config)
30
- */
31
- initializeTenant(tenantProgramId: web3.PublicKey, options?: InitializeTenantOptions, confirmOptions?: web3.ConfirmOptions, signers?: web3.Keypair[]): Promise<web3.TransactionSignature>;
32
- /**
33
- * Initialize a Queue
34
- */
35
- initializeQueue(authority: web3.PublicKey, tenant: web3.PublicKey, confirmOptions?: web3.ConfirmOptions, signers?: web3.Keypair[]): Promise<web3.TransactionSignature>;
36
- /**
37
- * Delegate Queue to TEE
38
- */
39
- delegateQueue(authority: web3.PublicKey, validator?: web3.PublicKey, confirmOptions?: web3.ConfirmOptions, signers?: web3.Keypair[]): Promise<web3.TransactionSignature>;
40
- /**
41
- * Flush pending matches - crank instruction to update opponent tickets
42
- * Can be called by any TEE-authenticated wallet (permissionless)
43
- */
44
- flushMatches(queue: web3.PublicKey, tenant: web3.PublicKey, ticketPdas: web3.PublicKey[], callbackProgram?: web3.PublicKey, confirmOptions?: web3.ConfirmOptions, signers?: web3.Keypair[]): Promise<web3.TransactionSignature>;
45
- /**
46
- * Commit matched tickets back to L1 (runs in TEE)
47
- */
48
- commitTickets(tenant: web3.PublicKey, ticketPdas: web3.PublicKey[], confirmOptions?: web3.ConfirmOptions, signers?: web3.Keypair[]): Promise<web3.TransactionSignature>;
12
+ rpc: Rpc<SolanaRpcApi>;
13
+ signer: TransactionSigner;
14
+ programId: Address;
15
+ constructor(rpc: Rpc<SolanaRpcApi>, signer: TransactionSigner, programId?: Address);
16
+ getQueuePda(authority: Address): Promise<Address>;
17
+ getTenantPda(authority: Address): Promise<Address>;
18
+ getTicketPda(player: Address, tenant: Address): Promise<Address>;
19
+ getQueue(queuePda: Address): Promise<import("@solana/accounts").Account<import("./generated/duel/index.js").Queue, string>>;
20
+ initializeTenant(tenantProgramId: Address, options?: InitializeTenantOptions): Promise<string>;
21
+ initializeQueue(_authority: Address, tenant: Address): Promise<string>;
22
+ delegateQueue(authority: Address, validator?: Address): Promise<string>;
23
+ flushMatches(queue: Address, tenant: Address, ticketPdas: Address[], callbackProgram?: Address): Promise<string>;
24
+ commitTickets(tenant: Address, ticketPdas: Address[]): Promise<string>;
25
+ /** Create a new MatchmakingAdmin pointing at a TEE RPC endpoint. */
26
+ withRpc(teeUrl: string): MatchmakingAdmin;
49
27
  }
package/dist/admin.js CHANGED
@@ -1,137 +1,102 @@
1
- import * as anchor from "@coral-xyz/anchor";
2
- import { BN } from "bn.js";
3
- import * as web3 from "@solana/web3.js";
4
- import IDL from "./duel.json" with { type: "json" };
1
+ import { createSolanaRpc, } from "@solana/kit";
2
+ import { getInitializeTenantInstructionAsync, getInitializeQueueInstructionAsync, getDelegateQueueInstructionAsync, getFlushMatchesInstruction, getCommitTicketsInstruction, fetchQueue, accountType, } from "./generated/duel/index.js";
3
+ import { sendInstruction } from "./transaction.js";
5
4
  import * as utils from "./utils.js";
6
- const TICKET_SEED = "ticket";
7
5
  function getEloSize(dataType) {
8
6
  switch (dataType) {
9
- case 'u8': return 1;
10
- case 'u16': return 2;
11
- case 'u32': return 4;
12
- case 'u64': return 8;
7
+ case "u8": return 1;
8
+ case "u16": return 2;
9
+ case "u32": return 4;
10
+ case "u64": return 8;
13
11
  }
14
12
  }
13
+ const DUEL_PROGRAM_ID = "EdZzUwKd1X2ZWjxLPpz1cpEzMF7RUZC43Pq64v1VcK5X";
15
14
  export class MatchmakingAdmin {
16
- constructor(provider, programId) {
17
- const address = typeof programId === "string" ? programId : programId.toBase58();
18
- const idl = { ...IDL, address };
19
- this.program = new anchor.Program(idl, provider);
20
- this.provider = provider;
15
+ constructor(rpc, signer, programId = DUEL_PROGRAM_ID) {
16
+ this.rpc = rpc;
17
+ this.signer = signer;
18
+ this.programId = programId;
21
19
  }
22
- // Derive PDAs Helpers
23
- getQueuePda(authority) {
24
- return utils.deriveQueuePda(this.program.programId, authority);
20
+ async getQueuePda(authority) {
21
+ return utils.deriveQueuePda(this.programId, authority);
25
22
  }
26
- getTenantPda(authority) {
27
- return utils.deriveTenantPda(this.program.programId, authority);
23
+ async getTenantPda(authority) {
24
+ return utils.deriveTenantPda(this.programId, authority);
28
25
  }
29
- getTicketPda(player, tenant) {
30
- return utils.deriveTicketPda(this.program.programId, player, tenant);
26
+ async getTicketPda(player, tenant) {
27
+ return utils.deriveTicketPda(this.programId, player, tenant);
31
28
  }
32
- /**
33
- * Fetch Queue account data
34
- */
35
29
  async getQueue(queuePda) {
36
- return await this.program.account.queue.fetch(queuePda);
30
+ return fetchQueue(this.rpc, queuePda);
37
31
  }
38
- /**
39
- * Fetch Tenant account data
40
- */
41
- async getTenant(tenantPda) {
42
- return await this.program.account.tenant.fetch(tenantPda);
43
- }
44
- /**
45
- * Initialize a Tenant (with optional callback config)
46
- */
47
- async initializeTenant(tenantProgramId, options, confirmOptions, signers = []) {
48
- const { authority = tenantProgramId, eloWindow = 100, eloOffset = 40, eloDataType = 'u16', callbackProgramId = null, callbackDiscriminator = null, } = options || {};
32
+ async initializeTenant(tenantProgramId, options) {
33
+ const { eloWindow = 100n, eloOffset = 40, eloDataType = "u16", callbackProgramId = null, callbackDiscriminator = null, } = options || {};
49
34
  const eloSize = getEloSize(eloDataType);
50
- const tenantPda = this.getTenantPda(authority);
51
- return await this.program.methods
52
- .initializeTenant(tenantProgramId, eloOffset, eloSize, new BN(eloWindow), callbackProgramId || null, callbackDiscriminator ? Array.from(Buffer.from(callbackDiscriminator)) : null)
53
- .accountsPartial({
54
- tenant: tenantPda,
55
- authority: authority,
56
- })
57
- .signers(signers)
58
- .rpc(confirmOptions);
35
+ const ix = await getInitializeTenantInstructionAsync({
36
+ authority: this.signer,
37
+ tenantProgramId,
38
+ eloOffset,
39
+ eloSize,
40
+ eloWindow,
41
+ callbackProgramId: callbackProgramId ? { __option: "Some", value: callbackProgramId } : { __option: "None" },
42
+ callbackDiscriminator: callbackDiscriminator
43
+ ? { __option: "Some", value: new Uint8Array(callbackDiscriminator) }
44
+ : { __option: "None" },
45
+ }, { programAddress: this.programId });
46
+ return sendInstruction(this.rpc, ix, this.signer);
59
47
  }
60
- /**
61
- * Initialize a Queue
62
- */
63
- async initializeQueue(authority, tenant, confirmOptions, signers = []) {
64
- const queuePda = this.getQueuePda(authority);
65
- return await this.program.methods
66
- .initializeQueue()
67
- .accountsPartial({
68
- queue: queuePda,
69
- tenant: tenant,
70
- authority: authority,
71
- })
72
- .signers(signers)
73
- .rpc(confirmOptions);
48
+ async initializeQueue(_authority, tenant) {
49
+ const ix = await getInitializeQueueInstructionAsync({
50
+ authority: this.signer,
51
+ tenant,
52
+ }, { programAddress: this.programId });
53
+ return sendInstruction(this.rpc, ix, this.signer);
74
54
  }
75
- /**
76
- * Delegate Queue to TEE
77
- */
78
- async delegateQueue(authority, validator = new web3.PublicKey("FnE6VJT5QNZdedZPnCoLsARgBwoE6DeJNjBs2H1gySXA"), confirmOptions, signers = []) {
79
- const queuePda = this.getQueuePda(authority);
80
- return await this.program.methods
81
- .delegateQueue({ queue: { authority } })
82
- .accounts({
55
+ async delegateQueue(authority, validator) {
56
+ const queuePda = await this.getQueuePda(authority);
57
+ const ix = await getDelegateQueueInstructionAsync({
83
58
  pda: queuePda,
84
- payer: authority,
85
- validator: validator,
86
- })
87
- .signers(signers)
88
- .rpc(confirmOptions);
59
+ payer: this.signer,
60
+ validator,
61
+ accountType: accountType("Queue", { authority }),
62
+ }, { programAddress: this.programId });
63
+ return sendInstruction(this.rpc, ix, this.signer);
64
+ }
65
+ async flushMatches(queue, tenant, ticketPdas, callbackProgram) {
66
+ const ix = getFlushMatchesInstruction({
67
+ queue,
68
+ tenant,
69
+ signer: this.signer,
70
+ }, { programAddress: this.programId });
71
+ const remainingAccounts = [
72
+ ...ticketPdas.map((address) => ({ address, role: 1 })),
73
+ ...(callbackProgram ? [{ address: callbackProgram, role: 0 }] : []),
74
+ ];
75
+ const ixWithRemaining = {
76
+ ...ix,
77
+ accounts: [...ix.accounts, ...remainingAccounts],
78
+ };
79
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
80
+ return sendInstruction(this.rpc, ixWithRemaining, this.signer);
89
81
  }
90
- /**
91
- * Flush pending matches - crank instruction to update opponent tickets
92
- * Can be called by any TEE-authenticated wallet (permissionless)
93
- */
94
- async flushMatches(queue, tenant, ticketPdas, callbackProgram, confirmOptions, signers = []) {
95
- const remainingAccounts = ticketPdas.map(pda => ({
96
- pubkey: pda,
97
- isSigner: false,
98
- isWritable: true,
99
- }));
100
- if (callbackProgram) {
101
- remainingAccounts.push({
102
- pubkey: callbackProgram,
103
- isSigner: false,
104
- isWritable: false,
105
- });
106
- }
107
- return await this.program.methods
108
- .flushMatches()
109
- .accountsPartial({
110
- queue: queue,
111
- tenant: tenant,
112
- signer: this.provider.publicKey,
113
- })
114
- .remainingAccounts(remainingAccounts)
115
- .signers(signers)
116
- .rpc(confirmOptions);
82
+ async commitTickets(tenant, ticketPdas) {
83
+ const ix = getCommitTicketsInstruction({
84
+ tenant,
85
+ payer: this.signer,
86
+ }, { programAddress: this.programId });
87
+ const ixWithRemaining = {
88
+ ...ix,
89
+ accounts: [
90
+ ...ix.accounts,
91
+ ...ticketPdas.map((address) => ({ address, role: 1 })),
92
+ ],
93
+ };
94
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
95
+ return sendInstruction(this.rpc, ixWithRemaining, this.signer);
117
96
  }
118
- /**
119
- * Commit matched tickets back to L1 (runs in TEE)
120
- */
121
- async commitTickets(tenant, ticketPdas, confirmOptions, signers = []) {
122
- return await this.program.methods
123
- .commitTickets()
124
- .accountsPartial({
125
- tenant: tenant,
126
- payer: this.provider.publicKey,
127
- })
128
- .remainingAccounts(ticketPdas.map(pda => ({
129
- pubkey: pda,
130
- isSigner: false,
131
- isWritable: true,
132
- })))
133
- .signers(signers)
134
- .rpc(confirmOptions);
97
+ /** Create a new MatchmakingAdmin pointing at a TEE RPC endpoint. */
98
+ withRpc(teeUrl) {
99
+ return new MatchmakingAdmin(createSolanaRpc(teeUrl), this.signer, this.programId);
135
100
  }
136
101
  }
137
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"admin.js","sourceRoot":"","sources":["../src/admin.ts"],"names":[],"mappings":"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","sourcesContent":["import * as anchor from \"@coral-xyz/anchor\";\nimport { BN } from \"bn.js\";\nimport * as web3 from \"@solana/web3.js\";\nimport type { Duel } from \"./types.js\";\nimport IDL from \"./duel.json\" with { type: \"json\" };\nimport * as utils from \"./utils.js\";\n\nconst TICKET_SEED = \"ticket\";\n\nexport type EloDataType = 'u8' | 'u16' | 'u32' | 'u64';\n\nexport interface InitializeTenantOptions {\n  authority?: web3.PublicKey;\n  eloWindow?: number;\n  eloOffset?: number;\n  eloDataType?: EloDataType;\n  callbackProgramId?: web3.PublicKey | null;\n  callbackDiscriminator?: number[] | null;\n}\n\nfunction getEloSize(dataType: EloDataType): number {\n  switch (dataType) {\n    case 'u8': return 1;\n    case 'u16': return 2;\n    case 'u32': return 4;\n    case 'u64': return 8;\n  }\n}\n\nexport class MatchmakingAdmin {\n  public program: anchor.Program<Duel>;\n  public provider: anchor.AnchorProvider;\n\n  constructor(provider: anchor.AnchorProvider, programId: web3.PublicKey | string) {\n    const address = typeof programId === \"string\" ? programId : programId.toBase58();\n    const idl = { ...IDL, address };\n    this.program = new anchor.Program(idl as any, provider);\n    this.provider = provider;\n  }\n\n  // Derive PDAs Helpers\n  getQueuePda(authority: web3.PublicKey): web3.PublicKey {\n    return utils.deriveQueuePda(this.program.programId, authority);\n  }\n\n  getTenantPda(authority: web3.PublicKey): web3.PublicKey {\n    return utils.deriveTenantPda(this.program.programId, authority);\n  }\n\n  getTicketPda(player: web3.PublicKey, tenant: web3.PublicKey): web3.PublicKey {\n    return utils.deriveTicketPda(this.program.programId, player, tenant);\n  }\n\n  /**\n   * Fetch Queue account data\n   */\n  async getQueue(queuePda: web3.PublicKey): Promise<any> {\n    return await this.program.account.queue.fetch(queuePda);\n  }\n\n  /**\n   * Fetch Tenant account data\n   */\n  async getTenant(tenantPda: web3.PublicKey): Promise<any> {\n    return await this.program.account.tenant.fetch(tenantPda);\n  }\n\n  /**\n   * Initialize a Tenant (with optional callback config)\n   */\n  async initializeTenant(\n    tenantProgramId: web3.PublicKey,\n    options?: InitializeTenantOptions,\n    confirmOptions?: web3.ConfirmOptions,\n    signers: web3.Keypair[] = []\n  ): Promise<web3.TransactionSignature> {\n    const {\n      authority = tenantProgramId,\n      eloWindow = 100,\n      eloOffset = 40,\n      eloDataType = 'u16',\n      callbackProgramId = null,\n      callbackDiscriminator = null,\n    } = options || {};\n\n    const eloSize = getEloSize(eloDataType);\n    const tenantPda = this.getTenantPda(authority);\n\n    return await this.program.methods\n      .initializeTenant(\n        tenantProgramId,\n        eloOffset,\n        eloSize,\n        new BN(eloWindow),\n        callbackProgramId || null,\n        callbackDiscriminator ? Array.from(Buffer.from(callbackDiscriminator)) : null\n      )\n      .accountsPartial({\n        tenant: tenantPda,\n        authority: authority,\n      })\n      .signers(signers)\n      .rpc(confirmOptions);\n  }\n\n  /**\n   * Initialize a Queue\n   */\n  async initializeQueue(\n    authority: web3.PublicKey,\n    tenant: web3.PublicKey,\n    confirmOptions?: web3.ConfirmOptions,\n    signers: web3.Keypair[] = []\n  ): Promise<web3.TransactionSignature> {\n    const queuePda = this.getQueuePda(authority);\n    return await this.program.methods\n      .initializeQueue()\n      .accountsPartial({\n        queue: queuePda,\n        tenant: tenant,\n        authority: authority,\n      })\n      .signers(signers)\n      .rpc(confirmOptions);\n  }\n\n  /**\n   * Delegate Queue to TEE\n   */\n  async delegateQueue(\n    authority: web3.PublicKey,\n    validator: web3.PublicKey = new web3.PublicKey(\"FnE6VJT5QNZdedZPnCoLsARgBwoE6DeJNjBs2H1gySXA\"),\n    confirmOptions?: web3.ConfirmOptions,\n    signers: web3.Keypair[] = []\n  ): Promise<web3.TransactionSignature> {\n      const queuePda = this.getQueuePda(authority);\n      return await this.program.methods\n        .delegateQueue({ queue: { authority } } as any)\n        .accounts({\n            pda: queuePda,\n            payer: authority,\n            validator: validator,\n        } as unknown as any)\n        .signers(signers)\n        .rpc(confirmOptions);\n  }\n\n  /**\n   * Flush pending matches - crank instruction to update opponent tickets\n   * Can be called by any TEE-authenticated wallet (permissionless)\n   */\n  async flushMatches(\n    queue: web3.PublicKey,\n    tenant: web3.PublicKey,\n    ticketPdas: web3.PublicKey[],\n    callbackProgram?: web3.PublicKey,\n    confirmOptions?: web3.ConfirmOptions,\n    signers: web3.Keypair[] = []\n  ): Promise<web3.TransactionSignature> {\n    const remainingAccounts = ticketPdas.map(pda => ({\n      pubkey: pda,\n      isSigner: false,\n      isWritable: true,\n    }));\n\n    if (callbackProgram) {\n      remainingAccounts.push({\n        pubkey: callbackProgram,\n        isSigner: false,\n        isWritable: false,\n      });\n    }\n\n    return await this.program.methods\n      .flushMatches()\n      .accountsPartial({\n        queue: queue,\n        tenant: tenant,\n        signer: this.provider.publicKey,\n      })\n      .remainingAccounts(remainingAccounts)\n      .signers(signers)\n      .rpc(confirmOptions);\n  }\n\n  /**\n   * Commit matched tickets back to L1 (runs in TEE)\n   */\n  async commitTickets(\n    tenant: web3.PublicKey,\n    ticketPdas: web3.PublicKey[],\n    confirmOptions?: web3.ConfirmOptions,\n    signers: web3.Keypair[] = []\n  ): Promise<web3.TransactionSignature> {\n    return await this.program.methods\n      .commitTickets()\n      .accountsPartial({\n        tenant: tenant,\n        payer: this.provider.publicKey,\n      })\n      .remainingAccounts(\n        ticketPdas.map(pda => ({\n          pubkey: pda,\n          isSigner: false,\n          isWritable: true,\n        }))\n      )\n      .signers(signers)\n      .rpc(confirmOptions);\n  }\n}\n"]}
102
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"admin.js","sourceRoot":"","sources":["../src/admin.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,eAAe,GAKhB,MAAM,aAAa,CAAC;AACrB,OAAO,EACL,mCAAmC,EACnC,kCAAkC,EAClC,gCAAgC,EAChC,0BAA0B,EAC1B,2BAA2B,EAC3B,UAAU,EACV,WAAW,GACZ,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AACnD,OAAO,KAAK,KAAK,MAAM,YAAY,CAAC;AAapC,SAAS,UAAU,CAAC,QAAqB;IACvC,QAAQ,QAAQ,EAAE,CAAC;QACjB,KAAK,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC;QACpB,KAAK,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC;QACrB,KAAK,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC;QACrB,KAAK,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC;IACvB,CAAC;AACH,CAAC;AAED,MAAM,eAAe,GAAG,8CAAyD,CAAC;AAElF,MAAM,OAAO,gBAAgB;IAK3B,YACE,GAAsB,EACtB,MAAyB,EACzB,YAAqB,eAAe;QAEpC,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;QACf,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;IAC7B,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,SAAkB;QAClC,OAAO,KAAK,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;IACzD,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,SAAkB;QACnC,OAAO,KAAK,CAAC,eAAe,CAAC,IAAI,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;IAC1D,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,MAAe,EAAE,MAAe;QACjD,OAAO,KAAK,CAAC,eAAe,CAAC,IAAI,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;IAC/D,CAAC;IAED,KAAK,CAAC,QAAQ,CAAC,QAAiB;QAC9B,OAAO,UAAU,CAAC,IAAI,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;IACxC,CAAC;IAED,KAAK,CAAC,gBAAgB,CACpB,eAAwB,EACxB,OAAiC;QAEjC,MAAM,EACJ,SAAS,GAAG,IAAI,EAChB,SAAS,GAAG,EAAE,EACd,WAAW,GAAG,KAAK,EACnB,iBAAiB,GAAG,IAAI,EACxB,qBAAqB,GAAG,IAAI,GAC7B,GAAG,OAAO,IAAI,EAAE,CAAC;QAElB,MAAM,OAAO,GAAG,UAAU,CAAC,WAAW,CAAC,CAAC;QACxC,MAAM,EAAE,GAAG,MAAM,mCAAmC,CAAC;YACnD,SAAS,EAAE,IAAI,CAAC,MAAM;YACtB,eAAe;YACf,SAAS;YACT,OAAO;YACP,SAAS;YACT,iBAAiB,EAAE,iBAAiB,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,iBAAiB,EAAE,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE;YAC5G,qBAAqB,EAAE,qBAAqB;gBAC1C,CAAC,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,UAAU,CAAC,qBAAqB,CAAC,EAAE;gBACpE,CAAC,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE;SACzB,EAAE,EAAE,cAAc,EAAE,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;QAEvC,OAAO,eAAe,CAAC,IAAI,CAAC,GAAG,EAAE,EAAE,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IACpD,CAAC;IAED,KAAK,CAAC,eAAe,CACnB,UAAmB,EACnB,MAAe;QAEf,MAAM,EAAE,GAAG,MAAM,kCAAkC,CAAC;YAClD,SAAS,EAAE,IAAI,CAAC,MAAM;YACtB,MAAM;SACP,EAAE,EAAE,cAAc,EAAE,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;QACvC,OAAO,eAAe,CAAC,IAAI,CAAC,GAAG,EAAE,EAAE,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IACpD,CAAC;IAED,KAAK,CAAC,aAAa,CACjB,SAAkB,EAClB,SAAmB;QAEnB,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;QACnD,MAAM,EAAE,GAAG,MAAM,gCAAgC,CAAC;YAChD,GAAG,EAAE,QAAQ;YACb,KAAK,EAAE,IAAI,CAAC,MAAM;YAClB,SAAS;YACT,WAAW,EAAE,WAAW,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,CAAC;SACjD,EAAE,EAAE,cAAc,EAAE,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;QACvC,OAAO,eAAe,CAAC,IAAI,CAAC,GAAG,EAAE,EAAE,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IACpD,CAAC;IAED,KAAK,CAAC,YAAY,CAChB,KAAc,EACd,MAAe,EACf,UAAqB,EACrB,eAAyB;QAEzB,MAAM,EAAE,GAAG,0BAA0B,CAAC;YACpC,KAAK;YACL,MAAM;YACN,MAAM,EAAE,IAAI,CAAC,MAAM;SACpB,EAAE,EAAE,cAAc,EAAE,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;QAEvC,MAAM,iBAAiB,GAAG;YACxB,GAAG,UAAU,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAU,EAAE,CAAC,CAAC;YAC/D,GAAG,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,eAAe,EAAE,IAAI,EAAE,CAAU,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;SAC7E,CAAC;QAEF,MAAM,eAAe,GAAG;YACtB,GAAG,EAAE;YACL,QAAQ,EAAE,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE,GAAG,iBAAiB,CAAC;SACjD,CAAC;QAEF,8DAA8D;QAC9D,OAAO,eAAe,CAAC,IAAI,CAAC,GAAG,EAAE,eAAsB,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IACxE,CAAC;IAED,KAAK,CAAC,aAAa,CACjB,MAAe,EACf,UAAqB;QAErB,MAAM,EAAE,GAAG,2BAA2B,CAAC;YACrC,MAAM;YACN,KAAK,EAAE,IAAI,CAAC,MAAM;SACnB,EAAE,EAAE,cAAc,EAAE,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;QAEvC,MAAM,eAAe,GAAG;YACtB,GAAG,EAAE;YACL,QAAQ,EAAE;gBACR,GAAG,EAAE,CAAC,QAAQ;gBACd,GAAG,UAAU,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAU,EAAE,CAAC,CAAC;aAChE;SACF,CAAC;QAEF,8DAA8D;QAC9D,OAAO,eAAe,CAAC,IAAI,CAAC,GAAG,EAAE,eAAsB,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IACxE,CAAC;IAED,oEAAoE;IACpE,OAAO,CAAC,MAAc;QACpB,OAAO,IAAI,gBAAgB,CAAC,eAAe,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;IACpF,CAAC;CACF","sourcesContent":["import {\n  createSolanaRpc,\n  type Address,\n  type TransactionSigner,\n  type Rpc,\n  type SolanaRpcApi,\n} from \"@solana/kit\";\nimport {\n  getInitializeTenantInstructionAsync,\n  getInitializeQueueInstructionAsync,\n  getDelegateQueueInstructionAsync,\n  getFlushMatchesInstruction,\n  getCommitTicketsInstruction,\n  fetchQueue,\n  accountType,\n} from \"./generated/duel/index.js\";\nimport { sendInstruction } from \"./transaction.js\";\nimport * as utils from \"./utils.js\";\n\nexport type EloDataType = \"u8\" | \"u16\" | \"u32\" | \"u64\";\n\nexport interface InitializeTenantOptions {\n  authority?: Address;\n  eloWindow?: bigint;\n  eloOffset?: number;\n  eloDataType?: EloDataType;\n  callbackProgramId?: Address | null;\n  callbackDiscriminator?: number[] | null;\n}\n\nfunction getEloSize(dataType: EloDataType): number {\n  switch (dataType) {\n    case \"u8\": return 1;\n    case \"u16\": return 2;\n    case \"u32\": return 4;\n    case \"u64\": return 8;\n  }\n}\n\nconst DUEL_PROGRAM_ID = \"EdZzUwKd1X2ZWjxLPpz1cpEzMF7RUZC43Pq64v1VcK5X\" as Address;\n\nexport class MatchmakingAdmin {\n  public rpc: Rpc<SolanaRpcApi>;\n  public signer: TransactionSigner;\n  public programId: Address;\n\n  constructor(\n    rpc: Rpc<SolanaRpcApi>,\n    signer: TransactionSigner,\n    programId: Address = DUEL_PROGRAM_ID,\n  ) {\n    this.rpc = rpc;\n    this.signer = signer;\n    this.programId = programId;\n  }\n\n  async getQueuePda(authority: Address): Promise<Address> {\n    return utils.deriveQueuePda(this.programId, authority);\n  }\n\n  async getTenantPda(authority: Address): Promise<Address> {\n    return utils.deriveTenantPda(this.programId, authority);\n  }\n\n  async getTicketPda(player: Address, tenant: Address): Promise<Address> {\n    return utils.deriveTicketPda(this.programId, player, tenant);\n  }\n\n  async getQueue(queuePda: Address) {\n    return fetchQueue(this.rpc, queuePda);\n  }\n\n  async initializeTenant(\n    tenantProgramId: Address,\n    options?: InitializeTenantOptions,\n  ): Promise<string> {\n    const {\n      eloWindow = 100n,\n      eloOffset = 40,\n      eloDataType = \"u16\",\n      callbackProgramId = null,\n      callbackDiscriminator = null,\n    } = options || {};\n\n    const eloSize = getEloSize(eloDataType);\n    const ix = await getInitializeTenantInstructionAsync({\n      authority: this.signer,\n      tenantProgramId,\n      eloOffset,\n      eloSize,\n      eloWindow,\n      callbackProgramId: callbackProgramId ? { __option: \"Some\", value: callbackProgramId } : { __option: \"None\" },\n      callbackDiscriminator: callbackDiscriminator\n        ? { __option: \"Some\", value: new Uint8Array(callbackDiscriminator) }\n        : { __option: \"None\" },\n    }, { programAddress: this.programId });\n\n    return sendInstruction(this.rpc, ix, this.signer);\n  }\n\n  async initializeQueue(\n    _authority: Address,\n    tenant: Address,\n  ): Promise<string> {\n    const ix = await getInitializeQueueInstructionAsync({\n      authority: this.signer,\n      tenant,\n    }, { programAddress: this.programId });\n    return sendInstruction(this.rpc, ix, this.signer);\n  }\n\n  async delegateQueue(\n    authority: Address,\n    validator?: Address,\n  ): Promise<string> {\n    const queuePda = await this.getQueuePda(authority);\n    const ix = await getDelegateQueueInstructionAsync({\n      pda: queuePda,\n      payer: this.signer,\n      validator,\n      accountType: accountType(\"Queue\", { authority }),\n    }, { programAddress: this.programId });\n    return sendInstruction(this.rpc, ix, this.signer);\n  }\n\n  async flushMatches(\n    queue: Address,\n    tenant: Address,\n    ticketPdas: Address[],\n    callbackProgram?: Address,\n  ): Promise<string> {\n    const ix = getFlushMatchesInstruction({\n      queue,\n      tenant,\n      signer: this.signer,\n    }, { programAddress: this.programId });\n\n    const remainingAccounts = [\n      ...ticketPdas.map((address) => ({ address, role: 1 as const })),\n      ...(callbackProgram ? [{ address: callbackProgram, role: 0 as const }] : []),\n    ];\n\n    const ixWithRemaining = {\n      ...ix,\n      accounts: [...ix.accounts, ...remainingAccounts],\n    };\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    return sendInstruction(this.rpc, ixWithRemaining as any, this.signer);\n  }\n\n  async commitTickets(\n    tenant: Address,\n    ticketPdas: Address[],\n  ): Promise<string> {\n    const ix = getCommitTicketsInstruction({\n      tenant,\n      payer: this.signer,\n    }, { programAddress: this.programId });\n\n    const ixWithRemaining = {\n      ...ix,\n      accounts: [\n        ...ix.accounts,\n        ...ticketPdas.map((address) => ({ address, role: 1 as const })),\n      ],\n    };\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    return sendInstruction(this.rpc, ixWithRemaining as any, this.signer);\n  }\n\n  /** Create a new MatchmakingAdmin pointing at a TEE RPC endpoint. */\n  withRpc(teeUrl: string): MatchmakingAdmin {\n    return new MatchmakingAdmin(createSolanaRpc(teeUrl), this.signer, this.programId);\n  }\n}\n"]}
@@ -1,4 +1,3 @@
1
- // import { x25519 } from "@noble/curves/ed25519";
2
1
  export class EncryptionProvider {
3
2
  constructor() {
4
3
  this.keyPair = null;
@@ -94,4 +93,4 @@ export class EncryptionProvider {
94
93
  return new Uint8Array(raw);
95
94
  }
96
95
  }
97
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"encryption.js","sourceRoot":"","sources":["../src/encryption.ts"],"names":[],"mappings":"AACA,mDAAmD;AAEnD,MAAM,OAAO,kBAAkB;IAA/B;QACY,YAAO,GAAyB,IAAI,CAAC;IAwJjD,CAAC;IAtJG,gCAAgC;IAChC,IAAY,MAAM;QACd,IAAI,OAAO,UAAU,CAAC,MAAM,KAAK,WAAW,EAAE,CAAC;YAC3C,OAAO,UAAU,CAAC,MAAM,CAAC;QAC7B,CAAC;QACD,0FAA0F;QAC1F,IAAI,CAAC;YACD,OAAO,OAAO,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC;QACvC,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACT,MAAM,IAAI,KAAK,CAAC,8BAA8B,CAAC,CAAC;QACpD,CAAC;IACL,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,kBAAkB;QACpB,IAAI,CAAC,OAAO,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,WAAW,CAC/C;YACI,IAAI,EAAE,MAAM;YACZ,UAAU,EAAE,OAAO;SACtB,EACD,IAAI,EACJ,CAAC,WAAW,EAAE,YAAY,CAAC,CACb,CAAC;QAEnB,OAAO,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC;IAClC,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,cAAc,CAChB,IAAgB,EAChB,iBAA6B;QAE7B,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAChB,MAAM,IAAI,CAAC,kBAAkB,EAAE,CAAC;QACpC,CAAC;QAED,wBAAwB;QACxB,wGAAwG;QACxG,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAC7C,KAAK,EACL,iBAA4C,EAC5C,EAAE,IAAI,EAAE,MAAM,EAAE,UAAU,EAAE,OAAO,EAAE,EACrC,KAAK,EACL,EAAE,CACL,CAAC;QAEF,qCAAqC;QACrC,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAChD;YACI,IAAI,EAAE,MAAM;YACZ,MAAM,EAAE,MAAM;SACjB,EACD,IAAI,CAAC,OAAQ,CAAC,UAAU,EACxB;YACI,IAAI,EAAE,SAAS;YACf,MAAM,EAAE,GAAG;SACd,EACD,KAAK,EACL,CAAC,SAAS,EAAE,SAAS,CAAC,CACzB,CAAC;QAEF,eAAe;QACf,MAAM,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,IAAI,UAAU,CAAC,EAAE,CAAC,CAAC,CAAC;QAC3D,MAAM,eAAe,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CACpD;YACI,IAAI,EAAE,SAAS;YACf,EAAE,EAAE,EAAE;SACT,EACD,SAAS,EACT,IAA+B,CAClC,CAAC;QAEF,8BAA8B;QAC9B,MAAM,SAAS,GAAG,IAAI,UAAU,CAAC,EAAE,CAAC,MAAM,GAAG,eAAe,CAAC,UAAU,CAAC,CAAC;QACzE,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAClB,SAAS,CAAC,GAAG,CAAC,IAAI,UAAU,CAAC,eAAe,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,CAAC;QAE1D,2BAA2B;QAC3B,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,EAAE,IAAI,CAAC,OAAQ,CAAC,SAAS,CAAC,CAAC;QAExF,OAAO;YACH,SAAS;YACT,eAAe,EAAE,IAAI,UAAU,CAAC,YAAY,CAAC;SAChD,CAAC;IACN,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,eAAe,CACjB,aAAyB,EACzB,iBAA6B;QAE3B,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,MAAM,IAAI,KAAK,CAAC,gBAAgB,CAAC,CAAC;QAEpD,wBAAwB;QAC3B,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAC7C,KAAK,EACL,iBAA4C,EAC5C,EAAE,IAAI,EAAE,MAAM,EAAE,UAAU,EAAE,OAAO,EAAE,EACrC,KAAK,EACL,EAAE,CACL,CAAC;QAEF,uBAAuB;QACvB,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAChD;YACI,IAAI,EAAE,MAAM;YACZ,MAAM,EAAE,MAAM;SACjB,EACD,IAAI,CAAC,OAAQ,CAAC,UAAU,EACxB;YACI,IAAI,EAAE,SAAS;YACf,MAAM,EAAE,GAAG;SACd,EACD,KAAK,EACL,CAAC,SAAS,EAAE,SAAS,CAAC,CACzB,CAAC;QAEF,MAAM,EAAE,GAAG,aAAa,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QACtC,MAAM,UAAU,GAAG,aAAa,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QAE3C,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAC9C;YACI,IAAI,EAAE,SAAS;YACf,EAAE,EAAE,EAAE;SACT,EACD,SAAS,EACT,UAAqC,CACxC,CAAC;QAEF,OAAO,IAAI,UAAU,CAAC,SAAS,CAAC,CAAC;IACrC,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,sBAAsB;QACxB,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,WAAW,CAC7C,EAAE,IAAI,EAAE,MAAM,EAAE,UAAU,EAAE,OAAO,EAAE,EACrC,IAAI,EACJ,CAAC,WAAW,CAAC,CACC,CAAC;QACnB,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;QACtE,OAAO,IAAI,UAAU,CAAC,GAAG,CAAC,CAAC;IAC/B,CAAC;CACJ","sourcesContent":["import { PublicKey } from \"@solana/web3.js\";\n// import { x25519 } from \"@noble/curves/ed25519\"; \n\nexport class EncryptionProvider {\n    private keyPair: CryptoKeyPair | null = null;\n    \n    // Check for crypto availability\n    private get crypto(): Crypto {\n        if (typeof globalThis.crypto !== 'undefined') {\n            return globalThis.crypto;\n        }\n        // Fallback for Node < 19 if global crypto not set (though SDK likely targets modern envs)\n        try {\n            return require('crypto').webcrypto;\n        } catch (e) {\n            throw new Error(\"WebCrypto API not available.\");\n        }\n    }\n\n    /**\n     * Generate a fresh ephemeral keypair for the session (X25519/P-256).\n     */\n    async generateSessionKey(): Promise<CryptoKey> {\n        this.keyPair = await this.crypto.subtle.generateKey(\n            {\n                name: \"ECDH\",\n                namedCurve: \"P-256\", \n            },\n            true,\n            [\"deriveKey\", \"deriveBits\"]\n        ) as CryptoKeyPair;\n        \n        return this.keyPair.publicKey;\n    }\n\n    /**\n     * Derive shared secret and encrypt payload.\n     */\n    async encryptPayload(\n        data: Uint8Array, \n        teePublicKeyBytes: Uint8Array\n    ): Promise<{ encrypted: Uint8Array, clientPublicKey: Uint8Array }> {\n        if (!this.keyPair) {\n            await this.generateSessionKey();\n        }\n\n        // Import TEE Public Key\n        // Fix: Explicitly cast to BufferSource/any because TS gets confused with SharedArrayBuffer in some envs\n        const teeKey = await this.crypto.subtle.importKey(\n            \"raw\",\n            teePublicKeyBytes as unknown as BufferSource,\n            { name: \"ECDH\", namedCurve: \"P-256\" }, \n            false,\n            []\n        );\n\n        // Derive Shared Secret (AES-GCM Key)\n        const sharedKey = await this.crypto.subtle.deriveKey(\n            {\n                name: \"ECDH\",\n                public: teeKey,\n            },\n            this.keyPair!.privateKey,\n            {\n                name: \"AES-GCM\",\n                length: 256,\n            },\n            false,\n            [\"encrypt\", \"decrypt\"]\n        );\n\n        // Encrypt Data\n        const iv = this.crypto.getRandomValues(new Uint8Array(12));\n        const encryptedBuffer = await this.crypto.subtle.encrypt(\n            {\n                name: \"AES-GCM\",\n                iv: iv,\n            },\n            sharedKey,\n            data as unknown as BufferSource\n        );\n\n        // Concatenate IV + CipherText\n        const encrypted = new Uint8Array(iv.length + encryptedBuffer.byteLength);\n        encrypted.set(iv);\n        encrypted.set(new Uint8Array(encryptedBuffer), iv.length);\n\n        // Export Client Public Key\n        const clientPubRaw = await this.crypto.subtle.exportKey(\"raw\", this.keyPair!.publicKey);\n\n        return {\n            encrypted,\n            clientPublicKey: new Uint8Array(clientPubRaw)\n        };\n    }\n    \n    /**\n     * Decrypt a response from the TEE.\n     */\n    async decryptResponse(\n        encryptedData: Uint8Array, \n        teePublicKeyBytes: Uint8Array\n    ): Promise<Uint8Array> {\n          if (!this.keyPair) throw new Error(\"No session key\");\n          \n           // Import TEE Public Key\n        const teeKey = await this.crypto.subtle.importKey(\n            \"raw\",\n            teePublicKeyBytes as unknown as BufferSource,\n            { name: \"ECDH\", namedCurve: \"P-256\" }, \n            false,\n            []\n        );\n\n        // Derive Shared Secret\n        const sharedKey = await this.crypto.subtle.deriveKey(\n            {\n                name: \"ECDH\",\n                public: teeKey,\n            },\n            this.keyPair!.privateKey,\n            {\n                name: \"AES-GCM\",\n                length: 256,\n            },\n            false,\n            [\"encrypt\", \"decrypt\"]\n        );\n        \n        const iv = encryptedData.slice(0, 12);\n        const ciphertext = encryptedData.slice(12);\n        \n        const decrypted = await this.crypto.subtle.decrypt(\n            {\n                name: \"AES-GCM\",\n                iv: iv,\n            },\n            sharedKey,\n            ciphertext as unknown as BufferSource\n        );\n        \n        return new Uint8Array(decrypted);\n    }\n\n    /**\n     * Helper to generate a valid random P-256 Public Key (65 bytes) for testing.\n     */\n    async createMockValidatorKey(): Promise<Uint8Array> {\n        const pair = await this.crypto.subtle.generateKey(\n            { name: \"ECDH\", namedCurve: \"P-256\" },\n            true, \n            [\"deriveKey\"]\n        ) as CryptoKeyPair;\n        const raw = await this.crypto.subtle.exportKey(\"raw\", pair.publicKey);\n        return new Uint8Array(raw);\n    }\n}\n"]}
96
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"encryption.js","sourceRoot":"","sources":["../src/encryption.ts"],"names":[],"mappings":"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","sourcesContent":["export class EncryptionProvider {\n    private keyPair: CryptoKeyPair | null = null;\n    \n    // Check for crypto availability\n    private get crypto(): Crypto {\n        if (typeof globalThis.crypto !== 'undefined') {\n            return globalThis.crypto;\n        }\n        // Fallback for Node < 19 if global crypto not set (though SDK likely targets modern envs)\n        try {\n            return require('crypto').webcrypto;\n        } catch (e) {\n            throw new Error(\"WebCrypto API not available.\");\n        }\n    }\n\n    /**\n     * Generate a fresh ephemeral keypair for the session (X25519/P-256).\n     */\n    async generateSessionKey(): Promise<CryptoKey> {\n        this.keyPair = await this.crypto.subtle.generateKey(\n            {\n                name: \"ECDH\",\n                namedCurve: \"P-256\", \n            },\n            true,\n            [\"deriveKey\", \"deriveBits\"]\n        ) as CryptoKeyPair;\n        \n        return this.keyPair.publicKey;\n    }\n\n    /**\n     * Derive shared secret and encrypt payload.\n     */\n    async encryptPayload(\n        data: Uint8Array, \n        teePublicKeyBytes: Uint8Array\n    ): Promise<{ encrypted: Uint8Array, clientPublicKey: Uint8Array }> {\n        if (!this.keyPair) {\n            await this.generateSessionKey();\n        }\n\n        // Import TEE Public Key\n        // Fix: Explicitly cast to BufferSource/any because TS gets confused with SharedArrayBuffer in some envs\n        const teeKey = await this.crypto.subtle.importKey(\n            \"raw\",\n            teePublicKeyBytes as unknown as BufferSource,\n            { name: \"ECDH\", namedCurve: \"P-256\" }, \n            false,\n            []\n        );\n\n        // Derive Shared Secret (AES-GCM Key)\n        const sharedKey = await this.crypto.subtle.deriveKey(\n            {\n                name: \"ECDH\",\n                public: teeKey,\n            },\n            this.keyPair!.privateKey,\n            {\n                name: \"AES-GCM\",\n                length: 256,\n            },\n            false,\n            [\"encrypt\", \"decrypt\"]\n        );\n\n        // Encrypt Data\n        const iv = this.crypto.getRandomValues(new Uint8Array(12));\n        const encryptedBuffer = await this.crypto.subtle.encrypt(\n            {\n                name: \"AES-GCM\",\n                iv: iv,\n            },\n            sharedKey,\n            data as unknown as BufferSource\n        );\n\n        // Concatenate IV + CipherText\n        const encrypted = new Uint8Array(iv.length + encryptedBuffer.byteLength);\n        encrypted.set(iv);\n        encrypted.set(new Uint8Array(encryptedBuffer), iv.length);\n\n        // Export Client Public Key\n        const clientPubRaw = await this.crypto.subtle.exportKey(\"raw\", this.keyPair!.publicKey);\n\n        return {\n            encrypted,\n            clientPublicKey: new Uint8Array(clientPubRaw)\n        };\n    }\n    \n    /**\n     * Decrypt a response from the TEE.\n     */\n    async decryptResponse(\n        encryptedData: Uint8Array, \n        teePublicKeyBytes: Uint8Array\n    ): Promise<Uint8Array> {\n          if (!this.keyPair) throw new Error(\"No session key\");\n          \n           // Import TEE Public Key\n        const teeKey = await this.crypto.subtle.importKey(\n            \"raw\",\n            teePublicKeyBytes as unknown as BufferSource,\n            { name: \"ECDH\", namedCurve: \"P-256\" }, \n            false,\n            []\n        );\n\n        // Derive Shared Secret\n        const sharedKey = await this.crypto.subtle.deriveKey(\n            {\n                name: \"ECDH\",\n                public: teeKey,\n            },\n            this.keyPair!.privateKey,\n            {\n                name: \"AES-GCM\",\n                length: 256,\n            },\n            false,\n            [\"encrypt\", \"decrypt\"]\n        );\n        \n        const iv = encryptedData.slice(0, 12);\n        const ciphertext = encryptedData.slice(12);\n        \n        const decrypted = await this.crypto.subtle.decrypt(\n            {\n                name: \"AES-GCM\",\n                iv: iv,\n            },\n            sharedKey,\n            ciphertext as unknown as BufferSource\n        );\n        \n        return new Uint8Array(decrypted);\n    }\n\n    /**\n     * Helper to generate a valid random P-256 Public Key (65 bytes) for testing.\n     */\n    async createMockValidatorKey(): Promise<Uint8Array> {\n        const pair = await this.crypto.subtle.generateKey(\n            { name: \"ECDH\", namedCurve: \"P-256\" },\n            true, \n            [\"deriveKey\"]\n        ) as CryptoKeyPair;\n        const raw = await this.crypto.subtle.exportKey(\"raw\", pair.publicKey);\n        return new Uint8Array(raw);\n    }\n}\n"]}
@@ -0,0 +1,10 @@
1
+ /**
2
+ * This code was AUTOGENERATED using the Codama library.
3
+ * Please DO NOT EDIT THIS FILE, instead use visitors
4
+ * to add features, then rerun Codama to update it.
5
+ *
6
+ * @see https://github.com/codama-idl/codama
7
+ */
8
+ export * from './matchTicket';
9
+ export * from './queue';
10
+ export * from './tenant';
@@ -0,0 +1,11 @@
1
+ /**
2
+ * This code was AUTOGENERATED using the Codama library.
3
+ * Please DO NOT EDIT THIS FILE, instead use visitors
4
+ * to add features, then rerun Codama to update it.
5
+ *
6
+ * @see https://github.com/codama-idl/codama
7
+ */
8
+ export * from './matchTicket';
9
+ export * from './queue';
10
+ export * from './tenant';
11
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvZ2VuZXJhdGVkL2R1ZWwvYWNjb3VudHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUgsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxVQUFVLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFRoaXMgY29kZSB3YXMgQVVUT0dFTkVSQVRFRCB1c2luZyB0aGUgQ29kYW1hIGxpYnJhcnkuXG4gKiBQbGVhc2UgRE8gTk9UIEVESVQgVEhJUyBGSUxFLCBpbnN0ZWFkIHVzZSB2aXNpdG9yc1xuICogdG8gYWRkIGZlYXR1cmVzLCB0aGVuIHJlcnVuIENvZGFtYSB0byB1cGRhdGUgaXQuXG4gKlxuICogQHNlZSBodHRwczovL2dpdGh1Yi5jb20vY29kYW1hLWlkbC9jb2RhbWFcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL21hdGNoVGlja2V0JztcbmV4cG9ydCAqIGZyb20gJy4vcXVldWUnO1xuZXhwb3J0ICogZnJvbSAnLi90ZW5hbnQnOyJdfQ==
@@ -0,0 +1,38 @@
1
+ /**
2
+ * This code was AUTOGENERATED using the Codama library.
3
+ * Please DO NOT EDIT THIS FILE, instead use visitors
4
+ * to add features, then rerun Codama to update it.
5
+ *
6
+ * @see https://github.com/codama-idl/codama
7
+ */
8
+ import { fetchEncodedAccount, fetchEncodedAccounts, type Account, type Address, type Codec, type Decoder, type EncodedAccount, type Encoder, type FetchAccountConfig, type FetchAccountsConfig, type MaybeAccount, type MaybeEncodedAccount, type ReadonlyUint8Array } from '@solana/kit';
9
+ import { type TicketStatus, type TicketStatusArgs } from '../types';
10
+ export declare const MATCH_TICKET_DISCRIMINATOR: Uint8Array<ArrayBuffer>;
11
+ export declare function getMatchTicketDiscriminatorBytes(): ReadonlyUint8Array<ArrayBuffer>;
12
+ export type MatchTicket = {
13
+ discriminator: ReadonlyUint8Array;
14
+ player: Address;
15
+ tenant: Address;
16
+ status: TicketStatus;
17
+ createdAt: bigint;
18
+ bump: number;
19
+ };
20
+ export type MatchTicketArgs = {
21
+ player: Address;
22
+ tenant: Address;
23
+ status: TicketStatusArgs;
24
+ createdAt: number | bigint;
25
+ bump: number;
26
+ };
27
+ /** Gets the encoder for {@link MatchTicketArgs} account data. */
28
+ export declare function getMatchTicketEncoder(): Encoder<MatchTicketArgs>;
29
+ /** Gets the decoder for {@link MatchTicket} account data. */
30
+ export declare function getMatchTicketDecoder(): Decoder<MatchTicket>;
31
+ /** Gets the codec for {@link MatchTicket} account data. */
32
+ export declare function getMatchTicketCodec(): Codec<MatchTicketArgs, MatchTicket>;
33
+ export declare function decodeMatchTicket<TAddress extends string = string>(encodedAccount: EncodedAccount<TAddress>): Account<MatchTicket, TAddress>;
34
+ export declare function decodeMatchTicket<TAddress extends string = string>(encodedAccount: MaybeEncodedAccount<TAddress>): MaybeAccount<MatchTicket, TAddress>;
35
+ export declare function fetchMatchTicket<TAddress extends string = string>(rpc: Parameters<typeof fetchEncodedAccount>[0], address: Address<TAddress>, config?: FetchAccountConfig): Promise<Account<MatchTicket, TAddress>>;
36
+ export declare function fetchMaybeMatchTicket<TAddress extends string = string>(rpc: Parameters<typeof fetchEncodedAccount>[0], address: Address<TAddress>, config?: FetchAccountConfig): Promise<MaybeAccount<MatchTicket, TAddress>>;
37
+ export declare function fetchAllMatchTicket(rpc: Parameters<typeof fetchEncodedAccounts>[0], addresses: Array<Address>, config?: FetchAccountsConfig): Promise<Account<MatchTicket>[]>;
38
+ export declare function fetchAllMaybeMatchTicket(rpc: Parameters<typeof fetchEncodedAccounts>[0], addresses: Array<Address>, config?: FetchAccountsConfig): Promise<MaybeAccount<MatchTicket>[]>;
@@ -0,0 +1,45 @@
1
+ /**
2
+ * This code was AUTOGENERATED using the Codama library.
3
+ * Please DO NOT EDIT THIS FILE, instead use visitors
4
+ * to add features, then rerun Codama to update it.
5
+ *
6
+ * @see https://github.com/codama-idl/codama
7
+ */
8
+ import { assertAccountExists, assertAccountsExist, combineCodec, decodeAccount, fetchEncodedAccount, fetchEncodedAccounts, fixDecoderSize, fixEncoderSize, getAddressDecoder, getAddressEncoder, getBytesDecoder, getBytesEncoder, getI64Decoder, getI64Encoder, getStructDecoder, getStructEncoder, getU8Decoder, getU8Encoder, transformEncoder } from '@solana/kit';
9
+ import { getTicketStatusDecoder, getTicketStatusEncoder } from '../types';
10
+ export const MATCH_TICKET_DISCRIMINATOR = new Uint8Array([11, 131, 4, 157, 207, 79, 126, 5]);
11
+ export function getMatchTicketDiscriminatorBytes() { return fixEncoderSize(getBytesEncoder(), 8).encode(MATCH_TICKET_DISCRIMINATOR); }
12
+ /** Gets the encoder for {@link MatchTicketArgs} account data. */
13
+ export function getMatchTicketEncoder() {
14
+ return transformEncoder(getStructEncoder([['discriminator', fixEncoderSize(getBytesEncoder(), 8)], ['player', getAddressEncoder()], ['tenant', getAddressEncoder()], ['status', getTicketStatusEncoder()], ['createdAt', getI64Encoder()], ['bump', getU8Encoder()]]), (value) => ({ ...value, discriminator: MATCH_TICKET_DISCRIMINATOR }));
15
+ }
16
+ /** Gets the decoder for {@link MatchTicket} account data. */
17
+ export function getMatchTicketDecoder() {
18
+ return getStructDecoder([['discriminator', fixDecoderSize(getBytesDecoder(), 8)], ['player', getAddressDecoder()], ['tenant', getAddressDecoder()], ['status', getTicketStatusDecoder()], ['createdAt', getI64Decoder()], ['bump', getU8Decoder()]]);
19
+ }
20
+ /** Gets the codec for {@link MatchTicket} account data. */
21
+ export function getMatchTicketCodec() {
22
+ return combineCodec(getMatchTicketEncoder(), getMatchTicketDecoder());
23
+ }
24
+ export function decodeMatchTicket(encodedAccount) {
25
+ return decodeAccount(encodedAccount, getMatchTicketDecoder());
26
+ }
27
+ export async function fetchMatchTicket(rpc, address, config) {
28
+ const maybeAccount = await fetchMaybeMatchTicket(rpc, address, config);
29
+ assertAccountExists(maybeAccount);
30
+ return maybeAccount;
31
+ }
32
+ export async function fetchMaybeMatchTicket(rpc, address, config) {
33
+ const maybeAccount = await fetchEncodedAccount(rpc, address, config);
34
+ return decodeMatchTicket(maybeAccount);
35
+ }
36
+ export async function fetchAllMatchTicket(rpc, addresses, config) {
37
+ const maybeAccounts = await fetchAllMaybeMatchTicket(rpc, addresses, config);
38
+ assertAccountsExist(maybeAccounts);
39
+ return maybeAccounts;
40
+ }
41
+ export async function fetchAllMaybeMatchTicket(rpc, addresses, config) {
42
+ const maybeAccounts = await fetchEncodedAccounts(rpc, addresses, config);
43
+ return maybeAccounts.map((maybeAccount) => decodeMatchTicket(maybeAccount));
44
+ }
45
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"matchTicket.js","sourceRoot":"","sources":["../../../../src/generated/duel/accounts/matchTicket.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * This code was AUTOGENERATED using the Codama library.\n * Please DO NOT EDIT THIS FILE, instead use visitors\n * to add features, then rerun Codama to update it.\n *\n * @see https://github.com/codama-idl/codama\n */\n\nimport { assertAccountExists, assertAccountsExist, combineCodec, decodeAccount, fetchEncodedAccount, fetchEncodedAccounts, fixDecoderSize, fixEncoderSize, getAddressDecoder, getAddressEncoder, getBytesDecoder, getBytesEncoder, getI64Decoder, getI64Encoder, getStructDecoder, getStructEncoder, getU8Decoder, getU8Encoder, transformEncoder, type Account, type Address, type Codec, type Decoder, type EncodedAccount, type Encoder, type FetchAccountConfig, type FetchAccountsConfig, type MaybeAccount, type MaybeEncodedAccount, type ReadonlyUint8Array } from '@solana/kit';\nimport { getTicketStatusDecoder, getTicketStatusEncoder, type TicketStatus, type TicketStatusArgs } from '../types';\n\nexport const MATCH_TICKET_DISCRIMINATOR = new Uint8Array([11, 131, 4, 157, 207, 79, 126, 5]);\n\nexport function getMatchTicketDiscriminatorBytes() { return fixEncoderSize(getBytesEncoder(), 8).encode(MATCH_TICKET_DISCRIMINATOR); }\n\nexport type MatchTicket = { discriminator: ReadonlyUint8Array; player: Address; tenant: Address; status: TicketStatus; createdAt: bigint; bump: number;  };\n\nexport type MatchTicketArgs = { player: Address; tenant: Address; status: TicketStatusArgs; createdAt: number | bigint; bump: number;  };\n\n/** Gets the encoder for {@link MatchTicketArgs} account data. */\nexport function getMatchTicketEncoder(): Encoder<MatchTicketArgs> {\n    return transformEncoder(getStructEncoder([['discriminator', fixEncoderSize(getBytesEncoder(), 8)], ['player', getAddressEncoder()], ['tenant', getAddressEncoder()], ['status', getTicketStatusEncoder()], ['createdAt', getI64Encoder()], ['bump', getU8Encoder()]]), (value) => ({ ...value, discriminator: MATCH_TICKET_DISCRIMINATOR }));\n}\n\n/** Gets the decoder for {@link MatchTicket} account data. */\nexport function getMatchTicketDecoder(): Decoder<MatchTicket> {\n    return getStructDecoder([['discriminator', fixDecoderSize(getBytesDecoder(), 8)], ['player', getAddressDecoder()], ['tenant', getAddressDecoder()], ['status', getTicketStatusDecoder()], ['createdAt', getI64Decoder()], ['bump', getU8Decoder()]]);\n}\n\n/** Gets the codec for {@link MatchTicket} account data. */\nexport function getMatchTicketCodec(): Codec<MatchTicketArgs, MatchTicket> {\n    return combineCodec(getMatchTicketEncoder(), getMatchTicketDecoder());\n}\n\nexport function decodeMatchTicket<TAddress extends string = string>(encodedAccount: EncodedAccount<TAddress>): Account<MatchTicket, TAddress>;\nexport function decodeMatchTicket<TAddress extends string = string>(encodedAccount: MaybeEncodedAccount<TAddress>): MaybeAccount<MatchTicket, TAddress>;\nexport function decodeMatchTicket<TAddress extends string = string>(encodedAccount: EncodedAccount<TAddress> | MaybeEncodedAccount<TAddress>): Account<MatchTicket, TAddress> | MaybeAccount<MatchTicket, TAddress> {\n  return decodeAccount(encodedAccount as MaybeEncodedAccount<TAddress>, getMatchTicketDecoder());\n}\n\nexport async function fetchMatchTicket<TAddress extends string = string>(\n  rpc: Parameters<typeof fetchEncodedAccount>[0],\n  address: Address<TAddress>,\n  config?: FetchAccountConfig,\n): Promise<Account<MatchTicket, TAddress>> {\n  const maybeAccount = await fetchMaybeMatchTicket(rpc, address, config);\n  assertAccountExists(maybeAccount);\n  return maybeAccount;\n}\n\nexport async function fetchMaybeMatchTicket<TAddress extends string = string>(\n  rpc: Parameters<typeof fetchEncodedAccount>[0],\n  address: Address<TAddress>,\n  config?: FetchAccountConfig,\n): Promise<MaybeAccount<MatchTicket, TAddress>> {\n  const maybeAccount = await fetchEncodedAccount(rpc, address, config);\n  return decodeMatchTicket(maybeAccount);\n}\n\nexport async function fetchAllMatchTicket(\n  rpc: Parameters<typeof fetchEncodedAccounts>[0],\n  addresses: Array<Address>,\n  config?: FetchAccountsConfig,\n): Promise<Account<MatchTicket>[]> {\n  const maybeAccounts = await fetchAllMaybeMatchTicket(rpc, addresses, config);\n  assertAccountsExist(maybeAccounts);\n  return maybeAccounts;\n}\n\nexport async function fetchAllMaybeMatchTicket(\n  rpc: Parameters<typeof fetchEncodedAccounts>[0],\n  addresses: Array<Address>,\n  config?: FetchAccountsConfig,\n): Promise<MaybeAccount<MatchTicket>[]> {\n  const maybeAccounts = await fetchEncodedAccounts(rpc, addresses, config);\n  return maybeAccounts.map((maybeAccount) => decodeMatchTicket(maybeAccount));\n}"]}
@@ -0,0 +1,42 @@
1
+ /**
2
+ * This code was AUTOGENERATED using the Codama library.
3
+ * Please DO NOT EDIT THIS FILE, instead use visitors
4
+ * to add features, then rerun Codama to update it.
5
+ *
6
+ * @see https://github.com/codama-idl/codama
7
+ */
8
+ import { fetchEncodedAccount, fetchEncodedAccounts, type Account, type Address, type Codec, type Decoder, type EncodedAccount, type Encoder, type FetchAccountConfig, type FetchAccountsConfig, type MaybeAccount, type MaybeEncodedAccount, type ReadonlyUint8Array } from '@solana/kit';
9
+ import { type MatchEntry, type MatchEntryArgs, type PendingMatch, type PendingMatchArgs, type QueueEntry, type QueueEntryArgs } from '../types';
10
+ export declare const QUEUE_DISCRIMINATOR: Uint8Array<ArrayBuffer>;
11
+ export declare function getQueueDiscriminatorBytes(): ReadonlyUint8Array<ArrayBuffer>;
12
+ export type Queue = {
13
+ discriminator: ReadonlyUint8Array;
14
+ authority: Address;
15
+ tenant: Address;
16
+ bump: number;
17
+ matchCounter: bigint;
18
+ entries: Array<QueueEntry>;
19
+ matches: Array<MatchEntry>;
20
+ pendingMatches: Array<PendingMatch>;
21
+ };
22
+ export type QueueArgs = {
23
+ authority: Address;
24
+ tenant: Address;
25
+ bump: number;
26
+ matchCounter: number | bigint;
27
+ entries: Array<QueueEntryArgs>;
28
+ matches: Array<MatchEntryArgs>;
29
+ pendingMatches: Array<PendingMatchArgs>;
30
+ };
31
+ /** Gets the encoder for {@link QueueArgs} account data. */
32
+ export declare function getQueueEncoder(): Encoder<QueueArgs>;
33
+ /** Gets the decoder for {@link Queue} account data. */
34
+ export declare function getQueueDecoder(): Decoder<Queue>;
35
+ /** Gets the codec for {@link Queue} account data. */
36
+ export declare function getQueueCodec(): Codec<QueueArgs, Queue>;
37
+ export declare function decodeQueue<TAddress extends string = string>(encodedAccount: EncodedAccount<TAddress>): Account<Queue, TAddress>;
38
+ export declare function decodeQueue<TAddress extends string = string>(encodedAccount: MaybeEncodedAccount<TAddress>): MaybeAccount<Queue, TAddress>;
39
+ export declare function fetchQueue<TAddress extends string = string>(rpc: Parameters<typeof fetchEncodedAccount>[0], address: Address<TAddress>, config?: FetchAccountConfig): Promise<Account<Queue, TAddress>>;
40
+ export declare function fetchMaybeQueue<TAddress extends string = string>(rpc: Parameters<typeof fetchEncodedAccount>[0], address: Address<TAddress>, config?: FetchAccountConfig): Promise<MaybeAccount<Queue, TAddress>>;
41
+ export declare function fetchAllQueue(rpc: Parameters<typeof fetchEncodedAccounts>[0], addresses: Array<Address>, config?: FetchAccountsConfig): Promise<Account<Queue>[]>;
42
+ export declare function fetchAllMaybeQueue(rpc: Parameters<typeof fetchEncodedAccounts>[0], addresses: Array<Address>, config?: FetchAccountsConfig): Promise<MaybeAccount<Queue>[]>;