@copilotkitnext/runtime 0.0.22-alpha.7 → 0.0.22-alpha.8
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/dist/{chunk-LATEWAAG.mjs → chunk-ZYGIZ6EK.mjs} +12 -106
- package/dist/chunk-ZYGIZ6EK.mjs.map +1 -0
- package/dist/express.js +45 -162
- package/dist/express.js.map +1 -1
- package/dist/express.mjs +17 -38
- package/dist/express.mjs.map +1 -1
- package/dist/index.js +53 -169
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +15 -43
- package/dist/index.mjs.map +1 -1
- package/package.json +9 -5
- package/dist/chunk-LATEWAAG.mjs.map +0 -1
|
@@ -1,14 +1,11 @@
|
|
|
1
|
+
import { ReplaySubject } from 'rxjs';
|
|
2
|
+
import { EventType, compactEvents, RunAgentInputSchema } from '@ag-ui/client';
|
|
3
|
+
import { logger, finalizeRunEvents } from '@copilotkitnext/shared';
|
|
4
|
+
import { EventEncoder } from '@ag-ui/encoder';
|
|
5
|
+
|
|
1
6
|
// src/runner/agent-runner.ts
|
|
2
7
|
var AgentRunner = class {
|
|
3
8
|
};
|
|
4
|
-
|
|
5
|
-
// src/runner/in-memory.ts
|
|
6
|
-
import { ReplaySubject } from "rxjs";
|
|
7
|
-
import {
|
|
8
|
-
EventType,
|
|
9
|
-
compactEvents
|
|
10
|
-
} from "@ag-ui/client";
|
|
11
|
-
import { finalizeRunEvents } from "@copilotkitnext/shared";
|
|
12
9
|
var InMemoryEventStore = class {
|
|
13
10
|
constructor(threadId) {
|
|
14
11
|
this.threadId = threadId;
|
|
@@ -244,68 +241,7 @@ var InMemoryAgentRunner = class extends AgentRunner {
|
|
|
244
241
|
|
|
245
242
|
// package.json
|
|
246
243
|
var package_default = {
|
|
247
|
-
|
|
248
|
-
version: "0.0.22-alpha.7",
|
|
249
|
-
description: "Server-side runtime package for CopilotKit2",
|
|
250
|
-
main: "dist/index.js",
|
|
251
|
-
types: "dist/index.d.ts",
|
|
252
|
-
exports: {
|
|
253
|
-
".": {
|
|
254
|
-
types: "./dist/index.d.ts",
|
|
255
|
-
import: "./dist/index.mjs",
|
|
256
|
-
require: "./dist/index.js"
|
|
257
|
-
},
|
|
258
|
-
"./express": {
|
|
259
|
-
types: "./dist/express.d.ts",
|
|
260
|
-
import: "./dist/express.mjs",
|
|
261
|
-
require: "./dist/express.js"
|
|
262
|
-
}
|
|
263
|
-
},
|
|
264
|
-
publishConfig: {
|
|
265
|
-
access: "public"
|
|
266
|
-
},
|
|
267
|
-
scripts: {
|
|
268
|
-
build: "tsup",
|
|
269
|
-
prepublishOnly: "pnpm run build",
|
|
270
|
-
dev: "tsup --watch",
|
|
271
|
-
lint: "eslint . --max-warnings 0",
|
|
272
|
-
"check-types": "tsc --noEmit",
|
|
273
|
-
clean: "rm -rf dist",
|
|
274
|
-
test: "vitest run",
|
|
275
|
-
"test:watch": "vitest",
|
|
276
|
-
"test:coverage": "vitest run --coverage"
|
|
277
|
-
},
|
|
278
|
-
devDependencies: {
|
|
279
|
-
"@copilotkitnext/eslint-config": "workspace:*",
|
|
280
|
-
"@copilotkitnext/typescript-config": "workspace:*",
|
|
281
|
-
"@types/cors": "^2.8.17",
|
|
282
|
-
"@types/express": "^4.17.21",
|
|
283
|
-
"@types/node": "^22.15.3",
|
|
284
|
-
eslint: "^9.30.0",
|
|
285
|
-
openai: "^5.9.0",
|
|
286
|
-
supertest: "^7.1.1",
|
|
287
|
-
tsup: "^8.5.0",
|
|
288
|
-
typescript: "5.8.2",
|
|
289
|
-
vitest: "^3.0.5"
|
|
290
|
-
},
|
|
291
|
-
dependencies: {
|
|
292
|
-
"@ag-ui/client": "0.0.41-alpha.0",
|
|
293
|
-
"@ag-ui/core": "0.0.41-alpha.0",
|
|
294
|
-
"@ag-ui/encoder": "0.0.41-alpha.0",
|
|
295
|
-
"@copilotkitnext/shared": "workspace:*",
|
|
296
|
-
cors: "^2.8.5",
|
|
297
|
-
rxjs: "7.8.1"
|
|
298
|
-
},
|
|
299
|
-
peerDependencies: {
|
|
300
|
-
express: "^4.21.2",
|
|
301
|
-
hono: "^4.6.13",
|
|
302
|
-
openai: "^5.9.0"
|
|
303
|
-
},
|
|
304
|
-
peerDependenciesMeta: {},
|
|
305
|
-
engines: {
|
|
306
|
-
node: ">=18"
|
|
307
|
-
}
|
|
308
|
-
};
|
|
244
|
+
version: "0.0.22-alpha.8"};
|
|
309
245
|
|
|
310
246
|
// src/runtime.ts
|
|
311
247
|
var VERSION = package_default.version;
|
|
@@ -329,12 +265,6 @@ var CopilotRuntime = class {
|
|
|
329
265
|
this.runner = runner ?? new InMemoryAgentRunner();
|
|
330
266
|
}
|
|
331
267
|
};
|
|
332
|
-
|
|
333
|
-
// src/handlers/handle-run.ts
|
|
334
|
-
import {
|
|
335
|
-
RunAgentInputSchema
|
|
336
|
-
} from "@ag-ui/client";
|
|
337
|
-
import { EventEncoder } from "@ag-ui/encoder";
|
|
338
268
|
async function handleRunAgent({
|
|
339
269
|
runtime,
|
|
340
270
|
request,
|
|
@@ -478,10 +408,6 @@ async function handleRunAgent({
|
|
|
478
408
|
);
|
|
479
409
|
}
|
|
480
410
|
}
|
|
481
|
-
|
|
482
|
-
// src/handlers/handle-connect.ts
|
|
483
|
-
import { RunAgentInputSchema as RunAgentInputSchema2 } from "@ag-ui/client";
|
|
484
|
-
import { EventEncoder as EventEncoder2 } from "@ag-ui/encoder";
|
|
485
411
|
async function handleConnectAgent({
|
|
486
412
|
runtime,
|
|
487
413
|
request,
|
|
@@ -503,13 +429,13 @@ async function handleConnectAgent({
|
|
|
503
429
|
}
|
|
504
430
|
const stream = new TransformStream();
|
|
505
431
|
const writer = stream.writable.getWriter();
|
|
506
|
-
const encoder = new
|
|
432
|
+
const encoder = new EventEncoder();
|
|
507
433
|
let streamClosed = false;
|
|
508
434
|
(async () => {
|
|
509
435
|
let input;
|
|
510
436
|
try {
|
|
511
437
|
const requestBody = await request.json();
|
|
512
|
-
input =
|
|
438
|
+
input = RunAgentInputSchema.parse(requestBody);
|
|
513
439
|
} catch {
|
|
514
440
|
return new Response(
|
|
515
441
|
JSON.stringify({
|
|
@@ -602,9 +528,6 @@ async function handleConnectAgent({
|
|
|
602
528
|
);
|
|
603
529
|
}
|
|
604
530
|
}
|
|
605
|
-
|
|
606
|
-
// src/handlers/handle-stop.ts
|
|
607
|
-
import { EventType as EventType2 } from "@ag-ui/client";
|
|
608
531
|
async function handleStopAgent({
|
|
609
532
|
runtime,
|
|
610
533
|
request,
|
|
@@ -642,7 +565,7 @@ async function handleStopAgent({
|
|
|
642
565
|
JSON.stringify({
|
|
643
566
|
stopped: true,
|
|
644
567
|
interrupt: {
|
|
645
|
-
type:
|
|
568
|
+
type: EventType.RUN_ERROR,
|
|
646
569
|
message: "Run stopped by user",
|
|
647
570
|
code: "STOPPED"
|
|
648
571
|
}
|
|
@@ -804,9 +727,6 @@ async function handleTranscribe({
|
|
|
804
727
|
);
|
|
805
728
|
}
|
|
806
729
|
}
|
|
807
|
-
|
|
808
|
-
// src/middleware.ts
|
|
809
|
-
import { logger } from "@copilotkitnext/shared";
|
|
810
730
|
async function callBeforeRequestMiddleware({
|
|
811
731
|
runtime,
|
|
812
732
|
request,
|
|
@@ -917,20 +837,6 @@ function serializeJsonBody(body) {
|
|
|
917
837
|
return JSON.stringify(body);
|
|
918
838
|
}
|
|
919
839
|
|
|
920
|
-
export {
|
|
921
|
-
|
|
922
|
-
|
|
923
|
-
handleStopAgent,
|
|
924
|
-
AgentRunner,
|
|
925
|
-
InMemoryAgentRunner,
|
|
926
|
-
VERSION,
|
|
927
|
-
CopilotRuntime,
|
|
928
|
-
handleGetRuntimeInfo,
|
|
929
|
-
handleTranscribe,
|
|
930
|
-
callBeforeRequestMiddleware,
|
|
931
|
-
callAfterRequestMiddleware,
|
|
932
|
-
parseMethodCall,
|
|
933
|
-
expectString,
|
|
934
|
-
createJsonRequest
|
|
935
|
-
};
|
|
936
|
-
//# sourceMappingURL=chunk-LATEWAAG.mjs.map
|
|
840
|
+
export { AgentRunner, CopilotRuntime, InMemoryAgentRunner, VERSION, callAfterRequestMiddleware, callBeforeRequestMiddleware, createJsonRequest, expectString, handleConnectAgent, handleGetRuntimeInfo, handleRunAgent, handleStopAgent, handleTranscribe, parseMethodCall };
|
|
841
|
+
//# sourceMappingURL=chunk-ZYGIZ6EK.mjs.map
|
|
842
|
+
//# sourceMappingURL=chunk-ZYGIZ6EK.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/runner/agent-runner.ts","../src/runner/in-memory.ts","../package.json","../src/runtime.ts","../src/handlers/handle-run.ts","../src/handlers/handle-connect.ts","../src/handlers/handle-stop.ts","../src/handlers/get-runtime-info.ts","../src/handlers/handle-transcribe.ts","../src/middleware.ts","../src/endpoints/single-route-helpers.ts"],"names":["EventEncoder","RunAgentInputSchema","EventType"],"mappings":"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","file":"chunk-ZYGIZ6EK.mjs","sourcesContent":["import { AbstractAgent, BaseEvent, RunAgentInput } from \"@ag-ui/client\";\nimport { Observable } from \"rxjs\";\n\nexport interface AgentRunnerRunRequest {\n threadId: string;\n agent: AbstractAgent;\n input: RunAgentInput;\n}\n\nexport interface AgentRunnerConnectRequest {\n threadId: string;\n}\n\nexport interface AgentRunnerIsRunningRequest {\n threadId: string;\n}\n\nexport interface AgentRunnerStopRequest {\n threadId: string;\n}\n\nexport abstract class AgentRunner {\n abstract run(request: AgentRunnerRunRequest): Observable<BaseEvent>;\n abstract connect(request: AgentRunnerConnectRequest): Observable<BaseEvent>;\n abstract isRunning(request: AgentRunnerIsRunningRequest): Promise<boolean>;\n abstract stop(request: AgentRunnerStopRequest): Promise<boolean | undefined>;\n}\n","import {\n AgentRunner,\n AgentRunnerConnectRequest,\n AgentRunnerIsRunningRequest,\n AgentRunnerRunRequest,\n type AgentRunnerStopRequest,\n} from \"./agent-runner\";\nimport { Observable, ReplaySubject } from \"rxjs\";\nimport {\n AbstractAgent,\n BaseEvent,\n EventType,\n MessagesSnapshotEvent,\n RunStartedEvent,\n compactEvents,\n} from \"@ag-ui/client\";\nimport { finalizeRunEvents } from \"@copilotkitnext/shared\";\n\ninterface HistoricRun {\n threadId: string;\n runId: string;\n parentRunId: string | null;\n events: BaseEvent[];\n createdAt: number;\n}\n\nclass InMemoryEventStore {\n constructor(public threadId: string) {}\n\n /** The subject that current consumers subscribe to. */\n subject: ReplaySubject<BaseEvent> | null = null;\n\n /** True while a run is actively producing events. */\n isRunning = false;\n\n /** Current run ID */\n currentRunId: string | null = null;\n\n /** Historic completed runs */\n historicRuns: HistoricRun[] = [];\n\n /** Currently running agent instance (if any). */\n agent: AbstractAgent | null = null;\n\n /** Subject returned from run() while the run is active. */\n runSubject: ReplaySubject<BaseEvent> | null = null;\n\n /** True once stop() has been requested but the run has not yet finalized. */\n stopRequested = false;\n\n /** Reference to the events emitted in the current run. */\n currentEvents: BaseEvent[] | null = null;\n}\n\nconst GLOBAL_STORE = new Map<string, InMemoryEventStore>();\n\nexport class InMemoryAgentRunner extends AgentRunner {\n run(request: AgentRunnerRunRequest): Observable<BaseEvent> {\n let existingStore = GLOBAL_STORE.get(request.threadId);\n if (!existingStore) {\n existingStore = new InMemoryEventStore(request.threadId);\n GLOBAL_STORE.set(request.threadId, existingStore);\n }\n const store = existingStore; // Now store is const and non-null\n\n if (store.isRunning) {\n throw new Error(\"Thread already running\");\n }\n store.isRunning = true;\n store.currentRunId = request.input.runId;\n store.agent = request.agent;\n store.stopRequested = false;\n\n // Track seen message IDs and current run events for this run\n const seenMessageIds = new Set<string>();\n const currentRunEvents: BaseEvent[] = [];\n store.currentEvents = currentRunEvents;\n\n // Get all previously seen message IDs from historic runs\n const historicMessageIds = new Set<string>();\n for (const run of store.historicRuns) {\n for (const event of run.events) {\n if (\"messageId\" in event && typeof event.messageId === \"string\") {\n historicMessageIds.add(event.messageId);\n }\n if (event.type === EventType.RUN_STARTED) {\n const runStarted = event as RunStartedEvent;\n const messages = runStarted.input?.messages ?? [];\n for (const message of messages) {\n historicMessageIds.add(message.id);\n }\n }\n }\n }\n\n const nextSubject = new ReplaySubject<BaseEvent>(Infinity);\n const prevSubject = store.subject;\n\n // Update the store's subject immediately\n store.subject = nextSubject;\n\n // Create a subject for run() return value\n const runSubject = new ReplaySubject<BaseEvent>(Infinity);\n store.runSubject = runSubject;\n\n // Helper function to run the agent and handle errors\n const runAgent = async () => {\n // Get parent run ID for chaining\n const lastRun = store.historicRuns[store.historicRuns.length - 1];\n const parentRunId = lastRun?.runId ?? null;\n\n try {\n await request.agent.runAgent(request.input, {\n onEvent: ({ event }) => {\n let processedEvent: BaseEvent = event;\n if (event.type === EventType.RUN_STARTED) {\n const runStartedEvent = event as RunStartedEvent;\n if (!runStartedEvent.input) {\n const sanitizedMessages = request.input.messages\n ? request.input.messages.filter(\n (message) => !historicMessageIds.has(message.id),\n )\n : undefined;\n const updatedInput = {\n ...request.input,\n ...(sanitizedMessages !== undefined\n ? { messages: sanitizedMessages }\n : {}),\n };\n processedEvent = {\n ...runStartedEvent,\n input: updatedInput,\n } as RunStartedEvent;\n }\n }\n\n runSubject.next(processedEvent); // For run() return - only agent events\n nextSubject.next(processedEvent); // For connect() / store - all events\n currentRunEvents.push(processedEvent); // Accumulate for storage\n },\n onNewMessage: ({ message }) => {\n // Called for each new message\n if (!seenMessageIds.has(message.id)) {\n seenMessageIds.add(message.id);\n }\n },\n onRunStartedEvent: () => {\n // Mark any messages from the input as seen so they aren't emitted twice\n if (request.input.messages) {\n for (const message of request.input.messages) {\n if (!seenMessageIds.has(message.id)) {\n seenMessageIds.add(message.id);\n }\n }\n }\n },\n });\n\n const appendedEvents = finalizeRunEvents(currentRunEvents, {\n stopRequested: store.stopRequested,\n });\n for (const event of appendedEvents) {\n runSubject.next(event);\n nextSubject.next(event);\n }\n\n // Store the completed run in memory with ONLY its events\n if (store.currentRunId) {\n // Compact the events before storing (like SQLite does)\n const compactedEvents = compactEvents(currentRunEvents);\n\n store.historicRuns.push({\n threadId: request.threadId,\n runId: store.currentRunId,\n parentRunId,\n events: compactedEvents,\n createdAt: Date.now(),\n });\n }\n\n // Complete the run\n store.currentEvents = null;\n store.currentRunId = null;\n store.agent = null;\n store.runSubject = null;\n store.stopRequested = false;\n store.isRunning = false;\n runSubject.complete();\n nextSubject.complete();\n } catch {\n const appendedEvents = finalizeRunEvents(currentRunEvents, {\n stopRequested: store.stopRequested,\n });\n for (const event of appendedEvents) {\n runSubject.next(event);\n nextSubject.next(event);\n }\n\n // Store the run even if it failed (partial events)\n if (store.currentRunId && currentRunEvents.length > 0) {\n // Compact the events before storing (like SQLite does)\n const compactedEvents = compactEvents(currentRunEvents);\n store.historicRuns.push({\n threadId: request.threadId,\n runId: store.currentRunId,\n parentRunId,\n events: compactedEvents,\n createdAt: Date.now(),\n });\n }\n\n // Complete the run\n store.currentEvents = null;\n store.currentRunId = null;\n store.agent = null;\n store.runSubject = null;\n store.stopRequested = false;\n store.isRunning = false;\n runSubject.complete();\n nextSubject.complete();\n }\n };\n\n // Bridge previous events if they exist\n if (prevSubject) {\n prevSubject.subscribe({\n next: (e) => nextSubject.next(e),\n error: (err) => nextSubject.error(err),\n complete: () => {\n // Don't complete nextSubject here - it needs to stay open for new events\n },\n });\n }\n\n // Start the agent execution immediately (not lazily)\n runAgent();\n\n // Return the run subject (only agent events, no injected messages)\n return runSubject.asObservable();\n }\n\n connect(request: AgentRunnerConnectRequest): Observable<BaseEvent> {\n const store = GLOBAL_STORE.get(request.threadId);\n const connectionSubject = new ReplaySubject<BaseEvent>(Infinity);\n\n if (!store) {\n // No store means no events\n connectionSubject.complete();\n return connectionSubject.asObservable();\n }\n\n // Collect all historic events from memory\n const allHistoricEvents: BaseEvent[] = [];\n for (const run of store.historicRuns) {\n allHistoricEvents.push(...run.events);\n }\n\n // Apply compaction to all historic events together (like SQLite)\n const compactedEvents = compactEvents(allHistoricEvents);\n\n // Emit compacted events and track message IDs\n const emittedMessageIds = new Set<string>();\n for (const event of compactedEvents) {\n connectionSubject.next(event);\n if (\"messageId\" in event && typeof event.messageId === \"string\") {\n emittedMessageIds.add(event.messageId);\n }\n }\n\n // Bridge active run to connection if exists\n if (store.subject && (store.isRunning || store.stopRequested)) {\n store.subject.subscribe({\n next: (event) => {\n // Skip message events that we've already emitted from historic\n if (\n \"messageId\" in event &&\n typeof event.messageId === \"string\" &&\n emittedMessageIds.has(event.messageId)\n ) {\n return;\n }\n connectionSubject.next(event);\n },\n complete: () => connectionSubject.complete(),\n error: (err) => connectionSubject.error(err),\n });\n } else {\n // No active run, complete after historic events\n connectionSubject.complete();\n }\n\n return connectionSubject.asObservable();\n }\n\n isRunning(request: AgentRunnerIsRunningRequest): Promise<boolean> {\n const store = GLOBAL_STORE.get(request.threadId);\n return Promise.resolve(store?.isRunning ?? false);\n }\n\n stop(request: AgentRunnerStopRequest): Promise<boolean | undefined> {\n const store = GLOBAL_STORE.get(request.threadId);\n if (!store || !store.isRunning) {\n return Promise.resolve(false);\n }\n if (store.stopRequested) {\n return Promise.resolve(false);\n }\n\n store.stopRequested = true;\n store.isRunning = false;\n\n const agent = store.agent;\n if (!agent) {\n store.stopRequested = false;\n store.isRunning = false;\n return Promise.resolve(false);\n }\n\n try {\n agent.abortRun();\n return Promise.resolve(true);\n } catch (error) {\n console.error(\"Failed to abort agent run\", error);\n store.stopRequested = false;\n store.isRunning = true;\n return Promise.resolve(false);\n }\n }\n}\n","{\n \"name\": \"@copilotkitnext/runtime\",\n \"version\": \"0.0.22-alpha.8\",\n \"description\": \"Server-side runtime package for CopilotKit2\",\n \"main\": \"dist/index.js\",\n \"types\": \"dist/index.d.ts\",\n \"exports\": {\n \".\": {\n \"types\": \"./dist/index.d.ts\",\n \"import\": \"./dist/index.mjs\",\n \"require\": \"./dist/index.js\"\n },\n \"./express\": {\n \"types\": \"./dist/express.d.ts\",\n \"import\": \"./dist/express.mjs\",\n \"require\": \"./dist/express.js\"\n }\n },\n \"publishConfig\": {\n \"access\": \"public\"\n },\n \"scripts\": {\n \"build\": \"tsup\",\n \"prepublishOnly\": \"pnpm run build\",\n \"dev\": \"tsup --watch\",\n \"lint\": \"eslint . --max-warnings 0\",\n \"check-types\": \"tsc --noEmit\",\n \"clean\": \"rm -rf dist\",\n \"test\": \"vitest run\",\n \"test:watch\": \"vitest\",\n \"test:coverage\": \"vitest run --coverage\"\n },\n \"devDependencies\": {\n \"@copilotkitnext/eslint-config\": \"workspace:*\",\n \"@copilotkitnext/typescript-config\": \"workspace:*\",\n \"@types/cors\": \"^2.8.17\",\n \"@types/express\": \"^4.17.21\",\n \"@types/node\": \"^22.15.3\",\n \"eslint\": \"^9.30.0\",\n \"openai\": \"^5.9.0\",\n \"supertest\": \"^7.1.1\",\n \"tsup\": \"^8.5.0\",\n \"typescript\": \"5.8.2\",\n \"vitest\": \"^3.0.5\"\n },\n \"dependencies\": {\n \"@ag-ui/client\": \"0.0.41-alpha.0\",\n \"@ag-ui/core\": \"0.0.41-alpha.0\",\n \"@ag-ui/encoder\": \"0.0.41-alpha.0\",\n \"@copilotkitnext/shared\": \"workspace:*\",\n \"cors\": \"^2.8.5\",\n \"rxjs\": \"7.8.1\"\n },\n \"peerDependencies\": {\n \"express\": \"^4.21.2\",\n \"hono\": \"^4.6.13\",\n \"openai\": \"^5.9.0\"\n },\n \"peerDependenciesMeta\": {\n \"express\": { \"optional\": true }\n },\n \"engines\": {\n \"node\": \">=18\"\n }\n}\n","import { MaybePromise, NonEmptyRecord } from \"@copilotkitnext/shared\";\nimport { AbstractAgent } from \"@ag-ui/client\";\nimport pkg from \"../package.json\";\nimport type {\n BeforeRequestMiddleware,\n AfterRequestMiddleware,\n} from \"./middleware\";\nimport { TranscriptionService } from \"./transcription-service/transcription-service\";\nimport { AgentRunner } from \"./runner/agent-runner\";\nimport { InMemoryAgentRunner } from \"./runner/in-memory\";\n\nexport const VERSION = pkg.version;\n\n/**\n * Options used to construct a `CopilotRuntime` instance.\n */\nexport interface CopilotRuntimeOptions {\n /** Map of available agents (loaded lazily is fine). */\n agents: MaybePromise<NonEmptyRecord<Record<string, AbstractAgent>>>;\n /** The runner to use for running agents. */\n runner?: AgentRunner;\n /** Optional transcription service for audio processing. */\n transcriptionService?: TranscriptionService;\n /** Optional *before* middleware – callback function or webhook URL. */\n beforeRequestMiddleware?: BeforeRequestMiddleware;\n /** Optional *after* middleware – callback function or webhook URL. */\n afterRequestMiddleware?: AfterRequestMiddleware;\n}\n\n/**\n * Central runtime object passed to all request handlers.\n */\nexport class CopilotRuntime {\n public agents: CopilotRuntimeOptions[\"agents\"];\n public transcriptionService: CopilotRuntimeOptions[\"transcriptionService\"];\n public beforeRequestMiddleware: CopilotRuntimeOptions[\"beforeRequestMiddleware\"];\n public afterRequestMiddleware: CopilotRuntimeOptions[\"afterRequestMiddleware\"];\n public runner: AgentRunner;\n\n constructor({\n agents,\n transcriptionService,\n beforeRequestMiddleware,\n afterRequestMiddleware,\n runner,\n }: CopilotRuntimeOptions) {\n this.agents = agents;\n this.transcriptionService = transcriptionService;\n this.beforeRequestMiddleware = beforeRequestMiddleware;\n this.afterRequestMiddleware = afterRequestMiddleware;\n this.runner = runner ?? new InMemoryAgentRunner();\n }\n}\n","import {\n AbstractAgent,\n HttpAgent,\n RunAgentInput,\n RunAgentInputSchema,\n} from \"@ag-ui/client\";\nimport { EventEncoder } from \"@ag-ui/encoder\";\nimport { CopilotRuntime } from \"../runtime\";\n\ninterface RunAgentParameters {\n request: Request;\n runtime: CopilotRuntime;\n agentId: string;\n}\n\nexport async function handleRunAgent({\n runtime,\n request,\n agentId,\n}: RunAgentParameters) {\n try {\n const agents = await runtime.agents;\n\n // Check if the requested agent exists\n if (!agents[agentId]) {\n return new Response(\n JSON.stringify({\n error: \"Agent not found\",\n message: `Agent '${agentId}' does not exist`,\n }),\n {\n status: 404,\n headers: { \"Content-Type\": \"application/json\" },\n }\n );\n }\n\n const registeredAgent = agents[agentId] as AbstractAgent;\n const agent = registeredAgent.clone() as AbstractAgent;\n\n if (agent && \"headers\" in agent) {\n const shouldForward = (headerName: string) => {\n const lower = headerName.toLowerCase();\n return lower === \"authorization\" || lower.startsWith(\"x-\");\n };\n\n const forwardableHeaders: Record<string, string> = {};\n request.headers.forEach((value, key) => {\n if (shouldForward(key)) {\n forwardableHeaders[key] = value;\n }\n });\n\n agent.headers = { \n ...agent.headers as Record<string, string>, \n ...forwardableHeaders \n };\n }\n\n const stream = new TransformStream();\n const writer = stream.writable.getWriter();\n const encoder = new EventEncoder();\n let streamClosed = false;\n\n // Process the request in the background\n (async () => {\n let input: RunAgentInput;\n try {\n const requestBody = await request.json();\n input = RunAgentInputSchema.parse(requestBody);\n } catch {\n return new Response(\n JSON.stringify({\n error: \"Invalid request body\",\n }),\n { status: 400 }\n );\n }\n\n agent.setMessages(input.messages);\n agent.setState(input.state);\n agent.threadId = input.threadId;\n\n runtime.runner\n .run({\n threadId: input.threadId,\n agent,\n input,\n })\n .subscribe({\n next: async (event) => {\n if (!request.signal.aborted && !streamClosed) {\n try {\n await writer.write(encoder.encode(event));\n } catch (error) {\n if (error instanceof Error && error.name === 'AbortError') {\n streamClosed = true;\n }\n }\n }\n },\n error: async (error) => {\n console.error(\"Error running agent:\", error);\n if (!streamClosed) {\n try {\n await writer.close();\n streamClosed = true;\n } catch {\n // Stream already closed\n }\n }\n },\n complete: async () => {\n if (!streamClosed) {\n try {\n await writer.close();\n streamClosed = true;\n } catch {\n // Stream already closed\n }\n }\n },\n });\n })().catch((error) => {\n console.error(\"Error running agent:\", error);\n console.error(\n \"Error stack:\",\n error instanceof Error ? error.stack : \"No stack trace\"\n );\n console.error(\"Error details:\", {\n name: error instanceof Error ? error.name : \"Unknown\",\n message: error instanceof Error ? error.message : String(error),\n cause: error instanceof Error ? error.cause : undefined,\n });\n if (!streamClosed) {\n try {\n writer.close();\n streamClosed = true;\n } catch {\n // Stream already closed\n }\n }\n });\n\n // Return the SSE response\n return new Response(stream.readable, {\n status: 200,\n headers: {\n \"Content-Type\": \"text/event-stream\",\n \"Cache-Control\": \"no-cache\",\n Connection: \"keep-alive\",\n },\n });\n } catch (error) {\n console.error(\"Error running agent:\", error);\n console.error(\n \"Error stack:\",\n error instanceof Error ? error.stack : \"No stack trace\"\n );\n console.error(\"Error details:\", {\n name: error instanceof Error ? error.name : \"Unknown\",\n message: error instanceof Error ? error.message : String(error),\n cause: error instanceof Error ? error.cause : undefined,\n });\n\n return new Response(\n JSON.stringify({\n error: \"Failed to run agent\",\n message: error instanceof Error ? error.message : \"Unknown error\",\n }),\n {\n status: 500,\n headers: { \"Content-Type\": \"application/json\" },\n }\n );\n }\n}\n","import { RunAgentInput, RunAgentInputSchema } from \"@ag-ui/client\";\nimport { EventEncoder } from \"@ag-ui/encoder\";\nimport { CopilotRuntime } from \"../runtime\";\n\ninterface ConnectAgentParameters {\n request: Request;\n runtime: CopilotRuntime;\n agentId: string;\n}\n\nexport async function handleConnectAgent({\n runtime,\n request,\n agentId,\n}: ConnectAgentParameters) {\n try {\n const agents = await runtime.agents;\n\n // Check if the requested agent exists\n if (!agents[agentId]) {\n return new Response(\n JSON.stringify({\n error: \"Agent not found\",\n message: `Agent '${agentId}' does not exist`,\n }),\n {\n status: 404,\n headers: { \"Content-Type\": \"application/json\" },\n }\n );\n }\n\n const stream = new TransformStream();\n const writer = stream.writable.getWriter();\n const encoder = new EventEncoder();\n let streamClosed = false;\n\n // Process the request in the background\n (async () => {\n let input: RunAgentInput;\n try {\n const requestBody = await request.json();\n input = RunAgentInputSchema.parse(requestBody);\n } catch {\n return new Response(\n JSON.stringify({\n error: \"Invalid request body\",\n }),\n { status: 400 }\n );\n }\n\n runtime.runner\n .connect({\n threadId: input.threadId,\n })\n .subscribe({\n next: async (event) => {\n if (!request.signal.aborted && !streamClosed) {\n try {\n await writer.write(encoder.encode(event));\n } catch (error) {\n if (error instanceof Error && error.name === \"AbortError\") {\n streamClosed = true;\n }\n }\n }\n },\n error: async (error) => {\n console.error(\"Error running agent:\", error);\n if (!streamClosed) {\n try {\n await writer.close();\n streamClosed = true;\n } catch {\n // Stream already closed\n }\n }\n },\n complete: async () => {\n if (!streamClosed) {\n try {\n await writer.close();\n streamClosed = true;\n } catch {\n // Stream already closed\n }\n }\n },\n });\n })().catch((error) => {\n console.error(\"Error running agent:\", error);\n console.error(\n \"Error stack:\",\n error instanceof Error ? error.stack : \"No stack trace\"\n );\n console.error(\"Error details:\", {\n name: error instanceof Error ? error.name : \"Unknown\",\n message: error instanceof Error ? error.message : String(error),\n cause: error instanceof Error ? error.cause : undefined,\n });\n if (!streamClosed) {\n try {\n writer.close();\n streamClosed = true;\n } catch {\n // Stream already closed\n }\n }\n });\n\n // Return the SSE response\n return new Response(stream.readable, {\n status: 200,\n headers: {\n \"Content-Type\": \"text/event-stream\",\n \"Cache-Control\": \"no-cache\",\n Connection: \"keep-alive\",\n },\n });\n } catch (error) {\n console.error(\"Error running agent:\", error);\n console.error(\n \"Error stack:\",\n error instanceof Error ? error.stack : \"No stack trace\"\n );\n console.error(\"Error details:\", {\n name: error instanceof Error ? error.name : \"Unknown\",\n message: error instanceof Error ? error.message : String(error),\n cause: error instanceof Error ? error.cause : undefined,\n });\n\n return new Response(\n JSON.stringify({\n error: \"Failed to run agent\",\n message: error instanceof Error ? error.message : \"Unknown error\",\n }),\n {\n status: 500,\n headers: { \"Content-Type\": \"application/json\" },\n }\n );\n }\n}\n","import { CopilotRuntime } from \"../runtime\";\nimport { EventType } from \"@ag-ui/client\";\n\ninterface StopAgentParameters {\n request: Request;\n runtime: CopilotRuntime;\n agentId: string;\n threadId: string;\n}\n\nexport async function handleStopAgent({\n runtime,\n request,\n agentId,\n threadId,\n}: StopAgentParameters) {\n try {\n const agents = await runtime.agents;\n\n if (!agents[agentId]) {\n return new Response(\n JSON.stringify({\n error: \"Agent not found\",\n message: `Agent '${agentId}' does not exist`,\n }),\n {\n status: 404,\n headers: { \"Content-Type\": \"application/json\" },\n }\n );\n }\n\n const stopped = await runtime.runner.stop({ threadId });\n\n if (!stopped) {\n return new Response(\n JSON.stringify({\n stopped: false,\n message: `No active run for thread '${threadId}'.`,\n }),\n {\n status: 200,\n headers: { \"Content-Type\": \"application/json\" },\n }\n );\n }\n\n return new Response(\n JSON.stringify({\n stopped: true,\n interrupt: {\n type: EventType.RUN_ERROR,\n message: \"Run stopped by user\",\n code: \"STOPPED\",\n },\n }),\n {\n status: 200,\n headers: { \"Content-Type\": \"application/json\" },\n }\n );\n } catch (error) {\n console.error(\"Error stopping agent run:\", error);\n\n return new Response(\n JSON.stringify({\n error: \"Failed to stop agent\",\n message: error instanceof Error ? error.message : \"Unknown error\",\n }),\n {\n status: 500,\n headers: { \"Content-Type\": \"application/json\" },\n }\n );\n }\n}\n","import { CopilotRuntime } from \"../runtime\";\nimport { AgentDescription, RuntimeInfo } from \"@copilotkitnext/shared\";\nimport { VERSION } from \"../runtime\";\n\ninterface HandleGetRuntimeInfoParameters {\n runtime: CopilotRuntime;\n request: Request;\n}\n\nexport async function handleGetRuntimeInfo({\n runtime,\n}: HandleGetRuntimeInfoParameters) {\n try {\n const agents = await runtime.agents;\n\n const agentsDict = Object.entries(agents).reduce(\n (acc, [name, agent]) => {\n acc[name] = {\n name,\n description: agent.description,\n className: agent.constructor.name,\n };\n return acc;\n },\n {} as Record<string, AgentDescription>\n );\n\n const runtimeInfo: RuntimeInfo = {\n version: VERSION,\n agents: agentsDict,\n audioFileTranscriptionEnabled: !!runtime.transcriptionService,\n };\n\n return new Response(JSON.stringify(runtimeInfo), {\n status: 200,\n headers: { \"Content-Type\": \"application/json\" },\n });\n } catch (error) {\n return new Response(\n JSON.stringify({\n error: \"Failed to retrieve runtime information\",\n message: error instanceof Error ? error.message : \"Unknown error\",\n }),\n {\n status: 500,\n headers: { \"Content-Type\": \"application/json\" },\n }\n );\n }\n}\n","import { CopilotRuntime } from \"../runtime\";\n\ninterface HandleTranscribeParameters {\n runtime: CopilotRuntime;\n request: Request;\n}\n\nexport async function handleTranscribe({\n runtime,\n request,\n}: HandleTranscribeParameters) {\n try {\n // Check if transcription service is configured\n if (!runtime.transcriptionService) {\n return new Response(\n JSON.stringify({\n error: \"Transcription service not configured\",\n message:\n \"No transcription service has been configured in the runtime\",\n }),\n {\n status: 503,\n headers: { \"Content-Type\": \"application/json\" },\n }\n );\n }\n\n // Check if request has form data\n const contentType = request.headers.get(\"content-type\");\n if (!contentType || !contentType.includes(\"multipart/form-data\")) {\n return new Response(\n JSON.stringify({\n error: \"Invalid content type\",\n message:\n \"Request must contain multipart/form-data with an audio file\",\n }),\n {\n status: 400,\n headers: { \"Content-Type\": \"application/json\" },\n }\n );\n }\n\n // Extract form data\n const formData = await request.formData();\n const audioFile = formData.get(\"audio\") as File | null;\n\n if (!audioFile || !(audioFile instanceof File)) {\n return new Response(\n JSON.stringify({\n error: \"Missing audio file\",\n message:\n \"No audio file found in form data. Please include an 'audio' field.\",\n }),\n {\n status: 400,\n headers: { \"Content-Type\": \"application/json\" },\n }\n );\n }\n\n // Validate file type (basic check)\n const validAudioTypes = [\n \"audio/mpeg\",\n \"audio/mp3\",\n \"audio/mp4\",\n \"audio/wav\",\n \"audio/webm\",\n \"audio/ogg\",\n \"audio/flac\",\n \"audio/aac\",\n ];\n\n // Allow empty types and application/octet-stream (common fallback for unknown types)\n const isValidType =\n validAudioTypes.includes(audioFile.type) ||\n audioFile.type === \"\" ||\n audioFile.type === \"application/octet-stream\";\n\n if (!isValidType) {\n return new Response(\n JSON.stringify({\n error: \"Invalid file type\",\n message: `Unsupported audio file type: ${audioFile.type}. Supported types: ${validAudioTypes.join(\", \")}, or files with unknown/empty types`,\n }),\n {\n status: 400,\n headers: { \"Content-Type\": \"application/json\" },\n }\n );\n }\n\n // Transcribe the audio file with options\n const transcription = await runtime.transcriptionService.transcribeFile({\n audioFile,\n mimeType: audioFile.type,\n size: audioFile.size,\n });\n\n return new Response(\n JSON.stringify({\n text: transcription,\n size: audioFile.size,\n type: audioFile.type,\n }),\n {\n status: 200,\n headers: { \"Content-Type\": \"application/json\" },\n }\n );\n } catch (error) {\n return new Response(\n JSON.stringify({\n error: \"Transcription failed\",\n message:\n error instanceof Error\n ? error.message\n : \"Unknown error occurred during transcription\",\n }),\n {\n status: 500,\n headers: { \"Content-Type\": \"application/json\" },\n }\n );\n }\n}\n","/**\n * Middleware support for CopilotKit Runtime.\n *\n * A middleware hook can be provided as either:\n * 1. A **callback function** executed in-process.\n * 2. A **webhook URL** (http/https). The runtime will `POST` a JSON payload\n * to the URL and, for *before* hooks, accept an optional modified\n * `Request` object in the response body.\n *\n * Two lifecycle hooks are available:\n * • `BEFORE_REQUEST` – runs *before* the request handler.\n * • `AFTER_REQUEST` – runs *after* the handler returns a `Response`.\n */\n\nimport type { CopilotRuntime } from \"./runtime\";\nimport type { MaybePromise } from \"@copilotkitnext/shared\";\nimport { logger } from \"@copilotkitnext/shared\";\n\n/* ------------------------------------------------------------------------------------------------\n * Public types\n * --------------------------------------------------------------------------------------------- */\n\nexport interface BeforeRequestMiddlewareParameters {\n runtime: CopilotRuntime;\n request: Request;\n path: string;\n}\nexport interface AfterRequestMiddlewareParameters {\n runtime: CopilotRuntime;\n response: Response;\n path: string;\n}\n\nexport type BeforeRequestMiddlewareFn = (\n params: BeforeRequestMiddlewareParameters\n) => MaybePromise<Request | void>;\nexport type AfterRequestMiddlewareFn = (\n params: AfterRequestMiddlewareParameters\n) => MaybePromise<void>;\n\n/**\n * A middleware value can be either a callback function or a webhook URL.\n */\nexport type BeforeRequestMiddleware = BeforeRequestMiddlewareFn;\nexport type AfterRequestMiddleware = AfterRequestMiddlewareFn;\n\n/** Lifecycle events emitted to webhook middleware. */\nexport enum CopilotKitMiddlewareEvent {\n BeforeRequest = \"BEFORE_REQUEST\",\n AfterRequest = \"AFTER_REQUEST\",\n}\n\n/** Stages used by the Middleware Webhook Protocol */\n/** Stages used by the CopilotKit webhook protocol */\nexport enum WebhookStage {\n BeforeRequest = \"before_request\",\n AfterRequest = \"after_request\",\n}\n\n/* ------------------------------------------------------------------------------------------------\n * Internal helpers – (de)serialisation\n * --------------------------------------------------------------------------------------------- */\n\nexport async function callBeforeRequestMiddleware({\n runtime,\n request,\n path,\n}: BeforeRequestMiddlewareParameters): Promise<Request | void> {\n const mw = runtime.beforeRequestMiddleware;\n if (!mw) return;\n\n // Function-based middleware (in-process)\n if (typeof mw === \"function\") {\n return (mw as BeforeRequestMiddlewareFn)({ runtime, request, path });\n }\n\n logger.warn({ mw }, \"Unsupported beforeRequestMiddleware value – skipped\");\n return;\n}\n\nexport async function callAfterRequestMiddleware({\n runtime,\n response,\n path,\n}: AfterRequestMiddlewareParameters): Promise<void> {\n const mw = runtime.afterRequestMiddleware;\n if (!mw) return;\n\n if (typeof mw === \"function\") {\n return (mw as AfterRequestMiddlewareFn)({ runtime, response, path });\n }\n\n logger.warn({ mw }, \"Unsupported afterRequestMiddleware value – skipped\");\n}\n","const METHOD_NAMES = [\n \"agent/run\",\n \"agent/connect\",\n \"agent/stop\",\n \"info\",\n \"transcribe\",\n] as const;\n\nexport type EndpointMethod = (typeof METHOD_NAMES)[number];\n\ninterface JsonEnvelope {\n method?: string;\n params?: Record<string, unknown>;\n body?: unknown;\n}\n\nexport interface MethodCall {\n method: EndpointMethod;\n params?: Record<string, unknown>;\n body?: unknown;\n}\n\nexport async function parseMethodCall(request: Request): Promise<MethodCall> {\n const contentType = request.headers.get(\"content-type\") || \"\";\n\n if (!contentType.includes(\"application/json\")) {\n throw createResponseError(\"Single-route endpoint expects JSON payloads\", 415);\n }\n\n let jsonEnvelope: JsonEnvelope;\n try {\n jsonEnvelope = (await request.clone().json()) as JsonEnvelope;\n } catch (error) {\n throw createResponseError(\"Invalid JSON payload\", 400);\n }\n\n const method = validateMethod(jsonEnvelope.method);\n\n return {\n method,\n params: jsonEnvelope.params,\n body: jsonEnvelope.body,\n };\n}\n\nexport function expectString(params: Record<string, unknown> | undefined, key: string): string {\n const value = params?.[key];\n if (typeof value === \"string\" && value.trim().length > 0) {\n return value;\n }\n\n throw createResponseError(`Missing or invalid parameter '${key}'`, 400);\n}\n\nexport function createJsonRequest(base: Request, body: unknown): Request {\n if (body === undefined || body === null) {\n throw createResponseError(\"Missing request body for JSON handler\", 400);\n }\n\n const headers = new Headers(base.headers);\n headers.set(\"content-type\", \"application/json\");\n headers.delete(\"content-length\");\n\n const serializedBody = serializeJsonBody(body);\n\n return new Request(base.url, {\n method: \"POST\",\n headers,\n body: serializedBody,\n signal: base.signal,\n });\n}\n\nexport function createResponseError(message: string, status: number): Response {\n return new Response(\n JSON.stringify({\n error: \"invalid_request\",\n message,\n }),\n {\n status,\n headers: {\n \"Content-Type\": \"application/json\",\n },\n },\n );\n}\n\nfunction validateMethod(method: string | undefined): EndpointMethod {\n if (!method) {\n throw createResponseError(\"Missing method field\", 400);\n }\n\n if ((METHOD_NAMES as readonly string[]).includes(method)) {\n return method as EndpointMethod;\n }\n\n throw createResponseError(`Unsupported method '${method}'`, 400);\n}\n\nfunction serializeJsonBody(body: unknown): BodyInit {\n if (typeof body === \"string\") {\n return body;\n }\n\n if (body instanceof Blob || body instanceof ArrayBuffer || body instanceof Uint8Array) {\n return body;\n }\n\n if (body instanceof FormData || body instanceof URLSearchParams) {\n return body;\n }\n\n return JSON.stringify(body);\n}\n"]}
|