@octavus/server-sdk 2.8.0 → 2.10.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 CHANGED
@@ -77,6 +77,9 @@ const { messages, status } = await client.agentSessions.getMessages(sessionId);
77
77
  // Restore expired session
78
78
  await client.agentSessions.restore(sessionId, storedMessages, input);
79
79
 
80
+ // Clear session state (resets to expired)
81
+ await client.agentSessions.clear(sessionId);
82
+
80
83
  // Attach to session for triggering
81
84
  const session = client.agentSessions.attach(sessionId, options);
82
85
  ```
@@ -201,7 +204,7 @@ Sessions remain active for 24 hours (configurable). Use `getMessages()` for UI d
201
204
 
202
205
  ### Expired Sessions
203
206
 
204
- When Redis state expires:
207
+ When session state expires:
205
208
 
206
209
  ```typescript
207
210
  const result = await client.agentSessions.getMessages(sessionId);
package/dist/index.d.ts CHANGED
@@ -23,6 +23,7 @@ declare abstract class BaseApiClient {
23
23
  protected httpGet<T>(path: string, schema: ZodType<T>): Promise<T>;
24
24
  protected httpPost<T>(path: string, body: unknown, schema: ZodType<T>): Promise<T>;
25
25
  protected httpPatch<T>(path: string, body: unknown, schema: ZodType<T>): Promise<T>;
26
+ protected httpDelete<T>(path: string, schema: ZodType<T>): Promise<T>;
26
27
  }
27
28
 
28
29
  /** Agent format - interactive (chat) or worker (background task) */
@@ -228,6 +229,10 @@ interface RestoreSessionResult {
228
229
  /** True if session was restored from messages, false if already active */
229
230
  restored: boolean;
230
231
  }
