drama-pm-client 0.1.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.
- package/README.md +521 -0
- package/dist/idl.d.ts +208 -0
- package/dist/idl.js +1067 -0
- package/dist/idl.json +1066 -0
- package/dist/index.d.ts +153 -0
- package/dist/index.js +232 -0
- package/dist/types.d.ts +1072 -0
- package/dist/types.js +2 -0
- package/dist/utils.d.ts +19 -0
- package/dist/utils.js +37 -0
- package/package.json +35 -0
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
import type { BN, Program } from "@coral-xyz/anchor";
|
|
2
|
+
import anchor from "@coral-xyz/anchor";
|
|
3
|
+
import { Connection, PublicKey, Transaction, TransactionInstruction } from "@solana/web3.js";
|
|
4
|
+
import { IDL } from "./idl.js";
|
|
5
|
+
import { DramaPm } from "./types.js";
|
|
6
|
+
export * from "./utils.js";
|
|
7
|
+
export { DramaPm, IDL };
|
|
8
|
+
export type Outcome = "Yes" | "No";
|
|
9
|
+
export interface CreateMarketParams {
|
|
10
|
+
admin: PublicKey;
|
|
11
|
+
marketId: number | BN;
|
|
12
|
+
yesPrice: number | BN;
|
|
13
|
+
noPrice: number | BN;
|
|
14
|
+
endTime: number | BN;
|
|
15
|
+
bettingToken: PublicKey;
|
|
16
|
+
}
|
|
17
|
+
export interface PlaceBetParams {
|
|
18
|
+
user: PublicKey;
|
|
19
|
+
admin: PublicKey;
|
|
20
|
+
marketId: number | BN;
|
|
21
|
+
amount: number | BN;
|
|
22
|
+
outcome: Outcome;
|
|
23
|
+
bettingToken: PublicKey;
|
|
24
|
+
createAta?: boolean;
|
|
25
|
+
}
|
|
26
|
+
export interface ClaimRewardsParams {
|
|
27
|
+
user: PublicKey;
|
|
28
|
+
admin: PublicKey;
|
|
29
|
+
marketId: number | BN;
|
|
30
|
+
bettingToken: PublicKey;
|
|
31
|
+
winningOutcome: Outcome;
|
|
32
|
+
}
|
|
33
|
+
export interface RefundParams {
|
|
34
|
+
user: PublicKey;
|
|
35
|
+
admin: PublicKey;
|
|
36
|
+
marketId: number | BN;
|
|
37
|
+
bettingToken: PublicKey;
|
|
38
|
+
outcome: Outcome;
|
|
39
|
+
}
|
|
40
|
+
export declare class DramaPmClient {
|
|
41
|
+
program: Program<DramaPm>;
|
|
42
|
+
provider: anchor.AnchorProvider;
|
|
43
|
+
connection: Connection;
|
|
44
|
+
constructor(connection: Connection, wallet?: anchor.Wallet);
|
|
45
|
+
/**
|
|
46
|
+
* Check if an associated token account exists
|
|
47
|
+
*/
|
|
48
|
+
ataExists(ata: PublicKey): Promise<boolean>;
|
|
49
|
+
/**
|
|
50
|
+
* Create an instruction to initialize an associated token account
|
|
51
|
+
*/
|
|
52
|
+
createAtaInstruction(payer: PublicKey, owner: PublicKey, mint: PublicKey): TransactionInstruction;
|
|
53
|
+
/**
|
|
54
|
+
* Create a new prediction market instruction
|
|
55
|
+
*/
|
|
56
|
+
createMarket(params: CreateMarketParams): Promise<TransactionInstruction>;
|
|
57
|
+
/**
|
|
58
|
+
* Build a complete transaction to create a market
|
|
59
|
+
*/
|
|
60
|
+
buildCreateMarketTx(params: CreateMarketParams): Promise<Transaction>;
|
|
61
|
+
/**
|
|
62
|
+
* Place a bet instruction (without ATA creation)
|
|
63
|
+
*/
|
|
64
|
+
placeBet(params: PlaceBetParams): Promise<TransactionInstruction>;
|
|
65
|
+
/**
|
|
66
|
+
* Build a complete transaction to place a bet (with optional ATA creation)
|
|
67
|
+
*/
|
|
68
|
+
buildPlaceBetTx(params: PlaceBetParams): Promise<Transaction>;
|
|
69
|
+
/**
|
|
70
|
+
* Claim rewards after market resolution
|
|
71
|
+
*/
|
|
72
|
+
claimRewards(params: ClaimRewardsParams): Promise<TransactionInstruction>;
|
|
73
|
+
/**
|
|
74
|
+
* Build a complete transaction to claim rewards
|
|
75
|
+
*/
|
|
76
|
+
buildClaimRewardsTx(params: ClaimRewardsParams): Promise<Transaction>;
|
|
77
|
+
/**
|
|
78
|
+
* Refund bets if market is refunded
|
|
79
|
+
*/
|
|
80
|
+
refund(params: RefundParams): Promise<TransactionInstruction>;
|
|
81
|
+
/**
|
|
82
|
+
* Build a complete transaction to refund
|
|
83
|
+
*/
|
|
84
|
+
buildRefundTx(params: RefundParams): Promise<Transaction>;
|
|
85
|
+
/**
|
|
86
|
+
* Resolve a market (Admin only)
|
|
87
|
+
*/
|
|
88
|
+
resolveMarket(admin: PublicKey, marketId: number | BN, winningOutcome: "Yes" | "No" | null): Promise<TransactionInstruction>;
|
|
89
|
+
/**
|
|
90
|
+
* Build a complete transaction to resolve a market
|
|
91
|
+
*/
|
|
92
|
+
buildResolveMarketTx(admin: PublicKey, marketId: number | BN, winningOutcome: "Yes" | "No" | null): Promise<Transaction>;
|
|
93
|
+
/**
|
|
94
|
+
* Close a market (Admin only)
|
|
95
|
+
*/
|
|
96
|
+
closeMarket(admin: PublicKey, marketId: number | BN): Promise<TransactionInstruction>;
|
|
97
|
+
/**
|
|
98
|
+
* Build a complete transaction to close a market
|
|
99
|
+
*/
|
|
100
|
+
buildCloseMarketTx(admin: PublicKey, marketId: number | BN): Promise<Transaction>;
|
|
101
|
+
/**
|
|
102
|
+
* Fetch market account data
|
|
103
|
+
*/
|
|
104
|
+
getMarketAccount(admin: PublicKey, marketId: number | BN): Promise<{
|
|
105
|
+
admin: anchor.web3.PublicKey;
|
|
106
|
+
marketId: BN;
|
|
107
|
+
yesMint: anchor.web3.PublicKey;
|
|
108
|
+
noMint: anchor.web3.PublicKey;
|
|
109
|
+
bettingToken: anchor.web3.PublicKey;
|
|
110
|
+
vault: anchor.web3.PublicKey;
|
|
111
|
+
yesPrice: BN;
|
|
112
|
+
noPrice: BN;
|
|
113
|
+
createTime: BN;
|
|
114
|
+
endTime: BN;
|
|
115
|
+
status: ({
|
|
116
|
+
closed?: undefined;
|
|
117
|
+
resolved?: undefined;
|
|
118
|
+
refunded?: undefined;
|
|
119
|
+
} & {
|
|
120
|
+
active: Record<string, never>;
|
|
121
|
+
}) | ({
|
|
122
|
+
active?: undefined;
|
|
123
|
+
resolved?: undefined;
|
|
124
|
+
refunded?: undefined;
|
|
125
|
+
} & {
|
|
126
|
+
closed: Record<string, never>;
|
|
127
|
+
}) | ({
|
|
128
|
+
active?: undefined;
|
|
129
|
+
closed?: undefined;
|
|
130
|
+
refunded?: undefined;
|
|
131
|
+
} & {
|
|
132
|
+
resolved: Record<string, never>;
|
|
133
|
+
}) | ({
|
|
134
|
+
active?: undefined;
|
|
135
|
+
closed?: undefined;
|
|
136
|
+
resolved?: undefined;
|
|
137
|
+
} & {
|
|
138
|
+
refunded: Record<string, never>;
|
|
139
|
+
});
|
|
140
|
+
winningOutcome: (({
|
|
141
|
+
yes?: undefined;
|
|
142
|
+
} & {
|
|
143
|
+
no: Record<string, never>;
|
|
144
|
+
}) | ({
|
|
145
|
+
no?: undefined;
|
|
146
|
+
} & {
|
|
147
|
+
yes: Record<string, never>;
|
|
148
|
+
})) | null;
|
|
149
|
+
totalYesSupply: BN;
|
|
150
|
+
totalNoSupply: BN;
|
|
151
|
+
bump: number;
|
|
152
|
+
}>;
|
|
153
|
+
}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,232 @@
|
|
|
1
|
+
import anchor from "@coral-xyz/anchor";
|
|
2
|
+
import { createAssociatedTokenAccountInstruction, getAccount, getAssociatedTokenAddressSync, TOKEN_PROGRAM_ID, } from "@solana/spl-token";
|
|
3
|
+
import { Keypair, Transaction } from "@solana/web3.js";
|
|
4
|
+
import { IDL } from "./idl.js";
|
|
5
|
+
import { getMarketPda, getMarketPdas } from "./utils.js";
|
|
6
|
+
const { BN: AnchorBN, Program: AnchorProgram } = anchor;
|
|
7
|
+
export * from "./utils.js";
|
|
8
|
+
export { IDL };
|
|
9
|
+
export class DramaPmClient {
|
|
10
|
+
constructor(connection, wallet) {
|
|
11
|
+
this.connection = connection;
|
|
12
|
+
this.provider = new anchor.AnchorProvider(connection, wallet || new anchor.Wallet(Keypair.generate()), { commitment: "confirmed" });
|
|
13
|
+
this.program = new AnchorProgram(IDL, this.provider);
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* Check if an associated token account exists
|
|
17
|
+
*/
|
|
18
|
+
async ataExists(ata) {
|
|
19
|
+
try {
|
|
20
|
+
await getAccount(this.connection, ata);
|
|
21
|
+
return true;
|
|
22
|
+
}
|
|
23
|
+
catch {
|
|
24
|
+
return false;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Create an instruction to initialize an associated token account
|
|
29
|
+
*/
|
|
30
|
+
createAtaInstruction(payer, owner, mint) {
|
|
31
|
+
const ata = getAssociatedTokenAddressSync(mint, owner);
|
|
32
|
+
return createAssociatedTokenAccountInstruction(payer, ata, owner, mint, TOKEN_PROGRAM_ID);
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Create a new prediction market instruction
|
|
36
|
+
*/
|
|
37
|
+
async createMarket(params) {
|
|
38
|
+
const { admin, marketId, yesPrice, noPrice, endTime, bettingToken } = params;
|
|
39
|
+
const marketIdBn = new AnchorBN(marketId);
|
|
40
|
+
const yesPriceBn = new AnchorBN(yesPrice);
|
|
41
|
+
const noPriceBn = new AnchorBN(noPrice);
|
|
42
|
+
const endTimeBn = new AnchorBN(endTime);
|
|
43
|
+
const pdas = getMarketPdas(this.program.programId, admin, marketIdBn);
|
|
44
|
+
return await this.program.methods
|
|
45
|
+
.createMarket({
|
|
46
|
+
marketId: marketIdBn,
|
|
47
|
+
yesPrice: yesPriceBn,
|
|
48
|
+
noPrice: noPriceBn,
|
|
49
|
+
endTime: endTimeBn,
|
|
50
|
+
})
|
|
51
|
+
.accountsPartial({
|
|
52
|
+
market: pdas.market,
|
|
53
|
+
yesMint: pdas.yesMint,
|
|
54
|
+
noMint: pdas.noMint,
|
|
55
|
+
bettingToken: bettingToken,
|
|
56
|
+
vault: pdas.vault,
|
|
57
|
+
admin: admin,
|
|
58
|
+
systemProgram: anchor.web3.SystemProgram.programId,
|
|
59
|
+
})
|
|
60
|
+
.instruction();
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Build a complete transaction to create a market
|
|
64
|
+
*/
|
|
65
|
+
async buildCreateMarketTx(params) {
|
|
66
|
+
const ix = await this.createMarket(params);
|
|
67
|
+
return new Transaction().add(ix);
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* Place a bet instruction (without ATA creation)
|
|
71
|
+
*/
|
|
72
|
+
async placeBet(params) {
|
|
73
|
+
const { user, admin, marketId, amount, outcome, bettingToken } = params;
|
|
74
|
+
const marketIdBn = new AnchorBN(marketId);
|
|
75
|
+
const amountBn = new AnchorBN(amount);
|
|
76
|
+
const outcomeEnum = outcome === "Yes" ? { yes: {} } : { no: {} };
|
|
77
|
+
const pdas = getMarketPdas(this.program.programId, admin, marketIdBn);
|
|
78
|
+
const userBettingToken = getAssociatedTokenAddressSync(bettingToken, user);
|
|
79
|
+
// Determine which outcome token the user will receive
|
|
80
|
+
const targetMint = outcome === "Yes" ? pdas.yesMint : pdas.noMint;
|
|
81
|
+
const userOutcomeToken = getAssociatedTokenAddressSync(targetMint, user);
|
|
82
|
+
return await this.program.methods
|
|
83
|
+
.placeBet({
|
|
84
|
+
buyOutcome: outcomeEnum,
|
|
85
|
+
amount: amountBn,
|
|
86
|
+
})
|
|
87
|
+
.accountsPartial({
|
|
88
|
+
market: pdas.market,
|
|
89
|
+
yesMint: pdas.yesMint,
|
|
90
|
+
noMint: pdas.noMint,
|
|
91
|
+
vault: pdas.vault,
|
|
92
|
+
userOutcomeToken,
|
|
93
|
+
userBettingToken,
|
|
94
|
+
user,
|
|
95
|
+
})
|
|
96
|
+
.instruction();
|
|
97
|
+
}
|
|
98
|
+
/**
|
|
99
|
+
* Build a complete transaction to place a bet (with optional ATA creation)
|
|
100
|
+
*/
|
|
101
|
+
async buildPlaceBetTx(params) {
|
|
102
|
+
const { user, admin, marketId, outcome, createAta = true } = params;
|
|
103
|
+
const tx = new Transaction();
|
|
104
|
+
const marketIdBn = new AnchorBN(marketId);
|
|
105
|
+
const pdas = getMarketPdas(this.program.programId, admin, marketIdBn);
|
|
106
|
+
const targetMint = outcome === "Yes" ? pdas.yesMint : pdas.noMint;
|
|
107
|
+
const userOutcomeToken = getAssociatedTokenAddressSync(targetMint, user);
|
|
108
|
+
// Check if ATA exists and create if needed
|
|
109
|
+
if (createAta) {
|
|
110
|
+
const exists = await this.ataExists(userOutcomeToken);
|
|
111
|
+
if (!exists) {
|
|
112
|
+
const createAtaIx = this.createAtaInstruction(user, user, targetMint);
|
|
113
|
+
tx.add(createAtaIx);
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
const placeBetIx = await this.placeBet(params);
|
|
117
|
+
tx.add(placeBetIx);
|
|
118
|
+
return tx;
|
|
119
|
+
}
|
|
120
|
+
/**
|
|
121
|
+
* Claim rewards after market resolution
|
|
122
|
+
*/
|
|
123
|
+
async claimRewards(params) {
|
|
124
|
+
const { user, admin, marketId, bettingToken, winningOutcome } = params;
|
|
125
|
+
const marketIdBn = new AnchorBN(marketId);
|
|
126
|
+
const pdas = getMarketPdas(this.program.programId, admin, marketIdBn);
|
|
127
|
+
const userBettingToken = getAssociatedTokenAddressSync(bettingToken, user);
|
|
128
|
+
const targetMint = winningOutcome === "Yes" ? pdas.yesMint : pdas.noMint;
|
|
129
|
+
const userOutcomeToken = getAssociatedTokenAddressSync(targetMint, user);
|
|
130
|
+
return await this.program.methods
|
|
131
|
+
.claimRewards()
|
|
132
|
+
.accountsPartial({
|
|
133
|
+
market: pdas.market,
|
|
134
|
+
userOutcomeToken,
|
|
135
|
+
userBettingToken,
|
|
136
|
+
user,
|
|
137
|
+
})
|
|
138
|
+
.instruction();
|
|
139
|
+
}
|
|
140
|
+
/**
|
|
141
|
+
* Build a complete transaction to claim rewards
|
|
142
|
+
*/
|
|
143
|
+
async buildClaimRewardsTx(params) {
|
|
144
|
+
const ix = await this.claimRewards(params);
|
|
145
|
+
return new Transaction().add(ix);
|
|
146
|
+
}
|
|
147
|
+
/**
|
|
148
|
+
* Refund bets if market is refunded
|
|
149
|
+
*/
|
|
150
|
+
async refund(params) {
|
|
151
|
+
const { user, admin, marketId, bettingToken, outcome } = params;
|
|
152
|
+
const marketIdBn = new AnchorBN(marketId);
|
|
153
|
+
const outcomeEnum = outcome === "Yes" ? { yes: {} } : { no: {} };
|
|
154
|
+
const pdas = getMarketPdas(this.program.programId, admin, marketIdBn);
|
|
155
|
+
const userBettingToken = getAssociatedTokenAddressSync(bettingToken, user);
|
|
156
|
+
const targetMint = outcome === "Yes" ? pdas.yesMint : pdas.noMint;
|
|
157
|
+
const userOutcomeToken = getAssociatedTokenAddressSync(targetMint, user);
|
|
158
|
+
return await this.program.methods
|
|
159
|
+
.refund(outcomeEnum)
|
|
160
|
+
.accountsPartial({
|
|
161
|
+
market: pdas.market,
|
|
162
|
+
userOutcomeToken,
|
|
163
|
+
userBettingToken,
|
|
164
|
+
user,
|
|
165
|
+
})
|
|
166
|
+
.instruction();
|
|
167
|
+
}
|
|
168
|
+
/**
|
|
169
|
+
* Build a complete transaction to refund
|
|
170
|
+
*/
|
|
171
|
+
async buildRefundTx(params) {
|
|
172
|
+
const ix = await this.refund(params);
|
|
173
|
+
return new Transaction().add(ix);
|
|
174
|
+
}
|
|
175
|
+
/**
|
|
176
|
+
* Resolve a market (Admin only)
|
|
177
|
+
*/
|
|
178
|
+
async resolveMarket(admin, marketId, winningOutcome) {
|
|
179
|
+
const marketIdBn = new AnchorBN(marketId);
|
|
180
|
+
const marketPda = getMarketPda(this.program.programId, admin, marketIdBn);
|
|
181
|
+
let outcomeEnum = null;
|
|
182
|
+
if (winningOutcome === "Yes") {
|
|
183
|
+
outcomeEnum = { yes: {} };
|
|
184
|
+
}
|
|
185
|
+
else if (winningOutcome === "No") {
|
|
186
|
+
outcomeEnum = { no: {} };
|
|
187
|
+
}
|
|
188
|
+
return await this.program.methods
|
|
189
|
+
.resolveMarket(outcomeEnum)
|
|
190
|
+
.accountsPartial({
|
|
191
|
+
market: marketPda,
|
|
192
|
+
admin,
|
|
193
|
+
})
|
|
194
|
+
.instruction();
|
|
195
|
+
}
|
|
196
|
+
/**
|
|
197
|
+
* Build a complete transaction to resolve a market
|
|
198
|
+
*/
|
|
199
|
+
async buildResolveMarketTx(admin, marketId, winningOutcome) {
|
|
200
|
+
const ix = await this.resolveMarket(admin, marketId, winningOutcome);
|
|
201
|
+
return new Transaction().add(ix);
|
|
202
|
+
}
|
|
203
|
+
/**
|
|
204
|
+
* Close a market (Admin only)
|
|
205
|
+
*/
|
|
206
|
+
async closeMarket(admin, marketId) {
|
|
207
|
+
const marketIdBn = new AnchorBN(marketId);
|
|
208
|
+
const marketPda = getMarketPda(this.program.programId, admin, marketIdBn);
|
|
209
|
+
return await this.program.methods
|
|
210
|
+
.closeMarket()
|
|
211
|
+
.accountsPartial({
|
|
212
|
+
market: marketPda,
|
|
213
|
+
})
|
|
214
|
+
.instruction();
|
|
215
|
+
}
|
|
216
|
+
/**
|
|
217
|
+
* Build a complete transaction to close a market
|
|
218
|
+
*/
|
|
219
|
+
async buildCloseMarketTx(admin, marketId) {
|
|
220
|
+
const ix = await this.closeMarket(admin, marketId);
|
|
221
|
+
return new Transaction().add(ix);
|
|
222
|
+
}
|
|
223
|
+
/**
|
|
224
|
+
* Fetch market account data
|
|
225
|
+
*/
|
|
226
|
+
async getMarketAccount(admin, marketId) {
|
|
227
|
+
const marketIdBn = new AnchorBN(marketId);
|
|
228
|
+
const marketPda = getMarketPda(this.program.programId, admin, marketIdBn);
|
|
229
|
+
return await this.program.account.market.fetch(marketPda);
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import type { BN, Idl, Program } from \"@coral-xyz/anchor\";\nimport anchor from \"@coral-xyz/anchor\";\nimport {\n    createAssociatedTokenAccountInstruction,\n    getAccount,\n    getAssociatedTokenAddressSync,\n    TOKEN_PROGRAM_ID,\n} from \"@solana/spl-token\";\nimport {\n    Connection,\n    Keypair,\n    PublicKey,\n    Transaction,\n    TransactionInstruction\n} from \"@solana/web3.js\";\nimport { IDL } from \"./idl.js\";\nimport { DramaPm } from \"./types.js\";\nimport {\n    getMarketPda,\n    getMarketPdas\n} from \"./utils.js\";\nconst { BN: AnchorBN, Program: AnchorProgram } = anchor;\n\nexport * from \"./utils.js\";\nexport { DramaPm, IDL };\n\nexport type Outcome = \"Yes\" | \"No\";\n\nexport interface CreateMarketParams {\n  admin: PublicKey;\n  marketId: number | BN;\n  yesPrice: number | BN;\n  noPrice: number | BN;\n  endTime: number | BN;\n  bettingToken: PublicKey;\n}\n\nexport interface PlaceBetParams {\n  user: PublicKey;\n  admin: PublicKey;\n  marketId: number | BN;\n  amount: number | BN;\n  outcome: Outcome;\n  bettingToken: PublicKey;\n  createAta?: boolean; // Whether to create ATA instruction automatically\n}\n\nexport interface ClaimRewardsParams {\n  user: PublicKey;\n  admin: PublicKey;\n  marketId: number | BN;\n  bettingToken: PublicKey;\n  winningOutcome: Outcome;\n}\n\nexport interface RefundParams {\n  user: PublicKey;\n  admin: PublicKey;\n  marketId: number | BN;\n  bettingToken: PublicKey;\n  outcome: Outcome;\n}\n\nexport class DramaPmClient {\n  program: Program<DramaPm>;\n  provider: anchor.AnchorProvider;\n  connection: Connection;\n\n  constructor(connection: Connection, wallet?: anchor.Wallet) {\n    this.connection = connection;\n    this.provider = new anchor.AnchorProvider(\n      connection,\n      wallet || new anchor.Wallet(Keypair.generate()),\n      { commitment: \"confirmed\" }\n    );\n    this.program = new AnchorProgram(IDL as Idl, this.provider) as unknown as Program<DramaPm>;\n  }\n\n  /**\n   * Check if an associated token account exists\n   */\n  async ataExists(ata: PublicKey): Promise<boolean> {\n    try {\n      await getAccount(this.connection, ata);\n      return true;\n    } catch {\n      return false;\n    }\n  }\n\n  /**\n   * Create an instruction to initialize an associated token account\n   */\n  createAtaInstruction(\n    payer: PublicKey,\n    owner: PublicKey,\n    mint: PublicKey\n  ): TransactionInstruction {\n    const ata = getAssociatedTokenAddressSync(mint, owner);\n    return createAssociatedTokenAccountInstruction(\n      payer,\n      ata,\n      owner,\n      mint,\n      TOKEN_PROGRAM_ID\n    );\n  }\n\n  /**\n   * Create a new prediction market instruction\n   */\n  async createMarket(params: CreateMarketParams): Promise<TransactionInstruction> {\n    const { admin, marketId, yesPrice, noPrice, endTime, bettingToken } = params;\n    \n    const marketIdBn = new AnchorBN(marketId);\n    const yesPriceBn = new AnchorBN(yesPrice);\n    const noPriceBn = new AnchorBN(noPrice);\n    const endTimeBn = new AnchorBN(endTime);\n\n    const pdas = getMarketPdas(this.program.programId, admin, marketIdBn);\n\n    return await this.program.methods\n      .createMarket({\n          marketId: marketIdBn,\n          yesPrice: yesPriceBn,\n          noPrice: noPriceBn,\n          endTime: endTimeBn,\n        })\n        .accountsPartial({\n          market: pdas.market,\n          yesMint: pdas.yesMint,\n          noMint: pdas.noMint,\n          bettingToken: bettingToken,\n          vault: pdas.vault,\n          admin: admin,\n          systemProgram: anchor.web3.SystemProgram.programId,\n        })\n        .instruction();\n  }\n\n  /**\n   * Build a complete transaction to create a market\n   */\n  async buildCreateMarketTx(params: CreateMarketParams): Promise<Transaction> {\n    const ix = await this.createMarket(params);\n    return new Transaction().add(ix);\n  }\n\n  /**\n   * Place a bet instruction (without ATA creation)\n   */\n  async placeBet(params: PlaceBetParams): Promise<TransactionInstruction> {\n    const { user, admin, marketId, amount, outcome, bettingToken } = params;\n    \n    const marketIdBn = new AnchorBN(marketId);\n    const amountBn = new AnchorBN(amount);\n    const outcomeEnum = outcome === \"Yes\" ? { yes: {} } : { no: {} };\n\n\n    const pdas = getMarketPdas(this.program.programId, admin, marketIdBn);\n    const userBettingToken = getAssociatedTokenAddressSync(bettingToken, user);\n    \n    // Determine which outcome token the user will receive\n    const targetMint = outcome === \"Yes\" ? pdas.yesMint : pdas.noMint;\n    const userOutcomeToken = getAssociatedTokenAddressSync(targetMint, user);\n\n    return await this.program.methods\n      .placeBet({\n        buyOutcome: outcomeEnum,\n        amount: amountBn,\n      })\n      .accountsPartial({\n        market: pdas.market,\n        yesMint: pdas.yesMint,\n        noMint: pdas.noMint,\n        vault: pdas.vault,\n        userOutcomeToken,\n        userBettingToken,\n        user,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to place a bet (with optional ATA creation)\n   */\n  async buildPlaceBetTx(params: PlaceBetParams): Promise<Transaction> {\n    const { user, admin, marketId, outcome, createAta = true } = params;\n    \n    const tx = new Transaction();\n    const marketIdBn = new AnchorBN(marketId);\n    const pdas = getMarketPdas(this.program.programId, admin, marketIdBn);\n    \n    const targetMint = outcome === \"Yes\" ? pdas.yesMint : pdas.noMint;\n    const userOutcomeToken = getAssociatedTokenAddressSync(targetMint, user);\n\n    // Check if ATA exists and create if needed\n    if (createAta) {\n      const exists = await this.ataExists(userOutcomeToken);\n      if (!exists) {\n        const createAtaIx = this.createAtaInstruction(user, user, targetMint);\n        tx.add(createAtaIx);\n      }\n    }\n\n    const placeBetIx = await this.placeBet(params);\n    tx.add(placeBetIx);\n\n    return tx;\n  }\n\n  /**\n   * Claim rewards after market resolution\n   */\n  async claimRewards(params: ClaimRewardsParams): Promise<TransactionInstruction> {\n    const { user, admin, marketId, bettingToken, winningOutcome } = params;\n    \n    const marketIdBn = new AnchorBN(marketId);\n    const pdas = getMarketPdas(this.program.programId, admin, marketIdBn);\n    const userBettingToken = getAssociatedTokenAddressSync(bettingToken, user);\n    \n    const targetMint = winningOutcome === \"Yes\" ? pdas.yesMint : pdas.noMint;\n    const userOutcomeToken = getAssociatedTokenAddressSync(targetMint, user);\n\n    return await this.program.methods\n      .claimRewards()\n      .accountsPartial({\n        market: pdas.market,\n        userOutcomeToken,\n        userBettingToken,\n        user,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to claim rewards\n   */\n  async buildClaimRewardsTx(params: ClaimRewardsParams): Promise<Transaction> {\n    const ix = await this.claimRewards(params);\n    return new Transaction().add(ix);\n  }\n\n  /**\n   * Refund bets if market is refunded\n   */\n  async refund(params: RefundParams): Promise<TransactionInstruction> {\n    const { user, admin, marketId, bettingToken, outcome } = params;\n    \n    const marketIdBn = new AnchorBN(marketId);\n    const outcomeEnum = outcome === \"Yes\" ? { yes: {} } : { no: {} };\n    const pdas = getMarketPdas(this.program.programId, admin, marketIdBn);\n    const userBettingToken = getAssociatedTokenAddressSync(bettingToken, user);\n    \n    const targetMint = outcome === \"Yes\" ? pdas.yesMint : pdas.noMint;\n    const userOutcomeToken = getAssociatedTokenAddressSync(targetMint, user);\n\n    return await this.program.methods\n      .refund(outcomeEnum)\n      .accountsPartial({\n        market: pdas.market,\n        userOutcomeToken,\n        userBettingToken,\n        user,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to refund\n   */\n  async buildRefundTx(params: RefundParams): Promise<Transaction> {\n    const ix = await this.refund(params);\n    return new Transaction().add(ix);\n  }\n\n  /**\n   * Resolve a market (Admin only)\n   */\n  async resolveMarket(\n    admin: PublicKey,\n    marketId: number | BN,\n    winningOutcome: \"Yes\" | \"No\" | null\n  ): Promise<TransactionInstruction> {\n    const marketIdBn = new AnchorBN(marketId);\n    const marketPda = getMarketPda(this.program.programId, admin, marketIdBn);\n\n    let outcomeEnum: any = null;\n    if (winningOutcome === \"Yes\") {\n      outcomeEnum = { yes: {} };\n    } else if (winningOutcome === \"No\") {\n      outcomeEnum = { no: {} };\n    }\n\n    return await this.program.methods\n      .resolveMarket(outcomeEnum)\n      .accountsPartial({\n        market: marketPda,\n        admin,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to resolve a market\n   */\n  async buildResolveMarketTx(\n    admin: PublicKey,\n    marketId: number | BN,\n    winningOutcome: \"Yes\" | \"No\" | null\n  ): Promise<Transaction> {\n    const ix = await this.resolveMarket(admin, marketId, winningOutcome);\n    return new Transaction().add(ix);\n  }\n\n  /**\n   * Close a market (Admin only)\n   */\n  async closeMarket(\n    admin: PublicKey,\n    marketId: number | BN\n  ): Promise<TransactionInstruction> {\n    const marketIdBn = new AnchorBN(marketId);\n    const marketPda = getMarketPda(this.program.programId, admin, marketIdBn);\n\n    return await this.program.methods\n      .closeMarket()\n      .accountsPartial({\n        market: marketPda,\n      })\n      .instruction();\n  }\n\n  /**\n   * Build a complete transaction to close a market\n   */\n  async buildCloseMarketTx(\n    admin: PublicKey,\n    marketId: number | BN\n  ): Promise<Transaction> {\n    const ix = await this.closeMarket(admin, marketId);\n    return new Transaction().add(ix);\n  }\n  \n  /**\n   * Fetch market account data\n   */\n  async getMarketAccount(admin: PublicKey, marketId: number | BN) {\n    const marketIdBn = new AnchorBN(marketId);\n    const marketPda = getMarketPda(this.program.programId, admin, marketIdBn);\n    return await this.program.account.market.fetch(marketPda);\n  }\n}\n"]}
|