@letta-ai/letta-code 0.27.8 → 0.27.9

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 (35) hide show
  1. package/README.md +2 -2
  2. package/dist/app-server-client.js +387 -0
  3. package/dist/app-server-client.js.map +10 -0
  4. package/dist/types/app-server-client.d.ts +99 -0
  5. package/dist/types/app-server-client.d.ts.map +1 -0
  6. package/dist/types/types/app-server-protocol.d.ts +3 -0
  7. package/dist/types/types/app-server-protocol.d.ts.map +1 -0
  8. package/dist/types/types/protocol.d.ts.map +1 -0
  9. package/dist/types/types/protocol_v2.d.ts +2277 -0
  10. package/dist/types/types/protocol_v2.d.ts.map +1 -0
  11. package/letta.js +21106 -18642
  12. package/package.json +11 -2
  13. package/scripts/check-test-coverage.cjs +1 -1
  14. package/scripts/run-unit-tests.cjs +1 -1
  15. package/skills/{creating-extensions → creating-mods}/SKILL.md +29 -29
  16. package/skills/{creating-extensions → creating-mods}/references/architecture.md +9 -9
  17. package/skills/{creating-extensions → creating-mods}/references/commands.md +10 -10
  18. package/skills/{creating-extensions → creating-mods}/references/events.md +10 -10
  19. package/skills/{creating-extensions → creating-mods}/references/permissions.md +3 -3
  20. package/skills/{creating-extensions → creating-mods}/references/plan-mode.md +10 -8
  21. package/skills/{creating-extensions → creating-mods}/references/providers.md +7 -7
  22. package/skills/{creating-extensions → creating-mods}/references/tools.md +20 -2
  23. package/skills/{creating-extensions → creating-mods}/references/ui.md +4 -4
  24. package/skills/customizing-commands/SKILL.md +18 -18
  25. package/skills/customizing-statusline/SKILL.md +11 -11
  26. package/skills/customizing-statusline/references/api.md +8 -8
  27. package/skills/customizing-statusline/references/examples.md +1 -1
  28. package/skills/customizing-statusline/references/migration.md +1 -1
  29. package/skills/editing-letta-code-desktop-preferences/SKILL.md +67 -0
  30. package/skills/image-generation/SKILL.md +22 -12
  31. package/skills/modifying-the-harness/SKILL.md +21 -2
  32. package/skills/modifying-the-harness/scripts/add_permission.py +2 -1
  33. package/skills/modifying-the-harness/scripts/show_config.py +4 -3
  34. package/dist/types/protocol.d.ts.map +0 -1
  35. /package/dist/types/{protocol.d.ts → types/protocol.d.ts} +0 -0
package/README.md CHANGED
@@ -21,8 +21,8 @@ Letta Code is a frontier coding agent and can also be used as a long-lived perso
21
21
 
22
22
  | Feature | Description |
23
23
  |---|---|
