@pear-protocol/agent-sdk 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/LICENSE +21 -0
- package/README.md +101 -0
- package/dist/client-EVhAAxSx.d.cts +348 -0
- package/dist/client-EVhAAxSx.d.ts +348 -0
- package/dist/index.cjs +456 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +22 -0
- package/dist/index.d.ts +22 -0
- package/dist/index.js +423 -0
- package/dist/index.js.map +1 -0
- package/dist/react/index.cjs +264 -0
- package/dist/react/index.cjs.map +1 -0
- package/dist/react/index.d.cts +76 -0
- package/dist/react/index.d.ts +76 -0
- package/dist/react/index.js +261 -0
- package/dist/react/index.js.map +1 -0
- package/package.json +77 -0
package/dist/index.js
ADDED
|
@@ -0,0 +1,423 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
|
|
3
|
+
// src/errors.ts
|
|
4
|
+
var AgentChatError = class extends Error {
|
|
5
|
+
status;
|
|
6
|
+
body;
|
|
7
|
+
constructor(message, status, body) {
|
|
8
|
+
super(message);
|
|
9
|
+
this.name = new.target.name;
|
|
10
|
+
this.status = status;
|
|
11
|
+
this.body = body;
|
|
12
|
+
}
|
|
13
|
+
};
|
|
14
|
+
var AuthError = class extends AgentChatError {
|
|
15
|
+
};
|
|
16
|
+
var ForbiddenError = class extends AgentChatError {
|
|
17
|
+
};
|
|
18
|
+
var ConflictError = class extends AgentChatError {
|
|
19
|
+
};
|
|
20
|
+
var TicketExpiredError = class extends AgentChatError {
|
|
21
|
+
};
|
|
22
|
+
var RateLimitError = class extends AgentChatError {
|
|
23
|
+
};
|
|
24
|
+
var ServerError = class extends AgentChatError {
|
|
25
|
+
};
|
|
26
|
+
function errorFromStatus(status, body) {
|
|
27
|
+
const msg = `Agent API error ${status}: ${body}`;
|
|
28
|
+
if (status === 401) return new AuthError(msg, status, body);
|
|
29
|
+
if (status === 403) return new ForbiddenError(msg, status, body);
|
|
30
|
+
if (status === 409) return new ConflictError(msg, status, body);
|
|
31
|
+
if (status === 410) return new TicketExpiredError(msg, status, body);
|
|
32
|
+
if (status === 429) return new RateLimitError(msg, status, body);
|
|
33
|
+
if (status >= 500) return new ServerError(msg, status, body);
|
|
34
|
+
return new AgentChatError(msg, status, body);
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
// src/http.ts
|
|
38
|
+
function createHttp(config) {
|
|
39
|
+
const baseUrl = config.baseUrl.replace(/\/+$/, "");
|
|
40
|
+
const tokenVersion = config.tokenVersion ?? "v2";
|
|
41
|
+
const rawFetch = config.fetch ?? globalThis.fetch;
|
|
42
|
+
if (!rawFetch) {
|
|
43
|
+
throw new Error("No fetch available \u2014 pass `fetch` in the client config");
|
|
44
|
+
}
|
|
45
|
+
const doFetch = rawFetch.bind(globalThis);
|
|
46
|
+
const buildUrl = (path) => `${baseUrl}${path.startsWith("/") ? path : `/${path}`}`;
|
|
47
|
+
const authHeaders = async () => {
|
|
48
|
+
const token = await config.getToken();
|
|
49
|
+
return {
|
|
50
|
+
Authorization: `Bearer ${token}`,
|
|
51
|
+
"X-Auth-Token-Version": tokenVersion
|
|
52
|
+
};
|
|
53
|
+
};
|
|
54
|
+
const json = async (method, path, body) => {
|
|
55
|
+
const headers = await authHeaders();
|
|
56
|
+
if (body !== void 0) headers["Content-Type"] = "application/json";
|
|
57
|
+
const res = await doFetch(buildUrl(path), {
|
|
58
|
+
method,
|
|
59
|
+
headers,
|
|
60
|
+
body: body !== void 0 ? JSON.stringify(body) : void 0
|
|
61
|
+
});
|
|
62
|
+
if (!res.ok) {
|
|
63
|
+
throw errorFromStatus(res.status, await res.text().catch(() => ""));
|
|
64
|
+
}
|
|
65
|
+
if (res.status === 204) return void 0;
|
|
66
|
+
const text = await res.text();
|
|
67
|
+
return text ? JSON.parse(text) : void 0;
|
|
68
|
+
};
|
|
69
|
+
return { buildUrl, authHeaders, fetch: doFetch, json };
|
|
70
|
+
}
|
|
71
|
+
var TradeLinkSchema = z.object({
|
|
72
|
+
link: z.string(),
|
|
73
|
+
platform: z.string(),
|
|
74
|
+
label: z.string()
|
|
75
|
+
});
|
|
76
|
+
var TwitterSourceSchema = z.object({
|
|
77
|
+
author: z.string(),
|
|
78
|
+
tweetUrl: z.string(),
|
|
79
|
+
publishedAt: z.string()
|
|
80
|
+
});
|
|
81
|
+
var CitationObjectSchema = z.object({
|
|
82
|
+
url: z.string(),
|
|
83
|
+
start_index: z.number().optional(),
|
|
84
|
+
end_index: z.number().optional(),
|
|
85
|
+
title: z.string().optional()
|
|
86
|
+
});
|
|
87
|
+
var CitationSourceSchema = z.union([
|
|
88
|
+
z.string().transform((url) => ({ url })),
|
|
89
|
+
CitationObjectSchema
|
|
90
|
+
]);
|
|
91
|
+
var SuggestedActionSchema = z.object({
|
|
92
|
+
question: z.string(),
|
|
93
|
+
options: z.array(z.string())
|
|
94
|
+
});
|
|
95
|
+
var ChatModeSchema = z.enum(["standard", "advanced"]);
|
|
96
|
+
var TicketActionSchema = z.enum([
|
|
97
|
+
"open_position",
|
|
98
|
+
"close_position",
|
|
99
|
+
"close_all_positions",
|
|
100
|
+
"adjust_position",
|
|
101
|
+
"adjust_advance_position",
|
|
102
|
+
"reverse_position",
|
|
103
|
+
"rebalance_position",
|
|
104
|
+
"set_risk_parameters"
|
|
105
|
+
]);
|
|
106
|
+
var TicketStatusSchema = z.enum([
|
|
107
|
+
"PENDING",
|
|
108
|
+
"EXECUTING",
|
|
109
|
+
"EXECUTED",
|
|
110
|
+
"CANCELLED",
|
|
111
|
+
"FAILED"
|
|
112
|
+
]);
|
|
113
|
+
var PendingActionSchema = z.object({
|
|
114
|
+
ticketId: z.string(),
|
|
115
|
+
action: z.string(),
|
|
116
|
+
consequence: z.string(),
|
|
117
|
+
options: z.array(z.string())
|
|
118
|
+
});
|
|
119
|
+
var ConfirmResultSchema = z.looseObject({
|
|
120
|
+
ok: z.boolean(),
|
|
121
|
+
status: z.enum(["EXECUTED", "FAILED"]),
|
|
122
|
+
// `.optional()` is load-bearing: in zod v4 `z.unknown()` is NO LONGER
|
|
123
|
+
// implicitly optional, so dropping it would make these fields required.
|
|
124
|
+
result: z.unknown().optional(),
|
|
125
|
+
positionsSnapshot: z.unknown().optional(),
|
|
126
|
+
images: z.array(z.string()).optional()
|
|
127
|
+
});
|
|
128
|
+
var CancelResultSchema = z.object({
|
|
129
|
+
ok: z.literal(true),
|
|
130
|
+
status: z.literal("CANCELLED")
|
|
131
|
+
});
|
|
132
|
+
var SetConfirmationsResultSchema = z.object({
|
|
133
|
+
ok: z.boolean(),
|
|
134
|
+
enabled: z.boolean()
|
|
135
|
+
});
|
|
136
|
+
var TradeSettingsSchema = z.object({
|
|
137
|
+
executionEnabled: z.boolean(),
|
|
138
|
+
confirmationsEnabled: z.boolean()
|
|
139
|
+
});
|
|
140
|
+
var SetExecutionResultSchema = z.object({
|
|
141
|
+
ok: z.boolean(),
|
|
142
|
+
enabled: z.boolean()
|
|
143
|
+
});
|
|
144
|
+
|
|
145
|
+
// src/protocol/events.ts
|
|
146
|
+
var TokenEventSchema = z.object({
|
|
147
|
+
type: z.literal("token"),
|
|
148
|
+
text: z.string()
|
|
149
|
+
});
|
|
150
|
+
var ThinkingEventSchema = z.object({
|
|
151
|
+
type: z.literal("thinking"),
|
|
152
|
+
text: z.string()
|
|
153
|
+
});
|
|
154
|
+
var StatusEventSchema = z.object({
|
|
155
|
+
type: z.literal("status"),
|
|
156
|
+
text: z.string(),
|
|
157
|
+
phase: z.enum(["start", "end"]).optional(),
|
|
158
|
+
node: z.string().optional()
|
|
159
|
+
});
|
|
160
|
+
var SourcesEventSchema = z.object({
|
|
161
|
+
type: z.literal("sources"),
|
|
162
|
+
// `.catch` on every NON-critical field so a malformed metadata array can
|
|
163
|
+
// never sink the whole event — `pendingAction` (a staged money-moving trade)
|
|
164
|
+
// rides on this same frame and MUST always survive.
|
|
165
|
+
researchAnnotations: z.array(CitationSourceSchema).catch([]).optional(),
|
|
166
|
+
twitterSources: z.array(TwitterSourceSchema).catch([]).optional(),
|
|
167
|
+
tradeLinks: z.array(TradeLinkSchema).catch([]).optional(),
|
|
168
|
+
images: z.array(z.string()).catch([]).optional(),
|
|
169
|
+
// resolved URL strings
|
|
170
|
+
suggestedAction: SuggestedActionSchema.nullish().catch(null),
|
|
171
|
+
// pendingAction is deliberately NOT `.catch`-ed: a corrupt ticket must reject,
|
|
172
|
+
// never be fabricated.
|
|
173
|
+
pendingAction: PendingActionSchema.nullish()
|
|
174
|
+
});
|
|
175
|
+
var ErrorEventSchema = z.object({
|
|
176
|
+
type: z.literal("error"),
|
|
177
|
+
message: z.string().optional()
|
|
178
|
+
});
|
|
179
|
+
var AgentWireEventSchema = z.discriminatedUnion("type", [
|
|
180
|
+
TokenEventSchema,
|
|
181
|
+
ThinkingEventSchema,
|
|
182
|
+
StatusEventSchema,
|
|
183
|
+
SourcesEventSchema,
|
|
184
|
+
ErrorEventSchema
|
|
185
|
+
]);
|
|
186
|
+
var ChatResultSchema = z.object({
|
|
187
|
+
finalText: z.string(),
|
|
188
|
+
sessionId: z.string().optional(),
|
|
189
|
+
// Same money-path guard as SourcesEventSchema: metadata degrades to [] / null
|
|
190
|
+
// on drift so a hard `.parse` can never throw away a real `pendingAction`.
|
|
191
|
+
researchAnnotations: z.array(CitationSourceSchema).catch([]).optional(),
|
|
192
|
+
twitterSources: z.array(TwitterSourceSchema).catch([]).optional(),
|
|
193
|
+
tradeLinks: z.array(TradeLinkSchema).catch([]).optional(),
|
|
194
|
+
images: z.array(z.string()).default([]),
|
|
195
|
+
suggestedAction: SuggestedActionSchema.nullable().default(null).catch(null),
|
|
196
|
+
pendingAction: PendingActionSchema.nullable().default(null)
|
|
197
|
+
});
|
|
198
|
+
var SessionListItemSchema = z.object({
|
|
199
|
+
id: z.string(),
|
|
200
|
+
appType: z.string(),
|
|
201
|
+
createdAt: z.string()
|
|
202
|
+
// ISO (Date serialized over the wire)
|
|
203
|
+
});
|
|
204
|
+
var SessionSummarySchema = z.object({
|
|
205
|
+
id: z.string(),
|
|
206
|
+
appType: z.string(),
|
|
207
|
+
createdAt: z.string(),
|
|
208
|
+
firstUserMessage: z.string().optional(),
|
|
209
|
+
lastUserMessage: z.string().optional(),
|
|
210
|
+
lastUserMessageAt: z.string().optional(),
|
|
211
|
+
lastAssistantMessageAt: z.string().optional()
|
|
212
|
+
});
|
|
213
|
+
var SessionSchema = z.object({
|
|
214
|
+
id: z.string(),
|
|
215
|
+
userId: z.string(),
|
|
216
|
+
appType: z.string(),
|
|
217
|
+
createdAt: z.string()
|
|
218
|
+
});
|
|
219
|
+
var AgentChatMessageSchema = z.looseObject({
|
|
220
|
+
id: z.string(),
|
|
221
|
+
role: z.string(),
|
|
222
|
+
content: z.string(),
|
|
223
|
+
createdAt: z.string(),
|
|
224
|
+
researchAnnotations: z.array(CitationSourceSchema).nullish(),
|
|
225
|
+
twitterSources: z.array(TwitterSourceSchema).nullish(),
|
|
226
|
+
tradeLinks: z.array(TradeLinkSchema).nullish(),
|
|
227
|
+
images: z.array(z.string()).nullish(),
|
|
228
|
+
suggestedAction: SuggestedActionSchema.nullish()
|
|
229
|
+
});
|
|
230
|
+
|
|
231
|
+
// src/stream.ts
|
|
232
|
+
async function* parseSseStream(body) {
|
|
233
|
+
const reader = body.getReader();
|
|
234
|
+
const decoder = new TextDecoder();
|
|
235
|
+
let buffer = "";
|
|
236
|
+
try {
|
|
237
|
+
while (true) {
|
|
238
|
+
const { done, value } = await reader.read();
|
|
239
|
+
if (done) break;
|
|
240
|
+
buffer += decoder.decode(value, { stream: true });
|
|
241
|
+
while (true) {
|
|
242
|
+
const idx = buffer.indexOf("\n\n");
|
|
243
|
+
if (idx < 0) break;
|
|
244
|
+
const rawEvent = buffer.slice(0, idx);
|
|
245
|
+
buffer = buffer.slice(idx + 2);
|
|
246
|
+
const lines = rawEvent.split("\n");
|
|
247
|
+
const eventLine = lines.find((l) => l.startsWith("event:"));
|
|
248
|
+
const dataLine = lines.find((l) => l.startsWith("data:"));
|
|
249
|
+
if (!dataLine) continue;
|
|
250
|
+
const payloadText = dataLine.replace(/^data:\s?/, "");
|
|
251
|
+
if (eventLine?.replace(/^event:\s?/, "") === "error") {
|
|
252
|
+
yield { type: "error", message: payloadText };
|
|
253
|
+
continue;
|
|
254
|
+
}
|
|
255
|
+
let json;
|
|
256
|
+
try {
|
|
257
|
+
json = JSON.parse(payloadText);
|
|
258
|
+
} catch {
|
|
259
|
+
continue;
|
|
260
|
+
}
|
|
261
|
+
const parsed = AgentWireEventSchema.safeParse(json);
|
|
262
|
+
if (!parsed.success) {
|
|
263
|
+
if (json?.type === "sources" && json?.pendingAction) {
|
|
264
|
+
yield {
|
|
265
|
+
type: "error",
|
|
266
|
+
message: "malformed sources frame with pendingAction"
|
|
267
|
+
};
|
|
268
|
+
}
|
|
269
|
+
continue;
|
|
270
|
+
}
|
|
271
|
+
const ev = parsed.data;
|
|
272
|
+
if (ev.type === "token") {
|
|
273
|
+
yield { ...ev, delta: ev.text };
|
|
274
|
+
} else if (ev.type === "thinking") {
|
|
275
|
+
yield { ...ev, delta: ev.text };
|
|
276
|
+
} else {
|
|
277
|
+
yield ev;
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
}
|
|
281
|
+
} finally {
|
|
282
|
+
reader.cancel().catch(() => void 0);
|
|
283
|
+
}
|
|
284
|
+
}
|
|
285
|
+
|
|
286
|
+
// src/client.ts
|
|
287
|
+
function parseChatResult(raw) {
|
|
288
|
+
const parsed = ChatResultSchema.safeParse(raw);
|
|
289
|
+
if (parsed.success) return parsed.data;
|
|
290
|
+
const r = raw;
|
|
291
|
+
const pa = PendingActionSchema.safeParse(r?.pendingAction);
|
|
292
|
+
return {
|
|
293
|
+
finalText: typeof r?.finalText === "string" ? r.finalText : "",
|
|
294
|
+
images: [],
|
|
295
|
+
suggestedAction: null,
|
|
296
|
+
pendingAction: pa.success ? pa.data : null
|
|
297
|
+
};
|
|
298
|
+
}
|
|
299
|
+
function assembleResult(sessionId, finalText, sources) {
|
|
300
|
+
return parseChatResult({
|
|
301
|
+
finalText,
|
|
302
|
+
sessionId,
|
|
303
|
+
researchAnnotations: sources?.researchAnnotations,
|
|
304
|
+
twitterSources: sources?.twitterSources,
|
|
305
|
+
tradeLinks: sources?.tradeLinks,
|
|
306
|
+
images: sources?.images ?? [],
|
|
307
|
+
suggestedAction: sources?.suggestedAction ?? null,
|
|
308
|
+
pendingAction: sources?.pendingAction ?? null
|
|
309
|
+
});
|
|
310
|
+
}
|
|
311
|
+
var AgentChatClient = class {
|
|
312
|
+
http;
|
|
313
|
+
constructor(config) {
|
|
314
|
+
this.http = createHttp(config);
|
|
315
|
+
}
|
|
316
|
+
listSessions() {
|
|
317
|
+
return this.http.json("GET", "/chat/sessions");
|
|
318
|
+
}
|
|
319
|
+
listSessionSummaries() {
|
|
320
|
+
return this.http.json("GET", "/chat/sessions/summary");
|
|
321
|
+
}
|
|
322
|
+
createSession() {
|
|
323
|
+
return this.http.json("POST", "/chat/sessions");
|
|
324
|
+
}
|
|
325
|
+
getSession(sessionId) {
|
|
326
|
+
return this.http.json(
|
|
327
|
+
"GET",
|
|
328
|
+
`/chat/sessions/${encodeURIComponent(sessionId)}`
|
|
329
|
+
);
|
|
330
|
+
}
|
|
331
|
+
async deleteSession(sessionId) {
|
|
332
|
+
await this.http.json(
|
|
333
|
+
"DELETE",
|
|
334
|
+
`/chat/sessions/${encodeURIComponent(sessionId)}`
|
|
335
|
+
);
|
|
336
|
+
}
|
|
337
|
+
getMessages(sessionId, opts) {
|
|
338
|
+
const params = new URLSearchParams();
|
|
339
|
+
if (opts?.limit !== void 0) params.set("limit", String(opts.limit));
|
|
340
|
+
if (opts?.before) params.set("before", opts.before);
|
|
341
|
+
const qs = params.toString();
|
|
342
|
+
return this.http.json(
|
|
343
|
+
"GET",
|
|
344
|
+
`/chat/sessions/${encodeURIComponent(sessionId)}/messages${qs ? `?${qs}` : ""}`
|
|
345
|
+
);
|
|
346
|
+
}
|
|
347
|
+
/** Stream a turn. Yields token/thinking/status/sources events, then a
|
|
348
|
+
* synthetic `{type:'done', result}` assembled from accumulated token deltas +
|
|
349
|
+
* the final `sources` payload (the SSE wire has no `done` frame). Throws an
|
|
350
|
+
* `AgentChatError` if the backend emits a mid-stream `error` frame. */
|
|
351
|
+
async *streamChat(args) {
|
|
352
|
+
const params = new URLSearchParams({
|
|
353
|
+
message: args.message,
|
|
354
|
+
sessionId: args.sessionId,
|
|
355
|
+
mode: args.mode ?? "standard"
|
|
356
|
+
});
|
|
357
|
+
if (args.cta) {
|
|
358
|
+
params.set("suggestedActionPreviousText", args.cta.previousText);
|
|
359
|
+
params.set("suggestedActionQuestion", args.cta.question);
|
|
360
|
+
params.set("suggestedActionSelectedOption", args.cta.selectedOption);
|
|
361
|
+
}
|
|
362
|
+
const headers = await this.http.authHeaders();
|
|
363
|
+
headers.Accept = "text/event-stream";
|
|
364
|
+
const res = await this.http.fetch(
|
|
365
|
+
this.http.buildUrl(`/chat/stream?${params.toString()}`),
|
|
366
|
+
{ method: "GET", headers, signal: args.signal }
|
|
367
|
+
);
|
|
368
|
+
if (!res.ok || !res.body) {
|
|
369
|
+
throw errorFromStatus(res.status, await res.text().catch(() => ""));
|
|
370
|
+
}
|
|
371
|
+
let finalText = "";
|
|
372
|
+
let sources;
|
|
373
|
+
for await (const ev of parseSseStream(res.body)) {
|
|
374
|
+
if (ev.type === "error") {
|
|
375
|
+
throw new AgentChatError(ev.message ?? "Agent stream error");
|
|
376
|
+
}
|
|
377
|
+
if (ev.type === "token") finalText += ev.delta;
|
|
378
|
+
if (ev.type === "sources") sources = ev;
|
|
379
|
+
yield ev;
|
|
380
|
+
}
|
|
381
|
+
yield {
|
|
382
|
+
type: "done",
|
|
383
|
+
result: assembleResult(args.sessionId, finalText, sources)
|
|
384
|
+
};
|
|
385
|
+
}
|
|
386
|
+
/** Sync send (POST /chat). Prefer `streamChat` for UX. */
|
|
387
|
+
sendMessage(args) {
|
|
388
|
+
return this.http.json("POST", "/chat", {
|
|
389
|
+
message: args.message,
|
|
390
|
+
sessionId: args.sessionId,
|
|
391
|
+
mode: args.mode ?? "standard"
|
|
392
|
+
}).then(parseChatResult);
|
|
393
|
+
}
|
|
394
|
+
confirmTicket(ticketId) {
|
|
395
|
+
return this.http.json(
|
|
396
|
+
"POST",
|
|
397
|
+
`/trade/tickets/${encodeURIComponent(ticketId)}/confirm`
|
|
398
|
+
).then((raw) => ConfirmResultSchema.parse(raw));
|
|
399
|
+
}
|
|
400
|
+
cancelTicket(ticketId) {
|
|
401
|
+
return this.http.json(
|
|
402
|
+
"POST",
|
|
403
|
+
`/trade/tickets/${encodeURIComponent(ticketId)}/cancel`
|
|
404
|
+
).then((raw) => CancelResultSchema.parse(raw));
|
|
405
|
+
}
|
|
406
|
+
setTradeConfirmations(enabled) {
|
|
407
|
+
return this.http.json("POST", "/trade/tickets/settings", { enabled }).then((raw) => SetConfirmationsResultSchema.parse(raw));
|
|
408
|
+
}
|
|
409
|
+
/** Read both trade toggles for the caller wallet: the master execution switch
|
|
410
|
+
* and the confirm-before-write preference. */
|
|
411
|
+
getTradeSettings() {
|
|
412
|
+
return this.http.json("GET", "/trade/tickets/settings").then((raw) => TradeSettingsSchema.parse(raw));
|
|
413
|
+
}
|
|
414
|
+
/** Flip the caller's master execution switch. `false` opts the wallet out of
|
|
415
|
+
* all money-moving writes; `true` restores the default-ON state. */
|
|
416
|
+
setTradeExecution(enabled) {
|
|
417
|
+
return this.http.json("POST", "/trade/tickets/execution", { enabled }).then((raw) => SetExecutionResultSchema.parse(raw));
|
|
418
|
+
}
|
|
419
|
+
};
|
|
420
|
+
|
|
421
|
+
export { AgentChatClient, AgentChatError, AgentChatMessageSchema, AgentWireEventSchema, AuthError, CancelResultSchema, ChatModeSchema, ChatResultSchema, CitationSourceSchema, ConfirmResultSchema, ConflictError, ErrorEventSchema, ForbiddenError, PendingActionSchema, RateLimitError, ServerError, SessionListItemSchema, SessionSchema, SessionSummarySchema, SetConfirmationsResultSchema, SetExecutionResultSchema, SourcesEventSchema, StatusEventSchema, SuggestedActionSchema, ThinkingEventSchema, TicketActionSchema, TicketExpiredError, TicketStatusSchema, TokenEventSchema, TradeLinkSchema, TradeSettingsSchema, TwitterSourceSchema };
|
|
422
|
+
//# sourceMappingURL=index.js.map
|
|
423
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/errors.ts","../src/http.ts","../src/protocol/primitives.ts","../src/protocol/tickets.ts","../src/protocol/events.ts","../src/protocol/messages.ts","../src/stream.ts","../src/client.ts"],"names":["z"],"mappings":"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","file":"index.js","sourcesContent":["export class AgentChatError extends Error {\n\treadonly status?: number;\n\treadonly body?: string;\n\tconstructor(message: string, status?: number, body?: string) {\n\t\tsuper(message);\n\t\tthis.name = new.target.name;\n\t\tthis.status = status;\n\t\tthis.body = body;\n\t}\n}\n\nexport class AuthError extends AgentChatError {}\nexport class ForbiddenError extends AgentChatError {}\nexport class ConflictError extends AgentChatError {}\nexport class TicketExpiredError extends AgentChatError {}\nexport class RateLimitError extends AgentChatError {}\nexport class ServerError extends AgentChatError {}\n\nexport function errorFromStatus(status: number, body: string): AgentChatError {\n\tconst msg = `Agent API error ${status}: ${body}`;\n\tif (status === 401) return new AuthError(msg, status, body);\n\tif (status === 403) return new ForbiddenError(msg, status, body);\n\tif (status === 409) return new ConflictError(msg, status, body);\n\tif (status === 410) return new TicketExpiredError(msg, status, body);\n\tif (status === 429) return new RateLimitError(msg, status, body);\n\tif (status >= 500) return new ServerError(msg, status, body);\n\treturn new AgentChatError(msg, status, body);\n}\n","import { errorFromStatus } from \"./errors\";\n\nexport interface AgentChatClientConfig {\n\t/** Base URL of the agent API, e.g. https://hl-v2-agent.pearprotocol.io */\n\tbaseUrl: string;\n\t/** Returns the freshest auth token (handles rotation). Required. */\n\tgetToken: () => string | Promise<string>;\n\t/** Sent as `X-Auth-Token-Version`. Defaults to \"v2\". */\n\ttokenVersion?: \"v2\" | \"v3\";\n\t/** Optional fetch override (SSR / tests). Defaults to global fetch. */\n\tfetch?: typeof fetch;\n}\n\nexport interface Http {\n\tbuildUrl: (path: string) => string;\n\tauthHeaders: () => Promise<Record<string, string>>;\n\t/** The resolved fetch — the single authoritative one (JSON + SSE share it). */\n\tfetch: typeof fetch;\n\tjson: <T>(method: string, path: string, body?: unknown) => Promise<T>;\n}\n\nexport function createHttp(config: AgentChatClientConfig): Http {\n\tconst baseUrl = config.baseUrl.replace(/\\/+$/, \"\");\n\tconst tokenVersion = config.tokenVersion ?? \"v2\";\n\tconst rawFetch = config.fetch ?? globalThis.fetch;\n\tif (!rawFetch) {\n\t\tthrow new Error(\"No fetch available — pass `fetch` in the client config\");\n\t}\n\t// Bind to globalThis. `fetch` is exposed on the Http object and the SSE path\n\t// invokes it as `http.fetch(...)` — called as a method, the browser's native\n\t// fetch runs with `this === the http object` and throws \"Illegal invocation\".\n\t// The JSON path calls it as a bare `doFetch(...)` (this === undefined), which\n\t// is why createSession worked but streamChat didn't. Binding pins `this`.\n\tconst doFetch: typeof fetch = rawFetch.bind(globalThis);\n\n\tconst buildUrl = (path: string): string =>\n\t\t`${baseUrl}${path.startsWith(\"/\") ? path : `/${path}`}`;\n\n\tconst authHeaders = async (): Promise<Record<string, string>> => {\n\t\tconst token = await config.getToken();\n\t\treturn {\n\t\t\tAuthorization: `Bearer ${token}`,\n\t\t\t\"X-Auth-Token-Version\": tokenVersion,\n\t\t};\n\t};\n\n\tconst json = async <T>(\n\t\tmethod: string,\n\t\tpath: string,\n\t\tbody?: unknown,\n\t): Promise<T> => {\n\t\tconst headers = await authHeaders();\n\t\tif (body !== undefined) headers[\"Content-Type\"] = \"application/json\";\n\t\tconst res = await doFetch(buildUrl(path), {\n\t\t\tmethod,\n\t\t\theaders,\n\t\t\tbody: body !== undefined ? JSON.stringify(body) : undefined,\n\t\t});\n\t\tif (!res.ok) {\n\t\t\tthrow errorFromStatus(res.status, await res.text().catch(() => \"\"));\n\t\t}\n\t\tif (res.status === 204) return undefined as T;\n\t\tconst text = await res.text();\n\t\treturn (text ? JSON.parse(text) : undefined) as T;\n\t};\n\n\treturn { buildUrl, authHeaders, fetch: doFetch, json };\n}\n","import { z } from \"zod\";\n\n/** A Pear trade link surfaced with an agent reply. `platform` is left an open\n * string (not an enum) so a new venue doesn't break older SDK consumers. */\nexport const TradeLinkSchema = z.object({\n\tlink: z.string(),\n\tplatform: z.string(),\n\tlabel: z.string(),\n});\nexport type TradeLink = z.infer<typeof TradeLinkSchema>;\n\nexport const TwitterSourceSchema = z.object({\n\tauthor: z.string(),\n\ttweetUrl: z.string(),\n\tpublishedAt: z.string(),\n});\nexport type TwitterSource = z.infer<typeof TwitterSourceSchema>;\n\n/** Research web-citation. The research node emits a bare URL **string** on the\n * wire (research/agent.ts maps annotations -> `url_citation.url`); a future\n * object form is also accepted and normalized to `{ url, ... }`. */\nconst CitationObjectSchema = z.object({\n\turl: z.string(),\n\tstart_index: z.number().optional(),\n\tend_index: z.number().optional(),\n\ttitle: z.string().optional(),\n});\nexport const CitationSourceSchema = z.union([\n\tz.string().transform((url) => ({ url })),\n\tCitationObjectSchema,\n]);\nexport type CitationSource = z.infer<typeof CitationSourceSchema>;\n\nexport const SuggestedActionSchema = z.object({\n\tquestion: z.string(),\n\toptions: z.array(z.string()),\n});\nexport type SuggestedAction = z.infer<typeof SuggestedActionSchema>;\n\nexport const ChatModeSchema = z.enum([\"standard\", \"advanced\"]);\nexport type ChatMode = z.infer<typeof ChatModeSchema>;\n","import { z } from \"zod\";\n\n/** Known ticket actions. Used for typing; the wire `action` field is parsed\n * permissively (plain string) elsewhere for forward-compat. */\nexport const TicketActionSchema = z.enum([\n\t\"open_position\",\n\t\"close_position\",\n\t\"close_all_positions\",\n\t\"adjust_position\",\n\t\"adjust_advance_position\",\n\t\"reverse_position\",\n\t\"rebalance_position\",\n\t\"set_risk_parameters\",\n]);\nexport type TicketAction = z.infer<typeof TicketActionSchema>;\n\nexport const TicketStatusSchema = z.enum([\n\t\"PENDING\",\n\t\"EXECUTING\",\n\t\"EXECUTED\",\n\t\"CANCELLED\",\n\t\"FAILED\",\n]);\nexport type TicketStatus = z.infer<typeof TicketStatusSchema>;\n\n/** Surfaced on a turn when a money-moving write was FROZEN (nothing executed).\n * `action` is a plain string (forward-compatible); compare against\n * `TicketActionSchema.options` if you need to switch on known actions. */\nexport const PendingActionSchema = z.object({\n\tticketId: z.string(),\n\taction: z.string(),\n\tconsequence: z.string(),\n\toptions: z.array(z.string()),\n});\nexport type PendingAction = z.infer<typeof PendingActionSchema>;\n\n/** Response of POST /trade/tickets/:id/confirm. Strict on the money fields,\n * loose (passthrough) on the action-specific `result` payload. `status` is\n * intentionally narrowed to the two TERMINAL confirm outcomes this endpoint\n * returns; widen to `TicketStatusSchema` if the BE can ever return another. */\nexport const ConfirmResultSchema = z.looseObject({\n\tok: z.boolean(),\n\tstatus: z.enum([\"EXECUTED\", \"FAILED\"]),\n\t// `.optional()` is load-bearing: in zod v4 `z.unknown()` is NO LONGER\n\t// implicitly optional, so dropping it would make these fields required.\n\tresult: z.unknown().optional(),\n\tpositionsSnapshot: z.unknown().optional(),\n\timages: z.array(z.string()).optional(),\n});\nexport type ConfirmResult = z.infer<typeof ConfirmResultSchema>;\n\nexport const CancelResultSchema = z.object({\n\tok: z.literal(true),\n\tstatus: z.literal(\"CANCELLED\"),\n});\nexport type CancelResult = z.infer<typeof CancelResultSchema>;\n\nexport const SetConfirmationsResultSchema = z.object({\n\tok: z.boolean(),\n\tenabled: z.boolean(),\n});\nexport type SetConfirmationsResult = z.infer<\n\ttypeof SetConfirmationsResultSchema\n>;\n\n/** Response of GET /trade/tickets/settings — the caller's two independent trade\n * toggles. `executionEnabled` is the master execution switch (any write at all);\n * `confirmationsEnabled` is the confirm-before-write preference. */\nexport const TradeSettingsSchema = z.object({\n\texecutionEnabled: z.boolean(),\n\tconfirmationsEnabled: z.boolean(),\n});\nexport type TradeSettings = z.infer<typeof TradeSettingsSchema>;\n\n/** Response of POST /trade/tickets/execution — the new master-switch state. */\nexport const SetExecutionResultSchema = z.object({\n\tok: z.boolean(),\n\tenabled: z.boolean(),\n});\nexport type SetExecutionResult = z.infer<typeof SetExecutionResultSchema>;\n","import { z } from \"zod\";\nimport {\n\tCitationSourceSchema,\n\tSuggestedActionSchema,\n\tTradeLinkSchema,\n\tTwitterSourceSchema,\n} from \"./primitives\";\nimport { PendingActionSchema } from \"./tickets\";\n\nexport const TokenEventSchema = z.object({\n\ttype: z.literal(\"token\"),\n\ttext: z.string(),\n});\n// `thinking` is emitted by ADVANCED mode only (the standard pipeline doesn't).\nexport const ThinkingEventSchema = z.object({\n\ttype: z.literal(\"thinking\"),\n\ttext: z.string(),\n});\nexport const StatusEventSchema = z.object({\n\ttype: z.literal(\"status\"),\n\ttext: z.string(),\n\tphase: z.enum([\"start\", \"end\"]).optional(),\n\tnode: z.string().optional(),\n});\nexport const SourcesEventSchema = z.object({\n\ttype: z.literal(\"sources\"),\n\t// `.catch` on every NON-critical field so a malformed metadata array can\n\t// never sink the whole event — `pendingAction` (a staged money-moving trade)\n\t// rides on this same frame and MUST always survive.\n\tresearchAnnotations: z.array(CitationSourceSchema).catch([]).optional(),\n\ttwitterSources: z.array(TwitterSourceSchema).catch([]).optional(),\n\ttradeLinks: z.array(TradeLinkSchema).catch([]).optional(),\n\timages: z.array(z.string()).catch([]).optional(), // resolved URL strings\n\tsuggestedAction: SuggestedActionSchema.nullish().catch(null),\n\t// pendingAction is deliberately NOT `.catch`-ed: a corrupt ticket must reject,\n\t// never be fabricated.\n\tpendingAction: PendingActionSchema.nullish(),\n});\nexport const ErrorEventSchema = z.object({\n\ttype: z.literal(\"error\"),\n\tmessage: z.string().optional(),\n});\n\n/** The discriminated union of events the SSE wire delivers. Parse each event\n * with `.safeParse`; on failure (unknown/legacy `cycle` etc.) IGNORE it — do\n * not throw. */\nexport const AgentWireEventSchema = z.discriminatedUnion(\"type\", [\n\tTokenEventSchema,\n\tThinkingEventSchema,\n\tStatusEventSchema,\n\tSourcesEventSchema,\n\tErrorEventSchema,\n]);\nexport type AgentWireEvent = z.infer<typeof AgentWireEventSchema>;\n\n/** Final assembled turn — the shape of `POST /chat` AND the SDK's synthetic\n * `done` event (the SSE wire has no `done` frame; the SDK assembles it). */\nexport const ChatResultSchema = z.object({\n\tfinalText: z.string(),\n\tsessionId: z.string().optional(),\n\t// Same money-path guard as SourcesEventSchema: metadata degrades to [] / null\n\t// on drift so a hard `.parse` can never throw away a real `pendingAction`.\n\tresearchAnnotations: z.array(CitationSourceSchema).catch([]).optional(),\n\ttwitterSources: z.array(TwitterSourceSchema).catch([]).optional(),\n\ttradeLinks: z.array(TradeLinkSchema).catch([]).optional(),\n\timages: z.array(z.string()).default([]),\n\tsuggestedAction: SuggestedActionSchema.nullable().default(null).catch(null),\n\tpendingAction: PendingActionSchema.nullable().default(null),\n});\nexport type ChatResult = z.infer<typeof ChatResultSchema>;\n\n/** The RAW wire union plus a synthetic terminal `done`. NOTE: the SDK actually\n * emits a NORMALIZED `StreamEvent` (token/thinking carry a `delta`) defined in\n * the SDK's stream module; this `AgentEvent` is the pre-normalization shape. */\nexport type AgentEvent = AgentWireEvent | { type: \"done\"; result: ChatResult };\n","import { z } from \"zod\";\nimport {\n\tCitationSourceSchema,\n\tSuggestedActionSchema,\n\tTradeLinkSchema,\n\tTwitterSourceSchema,\n} from \"./primitives\";\n\nexport const SessionListItemSchema = z.object({\n\tid: z.string(),\n\tappType: z.string(),\n\tcreatedAt: z.string(), // ISO (Date serialized over the wire)\n});\nexport type SessionListItem = z.infer<typeof SessionListItemSchema>;\n\nexport const SessionSummarySchema = z.object({\n\tid: z.string(),\n\tappType: z.string(),\n\tcreatedAt: z.string(),\n\tfirstUserMessage: z.string().optional(),\n\tlastUserMessage: z.string().optional(),\n\tlastUserMessageAt: z.string().optional(),\n\tlastAssistantMessageAt: z.string().optional(),\n});\nexport type SessionSummary = z.infer<typeof SessionSummarySchema>;\n\nexport const SessionSchema = z.object({\n\tid: z.string(),\n\tuserId: z.string(),\n\tappType: z.string(),\n\tcreatedAt: z.string(),\n});\nexport type Session = z.infer<typeof SessionSchema>;\n\n/** A persisted chat message (history). `images` are pre-resolved URL strings.\n * `z.looseObject` keeps unknown future fields instead of stripping them. */\nexport const AgentChatMessageSchema = z.looseObject({\n\tid: z.string(),\n\trole: z.string(),\n\tcontent: z.string(),\n\tcreatedAt: z.string(),\n\tresearchAnnotations: z.array(CitationSourceSchema).nullish(),\n\ttwitterSources: z.array(TwitterSourceSchema).nullish(),\n\ttradeLinks: z.array(TradeLinkSchema).nullish(),\n\timages: z.array(z.string()).nullish(),\n\tsuggestedAction: SuggestedActionSchema.nullish(),\n});\nexport type AgentChatMessage = z.infer<typeof AgentChatMessageSchema>;\n","import { type AgentWireEvent, AgentWireEventSchema } from \"./protocol\";\n\n/** A token/thinking event normalized to expose an incremental `delta`. This\n * backend is DELTA-only on every path, so `delta === text` — there is no\n * cumulative reconciliation (a `startsWith` heuristic corrupts real output). */\nexport type StreamEvent =\n\t| (Extract<AgentWireEvent, { type: \"token\" }> & { delta: string })\n\t| (Extract<AgentWireEvent, { type: \"thinking\" }> & { delta: string })\n\t| Exclude<AgentWireEvent, { type: \"token\" | \"thinking\" }>;\n\nexport async function* parseSseStream(\n\tbody: ReadableStream<Uint8Array>,\n): AsyncGenerator<StreamEvent> {\n\tconst reader = body.getReader();\n\tconst decoder = new TextDecoder();\n\tlet buffer = \"\";\n\n\ttry {\n\t\twhile (true) {\n\t\t\tconst { done, value } = await reader.read();\n\t\t\tif (done) break;\n\t\t\tbuffer += decoder.decode(value, { stream: true });\n\n\t\t\t// Drain every complete `\\n\\n`-delimited frame in the buffer. `const idx`\n\t\t\t// is recomputed each iteration (no assignment-in-`while`-head: that trips\n\t\t\t// biome `noAssignInExpressions`, a non-auto-fixable CI error).\n\t\t\twhile (true) {\n\t\t\t\tconst idx = buffer.indexOf(\"\\n\\n\");\n\t\t\t\tif (idx < 0) break;\n\t\t\t\tconst rawEvent = buffer.slice(0, idx);\n\t\t\t\tbuffer = buffer.slice(idx + 2);\n\n\t\t\t\tconst lines = rawEvent.split(\"\\n\");\n\t\t\t\tconst eventLine = lines.find((l) => l.startsWith(\"event:\"));\n\t\t\t\tconst dataLine = lines.find((l) => l.startsWith(\"data:\"));\n\t\t\t\tif (!dataLine) continue;\n\t\t\t\tconst payloadText = dataLine.replace(/^data:\\s?/, \"\");\n\n\t\t\t\t// NestJS surfaces stream errors as `event: error\\ndata: <plain string>`\n\t\t\t\t// (NON-JSON). Detect it BEFORE JSON.parse so it isn't swallowed.\n\t\t\t\tif (eventLine?.replace(/^event:\\s?/, \"\") === \"error\") {\n\t\t\t\t\tyield { type: \"error\", message: payloadText };\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tlet json: unknown;\n\t\t\t\ttry {\n\t\t\t\t\tjson = JSON.parse(payloadText);\n\t\t\t\t} catch {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tconst parsed = AgentWireEventSchema.safeParse(json);\n\t\t\t\tif (!parsed.success) {\n\t\t\t\t\t// Never SILENTLY drop a money-path frame: if it looks like a sources\n\t\t\t\t\t// event carrying pendingAction, fail loud instead of losing a trade.\n\t\t\t\t\tif (\n\t\t\t\t\t\t(json as { type?: string })?.type === \"sources\" &&\n\t\t\t\t\t\t(json as { pendingAction?: unknown })?.pendingAction\n\t\t\t\t\t) {\n\t\t\t\t\t\tyield {\n\t\t\t\t\t\t\ttype: \"error\",\n\t\t\t\t\t\t\tmessage: \"malformed sources frame with pendingAction\",\n\t\t\t\t\t\t};\n\t\t\t\t\t}\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tconst ev = parsed.data;\n\t\t\t\tif (ev.type === \"token\") {\n\t\t\t\t\tyield { ...ev, delta: ev.text };\n\t\t\t\t} else if (ev.type === \"thinking\") {\n\t\t\t\t\tyield { ...ev, delta: ev.text };\n\t\t\t\t} else {\n\t\t\t\t\tyield ev;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t} finally {\n\t\treader.cancel().catch(() => undefined);\n\t}\n}\n","import { AgentChatError, errorFromStatus } from \"./errors\";\nimport { type AgentChatClientConfig, createHttp, type Http } from \"./http\";\nimport {\n\ttype AgentChatMessage,\n\ttype CancelResult,\n\tCancelResultSchema,\n\ttype ChatMode,\n\ttype ChatResult,\n\tChatResultSchema,\n\ttype ConfirmResult,\n\tConfirmResultSchema,\n\tPendingActionSchema,\n\ttype Session,\n\ttype SessionListItem,\n\ttype SessionSummary,\n\ttype SetConfirmationsResult,\n\tSetConfirmationsResultSchema,\n\ttype SetExecutionResult,\n\tSetExecutionResultSchema,\n\ttype TradeSettings,\n\tTradeSettingsSchema,\n} from \"./protocol\";\nimport { parseSseStream, type StreamEvent } from \"./stream\";\n\n/** Parse a ChatResult but NEVER throw away a real `pendingAction` on metadata\n * drift: on a parse failure, fall back to a minimal result that preserves\n * `finalText` + `pendingAction` rather than rejecting the whole turn. */\nfunction parseChatResult(raw: unknown): ChatResult {\n\tconst parsed = ChatResultSchema.safeParse(raw);\n\tif (parsed.success) return parsed.data;\n\tconst r = raw as { finalText?: unknown; pendingAction?: unknown };\n\t// Salvage finalText, but NEVER fabricate a ticket: keep pendingAction only if\n\t// it INDEPENDENTLY validates — a corrupt ticket is dropped, never handed to\n\t// confirmTicket() (the money endpoint).\n\tconst pa = PendingActionSchema.safeParse(r?.pendingAction);\n\treturn {\n\t\tfinalText: typeof r?.finalText === \"string\" ? r.finalText : \"\",\n\t\timages: [],\n\t\tsuggestedAction: null,\n\t\tpendingAction: pa.success ? pa.data : null,\n\t};\n}\n\nfunction assembleResult(\n\tsessionId: string,\n\tfinalText: string,\n\tsources: Extract<StreamEvent, { type: \"sources\" }> | undefined,\n): ChatResult {\n\treturn parseChatResult({\n\t\tfinalText,\n\t\tsessionId,\n\t\tresearchAnnotations: sources?.researchAnnotations,\n\t\ttwitterSources: sources?.twitterSources,\n\t\ttradeLinks: sources?.tradeLinks,\n\t\timages: sources?.images ?? [],\n\t\tsuggestedAction: sources?.suggestedAction ?? null,\n\t\tpendingAction: sources?.pendingAction ?? null,\n\t});\n}\n\nexport class AgentChatClient {\n\tprivate readonly http: Http;\n\n\tconstructor(config: AgentChatClientConfig) {\n\t\tthis.http = createHttp(config);\n\t}\n\n\tlistSessions(): Promise<SessionListItem[]> {\n\t\treturn this.http.json(\"GET\", \"/chat/sessions\");\n\t}\n\n\tlistSessionSummaries(): Promise<SessionSummary[]> {\n\t\treturn this.http.json(\"GET\", \"/chat/sessions/summary\");\n\t}\n\n\tcreateSession(): Promise<{ id: string }> {\n\t\treturn this.http.json(\"POST\", \"/chat/sessions\");\n\t}\n\n\tgetSession(sessionId: string): Promise<Session> {\n\t\treturn this.http.json(\n\t\t\t\"GET\",\n\t\t\t`/chat/sessions/${encodeURIComponent(sessionId)}`,\n\t\t);\n\t}\n\n\tasync deleteSession(sessionId: string): Promise<void> {\n\t\tawait this.http.json(\n\t\t\t\"DELETE\",\n\t\t\t`/chat/sessions/${encodeURIComponent(sessionId)}`,\n\t\t);\n\t}\n\n\tgetMessages(\n\t\tsessionId: string,\n\t\topts?: { limit?: number; before?: string },\n\t): Promise<AgentChatMessage[]> {\n\t\tconst params = new URLSearchParams();\n\t\tif (opts?.limit !== undefined) params.set(\"limit\", String(opts.limit));\n\t\tif (opts?.before) params.set(\"before\", opts.before);\n\t\tconst qs = params.toString();\n\t\treturn this.http.json(\n\t\t\t\"GET\",\n\t\t\t`/chat/sessions/${encodeURIComponent(sessionId)}/messages${qs ? `?${qs}` : \"\"}`,\n\t\t);\n\t}\n\n\t/** Stream a turn. Yields token/thinking/status/sources events, then a\n\t * synthetic `{type:'done', result}` assembled from accumulated token deltas +\n\t * the final `sources` payload (the SSE wire has no `done` frame). Throws an\n\t * `AgentChatError` if the backend emits a mid-stream `error` frame. */\n\tasync *streamChat(args: {\n\t\tsessionId: string;\n\t\tmessage: string;\n\t\tmode?: ChatMode;\n\t\tsignal?: AbortSignal;\n\t\t/** CTA callback — set when the user clicks a suggested-action option; the\n\t\t * agent rebuilds the turn from this context server-side. */\n\t\tcta?: { previousText: string; question: string; selectedOption: string };\n\t}): AsyncGenerator<StreamEvent | { type: \"done\"; result: ChatResult }> {\n\t\tconst params = new URLSearchParams({\n\t\t\tmessage: args.message,\n\t\t\tsessionId: args.sessionId,\n\t\t\tmode: args.mode ?? \"standard\",\n\t\t});\n\t\tif (args.cta) {\n\t\t\tparams.set(\"suggestedActionPreviousText\", args.cta.previousText);\n\t\t\tparams.set(\"suggestedActionQuestion\", args.cta.question);\n\t\t\tparams.set(\"suggestedActionSelectedOption\", args.cta.selectedOption);\n\t\t}\n\t\tconst headers = await this.http.authHeaders();\n\t\theaders.Accept = \"text/event-stream\";\n\t\tconst res = await this.http.fetch(\n\t\t\tthis.http.buildUrl(`/chat/stream?${params.toString()}`),\n\t\t\t{ method: \"GET\", headers, signal: args.signal },\n\t\t);\n\t\tif (!res.ok || !res.body) {\n\t\t\tthrow errorFromStatus(res.status, await res.text().catch(() => \"\"));\n\t\t}\n\n\t\tlet finalText = \"\";\n\t\tlet sources: Extract<StreamEvent, { type: \"sources\" }> | undefined;\n\t\tfor await (const ev of parseSseStream(res.body)) {\n\t\t\tif (ev.type === \"error\") {\n\t\t\t\tthrow new AgentChatError(ev.message ?? \"Agent stream error\");\n\t\t\t}\n\t\t\tif (ev.type === \"token\") finalText += ev.delta;\n\t\t\tif (ev.type === \"sources\") sources = ev;\n\t\t\tyield ev;\n\t\t}\n\n\t\tyield {\n\t\t\ttype: \"done\",\n\t\t\tresult: assembleResult(args.sessionId, finalText, sources),\n\t\t};\n\t}\n\n\t/** Sync send (POST /chat). Prefer `streamChat` for UX. */\n\tsendMessage(args: {\n\t\tsessionId: string;\n\t\tmessage: string;\n\t\tmode?: ChatMode;\n\t}): Promise<ChatResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"POST\", \"/chat\", {\n\t\t\t\tmessage: args.message,\n\t\t\t\tsessionId: args.sessionId,\n\t\t\t\tmode: args.mode ?? \"standard\",\n\t\t\t})\n\t\t\t.then(parseChatResult);\n\t}\n\n\tconfirmTicket(ticketId: string): Promise<ConfirmResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\n\t\t\t\t\"POST\",\n\t\t\t\t`/trade/tickets/${encodeURIComponent(ticketId)}/confirm`,\n\t\t\t)\n\t\t\t.then((raw) => ConfirmResultSchema.parse(raw));\n\t}\n\n\tcancelTicket(ticketId: string): Promise<CancelResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\n\t\t\t\t\"POST\",\n\t\t\t\t`/trade/tickets/${encodeURIComponent(ticketId)}/cancel`,\n\t\t\t)\n\t\t\t.then((raw) => CancelResultSchema.parse(raw));\n\t}\n\n\tsetTradeConfirmations(enabled: boolean): Promise<SetConfirmationsResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"POST\", \"/trade/tickets/settings\", { enabled })\n\t\t\t.then((raw) => SetConfirmationsResultSchema.parse(raw));\n\t}\n\n\t/** Read both trade toggles for the caller wallet: the master execution switch\n\t * and the confirm-before-write preference. */\n\tgetTradeSettings(): Promise<TradeSettings> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"GET\", \"/trade/tickets/settings\")\n\t\t\t.then((raw) => TradeSettingsSchema.parse(raw));\n\t}\n\n\t/** Flip the caller's master execution switch. `false` opts the wallet out of\n\t * all money-moving writes; `true` restores the default-ON state. */\n\tsetTradeExecution(enabled: boolean): Promise<SetExecutionResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"POST\", \"/trade/tickets/execution\", { enabled })\n\t\t\t.then((raw) => SetExecutionResultSchema.parse(raw));\n\t}\n}\n"]}
|