232
+ interface ClearSessionResult {
233
+ sessionId: string;
234
+ cleared: boolean;
235
+ }
231
236
  interface SessionAttachOptions {
232
237
  tools?: ToolHandlers;
233
238
  resources?: Resource[];
@@ -264,6 +269,12 @@ declare class AgentSessionsApi extends BaseApiClient {
264
269
  * @returns { sessionId, restored: true } if restored, { sessionId, restored: false } if already active
265
270
  */
266
271
  restore(sessionId: string, messages: UIMessage[], input?: Record<string, unknown>): Promise<RestoreSessionResult>;
272
+ /**
273
+ * Clear session state from the server.
274
+ * The session will transition to 'expired' status and can be restored with restore().
275
+ * Idempotent: succeeds even if state was already cleared/expired.
276
+ */
277
+ clear(sessionId: string): Promise<ClearSessionResult>;
267
278
  /** Attach to an existing session for triggering events */
268
279
  attach(sessionId: string, options?: SessionAttachOptions): AgentSession;
269
280
  }
@@ -368,6 +379,13 @@ interface WorkerExecuteOptions {
368
379
  /** Abort signal to cancel the execution */
369
380
  signal?: AbortSignal;
370
381
  }
382
+ /** Result from a non-streaming worker execution via `generate()` */
383
+ interface WorkerGenerateResult {
384
+ /** The worker's output value */
385
+ output: unknown;
386
+ /** Session ID for the worker execution (usable for debugging/session URLs) */
387
+ sessionId: string;
388
+ }
371
389
  /** API for executing worker agents */
372
390
  declare class WorkersApi extends BaseApiClient {
373
391
  /**
@@ -414,6 +432,36 @@ declare class WorkersApi extends BaseApiClient {
414
432
  * ```
415
433
  */
416
434
  execute(agentId: string, input: Record<string, unknown>, options?: WorkerExecuteOptions): AsyncGenerator<StreamEvent>;
435
+ /**
436
+ * Execute a worker agent and return the final output.
437
+ *
438
+ * Non-streaming equivalent of `execute()` — runs the worker to completion
439
+ * and returns the output value directly. Use this when you don't need to
440
+ * observe intermediate streaming events.
441
+ *
442
+ * @param agentId - The worker agent ID
443
+ * @param input - Input values for the worker
444
+ * @param options - Optional configuration including tools and abort signal
445
+ * @returns The worker output and session ID
446
+ * @throws {WorkerError} If the worker fails or completes without output
447
+ *
448
+ * @example Basic usage
449
+ * ```typescript
450
+ * const { output, sessionId } = await client.workers.generate(agentId, {
451
+ * TOPIC: 'AI safety',
452
+ * });
453
+ * console.log(output);
454
+ * console.log(`Debug: ${client.baseUrl}/sessions/${sessionId}`);
455
+ * ```
456
+ *
457
+ * @example With timeout
458
+ * ```typescript
459
+ * const { output } = await client.workers.generate(agentId, input, {
460
+ * signal: AbortSignal.timeout(120_000),
461
+ * });
462
+ * ```
463
+ */
464
+ generate(agentId: string, input: Record<string, unknown>, options?: WorkerExecuteOptions): Promise<WorkerGenerateResult>;
417
465
  /**
418
466
  * Continue a worker execution after client-side tool handling.
419
467
  *
@@ -448,6 +496,8 @@ declare class WorkersApi extends BaseApiClient {
448
496
  interface OctavusClientConfig {
449
497
  baseUrl: string;
450
498
  apiKey?: string;
499
+ /** Enable model request tracing to capture full payloads sent to providers (default: false) */
500
+ traceModelRequests?: boolean;
451
501
  }
452
502
  /** Client for interacting with the Octavus platform API */
453
503
  declare class OctavusClient {
@@ -457,8 +507,18 @@ declare class OctavusClient {
457
507
  readonly workers: WorkersApi;
458
508
  readonly baseUrl: string;
459
509
  private readonly apiKey?;
510
+ private readonly traceModelRequests;
460
511
  constructor(config: OctavusClientConfig);
461
512
  getHeaders(): Record<string, string>;
462
513
  }
463
514
 
464
- export { type Agent, type AgentDefinition, type AgentFormat, type AgentPrompt, AgentSession, AgentSessionsApi, type AgentSettings, AgentsApi, ApiError, type ContinueRequest, type ExpiredSessionState, type FileUploadInfo, type FileUploadRequest, FilesApi, OctavusClient, type OctavusClientConfig, Resource, type RestoreSessionResult, type SessionAttachOptions, type SessionConfig, type SessionRequest, type SessionState, type SessionStatus, type SocketMessage, type SocketMessageHandlers, type StopMessage, type TriggerOptions, type TriggerRequest, type UISessionState, type UploadUrlsResponse, type WorkerContinueRequest, type WorkerExecuteOptions, type WorkerRequest, type WorkerStartRequest, WorkersApi, toSSEStream };
515
+ /** Error thrown when a worker execution fails */
516
+ declare class WorkerError extends Error {
517
+ /** Session ID if the worker started before failing (for debugging URLs) */
518
+ readonly sessionId?: string | undefined;
519
+ constructor(message: string,
520
+ /** Session ID if the worker started before failing (for debugging URLs) */
521
+ sessionId?: string | undefined);
522
+ }
523
+
524
+ export { type Agent, type AgentDefinition, type AgentFormat, type AgentPrompt, AgentSession, AgentSessionsApi, type AgentSettings, AgentsApi, ApiError, type ClearSessionResult, type ContinueRequest, type ExpiredSessionState, type FileUploadInfo, type FileUploadRequest, FilesApi, OctavusClient, type OctavusClientConfig, Resource, type RestoreSessionResult, type SessionAttachOptions, type SessionConfig, type SessionRequest, type SessionState, type SessionStatus, type SocketMessage, type SocketMessageHandlers, type StopMessage, type TriggerOptions, type TriggerRequest, type UISessionState, type UploadUrlsResponse, type WorkerContinueRequest, WorkerError, type WorkerExecuteOptions, type WorkerGenerateResult, type WorkerRequest, type WorkerStartRequest, WorkersApi, toSSEStream };
package/dist/index.js CHANGED
@@ -74,6 +74,17 @@ var BaseApiClient = class {
74
74
  const data = await response.json();
75
75
  return schema.parse(data);
76
76
  }
77
+ async httpDelete(path, schema) {
78
+ const response = await fetch(`${this.config.baseUrl}${path}`, {
79
+ method: "DELETE",
80
+ headers: this.config.getHeaders()
81
+ });
82
+ if (!response.ok) {
83
+ await throwApiError(response, "Request failed");
84
+ }
85
+ const data = await response.json();
86
+ return schema.parse(data);
87
+ }
77
88
  };
78
89
 
79
90
  // src/agent-types.ts
@@ -484,6 +495,10 @@ var restoreSessionResponseSchema = z3.object({
484
495
  sessionId: z3.string(),
485
496
  restored: z3.boolean()
486
497
  });
498
+ var clearSessionResponseSchema = z3.object({
499
+ sessionId: z3.string(),
500
+ cleared: z3.boolean()
501
+ });
487
502
  var AgentSessionsApi = class extends BaseApiClient {
488
503
  /** Create a new session for an agent */
489
504
  async create(agentId, input) {
@@ -559,6 +574,14 @@ var AgentSessionsApi = class extends BaseApiClient {
559
574
  restoreSessionResponseSchema
560
575
  );
561
576
  }
577
+ /**
578
+ * Clear session state from the server.
579
+ * The session will transition to 'expired' status and can be restored with restore().
580
+ * Idempotent: succeeds even if state was already cleared/expired.
581
+ */
582
+ async clear(sessionId) {
583
+ return await this.httpDelete(`/api/agent-sessions/${sessionId}`, clearSessionResponseSchema);
584
+ }
562
585
  /** Attach to an existing session for triggering events */
563
586
  attach(sessionId, options = {}) {
564
587
  return new AgentSession({
@@ -622,6 +645,15 @@ var FilesApi = class extends BaseApiClient {
622
645
  }
623
646
  };
624
647
 
648
+ // src/worker-error.ts
649
+ var WorkerError = class extends Error {
650
+ constructor(message, sessionId) {
651
+ super(message);
652
+ this.sessionId = sessionId;
653
+ this.name = "WorkerError";
654
+ }
655
+ };
656
+
625
657
  // src/workers.ts
626
658
  var WorkersApi = class extends BaseApiClient {
627
659
  /**
@@ -680,6 +712,54 @@ var WorkersApi = class extends BaseApiClient {
680
712
  options.signal
681
713
  );
682
714
  }
715
+ /**
716
+ * Execute a worker agent and return the final output.
717
+ *
718
+ * Non-streaming equivalent of `execute()` — runs the worker to completion
719
+ * and returns the output value directly. Use this when you don't need to
720
+ * observe intermediate streaming events.
721
+ *
722
+ * @param agentId - The worker agent ID
723
+ * @param input - Input values for the worker
724
+ * @param options - Optional configuration including tools and abort signal
725
+ * @returns The worker output and session ID
726
+ * @throws {WorkerError} If the worker fails or completes without output
727
+ *
728
+ * @example Basic usage
729
+ * ```typescript
730
+ * const { output, sessionId } = await client.workers.generate(agentId, {
731
+ * TOPIC: 'AI safety',
732
+ * });
733
+ * console.log(output);
734
+ * console.log(`Debug: ${client.baseUrl}/sessions/${sessionId}`);
735
+ * ```
736
+ *
737
+ * @example With timeout
738
+ * ```typescript
739
+ * const { output } = await client.workers.generate(agentId, input, {
740
+ * signal: AbortSignal.timeout(120_000),
741
+ * });
742
+ * ```
743
+ */
744
+ async generate(agentId, input, options = {}) {
745
+ let sessionId;
746
+ for await (const event of this.execute(agentId, input, options)) {
747
+ if (event.type === "start" && event.executionId) {
748
+ sessionId = event.executionId;
749
+ } else if (event.type === "error") {
750
+ throw new WorkerError(event.message, sessionId);
751
+ } else if (event.type === "worker-result") {
752
+ if (event.error) {
753
+ throw new WorkerError(event.error, sessionId ?? event.workerId);
754
+ }
755
+ return {
756
+ output: event.output,
757
+ sessionId: sessionId ?? event.workerId
758
+ };
759
+ }
760
+ }
761
+ throw new WorkerError("Worker completed without producing a result", sessionId);
762
+ }
683
763
  /**
684
764
  * Continue a worker execution after client-side tool handling.
685
765
  *
@@ -735,9 +815,11 @@ var OctavusClient = class {
735
815
  workers;
736
816
  baseUrl;
737
817
  apiKey;
818
+ traceModelRequests;
738
819
  constructor(config) {
739
820
  this.baseUrl = config.baseUrl.replace(/\/$/, "");
740
821
  this.apiKey = config.apiKey;
822
+ this.traceModelRequests = config.traceModelRequests ?? false;
741
823
  const apiConfig = {
742
824
  baseUrl: this.baseUrl,
743
825
  getHeaders: () => this.getHeaders()
@@ -754,6 +836,9 @@ var OctavusClient = class {
754
836
  if (this.apiKey) {
755
837
  headers.Authorization = `Bearer ${this.apiKey}`;
756
838
  }
839
+ if (this.traceModelRequests) {
840
+ headers["X-Octavus-Trace"] = "true";
841
+ }
757
842
  return headers;
758
843
  }
759
844
  };
@@ -812,6 +897,7 @@ export {
812
897
  OctavusError,
813
898
  Resource,
814
899
  ValidationError,
900
+ WorkerError,
815
901
  WorkersApi,
816
902
  createApiErrorEvent2 as createApiErrorEvent,
817
903
  createErrorEvent,
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/api-error.ts","../src/base-api-client.ts","../src/agent-types.ts","../src/agents.ts","../src/agent-sessions.ts","../src/session.ts","../src/streaming.ts","../src/files.ts","../src/workers.ts","../src/client.ts","../src/resource.ts","../src/index.ts"],"sourcesContent":["import { z } from 'zod';\n\nconst ApiErrorResponseSchema = z.object({\n error: z.string().optional(),\n message: z.string().optional(),\n code: z.string().optional(),\n});\n\n/**\n * Error thrown when API request fails\n */\nexport class ApiError extends Error {\n constructor(\n message: string,\n public status: number,\n public code?: string,\n ) {\n super(message);\n this.name = 'ApiError';\n }\n}\n\ninterface ParsedApiError {\n message: string;\n code?: string;\n}\n\n/**\n * Parse error from API response using Zod\n */\nexport async function parseApiError(\n response: Response,\n defaultMessage: string,\n): Promise<ParsedApiError> {\n const fallbackMessage = `${defaultMessage}: ${response.statusText}`;\n\n try {\n const json: unknown = await response.json();\n const parsed = ApiErrorResponseSchema.safeParse(json);\n\n if (parsed.success) {\n return {\n message: parsed.data.error ?? parsed.data.message ?? fallbackMessage,\n code: parsed.data.code,\n };\n }\n } catch {\n // Use default message\n }\n\n return { message: fallbackMessage };\n}\n\n/**\n * Parse error from API response and throw ApiError\n */\nexport async function throwApiError(response: Response, defaultMessage: string): Promise<never> {\n const { message, code } = await parseApiError(response, defaultMessage);\n throw new ApiError(message, response.status, code);\n}\n","import type { ZodType } from 'zod';\nimport { throwApiError } from '@/api-error.js';\n\nexport { ApiError } from '@/api-error.js';\n\nexport interface ApiClientConfig {\n baseUrl: string;\n getHeaders: () => Record<string, string>;\n}\n\n/** Base class for API clients with shared HTTP utilities */\nexport abstract class BaseApiClient {\n protected readonly config: ApiClientConfig;\n\n constructor(config: ApiClientConfig) {\n this.config = config;\n }\n\n protected async httpGet<T>(path: string, schema: ZodType<T>): Promise<T> {\n const response = await fetch(`${this.config.baseUrl}${path}`, {\n method: 'GET',\n headers: this.config.getHeaders(),\n });\n\n if (!response.ok) {\n await throwApiError(response, 'Request failed');\n }\n\n const data: unknown = await response.json();\n return schema.parse(data);\n }\n\n protected async httpPost<T>(path: string, body: unknown, schema: ZodType<T>): Promise<T> {\n const response = await fetch(`${this.config.baseUrl}${path}`, {\n method: 'POST',\n headers: this.config.getHeaders(),\n body: JSON.stringify(body),\n });\n\n if (!response.ok) {\n await throwApiError(response, 'Request failed');\n }\n\n const data: unknown = await response.json();\n return schema.parse(data);\n }\n\n protected async httpPatch<T>(path: string, body: unknown, schema: ZodType<T>): Promise<T> {\n const response = await fetch(`${this.config.baseUrl}${path}`, {\n method: 'PATCH',\n headers: this.config.getHeaders(),\n body: JSON.stringify(body),\n });\n\n if (!response.ok) {\n await throwApiError(response, 'Request failed');\n }\n\n const data: unknown = await response.json();\n return schema.parse(data);\n }\n}\n","import { z } from 'zod';\n\n/** Agent format - interactive (chat) or worker (background task) */\nexport type AgentFormat = 'interactive' | 'worker';\n\n/** Agent settings */\nexport interface AgentSettings {\n slug: string;\n name: string;\n description?: string;\n format: AgentFormat;\n}\n\n/** Agent prompt */\nexport interface AgentPrompt {\n name: string;\n content: string;\n}\n\n/**\n * Agent summary returned from list endpoint\n */\nexport interface Agent {\n /** Agent slug (human-readable identifier within project) */\n slug: string;\n /** Agent ID - use this for API calls */\n id: string;\n name: string;\n description: string | null;\n format: AgentFormat;\n createdAt: string;\n updatedAt: string;\n projectId: string;\n}\n\n/**\n * Full agent definition returned from get endpoint\n */\nexport interface AgentDefinition {\n settings: AgentSettings;\n protocol: string;\n prompts: AgentPrompt[];\n /** Agent ID - use this for API calls like createSession */\n id: string;\n}\n\n// Schemas\n\nexport const agentFormatSchema = z.enum(['interactive', 'worker']);\n\nconst agentSettingsSchema = z.object({\n slug: z.string(),\n name: z.string(),\n description: z.string().optional(),\n format: agentFormatSchema,\n});\n\nconst agentPromptSchema = z.object({\n name: z.string(),\n content: z.string(),\n});\n\nexport const agentSchema = z.object({\n slug: z.string(),\n id: z.string(),\n name: z.string(),\n description: z.string().nullable(),\n format: agentFormatSchema,\n createdAt: z.string(),\n updatedAt: z.string(),\n projectId: z.string(),\n});\n\nexport const agentsResponseSchema = z.object({\n agents: z.array(agentSchema),\n});\n\nexport const agentDefinitionSchema = z.object({\n settings: agentSettingsSchema,\n protocol: z.string(),\n prompts: z.array(agentPromptSchema),\n id: z.string(),\n});\n","import { BaseApiClient } from '@/base-api-client.js';\nimport {\n agentsResponseSchema,\n agentDefinitionSchema,\n type Agent,\n type AgentDefinition,\n} from '@/agent-types.js';\n\n/**\n * API for listing and retrieving agent definitions.\n *\n * Note: Agent management (create, update, sync) should be done via the @octavus/cli package.\n * This API uses agent IDs only - use CLI for slug-based operations.\n */\nexport class AgentsApi extends BaseApiClient {\n /** List all agents in the project */\n async list(): Promise<Agent[]> {\n const response = await this.httpGet('/api/agents', agentsResponseSchema);\n return response.agents;\n }\n\n /** Get a single agent by ID */\n async get(agentId: string): Promise<AgentDefinition> {\n return await this.httpGet(`/api/agents/${agentId}`, agentDefinitionSchema);\n }\n}\n","import { z } from 'zod';\nimport {\n chatMessageSchema,\n uiMessageSchema,\n type ChatMessage,\n type ToolHandlers,\n type UIMessage,\n} from '@octavus/core';\nimport { BaseApiClient } from '@/base-api-client.js';\nimport { throwApiError } from '@/api-error.js';\nimport { AgentSession } from '@/session.js';\nimport type { Resource } from '@/resource.js';\n\nconst createSessionResponseSchema = z.object({\n sessionId: z.string(),\n});\n\nconst sessionStateSchema = z.object({\n id: z.string(),\n agentId: z.string(),\n input: z.record(z.string(), z.unknown()),\n variables: z.record(z.string(), z.unknown()),\n resources: z.record(z.string(), z.unknown()),\n messages: z.array(chatMessageSchema),\n status: z.literal('active').optional(),\n createdAt: z.string(),\n updatedAt: z.string(),\n});\n\nconst uiSessionResponseSchema = z.object({\n sessionId: z.string(),\n agentId: z.string(),\n messages: z.array(uiMessageSchema),\n status: z.literal('active').optional(),\n});\n\nconst expiredSessionResponseSchema = z.object({\n sessionId: z.string(),\n agentId: z.string(),\n status: z.literal('expired'),\n createdAt: z.string(),\n});\n\nconst restoreSessionResponseSchema = z.object({\n sessionId: z.string(),\n restored: z.boolean(),\n});\n\n/** Session status indicating whether it's active or expired */\nexport type SessionStatus = 'active' | 'expired';\n\nexport interface SessionState {\n id: string;\n agentId: string;\n input: Record<string, unknown>;\n variables: Record<string, unknown>;\n resources: Record<string, unknown>;\n messages: ChatMessage[];\n status?: 'active';\n createdAt: string;\n updatedAt: string;\n}\n\nexport interface UISessionState {\n sessionId: string;\n agentId: string;\n messages: UIMessage[];\n status?: 'active';\n}\n\nexport interface ExpiredSessionState {\n sessionId: string;\n agentId: string;\n status: 'expired';\n createdAt: string;\n}\n\nexport interface RestoreSessionResult {\n sessionId: string;\n /** True if session was restored from messages, false if already active */\n restored: boolean;\n}\n\nexport interface SessionAttachOptions {\n tools?: ToolHandlers;\n resources?: Resource[];\n}\n\n/** API for managing agent sessions */\nexport class AgentSessionsApi extends BaseApiClient {\n /** Create a new session for an agent */\n async create(agentId: string, input?: Record<string, unknown>): Promise<string> {\n const response = await this.httpPost(\n '/api/agent-sessions',\n { agentId, input },\n createSessionResponseSchema,\n );\n return response.sessionId;\n }\n\n /**\n * Get full session state (for internal/debug use)\n * Note: Contains all messages including hidden content\n *\n * Returns SessionState for active sessions, ExpiredSessionState for expired sessions.\n * Check `status` field to determine which type was returned.\n */\n async get(sessionId: string): Promise<SessionState | ExpiredSessionState> {\n const response = await fetch(`${this.config.baseUrl}/api/agent-sessions/${sessionId}`, {\n method: 'GET',\n headers: this.config.getHeaders(),\n });\n\n if (!response.ok) {\n await throwApiError(response, 'Request failed');\n }\n\n const data: unknown = await response.json();\n\n const expiredResult = expiredSessionResponseSchema.safeParse(data);\n if (expiredResult.success) {\n return expiredResult.data;\n }\n\n return sessionStateSchema.parse(data);\n }\n\n /**\n * Get UI-ready session messages (for client display)\n * Returns only visible messages with hidden content filtered out.\n *\n * For expired sessions, returns status: 'expired' without messages.\n * Use restore() to restore from stored messages before continuing.\n */\n async getMessages(sessionId: string): Promise<UISessionState | ExpiredSessionState> {\n const response = await fetch(\n `${this.config.baseUrl}/api/agent-sessions/${sessionId}?format=ui`,\n {\n method: 'GET',\n headers: this.config.getHeaders(),\n },\n );\n\n if (!response.ok) {\n await throwApiError(response, 'Request failed');\n }\n\n const data: unknown = await response.json();\n\n const expiredResult = expiredSessionResponseSchema.safeParse(data);\n if (expiredResult.success) {\n return expiredResult.data;\n }\n\n return uiSessionResponseSchema.parse(data);\n }\n\n /**\n * Restore an expired session from stored messages.\n *\n * Use this to restore a session after its state has expired.\n * The consumer should have stored the UIMessage[] array from previous interactions.\n *\n * @param sessionId - The session ID to restore\n * @param messages - Previously stored UIMessage[] array\n * @param input - Optional session input for system prompt interpolation (same as create)\n * @returns { sessionId, restored: true } if restored, { sessionId, restored: false } if already active\n */\n async restore(\n sessionId: string,\n messages: UIMessage[],\n input?: Record<string, unknown>,\n ): Promise<RestoreSessionResult> {\n return await this.httpPost(\n `/api/agent-sessions/${sessionId}/restore`,\n { messages, input },\n restoreSessionResponseSchema,\n );\n }\n\n /** Attach to an existing session for triggering events */\n attach(sessionId: string, options: SessionAttachOptions = {}): AgentSession {\n return new AgentSession({\n sessionId,\n config: this.config,\n tools: options.tools,\n resources: options.resources,\n });\n }\n}\n","import {\n createInternalErrorEvent,\n type StreamEvent,\n type ToolHandlers,\n type ToolResult,\n} from '@octavus/core';\nimport type { ApiClientConfig } from '@/base-api-client.js';\nimport type { Resource } from '@/resource.js';\nimport { executeStream } from '@/streaming.js';\n\n// =============================================================================\n// Request Types\n// =============================================================================\n\n/** Start a new trigger execution */\nexport interface TriggerRequest {\n type: 'trigger';\n triggerName: string;\n input?: Record<string, unknown>;\n}\n\n/** Continue execution after client-side tool handling */\nexport interface ContinueRequest {\n type: 'continue';\n executionId: string;\n toolResults: ToolResult[];\n}\n\n/** All request types supported by the session */\nexport type SessionRequest = TriggerRequest | ContinueRequest;\n\n/** Stop message to abort in-flight requests */\nexport interface StopMessage {\n type: 'stop';\n}\n\n/** All socket protocol messages (trigger, continue, stop) */\nexport type SocketMessage = TriggerRequest | ContinueRequest | StopMessage;\n\n// =============================================================================\n// Socket Message Handler Types\n// =============================================================================\n\n/** Handlers for socket message streaming */\nexport interface SocketMessageHandlers {\n /** Called for each stream event */\n onEvent: (event: StreamEvent) => void;\n /** Called after streaming completes (not called if aborted) */\n onFinish?: () => void | Promise<void>;\n}\n\n/**\n * Converts an async iterable of stream events to an SSE-formatted ReadableStream.\n * Use this when you need to return an SSE response (e.g., HTTP endpoints).\n *\n * @example\n * ```typescript\n * const events = session.trigger('user-message', input);\n * return new Response(toSSEStream(events), {\n * headers: { 'Content-Type': 'text/event-stream' },\n * });\n * ```\n */\nexport function toSSEStream(events: AsyncIterable<StreamEvent>): ReadableStream<Uint8Array> {\n const encoder = new TextEncoder();\n\n return new ReadableStream({\n async start(controller) {\n try {\n for await (const event of events) {\n controller.enqueue(encoder.encode(`data: ${JSON.stringify(event)}\\n\\n`));\n }\n controller.enqueue(encoder.encode('data: [DONE]\\n\\n'));\n controller.close();\n } catch (err) {\n const errorEvent = createInternalErrorEvent(\n err instanceof Error ? err.message : 'Unknown error',\n );\n controller.enqueue(encoder.encode(`data: ${JSON.stringify(errorEvent)}\\n\\n`));\n controller.close();\n }\n },\n });\n}\n\nexport interface SessionConfig {\n sessionId: string;\n config: ApiClientConfig;\n tools?: ToolHandlers;\n resources?: Resource[];\n}\n\n/**\n * Options for trigger execution.\n */\nexport interface TriggerOptions {\n /** Abort signal to cancel the trigger execution */\n signal?: AbortSignal;\n}\n\n/** Handles streaming and tool continuation for agent sessions */\nexport class AgentSession {\n private sessionId: string;\n private config: ApiClientConfig;\n private toolHandlers: ToolHandlers;\n private resourceMap: Map<string, Resource>;\n private socketAbortController: AbortController | null = null;\n\n constructor(sessionConfig: SessionConfig) {\n this.sessionId = sessionConfig.sessionId;\n this.config = sessionConfig.config;\n this.toolHandlers = sessionConfig.tools ?? {};\n this.resourceMap = new Map();\n\n for (const resource of sessionConfig.resources ?? []) {\n this.resourceMap.set(resource.name, resource);\n }\n }\n\n /**\n * Execute a session request and stream the response.\n *\n * This is the unified method that handles both triggers and continuations.\n * Use this when you want to pass through requests from the client directly.\n *\n * @param request - The request (check `request.type` for the kind)\n * @param options - Optional configuration including abort signal\n *\n * @example HTTP route (simple passthrough)\n * ```typescript\n * const events = session.execute(body, { signal: request.signal });\n * return new Response(toSSEStream(events));\n * ```\n *\n * @example WebSocket handler\n * ```typescript\n * socket.on('message', (data) => {\n * const events = session.execute(data);\n * for await (const event of events) {\n * socket.send(JSON.stringify(event));\n * }\n * });\n * ```\n */\n async *execute(request: SessionRequest, options?: TriggerOptions): AsyncGenerator<StreamEvent> {\n if (request.type === 'continue') {\n yield* this.executeStream(\n { executionId: request.executionId, toolResults: request.toolResults },\n options?.signal,\n );\n } else {\n yield* this.executeStream(\n { triggerName: request.triggerName, input: request.input },\n options?.signal,\n );\n }\n }\n\n getSessionId(): string {\n return this.sessionId;\n }\n\n /**\n * Handle a WebSocket protocol message (trigger, continue, or stop).\n * Manages abort controller lifecycle internally.\n *\n * @example\n * ```typescript\n * conn.on('data', (raw) => {\n * session.handleSocketMessage(JSON.parse(raw), {\n * onEvent: (event) => conn.write(JSON.stringify(event)),\n * onFinish: async () => {\n * // Fetch messages and persist to your database for restoration\n * },\n * });\n * });\n * ```\n */\n async handleSocketMessage(\n message: SocketMessage,\n handlers: SocketMessageHandlers,\n ): Promise<void> {\n if (message.type === 'stop') {\n this.socketAbortController?.abort();\n return;\n }\n\n this.socketAbortController?.abort();\n this.socketAbortController = new AbortController();\n\n const localController = this.socketAbortController;\n\n try {\n const events = this.execute(message, { signal: localController.signal });\n\n for await (const event of events) {\n if (localController.signal.aborted) break;\n handlers.onEvent(event);\n }\n\n if (!localController.signal.aborted && handlers.onFinish) {\n await handlers.onFinish();\n }\n } catch (err) {\n if (!localController.signal.aborted) {\n const errorEvent = createInternalErrorEvent(\n err instanceof Error ? err.message : 'Unknown error',\n );\n handlers.onEvent(errorEvent);\n }\n }\n }\n\n private async *executeStream(\n payload: {\n triggerName?: string;\n input?: Record<string, unknown>;\n executionId?: string;\n toolResults?: ToolResult[];\n },\n signal?: AbortSignal,\n ): AsyncGenerator<StreamEvent> {\n yield* executeStream(\n {\n config: this.config,\n toolHandlers: this.toolHandlers,\n url: `${this.config.baseUrl}/api/agent-sessions/${this.sessionId}/trigger`,\n buildBody: ({ executionId, toolResults }) => {\n const body: Record<string, unknown> = {};\n if (payload.triggerName !== undefined) body.triggerName = payload.triggerName;\n if (payload.input !== undefined) body.input = payload.input;\n if (executionId !== undefined) body.executionId = executionId;\n if (toolResults !== undefined) body.toolResults = toolResults;\n return body;\n },\n onResourceUpdate: (name, value) => this.handleResourceUpdate(name, value),\n errorContext: 'Failed to trigger',\n },\n { executionId: payload.executionId, toolResults: payload.toolResults },\n signal,\n );\n }\n\n private handleResourceUpdate(name: string, value: unknown): void {\n const resource = this.resourceMap.get(name);\n if (resource) {\n void resource.onUpdate(value);\n }\n }\n}\n","import {\n safeParseStreamEvent,\n isAbortError,\n createInternalErrorEvent,\n createApiErrorEvent,\n type StreamEvent,\n type ToolHandlers,\n type PendingToolCall,\n type ToolResult,\n} from '@octavus/core';\nimport { parseApiError } from '@/api-error.js';\nimport type { ApiClientConfig } from '@/base-api-client.js';\n\n/**\n * Configuration for streaming execution.\n */\nexport interface StreamExecutionConfig {\n /** API client config with baseUrl and headers */\n config: ApiClientConfig;\n /** Tool handlers for server-side execution */\n toolHandlers: ToolHandlers;\n /** Full URL to make the request to */\n url: string;\n /** Build the request body for this execution */\n buildBody: (state: {\n executionId?: string;\n toolResults?: ToolResult[];\n }) => Record<string, unknown>;\n /** Called when a resource-update event is received (optional) */\n onResourceUpdate?: (name: string, value: unknown) => void;\n /** Error message prefix for API errors */\n errorContext?: string;\n}\n\n/**\n * Initial payload for starting an execution stream.\n */\nexport interface StreamExecutionPayload {\n /** Initial execution ID (for continuation) */\n executionId?: string;\n /** Initial tool results (for continuation) */\n toolResults?: ToolResult[];\n}\n\n/**\n * Executes a streaming request with tool continuation support.\n *\n * This is the shared implementation for both interactive sessions and workers.\n * It handles:\n * - SSE stream parsing\n * - Abort signal handling\n * - Tool-request interception and server/client splitting\n * - Automatic continuation for server-handled tools\n * - Client-tool-request emission for client-handled tools\n */\nexport async function* executeStream(\n config: StreamExecutionConfig,\n payload: StreamExecutionPayload,\n signal?: AbortSignal,\n): AsyncGenerator<StreamEvent> {\n let toolResults = payload.toolResults;\n let executionId = payload.executionId;\n let continueLoop = true;\n\n while (continueLoop) {\n if (signal?.aborted) {\n yield { type: 'finish', finishReason: 'stop' };\n return;\n }\n\n const body = config.buildBody({ executionId, toolResults });\n\n let response: Response;\n try {\n response = await fetch(config.url, {\n method: 'POST',\n headers: config.config.getHeaders(),\n body: JSON.stringify(body),\n signal,\n });\n } catch (err) {\n if (isAbortError(err)) {\n yield { type: 'finish', finishReason: 'stop' };\n return;\n }\n throw err;\n }\n\n if (!response.ok) {\n const { message } = await parseApiError(response, config.errorContext ?? 'Request failed');\n yield createApiErrorEvent(response.status, message);\n return;\n }\n\n if (!response.body) {\n yield createInternalErrorEvent('Response body is not readable');\n return;\n }\n\n toolResults = undefined;\n\n const reader = response.body.getReader();\n const decoder = new TextDecoder();\n let buffer = '';\n let pendingToolCalls: PendingToolCall[] | null = null;\n\n let streamDone = false;\n while (!streamDone) {\n if (signal?.aborted) {\n reader.releaseLock();\n yield { type: 'finish', finishReason: 'stop' };\n return;\n }\n\n let readResult: ReadableStreamReadResult<Uint8Array>;\n try {\n readResult = await reader.read();\n } catch (err) {\n if (isAbortError(err)) {\n reader.releaseLock();\n yield { type: 'finish', finishReason: 'stop' };\n return;\n }\n throw err;\n }\n\n const { done, value } = readResult;\n\n if (done) {\n streamDone = true;\n continue;\n }\n\n buffer += decoder.decode(value, { stream: true });\n const lines = buffer.split('\\n');\n buffer = lines.pop() ?? '';\n\n for (const line of lines) {\n if (line.startsWith('data: ') && line !== 'data: [DONE]') {\n try {\n const parsed = safeParseStreamEvent(JSON.parse(line.slice(6)));\n if (!parsed.success) {\n continue;\n }\n const event = parsed.data;\n\n if (event.type === 'start' && event.executionId) {\n executionId = event.executionId;\n }\n\n if (event.type === 'tool-request') {\n pendingToolCalls = event.toolCalls;\n continue;\n }\n\n if (event.type === 'finish') {\n if (event.finishReason === 'tool-calls' && pendingToolCalls) {\n continue;\n }\n yield event;\n continueLoop = false;\n continue;\n }\n\n if (event.type === 'resource-update' && config.onResourceUpdate) {\n config.onResourceUpdate(event.name, event.value);\n }\n\n yield event;\n } catch {\n // Skip malformed JSON\n }\n }\n }\n }\n\n if (signal?.aborted) {\n yield { type: 'finish', finishReason: 'stop' };\n return;\n }\n\n if (pendingToolCalls && pendingToolCalls.length > 0) {\n const serverTools = pendingToolCalls.filter((tc) => config.toolHandlers[tc.toolName]);\n const clientTools = pendingToolCalls.filter((tc) => !config.toolHandlers[tc.toolName]);\n\n const serverResults = await Promise.all(\n serverTools.map(async (tc): Promise<ToolResult> => {\n const handler = config.toolHandlers[tc.toolName]!;\n try {\n const result = await handler(tc.args);\n return {\n toolCallId: tc.toolCallId,\n toolName: tc.toolName,\n result,\n outputVariable: tc.outputVariable,\n blockIndex: tc.blockIndex,\n thread: tc.thread,\n workerId: tc.workerId,\n };\n } catch (err) {\n return {\n toolCallId: tc.toolCallId,\n toolName: tc.toolName,\n error: err instanceof Error ? err.message : 'Tool execution failed',\n outputVariable: tc.outputVariable,\n blockIndex: tc.blockIndex,\n thread: tc.thread,\n workerId: tc.workerId,\n };\n }\n }),\n );\n\n for (const tr of serverResults) {\n if (tr.error) {\n yield { type: 'tool-output-error', toolCallId: tr.toolCallId, error: tr.error };\n } else {\n yield { type: 'tool-output-available', toolCallId: tr.toolCallId, output: tr.result };\n }\n }\n\n if (clientTools.length > 0) {\n if (!executionId) {\n yield createInternalErrorEvent('Missing executionId for client-tool-request');\n return;\n }\n yield {\n type: 'client-tool-request',\n executionId,\n toolCalls: clientTools,\n serverToolResults: serverResults.length > 0 ? serverResults : undefined,\n };\n yield { type: 'finish', finishReason: 'client-tool-calls', executionId };\n continueLoop = false;\n } else {\n toolResults = serverResults;\n }\n } else {\n continueLoop = false;\n }\n }\n}\n","import { z } from 'zod';\nimport { BaseApiClient } from '@/base-api-client.js';\n\n// =============================================================================\n// Schemas\n// =============================================================================\n\n/**\n * Schema for a single file upload request\n */\nexport const fileUploadRequestSchema = z.object({\n filename: z.string().min(1).max(255),\n mediaType: z.string().min(1),\n size: z.number().int().positive(),\n});\n\n/**\n * Schema for a single file upload response\n */\nexport const fileUploadInfoSchema = z.object({\n /** File ID to reference in messages */\n id: z.string(),\n /** Presigned PUT URL for uploading to S3 */\n uploadUrl: z.url(),\n /** Presigned GET URL for downloading after upload */\n downloadUrl: z.url(),\n});\n\n/**\n * Schema for the upload URLs response\n */\nexport const uploadUrlsResponseSchema = z.object({\n files: z.array(fileUploadInfoSchema),\n});\n\n// =============================================================================\n// Types\n// =============================================================================\n\nexport type FileUploadRequest = z.infer<typeof fileUploadRequestSchema>;\nexport type FileUploadInfo = z.infer<typeof fileUploadInfoSchema>;\nexport type UploadUrlsResponse = z.infer<typeof uploadUrlsResponseSchema>;\n\n// =============================================================================\n// API\n// =============================================================================\n\n/**\n * API for file operations.\n *\n * Provides methods to generate presigned URLs for file uploads.\n * Files are uploaded directly to S3, not through the platform.\n *\n * @example\n * ```typescript\n * // Get upload URLs\n * const { files } = await client.files.getUploadUrls(sessionId, [\n * { filename: 'image.png', mediaType: 'image/png', size: 12345 }\n * ]);\n *\n * // Upload directly to S3\n * await fetch(files[0].uploadUrl, {\n * method: 'PUT',\n * body: imageFile,\n * headers: { 'Content-Type': 'image/png' }\n * });\n *\n * // Use downloadUrl as FileReference in trigger input\n * ```\n */\nexport class FilesApi extends BaseApiClient {\n /**\n * Get presigned URLs for uploading files to a session.\n *\n * Returns upload URLs (PUT) and download URLs (GET) for each file.\n * Upload URLs expire in 15 minutes, download URLs match session TTL (24 hours).\n *\n * @param sessionId - The session ID to associate files with\n * @param files - Array of file metadata (filename, mediaType, size)\n * @returns Upload info with presigned URLs for each file\n *\n * @throws ApiError if session doesn't exist or validation fails\n *\n * @example\n * ```typescript\n * const { files } = await client.files.getUploadUrls(sessionId, [\n * { filename: 'photo.jpg', mediaType: 'image/jpeg', size: 102400 },\n * { filename: 'doc.pdf', mediaType: 'application/pdf', size: 204800 },\n * ]);\n *\n * // files[0].id - Use in FileReference\n * // files[0].uploadUrl - PUT to this URL\n * // files[0].downloadUrl - Use as FileReference.url\n * ```\n */\n async getUploadUrls(sessionId: string, files: FileUploadRequest[]): Promise<UploadUrlsResponse> {\n return await this.httpPost(\n '/api/files/upload-urls',\n { sessionId, files },\n uploadUrlsResponseSchema,\n );\n }\n}\n","import type { StreamEvent, ToolHandlers, ToolResult } from '@octavus/core';\nimport { BaseApiClient } from '@/base-api-client.js';\nimport { executeStream } from '@/streaming.js';\n\n// =============================================================================\n// Request Types\n// =============================================================================\n\n/** Start a new worker execution */\nexport interface WorkerStartRequest {\n type: 'start';\n input: Record<string, unknown>;\n}\n\n/** Continue execution after client-side tool handling */\nexport interface WorkerContinueRequest {\n type: 'continue';\n executionId: string;\n toolResults: ToolResult[];\n}\n\n/** All request types supported by workers */\nexport type WorkerRequest = WorkerStartRequest | WorkerContinueRequest;\n\n// =============================================================================\n// Execution Options\n// =============================================================================\n\n/** Options for worker execution */\nexport interface WorkerExecuteOptions {\n /** Tool handlers for server-side tool execution */\n tools?: ToolHandlers;\n /** Abort signal to cancel the execution */\n signal?: AbortSignal;\n}\n\n// =============================================================================\n// Workers API\n// =============================================================================\n\n/** API for executing worker agents */\nexport class WorkersApi extends BaseApiClient {\n /**\n * Execute a worker agent and stream the response.\n *\n * Worker agents execute steps sequentially and return an output value.\n * Unlike interactive sessions, workers don't maintain persistent state.\n *\n * The execution handles the tool continuation pattern automatically:\n * - Server tools (with handlers provided) are executed automatically\n * - Client tools (without handlers) emit a client-tool-request event\n *\n * @param agentId - The worker agent ID\n * @param input - Input values for the worker\n * @param options - Optional configuration including tools and abort signal\n * @returns An async generator of stream events\n *\n * @example Basic execution\n * ```typescript\n * const events = client.workers.execute(agentId, { TOPIC: 'AI safety' });\n * for await (const event of events) {\n * if (event.type === 'worker-start') {\n * console.log(`Worker ${event.workerSlug} started (${event.workerId})`);\n * }\n * if (event.type === 'worker-result') {\n * if (event.error) {\n * console.error('Worker failed:', event.error);\n * } else {\n * console.log('Output:', event.output);\n * }\n * }\n * }\n * ```\n *\n * @example With tool handlers\n * ```typescript\n * const events = client.workers.execute(agentId, { TOPIC: 'AI safety' }, {\n * tools: {\n * 'web-search': async (args) => {\n * return await searchWeb(args.query);\n * },\n * },\n * });\n * ```\n */\n async *execute(\n agentId: string,\n input: Record<string, unknown>,\n options: WorkerExecuteOptions = {},\n ): AsyncGenerator<StreamEvent> {\n yield* executeStream(\n {\n config: this.config,\n toolHandlers: options.tools ?? {},\n url: `${this.config.baseUrl}/api/agents/${agentId}/execute`,\n buildBody: ({ executionId, toolResults }) =>\n !executionId ? { type: 'start', input } : { type: 'continue', executionId, toolResults },\n errorContext: 'Failed to execute worker',\n },\n {},\n options.signal,\n );\n }\n\n /**\n * Continue a worker execution after client-side tool handling.\n *\n * Use this when your worker has tools without server-side handlers.\n * The execution returns a client-tool-request event with an executionId.\n * Execute the tools client-side, then call this method to continue.\n *\n * @param agentId - The worker agent ID\n * @param executionId - The execution ID from the client-tool-request event\n * @param toolResults - Results from client-side tool execution\n * @param options - Optional configuration including tools and abort signal\n * @returns An async generator of stream events\n *\n * @example\n * ```typescript\n * // Start execution\n * for await (const event of client.workers.execute(agentId, input)) {\n * if (event.type === 'client-tool-request') {\n * // Execute tools client-side\n * const results = await executeToolsClientSide(event.toolCalls);\n * // Continue execution\n * for await (const ev of client.workers.continue(agentId, event.executionId, results)) {\n * // Handle remaining events\n * }\n * }\n * }\n * ```\n */\n async *continue(\n agentId: string,\n executionId: string,\n toolResults: ToolResult[],\n options: WorkerExecuteOptions = {},\n ): AsyncGenerator<StreamEvent> {\n yield* executeStream(\n {\n config: this.config,\n toolHandlers: options.tools ?? {},\n url: `${this.config.baseUrl}/api/agents/${agentId}/execute`,\n buildBody: ({ executionId: execId, toolResults: results }) => ({\n type: 'continue',\n executionId: execId ?? executionId,\n toolResults: results ?? toolResults,\n }),\n errorContext: 'Failed to continue worker',\n },\n { executionId, toolResults },\n options.signal,\n );\n }\n}\n","import type { ApiClientConfig } from '@/base-api-client.js';\nimport { AgentsApi } from '@/agents.js';\nimport { AgentSessionsApi } from '@/agent-sessions.js';\nimport { FilesApi } from '@/files.js';\nimport { WorkersApi } from '@/workers.js';\n\nexport interface OctavusClientConfig {\n baseUrl: string;\n apiKey?: string;\n}\n\n/** Client for interacting with the Octavus platform API */\nexport class OctavusClient {\n readonly agents: AgentsApi;\n readonly agentSessions: AgentSessionsApi;\n readonly files: FilesApi;\n readonly workers: WorkersApi;\n readonly baseUrl: string;\n private readonly apiKey?: string;\n\n constructor(config: OctavusClientConfig) {\n this.baseUrl = config.baseUrl.replace(/\\/$/, '');\n this.apiKey = config.apiKey;\n\n const apiConfig: ApiClientConfig = {\n baseUrl: this.baseUrl,\n getHeaders: () => this.getHeaders(),\n };\n\n this.agents = new AgentsApi(apiConfig);\n this.agentSessions = new AgentSessionsApi(apiConfig);\n this.files = new FilesApi(apiConfig);\n this.workers = new WorkersApi(apiConfig);\n }\n\n getHeaders(): Record<string, string> {\n const headers: Record<string, string> = {\n 'Content-Type': 'application/json',\n };\n\n if (this.apiKey) {\n headers.Authorization = `Bearer ${this.apiKey}`;\n }\n\n return headers;\n }\n}\n","/**\n * Base class for agent-managed resources.\n * Extend this class to define how each resource should be persisted when the agent updates it.\n */\nexport abstract class Resource {\n /** The resource name as defined in the agent protocol */\n abstract readonly name: string;\n\n /** Called when the agent updates this resource */\n abstract onUpdate(value: unknown): Promise<void> | void;\n}\n","export { OctavusClient, type OctavusClientConfig } from '@/client.js';\nexport { AgentsApi } from '@/agents.js';\nexport {\n AgentSessionsApi,\n type SessionState,\n type UISessionState,\n type ExpiredSessionState,\n type RestoreSessionResult,\n type SessionStatus,\n type SessionAttachOptions,\n} from '@/agent-sessions.js';\nexport {\n FilesApi,\n type FileUploadRequest,\n type FileUploadInfo,\n type UploadUrlsResponse,\n} from '@/files.js';\nexport {\n AgentSession,\n toSSEStream,\n type SessionConfig,\n type TriggerOptions,\n type SessionRequest,\n type TriggerRequest,\n type ContinueRequest,\n type StopMessage,\n type SocketMessage,\n type SocketMessageHandlers,\n} from '@/session.js';\nexport {\n WorkersApi,\n type WorkerStartRequest,\n type WorkerContinueRequest,\n type WorkerRequest,\n type WorkerExecuteOptions,\n} from '@/workers.js';\nexport { Resource } from '@/resource.js';\nexport { ApiError } from '@/api-error.js';\n\n// Agent types (read-only - use @octavus/cli for agent management)\nexport type {\n AgentFormat,\n AgentSettings,\n AgentPrompt,\n Agent,\n AgentDefinition,\n} from '@/agent-types.js';\n\nexport type * from '@octavus/core';\nexport {\n // Error classes\n AppError,\n NotFoundError,\n ValidationError,\n ConflictError,\n ForbiddenError,\n OctavusError,\n // Error type guards\n isRateLimitError,\n isAuthenticationError,\n isProviderError,\n isToolError,\n isRetryableError,\n isValidationError,\n // Error event helpers\n createErrorEvent,\n errorToStreamEvent,\n createInternalErrorEvent,\n createApiErrorEvent,\n // Utilities\n generateId,\n isAbortError,\n // Thread helpers\n MAIN_THREAD,\n resolveThread,\n isMainThread,\n threadForPart,\n isOtherThread,\n // Type guards\n isFileReference,\n isFileReferenceArray,\n // Safe parse helpers\n safeParseStreamEvent,\n safeParseUIMessage,\n safeParseUIMessages,\n // Skills\n OCTAVUS_SKILL_TOOLS,\n isOctavusSkillTool,\n getSkillSlugFromToolCall,\n} from '@octavus/core';\n"],"mappings":"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","names":["z","z","createInternalErrorEvent","createInternalErrorEvent","z","z","z","createInternalErrorEvent","createApiErrorEvent","isAbortError","safeParseStreamEvent"]}
1
+ {"version":3,"sources":["../src/api-error.ts","../src/base-api-client.ts","../src/agent-types.ts","../src/agents.ts","../src/agent-sessions.ts","../src/session.ts","../src/streaming.ts","../src/files.ts","../src/worker-error.ts","../src/workers.ts","../src/client.ts","../src/resource.ts","../src/index.ts"],"sourcesContent":["import { z } from 'zod';\n\nconst ApiErrorResponseSchema = z.object({\n error: z.string().optional(),\n message: z.string().optional(),\n code: z.string().optional(),\n});\n\n/**\n * Error thrown when API request fails\n */\nexport class ApiError extends Error {\n constructor(\n message: string,\n public status: number,\n public code?: string,\n ) {\n super(message);\n this.name = 'ApiError';\n }\n}\n\ninterface ParsedApiError {\n message: string;\n code?: string;\n}\n\n/**\n * Parse error from API response using Zod\n */\nexport async function parseApiError(\n response: Response,\n defaultMessage: string,\n): Promise<ParsedApiError> {\n const fallbackMessage = `${defaultMessage}: ${response.statusText}`;\n\n try {\n const json: unknown = await response.json();\n const parsed = ApiErrorResponseSchema.safeParse(json);\n\n if (parsed.success) {\n return {\n message: parsed.data.error ?? parsed.data.message ?? fallbackMessage,\n code: parsed.data.code,\n };\n }\n } catch {\n // Use default message\n }\n\n return { message: fallbackMessage };\n}\n\n/**\n * Parse error from API response and throw ApiError\n */\nexport async function throwApiError(response: Response, defaultMessage: string): Promise<never> {\n const { message, code } = await parseApiError(response, defaultMessage);\n throw new ApiError(message, response.status, code);\n}\n","import type { ZodType } from 'zod';\nimport { throwApiError } from '@/api-error.js';\n\nexport { ApiError } from '@/api-error.js';\n\nexport interface ApiClientConfig {\n baseUrl: string;\n getHeaders: () => Record<string, string>;\n}\n\n/** Base class for API clients with shared HTTP utilities */\nexport abstract class BaseApiClient {\n protected readonly config: ApiClientConfig;\n\n constructor(config: ApiClientConfig) {\n this.config = config;\n }\n\n protected async httpGet<T>(path: string, schema: ZodType<T>): Promise<T> {\n const response = await fetch(`${this.config.baseUrl}${path}`, {\n method: 'GET',\n headers: this.config.getHeaders(),\n });\n\n if (!response.ok) {\n await throwApiError(response, 'Request failed');\n }\n\n const data: unknown = await response.json();\n return schema.parse(data);\n }\n\n protected async httpPost<T>(path: string, body: unknown, schema: ZodType<T>): Promise<T> {\n const response = await fetch(`${this.config.baseUrl}${path}`, {\n method: 'POST',\n headers: this.config.getHeaders(),\n body: JSON.stringify(body),\n });\n\n if (!response.ok) {\n await throwApiError(response, 'Request failed');\n }\n\n const data: unknown = await response.json();\n return schema.parse(data);\n }\n\n protected async httpPatch<T>(path: string, body: unknown, schema: ZodType<T>): Promise<T> {\n const response = await fetch(`${this.config.baseUrl}${path}`, {\n method: 'PATCH',\n headers: this.config.getHeaders(),\n body: JSON.stringify(body),\n });\n\n if (!response.ok) {\n await throwApiError(response, 'Request failed');\n }\n\n const data: unknown = await response.json();\n return schema.parse(data);\n }\n\n protected async httpDelete<T>(path: string, schema: ZodType<T>): Promise<T> {\n const response = await fetch(`${this.config.baseUrl}${path}`, {\n method: 'DELETE',\n headers: this.config.getHeaders(),\n });\n\n if (!response.ok) {\n await throwApiError(response, 'Request failed');\n }\n\n const data: unknown = await response.json();\n return schema.parse(data);\n }\n}\n","import { z } from 'zod';\n\n/** Agent format - interactive (chat) or worker (background task) */\nexport type AgentFormat = 'interactive' | 'worker';\n\n/** Agent settings */\nexport interface AgentSettings {\n slug: string;\n name: string;\n description?: string;\n format: AgentFormat;\n}\n\n/** Agent prompt */\nexport interface AgentPrompt {\n name: string;\n content: string;\n}\n\n/**\n * Agent summary returned from list endpoint\n */\nexport interface Agent {\n /** Agent slug (human-readable identifier within project) */\n slug: string;\n /** Agent ID - use this for API calls */\n id: string;\n name: string;\n description: string | null;\n format: AgentFormat;\n createdAt: string;\n updatedAt: string;\n projectId: string;\n}\n\n/**\n * Full agent definition returned from get endpoint\n */\nexport interface AgentDefinition {\n settings: AgentSettings;\n protocol: string;\n prompts: AgentPrompt[];\n /** Agent ID - use this for API calls like createSession */\n id: string;\n}\n\n// Schemas\n\nexport const agentFormatSchema = z.enum(['interactive', 'worker']);\n\nconst agentSettingsSchema = z.object({\n slug: z.string(),\n name: z.string(),\n description: z.string().optional(),\n format: agentFormatSchema,\n});\n\nconst agentPromptSchema = z.object({\n name: z.string(),\n content: z.string(),\n});\n\nexport const agentSchema = z.object({\n slug: z.string(),\n id: z.string(),\n name: z.string(),\n description: z.string().nullable(),\n format: agentFormatSchema,\n createdAt: z.string(),\n updatedAt: z.string(),\n projectId: z.string(),\n});\n\nexport const agentsResponseSchema = z.object({\n agents: z.array(agentSchema),\n});\n\nexport const agentDefinitionSchema = z.object({\n settings: agentSettingsSchema,\n protocol: z.string(),\n prompts: z.array(agentPromptSchema),\n id: z.string(),\n});\n","import { BaseApiClient } from '@/base-api-client.js';\nimport {\n agentsResponseSchema,\n agentDefinitionSchema,\n type Agent,\n type AgentDefinition,\n} from '@/agent-types.js';\n\n/**\n * API for listing and retrieving agent definitions.\n *\n * Note: Agent management (create, update, sync) should be done via the @octavus/cli package.\n * This API uses agent IDs only - use CLI for slug-based operations.\n */\nexport class AgentsApi extends BaseApiClient {\n /** List all agents in the project */\n async list(): Promise<Agent[]> {\n const response = await this.httpGet('/api/agents', agentsResponseSchema);\n return response.agents;\n }\n\n /** Get a single agent by ID */\n async get(agentId: string): Promise<AgentDefinition> {\n return await this.httpGet(`/api/agents/${agentId}`, agentDefinitionSchema);\n }\n}\n","import { z } from 'zod';\nimport {\n chatMessageSchema,\n uiMessageSchema,\n type ChatMessage,\n type ToolHandlers,\n type UIMessage,\n} from '@octavus/core';\nimport { BaseApiClient } from '@/base-api-client.js';\nimport { throwApiError } from '@/api-error.js';\nimport { AgentSession } from '@/session.js';\nimport type { Resource } from '@/resource.js';\n\nconst createSessionResponseSchema = z.object({\n sessionId: z.string(),\n});\n\nconst sessionStateSchema = z.object({\n id: z.string(),\n agentId: z.string(),\n input: z.record(z.string(), z.unknown()),\n variables: z.record(z.string(), z.unknown()),\n resources: z.record(z.string(), z.unknown()),\n messages: z.array(chatMessageSchema),\n status: z.literal('active').optional(),\n createdAt: z.string(),\n updatedAt: z.string(),\n});\n\nconst uiSessionResponseSchema = z.object({\n sessionId: z.string(),\n agentId: z.string(),\n messages: z.array(uiMessageSchema),\n status: z.literal('active').optional(),\n});\n\nconst expiredSessionResponseSchema = z.object({\n sessionId: z.string(),\n agentId: z.string(),\n status: z.literal('expired'),\n createdAt: z.string(),\n});\n\nconst restoreSessionResponseSchema = z.object({\n sessionId: z.string(),\n restored: z.boolean(),\n});\n\nconst clearSessionResponseSchema = z.object({\n sessionId: z.string(),\n cleared: z.boolean(),\n});\n\n/** Session status indicating whether it's active or expired */\nexport type SessionStatus = 'active' | 'expired';\n\nexport interface SessionState {\n id: string;\n agentId: string;\n input: Record<string, unknown>;\n variables: Record<string, unknown>;\n resources: Record<string, unknown>;\n messages: ChatMessage[];\n status?: 'active';\n createdAt: string;\n updatedAt: string;\n}\n\nexport interface UISessionState {\n sessionId: string;\n agentId: string;\n messages: UIMessage[];\n status?: 'active';\n}\n\nexport interface ExpiredSessionState {\n sessionId: string;\n agentId: string;\n status: 'expired';\n createdAt: string;\n}\n\nexport interface RestoreSessionResult {\n sessionId: string;\n /** True if session was restored from messages, false if already active */\n restored: boolean;\n}\n\nexport interface ClearSessionResult {\n sessionId: string;\n cleared: boolean;\n}\n\nexport interface SessionAttachOptions {\n tools?: ToolHandlers;\n resources?: Resource[];\n}\n\n/** API for managing agent sessions */\nexport class AgentSessionsApi extends BaseApiClient {\n /** Create a new session for an agent */\n async create(agentId: string, input?: Record<string, unknown>): Promise<string> {\n const response = await this.httpPost(\n '/api/agent-sessions',\n { agentId, input },\n createSessionResponseSchema,\n );\n return response.sessionId;\n }\n\n /**\n * Get full session state (for internal/debug use)\n * Note: Contains all messages including hidden content\n *\n * Returns SessionState for active sessions, ExpiredSessionState for expired sessions.\n * Check `status` field to determine which type was returned.\n */\n async get(sessionId: string): Promise<SessionState | ExpiredSessionState> {\n const response = await fetch(`${this.config.baseUrl}/api/agent-sessions/${sessionId}`, {\n method: 'GET',\n headers: this.config.getHeaders(),\n });\n\n if (!response.ok) {\n await throwApiError(response, 'Request failed');\n }\n\n const data: unknown = await response.json();\n\n const expiredResult = expiredSessionResponseSchema.safeParse(data);\n if (expiredResult.success) {\n return expiredResult.data;\n }\n\n return sessionStateSchema.parse(data);\n }\n\n /**\n * Get UI-ready session messages (for client display)\n * Returns only visible messages with hidden content filtered out.\n *\n * For expired sessions, returns status: 'expired' without messages.\n * Use restore() to restore from stored messages before continuing.\n */\n async getMessages(sessionId: string): Promise<UISessionState | ExpiredSessionState> {\n const response = await fetch(\n `${this.config.baseUrl}/api/agent-sessions/${sessionId}?format=ui`,\n {\n method: 'GET',\n headers: this.config.getHeaders(),\n },\n );\n\n if (!response.ok) {\n await throwApiError(response, 'Request failed');\n }\n\n const data: unknown = await response.json();\n\n const expiredResult = expiredSessionResponseSchema.safeParse(data);\n if (expiredResult.success) {\n return expiredResult.data;\n }\n\n return uiSessionResponseSchema.parse(data);\n }\n\n /**\n * Restore an expired session from stored messages.\n *\n * Use this to restore a session after its state has expired.\n * The consumer should have stored the UIMessage[] array from previous interactions.\n *\n * @param sessionId - The session ID to restore\n * @param messages - Previously stored UIMessage[] array\n * @param input - Optional session input for system prompt interpolation (same as create)\n * @returns { sessionId, restored: true } if restored, { sessionId, restored: false } if already active\n */\n async restore(\n sessionId: string,\n messages: UIMessage[],\n input?: Record<string, unknown>,\n ): Promise<RestoreSessionResult> {\n return await this.httpPost(\n `/api/agent-sessions/${sessionId}/restore`,\n { messages, input },\n restoreSessionResponseSchema,\n );\n }\n\n /**\n * Clear session state from the server.\n * The session will transition to 'expired' status and can be restored with restore().\n * Idempotent: succeeds even if state was already cleared/expired.\n */\n async clear(sessionId: string): Promise<ClearSessionResult> {\n return await this.httpDelete(`/api/agent-sessions/${sessionId}`, clearSessionResponseSchema);\n }\n\n /** Attach to an existing session for triggering events */\n attach(sessionId: string, options: SessionAttachOptions = {}): AgentSession {\n return new AgentSession({\n sessionId,\n config: this.config,\n tools: options.tools,\n resources: options.resources,\n });\n }\n}\n","import {\n createInternalErrorEvent,\n type StreamEvent,\n type ToolHandlers,\n type ToolResult,\n} from '@octavus/core';\nimport type { ApiClientConfig } from '@/base-api-client.js';\nimport type { Resource } from '@/resource.js';\nimport { executeStream } from '@/streaming.js';\n\n// =============================================================================\n// Request Types\n// =============================================================================\n\n/** Start a new trigger execution */\nexport interface TriggerRequest {\n type: 'trigger';\n triggerName: string;\n input?: Record<string, unknown>;\n}\n\n/** Continue execution after client-side tool handling */\nexport interface ContinueRequest {\n type: 'continue';\n executionId: string;\n toolResults: ToolResult[];\n}\n\n/** All request types supported by the session */\nexport type SessionRequest = TriggerRequest | ContinueRequest;\n\n/** Stop message to abort in-flight requests */\nexport interface StopMessage {\n type: 'stop';\n}\n\n/** All socket protocol messages (trigger, continue, stop) */\nexport type SocketMessage = TriggerRequest | ContinueRequest | StopMessage;\n\n// =============================================================================\n// Socket Message Handler Types\n// =============================================================================\n\n/** Handlers for socket message streaming */\nexport interface SocketMessageHandlers {\n /** Called for each stream event */\n onEvent: (event: StreamEvent) => void;\n /** Called after streaming completes (not called if aborted) */\n onFinish?: () => void | Promise<void>;\n}\n\n/**\n * Converts an async iterable of stream events to an SSE-formatted ReadableStream.\n * Use this when you need to return an SSE response (e.g., HTTP endpoints).\n *\n * @example\n * ```typescript\n * const events = session.trigger('user-message', input);\n * return new Response(toSSEStream(events), {\n * headers: { 'Content-Type': 'text/event-stream' },\n * });\n * ```\n */\nexport function toSSEStream(events: AsyncIterable<StreamEvent>): ReadableStream<Uint8Array> {\n const encoder = new TextEncoder();\n\n return new ReadableStream({\n async start(controller) {\n try {\n for await (const event of events) {\n controller.enqueue(encoder.encode(`data: ${JSON.stringify(event)}\\n\\n`));\n }\n controller.enqueue(encoder.encode('data: [DONE]\\n\\n'));\n controller.close();\n } catch (err) {\n const errorEvent = createInternalErrorEvent(\n err instanceof Error ? err.message : 'Unknown error',\n );\n controller.enqueue(encoder.encode(`data: ${JSON.stringify(errorEvent)}\\n\\n`));\n controller.close();\n }\n },\n });\n}\n\nexport interface SessionConfig {\n sessionId: string;\n config: ApiClientConfig;\n tools?: ToolHandlers;\n resources?: Resource[];\n}\n\n/**\n * Options for trigger execution.\n */\nexport interface TriggerOptions {\n /** Abort signal to cancel the trigger execution */\n signal?: AbortSignal;\n}\n\n/** Handles streaming and tool continuation for agent sessions */\nexport class AgentSession {\n private sessionId: string;\n private config: ApiClientConfig;\n private toolHandlers: ToolHandlers;\n private resourceMap: Map<string, Resource>;\n private socketAbortController: AbortController | null = null;\n\n constructor(sessionConfig: SessionConfig) {\n this.sessionId = sessionConfig.sessionId;\n this.config = sessionConfig.config;\n this.toolHandlers = sessionConfig.tools ?? {};\n this.resourceMap = new Map();\n\n for (const resource of sessionConfig.resources ?? []) {\n this.resourceMap.set(resource.name, resource);\n }\n }\n\n /**\n * Execute a session request and stream the response.\n *\n * This is the unified method that handles both triggers and continuations.\n * Use this when you want to pass through requests from the client directly.\n *\n * @param request - The request (check `request.type` for the kind)\n * @param options - Optional configuration including abort signal\n *\n * @example HTTP route (simple passthrough)\n * ```typescript\n * const events = session.execute(body, { signal: request.signal });\n * return new Response(toSSEStream(events));\n * ```\n *\n * @example WebSocket handler\n * ```typescript\n * socket.on('message', (data) => {\n * const events = session.execute(data);\n * for await (const event of events) {\n * socket.send(JSON.stringify(event));\n * }\n * });\n * ```\n */\n async *execute(request: SessionRequest, options?: TriggerOptions): AsyncGenerator<StreamEvent> {\n if (request.type === 'continue') {\n yield* this.executeStream(\n { executionId: request.executionId, toolResults: request.toolResults },\n options?.signal,\n );\n } else {\n yield* this.executeStream(\n { triggerName: request.triggerName, input: request.input },\n options?.signal,\n );\n }\n }\n\n getSessionId(): string {\n return this.sessionId;\n }\n\n /**\n * Handle a WebSocket protocol message (trigger, continue, or stop).\n * Manages abort controller lifecycle internally.\n *\n * @example\n * ```typescript\n * conn.on('data', (raw) => {\n * session.handleSocketMessage(JSON.parse(raw), {\n * onEvent: (event) => conn.write(JSON.stringify(event)),\n * onFinish: async () => {\n * // Fetch messages and persist to your database for restoration\n * },\n * });\n * });\n * ```\n */\n async handleSocketMessage(\n message: SocketMessage,\n handlers: SocketMessageHandlers,\n ): Promise<void> {\n if (message.type === 'stop') {\n this.socketAbortController?.abort();\n return;\n }\n\n this.socketAbortController?.abort();\n this.socketAbortController = new AbortController();\n\n const localController = this.socketAbortController;\n\n try {\n const events = this.execute(message, { signal: localController.signal });\n\n for await (const event of events) {\n if (localController.signal.aborted) break;\n handlers.onEvent(event);\n }\n\n if (!localController.signal.aborted && handlers.onFinish) {\n await handlers.onFinish();\n }\n } catch (err) {\n if (!localController.signal.aborted) {\n const errorEvent = createInternalErrorEvent(\n err instanceof Error ? err.message : 'Unknown error',\n );\n handlers.onEvent(errorEvent);\n }\n }\n }\n\n private async *executeStream(\n payload: {\n triggerName?: string;\n input?: Record<string, unknown>;\n executionId?: string;\n toolResults?: ToolResult[];\n },\n signal?: AbortSignal,\n ): AsyncGenerator<StreamEvent> {\n yield* executeStream(\n {\n config: this.config,\n toolHandlers: this.toolHandlers,\n url: `${this.config.baseUrl}/api/agent-sessions/${this.sessionId}/trigger`,\n buildBody: ({ executionId, toolResults }) => {\n const body: Record<string, unknown> = {};\n if (payload.triggerName !== undefined) body.triggerName = payload.triggerName;\n if (payload.input !== undefined) body.input = payload.input;\n if (executionId !== undefined) body.executionId = executionId;\n if (toolResults !== undefined) body.toolResults = toolResults;\n return body;\n },\n onResourceUpdate: (name, value) => this.handleResourceUpdate(name, value),\n errorContext: 'Failed to trigger',\n },\n { executionId: payload.executionId, toolResults: payload.toolResults },\n signal,\n );\n }\n\n private handleResourceUpdate(name: string, value: unknown): void {\n const resource = this.resourceMap.get(name);\n if (resource) {\n void resource.onUpdate(value);\n }\n }\n}\n","import {\n safeParseStreamEvent,\n isAbortError,\n createInternalErrorEvent,\n createApiErrorEvent,\n type StreamEvent,\n type ToolHandlers,\n type PendingToolCall,\n type ToolResult,\n} from '@octavus/core';\nimport { parseApiError } from '@/api-error.js';\nimport type { ApiClientConfig } from '@/base-api-client.js';\n\n/**\n * Configuration for streaming execution.\n */\nexport interface StreamExecutionConfig {\n /** API client config with baseUrl and headers */\n config: ApiClientConfig;\n /** Tool handlers for server-side execution */\n toolHandlers: ToolHandlers;\n /** Full URL to make the request to */\n url: string;\n /** Build the request body for this execution */\n buildBody: (state: {\n executionId?: string;\n toolResults?: ToolResult[];\n }) => Record<string, unknown>;\n /** Called when a resource-update event is received (optional) */\n onResourceUpdate?: (name: string, value: unknown) => void;\n /** Error message prefix for API errors */\n errorContext?: string;\n}\n\n/**\n * Initial payload for starting an execution stream.\n */\nexport interface StreamExecutionPayload {\n /** Initial execution ID (for continuation) */\n executionId?: string;\n /** Initial tool results (for continuation) */\n toolResults?: ToolResult[];\n}\n\n/**\n * Executes a streaming request with tool continuation support.\n *\n * This is the shared implementation for both interactive sessions and workers.\n * It handles:\n * - SSE stream parsing\n * - Abort signal handling\n * - Tool-request interception and server/client splitting\n * - Automatic continuation for server-handled tools\n * - Client-tool-request emission for client-handled tools\n */\nexport async function* executeStream(\n config: StreamExecutionConfig,\n payload: StreamExecutionPayload,\n signal?: AbortSignal,\n): AsyncGenerator<StreamEvent> {\n let toolResults = payload.toolResults;\n let executionId = payload.executionId;\n let continueLoop = true;\n\n while (continueLoop) {\n if (signal?.aborted) {\n yield { type: 'finish', finishReason: 'stop' };\n return;\n }\n\n const body = config.buildBody({ executionId, toolResults });\n\n let response: Response;\n try {\n response = await fetch(config.url, {\n method: 'POST',\n headers: config.config.getHeaders(),\n body: JSON.stringify(body),\n signal,\n });\n } catch (err) {\n if (isAbortError(err)) {\n yield { type: 'finish', finishReason: 'stop' };\n return;\n }\n throw err;\n }\n\n if (!response.ok) {\n const { message } = await parseApiError(response, config.errorContext ?? 'Request failed');\n yield createApiErrorEvent(response.status, message);\n return;\n }\n\n if (!response.body) {\n yield createInternalErrorEvent('Response body is not readable');\n return;\n }\n\n toolResults = undefined;\n\n const reader = response.body.getReader();\n const decoder = new TextDecoder();\n let buffer = '';\n let pendingToolCalls: PendingToolCall[] | null = null;\n\n let streamDone = false;\n while (!streamDone) {\n if (signal?.aborted) {\n reader.releaseLock();\n yield { type: 'finish', finishReason: 'stop' };\n return;\n }\n\n let readResult: ReadableStreamReadResult<Uint8Array>;\n try {\n readResult = await reader.read();\n } catch (err) {\n if (isAbortError(err)) {\n reader.releaseLock();\n yield { type: 'finish', finishReason: 'stop' };\n return;\n }\n throw err;\n }\n\n const { done, value } = readResult;\n\n if (done) {\n streamDone = true;\n continue;\n }\n\n buffer += decoder.decode(value, { stream: true });\n const lines = buffer.split('\\n');\n buffer = lines.pop() ?? '';\n\n for (const line of lines) {\n if (line.startsWith('data: ') && line !== 'data: [DONE]') {\n try {\n const parsed = safeParseStreamEvent(JSON.parse(line.slice(6)));\n if (!parsed.success) {\n continue;\n }\n const event = parsed.data;\n\n if (event.type === 'start' && event.executionId) {\n executionId = event.executionId;\n }\n\n if (event.type === 'tool-request') {\n pendingToolCalls = event.toolCalls;\n continue;\n }\n\n if (event.type === 'finish') {\n if (event.finishReason === 'tool-calls' && pendingToolCalls) {\n continue;\n }\n yield event;\n continueLoop = false;\n continue;\n }\n\n if (event.type === 'resource-update' && config.onResourceUpdate) {\n config.onResourceUpdate(event.name, event.value);\n }\n\n yield event;\n } catch {\n // Skip malformed JSON\n }\n }\n }\n }\n\n if (signal?.aborted) {\n yield { type: 'finish', finishReason: 'stop' };\n return;\n }\n\n if (pendingToolCalls && pendingToolCalls.length > 0) {\n const serverTools = pendingToolCalls.filter((tc) => config.toolHandlers[tc.toolName]);\n const clientTools = pendingToolCalls.filter((tc) => !config.toolHandlers[tc.toolName]);\n\n const serverResults = await Promise.all(\n serverTools.map(async (tc): Promise<ToolResult> => {\n const handler = config.toolHandlers[tc.toolName]!;\n try {\n const result = await handler(tc.args);\n return {\n toolCallId: tc.toolCallId,\n toolName: tc.toolName,\n result,\n outputVariable: tc.outputVariable,\n blockIndex: tc.blockIndex,\n thread: tc.thread,\n workerId: tc.workerId,\n };\n } catch (err) {\n return {\n toolCallId: tc.toolCallId,\n toolName: tc.toolName,\n error: err instanceof Error ? err.message : 'Tool execution failed',\n outputVariable: tc.outputVariable,\n blockIndex: tc.blockIndex,\n thread: tc.thread,\n workerId: tc.workerId,\n };\n }\n }),\n );\n\n for (const tr of serverResults) {\n if (tr.error) {\n yield { type: 'tool-output-error', toolCallId: tr.toolCallId, error: tr.error };\n } else {\n yield { type: 'tool-output-available', toolCallId: tr.toolCallId, output: tr.result };\n }\n }\n\n if (clientTools.length > 0) {\n if (!executionId) {\n yield createInternalErrorEvent('Missing executionId for client-tool-request');\n return;\n }\n yield {\n type: 'client-tool-request',\n executionId,\n toolCalls: clientTools,\n serverToolResults: serverResults.length > 0 ? serverResults : undefined,\n };\n yield { type: 'finish', finishReason: 'client-tool-calls', executionId };\n continueLoop = false;\n } else {\n toolResults = serverResults;\n }\n } else {\n continueLoop = false;\n }\n }\n}\n","import { z } from 'zod';\nimport { BaseApiClient } from '@/base-api-client.js';\n\n// =============================================================================\n// Schemas\n// =============================================================================\n\n/**\n * Schema for a single file upload request\n */\nexport const fileUploadRequestSchema = z.object({\n filename: z.string().min(1).max(255),\n mediaType: z.string().min(1),\n size: z.number().int().positive(),\n});\n\n/**\n * Schema for a single file upload response\n */\nexport const fileUploadInfoSchema = z.object({\n /** File ID to reference in messages */\n id: z.string(),\n /** Presigned PUT URL for uploading to S3 */\n uploadUrl: z.url(),\n /** Presigned GET URL for downloading after upload */\n downloadUrl: z.url(),\n});\n\n/**\n * Schema for the upload URLs response\n */\nexport const uploadUrlsResponseSchema = z.object({\n files: z.array(fileUploadInfoSchema),\n});\n\n// =============================================================================\n// Types\n// =============================================================================\n\nexport type FileUploadRequest = z.infer<typeof fileUploadRequestSchema>;\nexport type FileUploadInfo = z.infer<typeof fileUploadInfoSchema>;\nexport type UploadUrlsResponse = z.infer<typeof uploadUrlsResponseSchema>;\n\n// =============================================================================\n// API\n// =============================================================================\n\n/**\n * API for file operations.\n *\n * Provides methods to generate presigned URLs for file uploads.\n * Files are uploaded directly to S3, not through the platform.\n *\n * @example\n * ```typescript\n * // Get upload URLs\n * const { files } = await client.files.getUploadUrls(sessionId, [\n * { filename: 'image.png', mediaType: 'image/png', size: 12345 }\n * ]);\n *\n * // Upload directly to S3\n * await fetch(files[0].uploadUrl, {\n * method: 'PUT',\n * body: imageFile,\n * headers: { 'Content-Type': 'image/png' }\n * });\n *\n * // Use downloadUrl as FileReference in trigger input\n * ```\n */\nexport class FilesApi extends BaseApiClient {\n /**\n * Get presigned URLs for uploading files to a session.\n *\n * Returns upload URLs (PUT) and download URLs (GET) for each file.\n * Upload URLs expire in 15 minutes, download URLs match session TTL (24 hours).\n *\n * @param sessionId - The session ID to associate files with\n * @param files - Array of file metadata (filename, mediaType, size)\n * @returns Upload info with presigned URLs for each file\n *\n * @throws ApiError if session doesn't exist or validation fails\n *\n * @example\n * ```typescript\n * const { files } = await client.files.getUploadUrls(sessionId, [\n * { filename: 'photo.jpg', mediaType: 'image/jpeg', size: 102400 },\n * { filename: 'doc.pdf', mediaType: 'application/pdf', size: 204800 },\n * ]);\n *\n * // files[0].id - Use in FileReference\n * // files[0].uploadUrl - PUT to this URL\n * // files[0].downloadUrl - Use as FileReference.url\n * ```\n */\n async getUploadUrls(sessionId: string, files: FileUploadRequest[]): Promise<UploadUrlsResponse> {\n return await this.httpPost(\n '/api/files/upload-urls',\n { sessionId, files },\n uploadUrlsResponseSchema,\n );\n }\n}\n","/** Error thrown when a worker execution fails */\nexport class WorkerError extends Error {\n constructor(\n message: string,\n /** Session ID if the worker started before failing (for debugging URLs) */\n public readonly sessionId?: string,\n ) {\n super(message);\n this.name = 'WorkerError';\n }\n}\n","import type { StreamEvent, ToolHandlers, ToolResult } from '@octavus/core';\nimport { BaseApiClient } from '@/base-api-client.js';\nimport { executeStream } from '@/streaming.js';\nimport { WorkerError } from '@/worker-error.js';\n\n// =============================================================================\n// Request Types\n// =============================================================================\n\n/** Start a new worker execution */\nexport interface WorkerStartRequest {\n type: 'start';\n input: Record<string, unknown>;\n}\n\n/** Continue execution after client-side tool handling */\nexport interface WorkerContinueRequest {\n type: 'continue';\n executionId: string;\n toolResults: ToolResult[];\n}\n\n/** All request types supported by workers */\nexport type WorkerRequest = WorkerStartRequest | WorkerContinueRequest;\n\n// =============================================================================\n// Execution Options & Results\n// =============================================================================\n\n/** Options for worker execution */\nexport interface WorkerExecuteOptions {\n /** Tool handlers for server-side tool execution */\n tools?: ToolHandlers;\n /** Abort signal to cancel the execution */\n signal?: AbortSignal;\n}\n\n/** Result from a non-streaming worker execution via `generate()` */\nexport interface WorkerGenerateResult {\n /** The worker's output value */\n output: unknown;\n /** Session ID for the worker execution (usable for debugging/session URLs) */\n sessionId: string;\n}\n\n// =============================================================================\n// Workers API\n// =============================================================================\n\n/** API for executing worker agents */\nexport class WorkersApi extends BaseApiClient {\n /**\n * Execute a worker agent and stream the response.\n *\n * Worker agents execute steps sequentially and return an output value.\n * Unlike interactive sessions, workers don't maintain persistent state.\n *\n * The execution handles the tool continuation pattern automatically:\n * - Server tools (with handlers provided) are executed automatically\n * - Client tools (without handlers) emit a client-tool-request event\n *\n * @param agentId - The worker agent ID\n * @param input - Input values for the worker\n * @param options - Optional configuration including tools and abort signal\n * @returns An async generator of stream events\n *\n * @example Basic execution\n * ```typescript\n * const events = client.workers.execute(agentId, { TOPIC: 'AI safety' });\n * for await (const event of events) {\n * if (event.type === 'worker-start') {\n * console.log(`Worker ${event.workerSlug} started (${event.workerId})`);\n * }\n * if (event.type === 'worker-result') {\n * if (event.error) {\n * console.error('Worker failed:', event.error);\n * } else {\n * console.log('Output:', event.output);\n * }\n * }\n * }\n * ```\n *\n * @example With tool handlers\n * ```typescript\n * const events = client.workers.execute(agentId, { TOPIC: 'AI safety' }, {\n * tools: {\n * 'web-search': async (args) => {\n * return await searchWeb(args.query);\n * },\n * },\n * });\n * ```\n */\n async *execute(\n agentId: string,\n input: Record<string, unknown>,\n options: WorkerExecuteOptions = {},\n ): AsyncGenerator<StreamEvent> {\n yield* executeStream(\n {\n config: this.config,\n toolHandlers: options.tools ?? {},\n url: `${this.config.baseUrl}/api/agents/${agentId}/execute`,\n buildBody: ({ executionId, toolResults }) =>\n !executionId ? { type: 'start', input } : { type: 'continue', executionId, toolResults },\n errorContext: 'Failed to execute worker',\n },\n {},\n options.signal,\n );\n }\n\n /**\n * Execute a worker agent and return the final output.\n *\n * Non-streaming equivalent of `execute()` — runs the worker to completion\n * and returns the output value directly. Use this when you don't need to\n * observe intermediate streaming events.\n *\n * @param agentId - The worker agent ID\n * @param input - Input values for the worker\n * @param options - Optional configuration including tools and abort signal\n * @returns The worker output and session ID\n * @throws {WorkerError} If the worker fails or completes without output\n *\n * @example Basic usage\n * ```typescript\n * const { output, sessionId } = await client.workers.generate(agentId, {\n * TOPIC: 'AI safety',\n * });\n * console.log(output);\n * console.log(`Debug: ${client.baseUrl}/sessions/${sessionId}`);\n * ```\n *\n * @example With timeout\n * ```typescript\n * const { output } = await client.workers.generate(agentId, input, {\n * signal: AbortSignal.timeout(120_000),\n * });\n * ```\n */\n async generate(\n agentId: string,\n input: Record<string, unknown>,\n options: WorkerExecuteOptions = {},\n ): Promise<WorkerGenerateResult> {\n let sessionId: string | undefined;\n\n for await (const event of this.execute(agentId, input, options)) {\n if (event.type === 'start' && event.executionId) {\n sessionId = event.executionId;\n } else if (event.type === 'error') {\n throw new WorkerError(event.message, sessionId);\n } else if (event.type === 'worker-result') {\n if (event.error) {\n throw new WorkerError(event.error, sessionId ?? event.workerId);\n }\n return {\n output: event.output,\n sessionId: sessionId ?? event.workerId,\n };\n }\n }\n\n throw new WorkerError('Worker completed without producing a result', sessionId);\n }\n\n /**\n * Continue a worker execution after client-side tool handling.\n *\n * Use this when your worker has tools without server-side handlers.\n * The execution returns a client-tool-request event with an executionId.\n * Execute the tools client-side, then call this method to continue.\n *\n * @param agentId - The worker agent ID\n * @param executionId - The execution ID from the client-tool-request event\n * @param toolResults - Results from client-side tool execution\n * @param options - Optional configuration including tools and abort signal\n * @returns An async generator of stream events\n *\n * @example\n * ```typescript\n * // Start execution\n * for await (const event of client.workers.execute(agentId, input)) {\n * if (event.type === 'client-tool-request') {\n * // Execute tools client-side\n * const results = await executeToolsClientSide(event.toolCalls);\n * // Continue execution\n * for await (const ev of client.workers.continue(agentId, event.executionId, results)) {\n * // Handle remaining events\n * }\n * }\n * }\n * ```\n */\n async *continue(\n agentId: string,\n executionId: string,\n toolResults: ToolResult[],\n options: WorkerExecuteOptions = {},\n ): AsyncGenerator<StreamEvent> {\n yield* executeStream(\n {\n config: this.config,\n toolHandlers: options.tools ?? {},\n url: `${this.config.baseUrl}/api/agents/${agentId}/execute`,\n buildBody: ({ executionId: execId, toolResults: results }) => ({\n type: 'continue',\n executionId: execId ?? executionId,\n toolResults: results ?? toolResults,\n }),\n errorContext: 'Failed to continue worker',\n },\n { executionId, toolResults },\n options.signal,\n );\n }\n}\n","import type { ApiClientConfig } from '@/base-api-client.js';\nimport { AgentsApi } from '@/agents.js';\nimport { AgentSessionsApi } from '@/agent-sessions.js';\nimport { FilesApi } from '@/files.js';\nimport { WorkersApi } from '@/workers.js';\n\nexport interface OctavusClientConfig {\n baseUrl: string;\n apiKey?: string;\n /** Enable model request tracing to capture full payloads sent to providers (default: false) */\n traceModelRequests?: boolean;\n}\n\n/** Client for interacting with the Octavus platform API */\nexport class OctavusClient {\n readonly agents: AgentsApi;\n readonly agentSessions: AgentSessionsApi;\n readonly files: FilesApi;\n readonly workers: WorkersApi;\n readonly baseUrl: string;\n private readonly apiKey?: string;\n private readonly traceModelRequests: boolean;\n\n constructor(config: OctavusClientConfig) {\n this.baseUrl = config.baseUrl.replace(/\\/$/, '');\n this.apiKey = config.apiKey;\n this.traceModelRequests = config.traceModelRequests ?? false;\n\n const apiConfig: ApiClientConfig = {\n baseUrl: this.baseUrl,\n getHeaders: () => this.getHeaders(),\n };\n\n this.agents = new AgentsApi(apiConfig);\n this.agentSessions = new AgentSessionsApi(apiConfig);\n this.files = new FilesApi(apiConfig);\n this.workers = new WorkersApi(apiConfig);\n }\n\n getHeaders(): Record<string, string> {\n const headers: Record<string, string> = {\n 'Content-Type': 'application/json',\n };\n\n if (this.apiKey) {\n headers.Authorization = `Bearer ${this.apiKey}`;\n }\n\n if (this.traceModelRequests) {\n headers['X-Octavus-Trace'] = 'true';\n }\n\n return headers;\n }\n}\n","/**\n * Base class for agent-managed resources.\n * Extend this class to define how each resource should be persisted when the agent updates it.\n */\nexport abstract class Resource {\n /** The resource name as defined in the agent protocol */\n abstract readonly name: string;\n\n /** Called when the agent updates this resource */\n abstract onUpdate(value: unknown): Promise<void> | void;\n}\n","export { OctavusClient, type OctavusClientConfig } from '@/client.js';\nexport { AgentsApi } from '@/agents.js';\nexport {\n AgentSessionsApi,\n type SessionState,\n type UISessionState,\n type ExpiredSessionState,\n type RestoreSessionResult,\n type ClearSessionResult,\n type SessionStatus,\n type SessionAttachOptions,\n} from '@/agent-sessions.js';\nexport {\n FilesApi,\n type FileUploadRequest,\n type FileUploadInfo,\n type UploadUrlsResponse,\n} from '@/files.js';\nexport {\n AgentSession,\n toSSEStream,\n type SessionConfig,\n type TriggerOptions,\n type SessionRequest,\n type TriggerRequest,\n type ContinueRequest,\n type StopMessage,\n type SocketMessage,\n type SocketMessageHandlers,\n} from '@/session.js';\nexport {\n WorkersApi,\n type WorkerStartRequest,\n type WorkerContinueRequest,\n type WorkerRequest,\n type WorkerExecuteOptions,\n type WorkerGenerateResult,\n} from '@/workers.js';\nexport { WorkerError } from '@/worker-error.js';\nexport { Resource } from '@/resource.js';\nexport { ApiError } from '@/api-error.js';\n\n// Agent types (read-only - use @octavus/cli for agent management)\nexport type {\n AgentFormat,\n AgentSettings,\n AgentPrompt,\n Agent,\n AgentDefinition,\n} from '@/agent-types.js';\n\nexport type * from '@octavus/core';\nexport {\n // Error classes\n AppError,\n NotFoundError,\n ValidationError,\n ConflictError,\n ForbiddenError,\n OctavusError,\n // Error type guards\n isRateLimitError,\n isAuthenticationError,\n isProviderError,\n isToolError,\n isRetryableError,\n isValidationError,\n // Error event helpers\n createErrorEvent,\n errorToStreamEvent,\n createInternalErrorEvent,\n createApiErrorEvent,\n // Utilities\n generateId,\n isAbortError,\n // Thread helpers\n MAIN_THREAD,\n resolveThread,\n isMainThread,\n threadForPart,\n isOtherThread,\n // Type guards\n isFileReference,\n isFileReferenceArray,\n // Safe parse helpers\n safeParseStreamEvent,\n safeParseUIMessage,\n safeParseUIMessages,\n // Skills\n OCTAVUS_SKILL_TOOLS,\n isOctavusSkillTool,\n getSkillSlugFromToolCall,\n} from '@octavus/core';\n"],"mappings":"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","names":["z","z","createInternalErrorEvent","createInternalErrorEvent","z","z","z","createInternalErrorEvent","createApiErrorEvent","isAbortError","safeParseStreamEvent"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@octavus/server-sdk",
3
- "version": "2.8.0",
3
+ "version": "2.10.0",
4
4
  "description": "Server SDK for integrating Octavus agents",
5
5
  "license": "MIT",
6
6
  "author": "Octavus AI <dev@octavus.ai>",
@@ -40,7 +40,7 @@
40
40
  },
41
41
  "dependencies": {
42
42
  "zod": "^4.1.13",
43
- "@octavus/core": "^2.8.0"
43
+ "@octavus/core": "^2.10.0"
44
44
  },
45
45
  "devDependencies": {
46
46
  "tsup": "^8.3.5",