24
- | [Self-improvement & Learning](https://docs.letta.com/letta-code/self-improvement) | Agents programmatically rewrite their context to improve and adapt over time, including system prompt learning (through [memory blocks](https://www.letta.com/blog/memory-blocks)) and [skill learning](https://www.letta.com/blog/skill-learning). Configure periodic dreaming with `/sleeptime`, audit memory quality with `/doctor`, and view memory with `/palace` |
25
- | [Message search](https://docs.letta.com/letta-code/conversation-search) | Search across all messages and agents with `/search`. Agent can also search their own conversations or the conversations of other agents |
24
+ | [Self-improvement & Learning](https://docs.letta.com/letta-code/memory) | Agents programmatically rewrite their context to improve and adapt over time, including system prompt learning (through [memory blocks](https://www.letta.com/blog/memory-blocks)) and [skill learning](https://www.letta.com/blog/skill-learning). Configure periodic dreaming with `/sleeptime`, audit memory quality with `/doctor`, and view memory with `/palace` |
25
+ | [Message search](https://docs.letta.com/letta-code/slash-commands) | Search across all messages and agents with `/search`. Agent can also search their own conversations or the conversations of other agents |
26
26
  | [MemFS](https://docs.letta.com/letta-code/memfs) | All context (including memory blocks) is tracked via git. Sync context to a custom GitHub repository by setting `/memory-repository set git@github.com:...` |
27
27
  | [Skills](https://docs.letta.com/letta-code/skills) | Loads global skills (`~/.letta`), project-scoped skills (`.agents/skills`), and agent-scoped skills (stored in MemFS). View skills with `/skills` and create with `/skill-creator` |
28
28
  | [Subagents & Multi-agent](https://docs.letta.com/letta-code/subagents) | Call built-in subagents (general-purpose, forked, recall, history-analyzer) async or sync. Agents can call any other agent (including themselves) as subagents |
@@ -0,0 +1,387 @@
1
+ // src/app-server-client.ts
2
+ var DEFAULT_REQUEST_TIMEOUT_MS = 30000;
3
+ var WEBSOCKET_OPEN_STATE = 1;
4
+ function getGlobalWebSocket() {
5
+ return globalThis.WebSocket;
6
+ }
7
+ function normalizeBaseUrl(url) {
8
+ const parsed = new URL(url);
9
+ if (parsed.protocol === "http:")
10
+ parsed.protocol = "ws:";
11
+ if (parsed.protocol === "https:")
12
+ parsed.protocol = "wss:";
13
+ if (parsed.protocol !== "ws:" && parsed.protocol !== "wss:") {
14
+ throw new Error(`Unsupported app-server URL protocol: ${parsed.protocol}`);
15
+ }
16
+ if (!parsed.pathname || parsed.pathname === "/") {
17
+ parsed.pathname = "/ws";
18
+ }
19
+ return parsed;
20
+ }
21
+ function resolveAppServerChannelUrl(url, channel) {
22
+ const parsed = normalizeBaseUrl(url);
23
+ parsed.searchParams.set("channel", channel);
24
+ return parsed.toString();
25
+ }
26
+ function attachSocketListener(socket, type, listener) {
27
+ if (socket.addEventListener && socket.removeEventListener) {
28
+ socket.addEventListener(type, listener);
29
+ return () => socket.removeEventListener?.(type, listener);
30
+ }
31
+ if (socket.on) {
32
+ socket.on(type, listener);
33
+ return () => socket.off?.(type, listener);
34
+ }
35
+ throw new Error("WebSocket implementation does not support event listeners");
36
+ }
37
+ function onceSocketEvent(socket, type, listener) {
38
+ if (socket.once) {
39
+ socket.once(type, listener);
40
+ return () => socket.off?.(type, listener);
41
+ }
42
+ let detach = () => {};
43
+ detach = attachSocketListener(socket, type, (event) => {
44
+ detach();
45
+ listener(event);
46
+ });
47
+ return detach;
48
+ }
49
+ function waitForSocketOpen(socket) {
50
+ if (socket.readyState === WEBSOCKET_OPEN_STATE) {
51
+ return Promise.resolve();
52
+ }
53
+ return new Promise((resolve, reject) => {
54
+ let detachOpen = () => {};
55
+ let detachError = () => {};
56
+ const cleanup = () => {
57
+ detachOpen();
58
+ detachError();
59
+ };
60
+ detachOpen = onceSocketEvent(socket, "open", () => {
61
+ cleanup();
62
+ resolve();
63
+ });
64
+ detachError = onceSocketEvent(socket, "error", (event) => {
65
+ cleanup();
66
+ reject(new Error(`App-server WebSocket failed to open: ${String(event)}`));
67
+ });
68
+ });
69
+ }
70
+ function rawEventData(event) {
71
+ if (event && typeof event === "object" && "data" in event) {
72
+ return event.data;
73
+ }
74
+ return event;
75
+ }
76
+ function messageDataToString(data) {
77
+ const raw = rawEventData(data);
78
+ if (typeof raw === "string")
79
+ return raw;
80
+ if (raw instanceof ArrayBuffer) {
81
+ return new TextDecoder().decode(raw);
82
+ }
83
+ if (raw instanceof Uint8Array) {
84
+ return new TextDecoder().decode(raw);
85
+ }
86
+ if (ArrayBuffer.isView(raw)) {
87
+ return new TextDecoder().decode(new Uint8Array(raw.buffer, raw.byteOffset, raw.byteLength));
88
+ }
89
+ return String(raw);
90
+ }
91
+ function parseProtocolMessage(event) {
92
+ return JSON.parse(messageDataToString(event));
93
+ }
94
+ function sameRuntime(a, b) {
95
+ return a?.agent_id === b.agent_id && a?.conversation_id === b.conversation_id;
96
+ }
97
+ function isWaitingLoopStatus(message) {
98
+ return message.loop_status.status === "WAITING_ON_INPUT";
99
+ }
100
+ function streamDeltaRunId(message) {
101
+ const runId = message.delta.run_id;
102
+ return typeof runId === "string" ? runId : null;
103
+ }
104
+ function streamDeltaMessageType(message) {
105
+ const messageType = message.delta.message_type;
106
+ return typeof messageType === "string" ? messageType : null;
107
+ }
108
+ function streamDeltaStopReason(message) {
109
+ const stopReason = message.delta.stop_reason;
110
+ return typeof stopReason === "string" ? stopReason : null;
111
+ }
112
+ function streamDeltaErrorMessage(message) {
113
+ const delta = message.delta;
114
+ const apiMessage = delta.api_error?.message ?? delta.api_error?.detail;
115
+ if (typeof apiMessage === "string" && apiMessage.length > 0)
116
+ return apiMessage;
117
+ if (typeof delta.message === "string" && delta.message.length > 0)
118
+ return delta.message;
119
+ return "App-server turn failed";
120
+ }
121
+
122
+ class AppServerClient {
123
+ control;
124
+ stream;
125
+ requestTimeoutMs;
126
+ pending = new Map;
127
+ messageHandlers = new Set;
128
+ sendHandlers = new Set;
129
+ activeTurnRuntimes = new Set;
130
+ nextRequestNumber = 0;
131
+ constructor(options) {
132
+ const WebSocket = options.WebSocket ?? getGlobalWebSocket();
133
+ if (!WebSocket) {
134
+ throw new Error("No WebSocket implementation available");
135
+ }
136
+ this.requestTimeoutMs = options.requestTimeoutMs ?? DEFAULT_REQUEST_TIMEOUT_MS;
137
+ this.control = new WebSocket(resolveAppServerChannelUrl(options.url, "control"));
138
+ this.stream = new WebSocket(resolveAppServerChannelUrl(options.url, "stream"));
139
+ attachSocketListener(this.control, "message", (event) => {
140
+ this.handleMessage(event, "control");
141
+ });
142
+ attachSocketListener(this.stream, "message", (event) => {
143
+ this.handleMessage(event, "stream");
144
+ });
145
+ const rejectPending = () => this.rejectAllPending("App-server socket closed");
146
+ attachSocketListener(this.control, "close", rejectPending);
147
+ attachSocketListener(this.stream, "close", rejectPending);
148
+ }
149
+ async connect() {
150
+ await Promise.all([
151
+ waitForSocketOpen(this.control),
152
+ waitForSocketOpen(this.stream)
153
+ ]);
154
+ return this;
155
+ }
156
+ close() {
157
+ this.rejectAllPending("App-server client closed");
158
+ this.control.close();
159
+ this.stream.close();
160
+ }
161
+ onMessage(handler) {
162
+ this.messageHandlers.add(handler);
163
+ return () => this.messageHandlers.delete(handler);
164
+ }
165
+ onSend(handler) {
166
+ this.sendHandlers.add(handler);
167
+ return () => this.sendHandlers.delete(handler);
168
+ }
169
+ nextRequestId(prefix = "req") {
170
+ this.nextRequestNumber += 1;
171
+ return `${prefix}-${this.nextRequestNumber}`;
172
+ }
173
+ send(command) {
174
+ for (const handler of this.sendHandlers) {
175
+ handler(command);
176
+ }
177
+ this.control.send(JSON.stringify(command));
178
+ }
179
+ request(commandOrType, bodyOrOptions = {}, maybeOptions = {}) {
180
+ const isTypeRequest = typeof commandOrType === "string";
181
+ const command = isTypeRequest ? {
182
+ type: commandOrType,
183
+ request_id: bodyOrOptions.request_id ?? this.nextRequestId(commandOrType),
184
+ ...bodyOrOptions
185
+ } : commandOrType;
186
+ const options = isTypeRequest ? maybeOptions : bodyOrOptions;
187
+ const timeoutMs = options.timeoutMs ?? this.requestTimeoutMs;
188
+ return new Promise((resolve, reject) => {
189
+ const timeout = setTimeout(() => {
190
+ this.pending.delete(command.request_id);
191
+ reject(new Error(`Timed out waiting for ${command.request_id}`));
192
+ }, timeoutMs);
193
+ this.pending.set(command.request_id, {
194
+ resolve: (message) => resolve(message),
195
+ reject,
196
+ predicate: options.predicate,
197
+ timeout
198
+ });
199
+ try {
200
+ this.send(command);
201
+ } catch (error) {
202
+ clearTimeout(timeout);
203
+ this.pending.delete(command.request_id);
204
+ reject(error instanceof Error ? error : new Error(String(error)));
205
+ }
206
+ });
207
+ }
208
+ runtimeStart(command, options = {}) {
209
+ return this.request({
210
+ type: "runtime_start",
211
+ request_id: command.request_id ?? this.nextRequestId("runtime-start"),
212
+ ...command
213
+ }, {
214
+ ...options,
215
+ predicate: (message) => message.type === "runtime_start_response"
216
+ });
217
+ }
218
+ sync(command, options = {}) {
219
+ return this.request({
220
+ type: "sync",
221
+ request_id: command.request_id ?? this.nextRequestId("sync"),
222
+ ...command
223
+ }, {
224
+ ...options,
225
+ predicate: (message) => message.type === "sync_response"
226
+ });
227
+ }
228
+ abort(command, options = {}) {
229
+ return this.request({
230
+ type: "abort_message",
231
+ request_id: command.request_id ?? this.nextRequestId("abort"),
232
+ ...command
233
+ }, {
234
+ ...options,
235
+ predicate: (message) => message.type === "abort_message_response"
236
+ });
237
+ }
238
+ onExternalToolCall(handler) {
239
+ return this.onMessage((message, channel) => {
240
+ if (channel !== "control" || message.type !== "external_tool_call_request") {
241
+ return;
242
+ }
243
+ Promise.resolve(handler(message)).then((result) => {
244
+ this.send({
245
+ type: "external_tool_call_response",
246
+ request_id: message.request_id,
247
+ result
248
+ });
249
+ }).catch((error) => {
250
+ this.send({
251
+ type: "external_tool_call_response",
252
+ request_id: message.request_id,
253
+ error: error instanceof Error ? error.message : String(error)
254
+ });
255
+ });
256
+ });
257
+ }
258
+ input(command) {
259
+ this.send({ type: "input", ...command });
260
+ }
261
+ runTurn(command, options = {}) {
262
+ const runtimeKey = `${command.runtime.agent_id}/${command.runtime.conversation_id}`;
263
+ if (this.activeTurnRuntimes.has(runtimeKey)) {
264
+ return Promise.reject(new Error(`A turn is already in flight for ${runtimeKey}`));
265
+ }
266
+ this.activeTurnRuntimes.add(runtimeKey);
267
+ const timeoutMs = options.timeoutMs ?? this.requestTimeoutMs;
268
+ const commandWithIds = this.withClientMessageIds(command);
269
+ const runIds = new Set;
270
+ let observedTurnEvidence = false;
271
+ return new Promise((resolve, reject) => {
272
+ const timeout = setTimeout(() => {
273
+ cleanup();
274
+ reject(new Error(`Timed out waiting for app-server turn on ${command.runtime.agent_id}/${command.runtime.conversation_id}`));
275
+ }, timeoutMs);
276
+ const cleanup = () => {
277
+ clearTimeout(timeout);
278
+ this.activeTurnRuntimes.delete(runtimeKey);
279
+ offMessage();
280
+ };
281
+ const finish = (completedBy, terminalMessage, stopReason) => {
282
+ cleanup();
283
+ resolve({
284
+ runtime: command.runtime,
285
+ stopReason,
286
+ runIds: [...runIds],
287
+ clientMessageIds: commandWithIds.clientMessageIds,
288
+ completedBy,
289
+ terminalMessage
290
+ });
291
+ };
292
+ const fail = (error) => {
293
+ cleanup();
294
+ reject(error);
295
+ };
296
+ const offMessage = this.onMessage((message) => {
297
+ if (!sameRuntime(message.runtime, command.runtime)) {
298
+ return;
299
+ }
300
+ if (message.type === "stream_delta") {
301
+ observedTurnEvidence = true;
302
+ const runId = streamDeltaRunId(message);
303
+ if (runId)
304
+ runIds.add(runId);
305
+ const messageType = streamDeltaMessageType(message);
306
+ if (messageType === "loop_error" || messageType === "error_message") {
307
+ fail(new Error(streamDeltaErrorMessage(message)));
308
+ return;
309
+ }
310
+ if (messageType === "stop_reason") {
311
+ finish("stop_reason", message, streamDeltaStopReason(message));
312
+ }
313
+ return;
314
+ }
315
+ if (message.type === "update_loop_status") {
316
+ for (const runId of message.loop_status.active_run_ids) {
317
+ observedTurnEvidence = true;
318
+ runIds.add(runId);
319
+ }
320
+ if (options.allowLoopStatusFallback === true && observedTurnEvidence && isWaitingLoopStatus(message)) {
321
+ finish("loop_status_waiting_fallback", message, null);
322
+ }
323
+ }
324
+ });
325
+ try {
326
+ this.input(commandWithIds.command);
327
+ } catch (error) {
328
+ fail(error instanceof Error ? error : new Error(String(error)));
329
+ }
330
+ });
331
+ }
332
+ withClientMessageIds(command) {
333
+ if (command.payload.kind !== "create_message") {
334
+ return { command, clientMessageIds: [] };
335
+ }
336
+ const clientMessageIds = [];
337
+ const messages = command.payload.messages.map((message) => {
338
+ if (message.role !== "user")
339
+ return message;
340
+ const existing = message.client_message_id;
341
+ const clientMessageId = typeof existing === "string" && existing.length > 0 ? existing : this.nextRequestId("client-message");
342
+ clientMessageIds.push(clientMessageId);
343
+ return { ...message, client_message_id: clientMessageId };
344
+ });
345
+ return {
346
+ command: {
347
+ ...command,
348
+ payload: { ...command.payload, messages }
349
+ },
350
+ clientMessageIds
351
+ };
352
+ }
353
+ handleMessage(event, channel) {
354
+ const message = parseProtocolMessage(event);
355
+ for (const handler of this.messageHandlers) {
356
+ handler(message, channel);
357
+ }
358
+ const requestId = message && typeof message === "object" && "request_id" in message ? message.request_id : undefined;
359
+ if (channel !== "control" || typeof requestId !== "string") {
360
+ return;
361
+ }
362
+ const pending = this.pending.get(requestId);
363
+ if (!pending || pending.predicate && !pending.predicate(message)) {
364
+ return;
365
+ }
366
+ clearTimeout(pending.timeout);
367
+ this.pending.delete(requestId);
368
+ pending.resolve(message);
369
+ }
370
+ rejectAllPending(reason) {
371
+ for (const [requestId, pending] of this.pending) {
372
+ clearTimeout(pending.timeout);
373
+ this.pending.delete(requestId);
374
+ pending.reject(new Error(reason));
375
+ }
376
+ }
377
+ }
378
+ function createAppServerClient(options) {
379
+ return new AppServerClient(options);
380
+ }
381
+ export {
382
+ resolveAppServerChannelUrl,
383
+ createAppServerClient,
384
+ AppServerClient
385
+ };
386
+
387
+ //# debugId=B78D9519CD31FEC264756E2164756E21
@@ -0,0 +1,10 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/app-server-client.ts"],
4
+ "sourcesContent": [
5
+ "import type {\n AbortMessageCommand,\n AbortMessageResponseMessage,\n ExternalToolCallRequestMessage,\n ExternalToolCallResult,\n InputCommand,\n LoopStatusUpdateMessage,\n RuntimeScope,\n RuntimeStartCommand,\n RuntimeStartResponseMessage,\n StreamDeltaMessage,\n SyncCommand,\n SyncResponseMessage,\n WsProtocolCommand,\n WsProtocolMessage,\n} from \"./types/app-server-protocol\";\n\nexport type AppServerChannel = \"control\" | \"stream\";\n\n/**\n * Receives every parsed protocol frame from both app-server websocket channels.\n * Treat this as the primary event stream: app-server may emit replay or turn\n * updates on the same channel that sent the triggering command, not only on the\n * stream channel. The channel argument is diagnostic/routing context.\n */\nexport type AppServerMessageHandler = (\n message: WsProtocolMessage,\n channel: AppServerChannel,\n) => void;\n\n/** Called synchronously before a protocol command is written to the control socket. */\nexport type AppServerSendHandler = (command: WsProtocolCommand) => void;\n\nexport type AppServerExternalToolCallHandler = (\n request: ExternalToolCallRequestMessage,\n) => Promise<ExternalToolCallResult> | ExternalToolCallResult;\n\nexport interface AppServerSocketLike {\n readyState: number;\n send(data: string): void;\n close(): void;\n addEventListener?(type: string, listener: (event: unknown) => void): void;\n removeEventListener?(type: string, listener: (event: unknown) => void): void;\n on?(type: string, listener: (event: unknown) => void): void;\n off?(type: string, listener: (event: unknown) => void): void;\n once?(type: string, listener: (event: unknown) => void): void;\n}\n\nexport type AppServerSocketConstructor = new (\n url: string,\n) => AppServerSocketLike;\n\nexport interface AppServerClientOptions {\n /** Base app-server URL, e.g. ws://127.0.0.1:4500 or http://127.0.0.1:4500. */\n url: string;\n /** Optional WebSocket constructor for Node/tests. Browsers use globalThis.WebSocket. */\n WebSocket?: AppServerSocketConstructor;\n /** Default timeout for request_id-correlated control requests. */\n requestTimeoutMs?: number;\n}\n\nexport interface AppServerRequestOptions<TMessage extends WsProtocolMessage> {\n timeoutMs?: number;\n predicate?: (message: WsProtocolMessage) => message is TMessage;\n}\n\nexport type AppServerRequestCommand = Extract<\n WsProtocolCommand,\n { request_id?: string }\n>;\n\nexport type AppServerRequestCommandWithId = AppServerRequestCommand & {\n request_id: string;\n};\n\nexport type AppServerRequestBody = Record<string, unknown> & {\n request_id?: string;\n};\n\ntype PendingRequest = {\n resolve: (message: WsProtocolMessage) => void;\n reject: (error: Error) => void;\n predicate?: (message: WsProtocolMessage) => boolean;\n timeout: ReturnType<typeof setTimeout>;\n};\n\nexport type AppServerTurnCompletionSource =\n | \"stop_reason\"\n | \"loop_status_waiting_fallback\";\n\nexport interface AppServerTurnResult {\n runtime: RuntimeScope;\n stopReason: string | null;\n runIds: string[];\n clientMessageIds: string[];\n completedBy: AppServerTurnCompletionSource;\n terminalMessage: WsProtocolMessage;\n}\n\nexport interface AppServerRunTurnOptions {\n timeoutMs?: number;\n /**\n * Prefer explicit stream terminal events. This fallback is only used after\n * the client has seen stream/run evidence for this runtime, never from idle\n * loop status alone.\n */\n allowLoopStatusFallback?: boolean;\n}\n\nconst DEFAULT_REQUEST_TIMEOUT_MS = 30_000;\nconst WEBSOCKET_OPEN_STATE = 1;\n\nfunction getGlobalWebSocket(): AppServerSocketConstructor | undefined {\n return (globalThis as { WebSocket?: AppServerSocketConstructor }).WebSocket;\n}\n\nfunction normalizeBaseUrl(url: string): URL {\n const parsed = new URL(url);\n if (parsed.protocol === \"http:\") parsed.protocol = \"ws:\";\n if (parsed.protocol === \"https:\") parsed.protocol = \"wss:\";\n if (parsed.protocol !== \"ws:\" && parsed.protocol !== \"wss:\") {\n throw new Error(`Unsupported app-server URL protocol: ${parsed.protocol}`);\n }\n if (!parsed.pathname || parsed.pathname === \"/\") {\n parsed.pathname = \"/ws\";\n }\n return parsed;\n}\n\nexport function resolveAppServerChannelUrl(\n url: string,\n channel: AppServerChannel,\n): string {\n const parsed = normalizeBaseUrl(url);\n parsed.searchParams.set(\"channel\", channel);\n return parsed.toString();\n}\n\nfunction attachSocketListener(\n socket: AppServerSocketLike,\n type: string,\n listener: (event: unknown) => void,\n): () => void {\n if (socket.addEventListener && socket.removeEventListener) {\n socket.addEventListener(type, listener);\n return () => socket.removeEventListener?.(type, listener);\n }\n\n if (socket.on) {\n socket.on(type, listener);\n return () => socket.off?.(type, listener);\n }\n\n throw new Error(\"WebSocket implementation does not support event listeners\");\n}\n\nfunction onceSocketEvent(\n socket: AppServerSocketLike,\n type: string,\n listener: (event: unknown) => void,\n): () => void {\n if (socket.once) {\n socket.once(type, listener);\n return () => socket.off?.(type, listener);\n }\n\n let detach = () => {};\n detach = attachSocketListener(socket, type, (event) => {\n detach();\n listener(event);\n });\n return detach;\n}\n\nfunction waitForSocketOpen(socket: AppServerSocketLike): Promise<void> {\n if (socket.readyState === WEBSOCKET_OPEN_STATE) {\n return Promise.resolve();\n }\n\n return new Promise((resolve, reject) => {\n let detachOpen = () => {};\n let detachError = () => {};\n const cleanup = () => {\n detachOpen();\n detachError();\n };\n detachOpen = onceSocketEvent(socket, \"open\", () => {\n cleanup();\n resolve();\n });\n detachError = onceSocketEvent(socket, \"error\", (event) => {\n cleanup();\n reject(\n new Error(`App-server WebSocket failed to open: ${String(event)}`),\n );\n });\n });\n}\n\nfunction rawEventData(event: unknown): unknown {\n if (event && typeof event === \"object\" && \"data\" in event) {\n return (event as { data: unknown }).data;\n }\n return event;\n}\n\nfunction messageDataToString(data: unknown): string {\n const raw = rawEventData(data);\n if (typeof raw === \"string\") return raw;\n if (raw instanceof ArrayBuffer) {\n return new TextDecoder().decode(raw);\n }\n if (raw instanceof Uint8Array) {\n return new TextDecoder().decode(raw);\n }\n if (ArrayBuffer.isView(raw)) {\n return new TextDecoder().decode(\n new Uint8Array(raw.buffer as ArrayBuffer, raw.byteOffset, raw.byteLength),\n );\n }\n return String(raw);\n}\n\nfunction parseProtocolMessage(event: unknown): WsProtocolMessage {\n return JSON.parse(messageDataToString(event)) as WsProtocolMessage;\n}\n\nfunction sameRuntime(a: RuntimeScope | undefined, b: RuntimeScope): boolean {\n return a?.agent_id === b.agent_id && a?.conversation_id === b.conversation_id;\n}\n\nfunction isWaitingLoopStatus(message: LoopStatusUpdateMessage): boolean {\n return message.loop_status.status === \"WAITING_ON_INPUT\";\n}\n\nfunction streamDeltaRunId(message: StreamDeltaMessage): string | null {\n const runId = (message.delta as { run_id?: unknown }).run_id;\n return typeof runId === \"string\" ? runId : null;\n}\n\nfunction streamDeltaMessageType(message: StreamDeltaMessage): string | null {\n const messageType = (message.delta as { message_type?: unknown })\n .message_type;\n return typeof messageType === \"string\" ? messageType : null;\n}\n\nfunction streamDeltaStopReason(message: StreamDeltaMessage): string | null {\n const stopReason = (message.delta as { stop_reason?: unknown }).stop_reason;\n return typeof stopReason === \"string\" ? stopReason : null;\n}\n\nfunction streamDeltaErrorMessage(message: StreamDeltaMessage): string {\n const delta = message.delta as {\n message?: unknown;\n api_error?: { message?: unknown; detail?: unknown };\n };\n const apiMessage = delta.api_error?.message ?? delta.api_error?.detail;\n if (typeof apiMessage === \"string\" && apiMessage.length > 0)\n return apiMessage;\n if (typeof delta.message === \"string\" && delta.message.length > 0)\n return delta.message;\n return \"App-server turn failed\";\n}\n\nexport class AppServerClient {\n readonly control: AppServerSocketLike;\n readonly stream: AppServerSocketLike;\n\n private readonly requestTimeoutMs: number;\n private readonly pending = new Map<string, PendingRequest>();\n private readonly messageHandlers = new Set<AppServerMessageHandler>();\n private readonly sendHandlers = new Set<AppServerSendHandler>();\n private readonly activeTurnRuntimes = new Set<string>();\n private nextRequestNumber = 0;\n\n constructor(options: AppServerClientOptions) {\n const WebSocket = options.WebSocket ?? getGlobalWebSocket();\n if (!WebSocket) {\n throw new Error(\"No WebSocket implementation available\");\n }\n\n this.requestTimeoutMs =\n options.requestTimeoutMs ?? DEFAULT_REQUEST_TIMEOUT_MS;\n this.control = new WebSocket(\n resolveAppServerChannelUrl(options.url, \"control\"),\n );\n this.stream = new WebSocket(\n resolveAppServerChannelUrl(options.url, \"stream\"),\n );\n\n attachSocketListener(this.control, \"message\", (event) => {\n this.handleMessage(event, \"control\");\n });\n attachSocketListener(this.stream, \"message\", (event) => {\n this.handleMessage(event, \"stream\");\n });\n const rejectPending = () =>\n this.rejectAllPending(\"App-server socket closed\");\n attachSocketListener(this.control, \"close\", rejectPending);\n attachSocketListener(this.stream, \"close\", rejectPending);\n }\n\n async connect(): Promise<this> {\n await Promise.all([\n waitForSocketOpen(this.control),\n waitForSocketOpen(this.stream),\n ]);\n return this;\n }\n\n close(): void {\n this.rejectAllPending(\"App-server client closed\");\n this.control.close();\n this.stream.close();\n }\n\n onMessage(handler: AppServerMessageHandler): () => void {\n this.messageHandlers.add(handler);\n return () => this.messageHandlers.delete(handler);\n }\n\n onSend(handler: AppServerSendHandler): () => void {\n this.sendHandlers.add(handler);\n return () => this.sendHandlers.delete(handler);\n }\n\n nextRequestId(prefix = \"req\"): string {\n this.nextRequestNumber += 1;\n return `${prefix}-${this.nextRequestNumber}`;\n }\n\n send(command: WsProtocolCommand): void {\n for (const handler of this.sendHandlers) {\n handler(command);\n }\n this.control.send(JSON.stringify(command));\n }\n\n request<TMessage extends WsProtocolMessage = WsProtocolMessage>(\n command: AppServerRequestCommandWithId,\n options?: AppServerRequestOptions<TMessage>,\n ): Promise<TMessage>;\n\n request<\n TType extends AppServerRequestCommand[\"type\"],\n TMessage extends WsProtocolMessage = WsProtocolMessage,\n >(\n type: TType,\n body?: AppServerRequestBody,\n options?: AppServerRequestOptions<TMessage>,\n ): Promise<TMessage>;\n\n request<TMessage extends WsProtocolMessage = WsProtocolMessage>(\n commandOrType:\n | AppServerRequestCommandWithId\n | AppServerRequestCommand[\"type\"],\n bodyOrOptions:\n | AppServerRequestBody\n | AppServerRequestOptions<TMessage> = {},\n maybeOptions: AppServerRequestOptions<TMessage> = {},\n ): Promise<TMessage> {\n const isTypeRequest = typeof commandOrType === \"string\";\n const command = isTypeRequest\n ? ({\n type: commandOrType,\n request_id:\n (bodyOrOptions as { request_id?: string }).request_id ??\n this.nextRequestId(commandOrType),\n ...(bodyOrOptions as object),\n } as AppServerRequestCommandWithId)\n : commandOrType;\n const options = isTypeRequest\n ? maybeOptions\n : (bodyOrOptions as AppServerRequestOptions<TMessage>);\n const timeoutMs = options.timeoutMs ?? this.requestTimeoutMs;\n\n return new Promise((resolve, reject) => {\n const timeout = setTimeout(() => {\n this.pending.delete(command.request_id);\n reject(new Error(`Timed out waiting for ${command.request_id}`));\n }, timeoutMs);\n\n this.pending.set(command.request_id, {\n resolve: (message) => resolve(message as TMessage),\n reject,\n predicate: options.predicate,\n timeout,\n });\n\n try {\n this.send(command);\n } catch (error) {\n clearTimeout(timeout);\n this.pending.delete(command.request_id);\n reject(error instanceof Error ? error : new Error(String(error)));\n }\n });\n }\n\n runtimeStart(\n command: Omit<RuntimeStartCommand, \"type\" | \"request_id\"> & {\n request_id?: string;\n },\n options: Omit<\n AppServerRequestOptions<RuntimeStartResponseMessage>,\n \"predicate\"\n > = {},\n ): Promise<RuntimeStartResponseMessage> {\n return this.request(\n {\n type: \"runtime_start\",\n request_id: command.request_id ?? this.nextRequestId(\"runtime-start\"),\n ...command,\n },\n {\n ...options,\n predicate: (message): message is RuntimeStartResponseMessage =>\n message.type === \"runtime_start_response\",\n },\n );\n }\n\n sync(\n command: Omit<SyncCommand, \"type\" | \"request_id\"> & { request_id?: string },\n options: Omit<\n AppServerRequestOptions<SyncResponseMessage>,\n \"predicate\"\n > = {},\n ): Promise<SyncResponseMessage> {\n return this.request(\n {\n type: \"sync\",\n request_id: command.request_id ?? this.nextRequestId(\"sync\"),\n ...command,\n },\n {\n ...options,\n predicate: (message): message is SyncResponseMessage =>\n message.type === \"sync_response\",\n },\n );\n }\n\n abort(\n command: Omit<AbortMessageCommand, \"type\" | \"request_id\"> & {\n request_id?: string;\n },\n options: Omit<\n AppServerRequestOptions<AbortMessageResponseMessage>,\n \"predicate\"\n > = {},\n ): Promise<AbortMessageResponseMessage> {\n return this.request(\n {\n type: \"abort_message\",\n request_id: command.request_id ?? this.nextRequestId(\"abort\"),\n ...command,\n },\n {\n ...options,\n predicate: (message): message is AbortMessageResponseMessage =>\n message.type === \"abort_message_response\",\n },\n );\n }\n\n onExternalToolCall(handler: AppServerExternalToolCallHandler): () => void {\n return this.onMessage((message, channel) => {\n if (\n channel !== \"control\" ||\n message.type !== \"external_tool_call_request\"\n ) {\n return;\n }\n\n void Promise.resolve(handler(message))\n .then((result) => {\n this.send({\n type: \"external_tool_call_response\",\n request_id: message.request_id,\n result,\n });\n })\n .catch((error) => {\n this.send({\n type: \"external_tool_call_response\",\n request_id: message.request_id,\n error: error instanceof Error ? error.message : String(error),\n });\n });\n });\n }\n\n input(command: Omit<InputCommand, \"type\">): void {\n this.send({ type: \"input\", ...command });\n }\n\n runTurn(\n command: Omit<InputCommand, \"type\">,\n options: AppServerRunTurnOptions = {},\n ): Promise<AppServerTurnResult> {\n const runtimeKey = `${command.runtime.agent_id}/${command.runtime.conversation_id}`;\n if (this.activeTurnRuntimes.has(runtimeKey)) {\n return Promise.reject(\n new Error(`A turn is already in flight for ${runtimeKey}`),\n );\n }\n this.activeTurnRuntimes.add(runtimeKey);\n const timeoutMs = options.timeoutMs ?? this.requestTimeoutMs;\n const commandWithIds = this.withClientMessageIds(command);\n const runIds = new Set<string>();\n let observedTurnEvidence = false;\n\n return new Promise((resolve, reject) => {\n const timeout = setTimeout(() => {\n cleanup();\n reject(\n new Error(\n `Timed out waiting for app-server turn on ${command.runtime.agent_id}/${command.runtime.conversation_id}`,\n ),\n );\n }, timeoutMs);\n\n const cleanup = () => {\n clearTimeout(timeout);\n this.activeTurnRuntimes.delete(runtimeKey);\n offMessage();\n };\n\n const finish = (\n completedBy: AppServerTurnCompletionSource,\n terminalMessage: WsProtocolMessage,\n stopReason: string | null,\n ) => {\n cleanup();\n resolve({\n runtime: command.runtime,\n stopReason,\n runIds: [...runIds],\n clientMessageIds: commandWithIds.clientMessageIds,\n completedBy,\n terminalMessage,\n });\n };\n\n const fail = (error: Error) => {\n cleanup();\n reject(error);\n };\n\n const offMessage = this.onMessage((message) => {\n if (\n !sameRuntime(\n (message as { runtime?: RuntimeScope }).runtime,\n command.runtime,\n )\n ) {\n return;\n }\n\n if (message.type === \"stream_delta\") {\n observedTurnEvidence = true;\n const runId = streamDeltaRunId(message);\n if (runId) runIds.add(runId);\n\n const messageType = streamDeltaMessageType(message);\n if (messageType === \"loop_error\" || messageType === \"error_message\") {\n fail(new Error(streamDeltaErrorMessage(message)));\n return;\n }\n if (messageType === \"stop_reason\") {\n finish(\"stop_reason\", message, streamDeltaStopReason(message));\n }\n return;\n }\n\n if (message.type === \"update_loop_status\") {\n for (const runId of message.loop_status.active_run_ids) {\n observedTurnEvidence = true;\n runIds.add(runId);\n }\n if (\n options.allowLoopStatusFallback === true &&\n observedTurnEvidence &&\n isWaitingLoopStatus(message)\n ) {\n finish(\"loop_status_waiting_fallback\", message, null);\n }\n }\n });\n\n try {\n this.input(commandWithIds.command);\n } catch (error) {\n fail(error instanceof Error ? error : new Error(String(error)));\n }\n });\n }\n\n private withClientMessageIds(command: Omit<InputCommand, \"type\">): {\n command: Omit<InputCommand, \"type\">;\n clientMessageIds: string[];\n } {\n if (command.payload.kind !== \"create_message\") {\n return { command, clientMessageIds: [] };\n }\n\n const clientMessageIds: string[] = [];\n const messages = command.payload.messages.map((message) => {\n if (message.role !== \"user\") return message;\n const existing = (message as { client_message_id?: unknown })\n .client_message_id;\n const clientMessageId =\n typeof existing === \"string\" && existing.length > 0\n ? existing\n : this.nextRequestId(\"client-message\");\n clientMessageIds.push(clientMessageId);\n return { ...message, client_message_id: clientMessageId };\n });\n\n return {\n command: {\n ...command,\n payload: { ...command.payload, messages },\n },\n clientMessageIds,\n };\n }\n\n private handleMessage(event: unknown, channel: AppServerChannel): void {\n const message = parseProtocolMessage(event);\n\n for (const handler of this.messageHandlers) {\n handler(message, channel);\n }\n\n const requestId =\n message && typeof message === \"object\" && \"request_id\" in message\n ? (message as { request_id?: unknown }).request_id\n : undefined;\n if (channel !== \"control\" || typeof requestId !== \"string\") {\n return;\n }\n\n const pending = this.pending.get(requestId);\n if (!pending || (pending.predicate && !pending.predicate(message))) {\n return;\n }\n\n clearTimeout(pending.timeout);\n this.pending.delete(requestId);\n pending.resolve(message);\n }\n\n private rejectAllPending(reason: string): void {\n for (const [requestId, pending] of this.pending) {\n clearTimeout(pending.timeout);\n this.pending.delete(requestId);\n pending.reject(new Error(reason));\n }\n }\n}\n\nexport function createAppServerClient(\n options: AppServerClientOptions,\n): AppServerClient {\n return new AppServerClient(options);\n}\n"
6
+ ],
7
+ "mappings": "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",
8
+ "debugId": "B78D9519CD31FEC264756E2164756E21",
9
+ "names": []
10
+ }
@@ -0,0 +1,99 @@
1
+ import type { AbortMessageCommand, AbortMessageResponseMessage, ExternalToolCallRequestMessage, ExternalToolCallResult, InputCommand, RuntimeScope, RuntimeStartCommand, RuntimeStartResponseMessage, SyncCommand, SyncResponseMessage, WsProtocolCommand, WsProtocolMessage } from "./types/app-server-protocol";
2
+ export type AppServerChannel = "control" | "stream";
3
+ /**
4
+ * Receives every parsed protocol frame from both app-server websocket channels.
5
+ * Treat this as the primary event stream: app-server may emit replay or turn
6
+ * updates on the same channel that sent the triggering command, not only on the
7
+ * stream channel. The channel argument is diagnostic/routing context.
8
+ */
9
+ export type AppServerMessageHandler = (message: WsProtocolMessage, channel: AppServerChannel) => void;
10
+ /** Called synchronously before a protocol command is written to the control socket. */
11
+ export type AppServerSendHandler = (command: WsProtocolCommand) => void;
12
+ export type AppServerExternalToolCallHandler = (request: ExternalToolCallRequestMessage) => Promise<ExternalToolCallResult> | ExternalToolCallResult;
13
+ export interface AppServerSocketLike {
14
+ readyState: number;
15
+ send(data: string): void;
16
+ close(): void;
17
+ addEventListener?(type: string, listener: (event: unknown) => void): void;
18
+ removeEventListener?(type: string, listener: (event: unknown) => void): void;
19
+ on?(type: string, listener: (event: unknown) => void): void;
20
+ off?(type: string, listener: (event: unknown) => void): void;
21
+ once?(type: string, listener: (event: unknown) => void): void;
22
+ }
23
+ export type AppServerSocketConstructor = new (url: string) => AppServerSocketLike;
24
+ export interface AppServerClientOptions {
25
+ /** Base app-server URL, e.g. ws://127.0.0.1:4500 or http://127.0.0.1:4500. */
26
+ url: string;
27
+ /** Optional WebSocket constructor for Node/tests. Browsers use globalThis.WebSocket. */
28
+ WebSocket?: AppServerSocketConstructor;
29
+ /** Default timeout for request_id-correlated control requests. */
30
+ requestTimeoutMs?: number;
31
+ }
32
+ export interface AppServerRequestOptions<TMessage extends WsProtocolMessage> {
33
+ timeoutMs?: number;
34
+ predicate?: (message: WsProtocolMessage) => message is TMessage;
35
+ }
36
+ export type AppServerRequestCommand = Extract<WsProtocolCommand, {
37
+ request_id?: string;
38
+ }>;
39
+ export type AppServerRequestCommandWithId = AppServerRequestCommand & {
40
+ request_id: string;
41
+ };
42
+ export type AppServerRequestBody = Record<string, unknown> & {
43
+ request_id?: string;
44
+ };
45
+ export type AppServerTurnCompletionSource = "stop_reason" | "loop_status_waiting_fallback";
46
+ export interface AppServerTurnResult {
47
+ runtime: RuntimeScope;
48
+ stopReason: string | null;
49
+ runIds: string[];
50
+ clientMessageIds: string[];
51
+ completedBy: AppServerTurnCompletionSource;
52
+ terminalMessage: WsProtocolMessage;
53
+ }
54
+ export interface AppServerRunTurnOptions {
55
+ timeoutMs?: number;
56
+ /**
57
+ * Prefer explicit stream terminal events. This fallback is only used after
58
+ * the client has seen stream/run evidence for this runtime, never from idle
59
+ * loop status alone.
60
+ */
61
+ allowLoopStatusFallback?: boolean;
62
+ }
63
+ export declare function resolveAppServerChannelUrl(url: string, channel: AppServerChannel): string;
64
+ export declare class AppServerClient {
65
+ readonly control: AppServerSocketLike;
66
+ readonly stream: AppServerSocketLike;
67
+ private readonly requestTimeoutMs;
68
+ private readonly pending;
69
+ private readonly messageHandlers;
70
+ private readonly sendHandlers;
71
+ private readonly activeTurnRuntimes;
72
+ private nextRequestNumber;
73
+ constructor(options: AppServerClientOptions);
74
+ connect(): Promise<this>;
75
+ close(): void;
76
+ onMessage(handler: AppServerMessageHandler): () => void;
77
+ onSend(handler: AppServerSendHandler): () => void;
78
+ nextRequestId(prefix?: string): string;
79
+ send(command: WsProtocolCommand): void;
80
+ request<TMessage extends WsProtocolMessage = WsProtocolMessage>(command: AppServerRequestCommandWithId, options?: AppServerRequestOptions<TMessage>): Promise<TMessage>;
81
+ request<TType extends AppServerRequestCommand["type"], TMessage extends WsProtocolMessage = WsProtocolMessage>(type: TType, body?: AppServerRequestBody, options?: AppServerRequestOptions<TMessage>): Promise<TMessage>;
82
+ runtimeStart(command: Omit<RuntimeStartCommand, "type" | "request_id"> & {
83
+ request_id?: string;
84
+ }, options?: Omit<AppServerRequestOptions<RuntimeStartResponseMessage>, "predicate">): Promise<RuntimeStartResponseMessage>;
85
+ sync(command: Omit<SyncCommand, "type" | "request_id"> & {
86
+ request_id?: string;
87
+ }, options?: Omit<AppServerRequestOptions<SyncResponseMessage>, "predicate">): Promise<SyncResponseMessage>;
88
+ abort(command: Omit<AbortMessageCommand, "type" | "request_id"> & {
89
+ request_id?: string;
90
+ }, options?: Omit<AppServerRequestOptions<AbortMessageResponseMessage>, "predicate">): Promise<AbortMessageResponseMessage>;
91
+ onExternalToolCall(handler: AppServerExternalToolCallHandler): () => void;
92
+ input(command: Omit<InputCommand, "type">): void;
93
+ runTurn(command: Omit<InputCommand, "type">, options?: AppServerRunTurnOptions): Promise<AppServerTurnResult>;
94
+ private withClientMessageIds;
95
+ private handleMessage;
96
+ private rejectAllPending;
97
+ }
98
+ export declare function createAppServerClient(options: AppServerClientOptions): AppServerClient;
99
+ //# sourceMappingURL=app-server-client.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"app-server-client.d.ts","sourceRoot":"","sources":["../../src/app-server-client.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ /** Public app-server websocket protocol export. */
2
+ export * from "./protocol_v2";
3
+ //# sourceMappingURL=app-server-protocol.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"app-server-protocol.d.ts","sourceRoot":"","sources":["../../../src/types/app-server-protocol.ts"],"names":[],"mappings":"AAAA,mDAAmD;AACnD,cAAc,eAAe,CAAC"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"protocol.d.ts","sourceRoot":"","sources":["../../../src/types/protocol.ts"],"names":[],"mappings":"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"}