@kb-labs/agent-cli 0.5.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 +56 -0
- package/dist/cli/commands/diff.d.ts +17 -0
- package/dist/cli/commands/diff.js +182 -0
- package/dist/cli/commands/diff.js.map +1 -0
- package/dist/cli/commands/history.d.ts +16 -0
- package/dist/cli/commands/history.js +216 -0
- package/dist/cli/commands/history.js.map +1 -0
- package/dist/cli/commands/quality-report.d.ts +21 -0
- package/dist/cli/commands/quality-report.js +457 -0
- package/dist/cli/commands/quality-report.js.map +1 -0
- package/dist/cli/commands/rollback.d.ts +27 -0
- package/dist/cli/commands/rollback.js +109 -0
- package/dist/cli/commands/rollback.js.map +1 -0
- package/dist/cli/commands/run.d.ts +42 -0
- package/dist/cli/commands/run.js +923 -0
- package/dist/cli/commands/run.js.map +1 -0
- package/dist/cli/commands/trace-context.d.ts +22 -0
- package/dist/cli/commands/trace-context.js +131 -0
- package/dist/cli/commands/trace-context.js.map +1 -0
- package/dist/cli/commands/trace-diagnose.d.ts +20 -0
- package/dist/cli/commands/trace-diagnose.js +434 -0
- package/dist/cli/commands/trace-diagnose.js.map +1 -0
- package/dist/cli/commands/trace-event-normalizer.d.ts +13 -0
- package/dist/cli/commands/trace-event-normalizer.js +39 -0
- package/dist/cli/commands/trace-event-normalizer.js.map +1 -0
- package/dist/cli/commands/trace-filter.d.ts +19 -0
- package/dist/cli/commands/trace-filter.js +153 -0
- package/dist/cli/commands/trace-filter.js.map +1 -0
- package/dist/cli/commands/trace-iteration.d.ts +18 -0
- package/dist/cli/commands/trace-iteration.js +192 -0
- package/dist/cli/commands/trace-iteration.js.map +1 -0
- package/dist/cli/commands/trace-stats.d.ts +17 -0
- package/dist/cli/commands/trace-stats.js +247 -0
- package/dist/cli/commands/trace-stats.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.js +473 -0
- package/dist/index.js.map +1 -0
- package/dist/manifest.d.ts +184 -0
- package/dist/manifest.js +473 -0
- package/dist/manifest.js.map +1 -0
- package/dist/rest/handlers/approve-handler.d.ts +15 -0
- package/dist/rest/handlers/approve-handler.js +60 -0
- package/dist/rest/handlers/approve-handler.js.map +1 -0
- package/dist/rest/handlers/approve-session-plan-handler.d.ts +10 -0
- package/dist/rest/handlers/approve-session-plan-handler.js +52 -0
- package/dist/rest/handlers/approve-session-plan-handler.js.map +1 -0
- package/dist/rest/handlers/correct-handler.d.ts +7 -0
- package/dist/rest/handlers/correct-handler.js +326 -0
- package/dist/rest/handlers/correct-handler.js.map +1 -0
- package/dist/rest/handlers/create-session-handler.d.ts +7 -0
- package/dist/rest/handlers/create-session-handler.js +25 -0
- package/dist/rest/handlers/create-session-handler.js.map +1 -0
- package/dist/rest/handlers/execute-session-plan-handler.d.ts +10 -0
- package/dist/rest/handlers/execute-session-plan-handler.js +635 -0
- package/dist/rest/handlers/execute-session-plan-handler.js.map +1 -0
- package/dist/rest/handlers/generate-spec-handler.d.ts +10 -0
- package/dist/rest/handlers/generate-spec-handler.js +389 -0
- package/dist/rest/handlers/generate-spec-handler.js.map +1 -0
- package/dist/rest/handlers/get-file-diff-handler.d.ts +24 -0
- package/dist/rest/handlers/get-file-diff-handler.js +44 -0
- package/dist/rest/handlers/get-file-diff-handler.js.map +1 -0
- package/dist/rest/handlers/get-session-handler.d.ts +10 -0
- package/dist/rest/handlers/get-session-handler.js +23 -0
- package/dist/rest/handlers/get-session-handler.js.map +1 -0
- package/dist/rest/handlers/get-session-plan-handler.d.ts +10 -0
- package/dist/rest/handlers/get-session-plan-handler.js +53 -0
- package/dist/rest/handlers/get-session-plan-handler.js.map +1 -0
- package/dist/rest/handlers/get-session-turns-handler.d.ts +16 -0
- package/dist/rest/handlers/get-session-turns-handler.js +35 -0
- package/dist/rest/handlers/get-session-turns-handler.js.map +1 -0
- package/dist/rest/handlers/get-spec-handler.d.ts +10 -0
- package/dist/rest/handlers/get-spec-handler.js +39 -0
- package/dist/rest/handlers/get-spec-handler.js.map +1 -0
- package/dist/rest/handlers/list-file-changes-handler.d.ts +13 -0
- package/dist/rest/handlers/list-file-changes-handler.js +34 -0
- package/dist/rest/handlers/list-file-changes-handler.js.map +1 -0
- package/dist/rest/handlers/list-sessions-handler.d.ts +7 -0
- package/dist/rest/handlers/list-sessions-handler.js +23 -0
- package/dist/rest/handlers/list-sessions-handler.js.map +1 -0
- package/dist/rest/handlers/rollback-handler.d.ts +22 -0
- package/dist/rest/handlers/rollback-handler.js +91 -0
- package/dist/rest/handlers/rollback-handler.js.map +1 -0
- package/dist/rest/handlers/run-handler.d.ts +7 -0
- package/dist/rest/handlers/run-handler.js +516 -0
- package/dist/rest/handlers/run-handler.js.map +1 -0
- package/dist/rest/handlers/sessions-handler.d.ts +18 -0
- package/dist/rest/handlers/sessions-handler.js +56 -0
- package/dist/rest/handlers/sessions-handler.js.map +1 -0
- package/dist/rest/handlers/status-handler.d.ts +7 -0
- package/dist/rest/handlers/status-handler.js +313 -0
- package/dist/rest/handlers/status-handler.js.map +1 -0
- package/dist/rest/handlers/stop-handler.d.ts +7 -0
- package/dist/rest/handlers/stop-handler.js +317 -0
- package/dist/rest/handlers/stop-handler.js.map +1 -0
- package/dist/widgets/220.js +446 -0
- package/dist/widgets/220.js.map +1 -0
- package/dist/widgets/331.js +2 -0
- package/dist/widgets/331.js.map +1 -0
- package/dist/widgets/403.js +2 -0
- package/dist/widgets/403.js.map +1 -0
- package/dist/widgets/406.js +35 -0
- package/dist/widgets/406.js.map +1 -0
- package/dist/widgets/455.js +2 -0
- package/dist/widgets/455.js.map +1 -0
- package/dist/widgets/482.js +2 -0
- package/dist/widgets/482.js.map +1 -0
- package/dist/widgets/485.js +2 -0
- package/dist/widgets/485.js.map +1 -0
- package/dist/widgets/527.js +2 -0
- package/dist/widgets/527.js.map +1 -0
- package/dist/widgets/628.js +2 -0
- package/dist/widgets/628.js.map +1 -0
- package/dist/widgets/694.js +2 -0
- package/dist/widgets/694.js.map +1 -0
- package/dist/widgets/712.js +2 -0
- package/dist/widgets/712.js.map +1 -0
- package/dist/widgets/866.js +2 -0
- package/dist/widgets/866.js.map +1 -0
- package/dist/widgets/915.js +39 -0
- package/dist/widgets/915.js.map +1 -0
- package/dist/widgets/957.js +10 -0
- package/dist/widgets/957.js.map +1 -0
- package/dist/widgets/983.js +2 -0
- package/dist/widgets/983.js.map +1 -0
- package/dist/widgets/@mf-types.d.ts +3 -0
- package/dist/widgets/@mf-types.zip +0 -0
- package/dist/widgets/__federation_expose_AgentsPage.js +2 -0
- package/dist/widgets/__federation_expose_AgentsPage.js.map +1 -0
- package/dist/widgets/mf-manifest.json +260 -0
- package/dist/widgets/mf-stats.json +305 -0
- package/dist/widgets/remoteEntry.js +7 -0
- package/dist/widgets/remoteEntry.js.map +1 -0
- package/dist/ws/session-stream-handler.d.ts +8 -0
- package/dist/ws/session-stream-handler.js +409 -0
- package/dist/ws/session-stream-handler.js.map +1 -0
- package/package.json +83 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/rest/run-manager.ts","../../../src/rest/handlers/run-handler.ts","../../../src/rest/handlers/execute-session-plan-handler.ts"],"names":["run","useCache","fs","defineHandler","SessionManager"],"mappings":"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","file":"execute-session-plan-handler.js","sourcesContent":["/**\n * Run Manager - tracks active agent runs for REST/WS API\n *\n * Uses platform cache for persistence and in-memory Map for active agents.\n * Cache stores serializable run state, Map stores live agent references.\n * Uses platform eventBus for cross-process event broadcasting.\n */\n\nimport type { IAgentRunner } from '@kb-labs/agent-sdk';\nimport type { SessionManager } from '@kb-labs/agent-core';\nimport type { AgentEvent, AgentEventCallback } from '@kb-labs/agent-contracts';\nimport { useCache, usePlatform } from '@kb-labs/sdk';\n\nconst CACHE_PREFIX = 'agent:run:';\nconst EVENT_TOPIC_PREFIX = 'agent:events:';\nconst CACHE_TTL = 3600000; // 1 hour\n\n/**\n * Run status\n */\nexport type RunStatus = 'pending' | 'running' | 'completed' | 'failed' | 'stopped';\n\n/**\n * Serializable run state (stored in cache)\n */\nexport interface RunState {\n runId: string;\n task: string;\n status: RunStatus;\n startedAt: string;\n completedAt?: string;\n durationMs?: number;\n summary?: string;\n error?: string;\n}\n\n/**\n * Active run with live agent (in-memory only)\n */\nexport interface ActiveRun extends RunState {\n agent?: IAgentRunner;\n sessionManager: SessionManager;\n listeners: Set<AgentEventCallback>;\n /** Monotonic sequence counter for event ordering */\n lastSeq: number;\n /** Replay buffer: all events emitted since run start (for late WS connections) */\n eventBuffer: AgentEvent[];\n}\n\n/**\n * Run Manager implementation\n */\nclass RunManagerImpl {\n /** Live agents and listeners (not cacheable) */\n private activeRuns: Map<string, ActiveRun> = new Map();\n\n /** Session-level listeners: sessionId → Set<callback> — receive events from ALL runs in session */\n private sessionListeners: Map<string, Set<AgentEventCallback>> = new Map();\n\n /** sessionId per runId — set when run is registered */\n private runSessionMap: Map<string, string> = new Map();\n\n /**\n * Generate unique run ID\n */\n generateRunId(): string {\n return `run-${Date.now()}-${Math.random().toString(36).slice(2, 7)}`;\n }\n\n /**\n * Register a new run\n */\n async register(\n runId: string,\n task: string,\n agent: IAgentRunner | undefined,\n sessionManager: SessionManager,\n sessionId?: string\n ): Promise<ActiveRun> {\n const now = new Date().toISOString();\n\n const run: ActiveRun = {\n runId,\n task,\n status: 'pending',\n agent,\n sessionManager,\n startedAt: now,\n listeners: new Set(),\n lastSeq: 0,\n eventBuffer: [],\n };\n\n // Store in memory (for live agent)\n this.activeRuns.set(runId, run);\n\n // Track sessionId → runId mapping for session-level listeners\n if (sessionId) {\n this.runSessionMap.set(runId, sessionId);\n }\n\n // Store serializable state in cache\n await this.saveToCache(run);\n\n return run;\n }\n\n /**\n * Get run by ID (from memory first, then cache for state)\n */\n get(runId: string): ActiveRun | undefined {\n return this.activeRuns.get(runId);\n }\n\n /**\n * Check if run exists (in memory or cache)\n */\n async exists(runId: string): Promise<boolean> {\n // Check memory first\n if (this.activeRuns.has(runId)) {\n return true;\n }\n // Fallback to cache\n const state = await this.getState(runId);\n return state !== null;\n }\n\n /**\n * Get run state from cache (for completed runs or cross-process access)\n */\n async getState(runId: string): Promise<RunState | null> {\n const cache = useCache();\n if (!cache) {return null;}\n\n return cache.get<RunState>(`${CACHE_PREFIX}${runId}`);\n }\n\n /**\n * Update run status\n */\n async updateStatus(runId: string, status: RunStatus, extra?: Partial<RunState>): Promise<void> {\n const run = this.activeRuns.get(runId);\n if (run) {\n run.status = status;\n if (extra) {\n Object.assign(run, extra);\n }\n await this.saveToCache(run);\n }\n }\n\n /**\n * Save run state to cache\n */\n private async saveToCache(run: ActiveRun): Promise<void> {\n const cache = useCache();\n if (!cache) {return;}\n\n const state: RunState = {\n runId: run.runId,\n task: run.task,\n status: run.status,\n startedAt: run.startedAt,\n completedAt: run.completedAt,\n durationMs: run.durationMs,\n summary: run.summary,\n error: run.error,\n };\n\n await cache.set(`${CACHE_PREFIX}${run.runId}`, state, CACHE_TTL);\n }\n\n /** Track subscriptions for cleanup */\n private subscriptions: Map<string, Map<AgentEventCallback, () => void>> = new Map();\n\n /**\n * Add event listener to run (uses eventBus for cross-process)\n */\n addListener(runId: string, callback: AgentEventCallback): boolean {\n const platform = usePlatform();\n if (!platform?.eventBus) {\n // Fallback to in-memory only\n const run = this.activeRuns.get(runId);\n if (run) {\n run.listeners.add(callback);\n return true;\n }\n return false;\n }\n\n // Subscribe to eventBus topic for this run\n const topic = `${EVENT_TOPIC_PREFIX}${runId}`;\n const unsubscribe = platform.eventBus.subscribe<AgentEvent>(topic, async (event) => {\n try {\n callback(event);\n } catch {\n // Ignore callback errors\n }\n });\n\n // Track subscription for cleanup\n if (!this.subscriptions.has(runId)) {\n this.subscriptions.set(runId, new Map());\n }\n this.subscriptions.get(runId)!.set(callback, unsubscribe);\n\n // Also add to in-memory if run exists locally\n const run = this.activeRuns.get(runId);\n if (run) {\n run.listeners.add(callback);\n }\n\n return true;\n }\n\n /**\n * Remove event listener from run\n */\n removeListener(runId: string, callback: AgentEventCallback): void {\n // Unsubscribe from eventBus\n const runSubs = this.subscriptions.get(runId);\n if (runSubs) {\n const unsubscribe = runSubs.get(callback);\n if (unsubscribe) {\n unsubscribe();\n runSubs.delete(callback);\n }\n if (runSubs.size === 0) {\n this.subscriptions.delete(runId);\n }\n }\n\n // Also remove from in-memory\n const run = this.activeRuns.get(runId);\n if (run) {\n run.listeners.delete(callback);\n }\n }\n\n /**\n * Broadcast event to all listeners of a run (uses eventBus for cross-process)\n * Assigns monotonic sequence number for reliable ordering\n * @returns The event with seq assigned (for persistence)\n */\n broadcast(runId: string, event: AgentEvent): AgentEvent {\n const platform = usePlatform();\n const run = this.activeRuns.get(runId);\n\n // Assign sequence number for ordering\n let seqEvent = event;\n if (run) {\n run.lastSeq++;\n seqEvent = { ...event, seq: run.lastSeq, runId };\n\n // Store in replay buffer (for late WS connections)\n run.eventBuffer.push(seqEvent);\n }\n\n // Publish to eventBus for cross-process delivery\n if (platform?.eventBus) {\n const topic = `${EVENT_TOPIC_PREFIX}${runId}`;\n platform.eventBus.publish(topic, seqEvent).catch(() => {\n // Ignore publish errors\n });\n }\n\n // Also notify local in-memory listeners (for same-process)\n if (run) {\n for (const listener of run.listeners) {\n try {\n listener(seqEvent);\n } catch {\n // Ignore listener errors\n }\n }\n }\n\n // Notify session-level listeners (persistent connections)\n const sessionId = this.runSessionMap.get(runId);\n if (sessionId) {\n const sListeners = this.sessionListeners.get(sessionId);\n if (sListeners) {\n for (const listener of sListeners) {\n try {\n listener(seqEvent);\n } catch {\n // Ignore listener errors\n }\n }\n }\n }\n\n return seqEvent;\n }\n\n /**\n * Add a session-level listener — receives events from ALL runs in this session.\n */\n addSessionListener(sessionId: string, callback: AgentEventCallback): void {\n if (!this.sessionListeners.has(sessionId)) {\n this.sessionListeners.set(sessionId, new Set());\n }\n this.sessionListeners.get(sessionId)!.add(callback);\n }\n\n /**\n * Remove a session-level listener.\n */\n removeSessionListener(sessionId: string, callback: AgentEventCallback): void {\n const listeners = this.sessionListeners.get(sessionId);\n if (listeners) {\n listeners.delete(callback);\n if (listeners.size === 0) {\n this.sessionListeners.delete(sessionId);\n }\n }\n }\n\n /**\n * Get replay buffer for a run (all events emitted since start).\n * Used by WS handler to send missed events on late connection.\n * Optionally filter by afterSeq to only get events the client hasn't seen.\n */\n getEventBuffer(runId: string, afterSeq?: number): AgentEvent[] {\n const run = this.activeRuns.get(runId);\n if (!run) {return [];}\n\n if (afterSeq != null) {\n return run.eventBuffer.filter((e) => e.seq != null && e.seq > afterSeq);\n }\n return [...run.eventBuffer];\n }\n\n /**\n * List all active runs\n */\n listActive(): Array<{ runId: string; task: string; status: RunStatus; startedAt: string }> {\n return Array.from(this.activeRuns.values()).map(r => ({\n runId: r.runId,\n task: r.task,\n status: r.status,\n startedAt: r.startedAt,\n }));\n }\n\n /**\n * Request graceful stop of a running agent (and its child agents via propagated AbortSignal).\n * Agent finishes its current tool call then exits at the next iteration boundary.\n */\n requestStop(runId: string): boolean {\n const run = this.activeRuns.get(runId);\n if (!run || run.status !== 'running' || !run.agent) {\n return false;\n }\n run.agent.requestStop();\n return true;\n }\n\n /**\n * Clean up completed runs from memory (cache handles its own TTL)\n */\n cleanup(): void {\n for (const [runId, run] of this.activeRuns) {\n if (run.status === 'completed' || run.status === 'failed' || run.status === 'stopped') {\n // Remove from memory but keep in cache\n this.activeRuns.delete(runId);\n }\n }\n }\n}\n\n/**\n * Singleton instance — stored on globalThis so all bundled modules share one instance.\n * When tsup compiles multiple entry points, each gets its own module scope,\n * so a plain `export const RunManager = new RunManagerImpl()` creates separate instances.\n * Using globalThis ensures run-handler.js and session-stream-handler.js share one RunManager.\n */\nconst GLOBAL_KEY = '__kb_agent_run_manager__';\nif (!(globalThis as Record<string, unknown>)[GLOBAL_KEY]) {\n (globalThis as Record<string, unknown>)[GLOBAL_KEY] = new RunManagerImpl();\n}\nexport const RunManager = (globalThis as Record<string, unknown>)[GLOBAL_KEY] as RunManagerImpl;\n","/**\n * POST /run handler\n *\n * Starts a new agent run via Orchestrator\n */\n\nimport { defineHandler, useAnalytics, useCache, useConfig, type RestInput, type PluginContextV3 } from '@kb-labs/sdk';\nimport { SessionManager, createCoreToolPack, bootstrapAgentSDK, createSessionMemoryBridge } from '@kb-labs/agent-core';\nimport { createDefaultResponseRequirementsSelector } from '@kb-labs/agent-runtime';\nimport { IncrementalTraceWriter } from '@kb-labs/agent-tracing';\n\n// Register SDKAgentRunner as the RunnerFactory (idempotent — runs once per process)\nbootstrapAgentSDK();\nimport { AgentSDK } from '@kb-labs/agent-sdk';\nimport { createToolRegistry } from '@kb-labs/agent-tools';\nimport type { RunRequest, RunResponse, AgentsPluginConfig, KernelState } from '@kb-labs/agent-contracts';\nimport path from 'node:path';\nimport fs from 'node:fs';\nimport {\n AGENTS_WS_BASE_PATH,\n AGENTS_WS_CHANNELS,\n AGENT_ANALYTICS_EVENTS,\n} from '@kb-labs/agent-contracts';\nimport { RunManager } from '../run-manager.js';\n\nconst FOLLOW_UP_SCOPE_RE = /\\b(глубже|подробнее|детал|слишком поверхност|deeper|more depth|details?)\\b/i;\n\nfunction isLikelyFollowUpScopeTask(task: string): boolean {\n return FOLLOW_UP_SCOPE_RE.test(task);\n}\n\nfunction pathExists(dir: string): boolean {\n try {\n return fs.existsSync(dir);\n } catch {\n return false;\n }\n}\n\nfunction scoreRepoFromToolPath(rawPath: string, scores: Map<string, number>): void {\n const p = rawPath.replace(/\\\\/g, '/');\n\n // Explicit repo prefix: kb-labs-xxx/...\n const explicit = p.match(/(^|\\/)(kb-labs-[^/]+)\\//);\n if (explicit?.[2]) {\n scores.set(explicit[2], (scores.get(explicit[2]) ?? 0) + 5);\n }\n\n // Heuristic by package naming patterns\n if (p.startsWith('packages/')) {\n if (/packages\\/agent[-/]/.test(p) || /agent-core|agent-tools|agent-cli|agent-task-runner/.test(p)) {\n scores.set('kb-labs-agents', (scores.get('kb-labs-agents') ?? 0) + 4);\n }\n if (/packages\\/mind[-/]/.test(p) || /mind-engine|mind-core/.test(p)) {\n scores.set('kb-labs-mind', (scores.get('kb-labs-mind') ?? 0) + 4);\n }\n }\n}\n\nasync function inferFollowUpWorkingDir(\n sessionManager: SessionManager,\n sessionId: string,\n baseWorkingDir: string,\n): Promise<string | null> {\n const events = await sessionManager.getSessionEvents(sessionId);\n if (!events.length) {\n return null;\n }\n\n // Find the latest completed run in this session\n const completedRuns = new Set<string>();\n for (const event of events) {\n if (event.type === 'agent:end' && event.runId) {\n completedRuns.add(event.runId);\n }\n }\n const lastRunId = Array.from(completedRuns).at(-1);\n if (!lastRunId) {\n return null;\n }\n\n const repoScores = new Map<string, number>();\n for (const event of events) {\n if (event.runId !== lastRunId) {\n continue;\n }\n\n if (event.type === 'tool:start') {\n const input = (event.data?.input as Record<string, unknown> | undefined) ?? {};\n const p1 = input.path;\n const p2 = input.directory;\n if (typeof p1 === 'string') {scoreRepoFromToolPath(p1, repoScores);}\n if (typeof p2 === 'string') {scoreRepoFromToolPath(p2, repoScores);}\n }\n\n if (event.type === 'tool:end') {\n const metadata = (event.data?.metadata as Record<string, unknown> | undefined) ?? {};\n const p = metadata.path;\n if (typeof p === 'string') {scoreRepoFromToolPath(p, repoScores);}\n }\n }\n\n const ranked = Array.from(repoScores.entries()).sort((a, b) => b[1] - a[1]);\n const top = ranked[0];\n if (!top || top[1] < 4) {\n return null;\n }\n\n const inferredDir = path.join(baseWorkingDir, top[0]);\n return pathExists(inferredDir) ? inferredDir : null;\n}\n\nexport default defineHandler({\n async execute(\n ctx: PluginContextV3,\n input: RestInput<RunRequest>\n ): Promise<RunResponse> {\n const body = input.body as RunRequest | undefined;\n\n if (!body?.task) {\n throw new Error('Task is required');\n }\n\n const analytics = useAnalytics();\n const runId = RunManager.generateRunId();\n const startTime = Date.now();\n\n // Get or create session\n let sessionId = body.sessionId;\n let workingDir = body.workingDir || ctx.cwd;\n let sessionManager = new SessionManager(workingDir);\n if (!sessionId) {\n // Create new session\n const session = await sessionManager.createSession({\n mode: 'execute',\n task: body.task,\n agentId: body.agentId ?? 'orchestrator',\n });\n sessionId = session.id;\n ctx.platform.logger.info(`[run-handler] Created new session ${sessionId}`);\n } else {\n // Verify session exists (from current manager first)\n const existingSession = await sessionManager.loadSession(sessionId);\n let resolvedSession = existingSession;\n\n // Fallback: session may belong to a different root than current ctx.cwd\n if (!resolvedSession && pathExists(ctx.cwd)) {\n const fallbackManager = new SessionManager(ctx.cwd);\n const fallbackSession = await fallbackManager.loadSession(sessionId);\n if (fallbackSession) {\n sessionManager = fallbackManager;\n resolvedSession = fallbackSession;\n }\n }\n\n if (!resolvedSession) {\n throw new Error(`Session not found: ${sessionId} (cwd=${ctx.cwd})`);\n }\n\n // Session workingDir is primary source of truth for follow-up runs\n workingDir = body.workingDir || resolvedSession.workingDir || workingDir;\n\n // Smart follow-up anchoring: keep depth requests in the same repo/module as previous run\n if (!body.workingDir && isLikelyFollowUpScopeTask(body.task)) {\n const inferred = await inferFollowUpWorkingDir(sessionManager, sessionId, resolvedSession.workingDir || ctx.cwd);\n if (inferred && inferred !== workingDir) {\n ctx.platform.logger.info(`[run-handler] Follow-up scope inferred: ${workingDir} -> ${inferred}`);\n workingDir = inferred;\n }\n }\n\n // Rebind session manager to effective working directory\n sessionManager = new SessionManager(workingDir);\n ctx.platform.logger.info(`[run-handler] Continuing session ${sessionId} (workingDir=${workingDir})`);\n }\n\n ctx.platform.logger.info(`[run-handler] Starting run ${runId} for task: ${body.task}`);\n\n // Create user turn with task/question\n await sessionManager.createUserTurn(sessionId, body.task, runId);\n\n // Track run started\n await analytics?.track(AGENT_ANALYTICS_EVENTS.RUN_STARTED, {\n runId,\n sessionId,\n taskLength: body.task.length,\n tier: body.tier ?? 'medium',\n enableEscalation: body.enableEscalation ?? true,\n responseMode: body.responseMode ?? 'auto',\n verbose: body.verbose ?? false,\n });\n\n // Create tool registry with standard tools\n const sessionMemory = createSessionMemoryBridge(workingDir, sessionId);\n const responseRequirementsSelector = createDefaultResponseRequirementsSelector();\n const toolRegistry = createToolRegistry({\n workingDir,\n currentTask: body.task,\n sessionId,\n verbose: body.verbose,\n cache: useCache(),\n sessionMemory,\n responseRequirementsResolver: async ({ task, kernel }: {\n task?: string;\n answer: string;\n kernel: KernelState | null;\n }) =>\n responseRequirementsSelector.select({\n state: kernel,\n messages: [],\n task: task ?? body.task,\n }),\n });\n const agentsConfig = await useConfig<AgentsPluginConfig>();\n\n const finalSessionId = sessionId; // Capture for closure\n const traceDir = path.join(workingDir, '.kb', 'traces', 'incremental');\n const traceWriter = new IncrementalTraceWriter(runId, {}, traceDir);\n\n // Create agent with event broadcasting and session persistence\n const agent = new AgentSDK()\n .register(createCoreToolPack(toolRegistry))\n .createRunner({\n sessionId: finalSessionId,\n workingDir,\n maxIterations: 50,\n temperature: 0.1,\n tier: body.tier ?? 'medium',\n tokenBudget: agentsConfig?.tokenBudget,\n onEvent: (event) => {\n // Broadcast to all WebSocket listeners (assigns seq)\n const seqEvent = RunManager.broadcast(runId, event);\n\n // Persist event with seq + runId + sessionId in metadata to session storage\n void sessionManager.addEvent(finalSessionId, {\n ...seqEvent,\n sessionId: finalSessionId,\n runId,\n metadata: {\n ...seqEvent.metadata,\n sessionId: finalSessionId,\n runId,\n workingDir,\n },\n });\n },\n });\n\n // Register run (pass sessionManager and sessionId so session-level WS listeners receive events)\n const run = await RunManager.register(runId, body.task, agent, sessionManager, finalSessionId);\n await RunManager.updateStatus(runId, 'running');\n\n // Start execution in background (don't await)\n void (async () => {\n try {\n const result = await agent.execute(body.task);\n const durationMs = Date.now() - startTime;\n const detailedTrace = traceWriter.getEntries() as Array<Record<string, unknown>>;\n await traceWriter.finalize?.();\n\n if (detailedTrace.length > 0) {\n await sessionManager.storeTraceArtifacts(finalSessionId, runId, detailedTrace);\n }\n\n // Attach file change summaries to the turn so the UI can show rollback/approve panel\n // Populated by ChangeTrackingMiddleware via run.meta → TaskResult.fileChanges\n if (result.fileChanges && result.fileChanges.length > 0) {\n await sessionManager.attachFileChangesToTurn(finalSessionId, runId, result.fileChanges);\n }\n\n await RunManager.updateStatus(runId, result.success ? 'completed' : 'failed', {\n completedAt: new Date().toISOString(),\n durationMs,\n summary: result.summary,\n error: result.error,\n });\n\n // Track completion\n await analytics?.track(\n result.success ? AGENT_ANALYTICS_EVENTS.RUN_COMPLETED : AGENT_ANALYTICS_EVENTS.RUN_FAILED,\n {\n runId,\n durationMs,\n success: result.success,\n summary: result.summary?.slice(0, 200),\n }\n );\n\n ctx.platform.logger.info(`[run-handler] Run ${runId} completed: ${result.success}`);\n } catch (error) {\n const errorMsg = error instanceof Error ? error.message : String(error);\n const durationMs = Date.now() - startTime;\n const detailedTrace = traceWriter.getEntries() as Array<Record<string, unknown>>;\n await traceWriter.finalize?.();\n if (detailedTrace.length > 0) {\n await sessionManager.storeTraceArtifacts(finalSessionId, runId, detailedTrace);\n }\n\n await RunManager.updateStatus(runId, 'failed', {\n completedAt: new Date().toISOString(),\n durationMs,\n error: errorMsg,\n });\n\n // Track failure\n await analytics?.track(AGENT_ANALYTICS_EVENTS.RUN_FAILED, {\n runId,\n durationMs,\n error: errorMsg.slice(0, 200),\n });\n\n ctx.platform.logger.error(`[run-handler] Run ${runId} failed: ${errorMsg}`);\n }\n })();\n\n // Return relative WS path — clients construct the full URL from their own base URL.\n const wsPath = AGENTS_WS_CHANNELS.SESSION_STREAM.replace(':sessionId', finalSessionId);\n const eventsPath = `${AGENTS_WS_BASE_PATH}${wsPath}`;\n\n return {\n runId,\n sessionId: finalSessionId,\n eventsPath,\n status: 'started',\n startedAt: run.startedAt,\n };\n },\n});\n","/**\n * POST /sessions/:sessionId/plan/execute\n * Execute approved session plan via standard run-handler pipeline.\n */\n\nimport { defineHandler, type RestInput, type PluginContextV3 } from '@kb-labs/sdk';\nimport { PlanDocumentService, SessionManager } from '@kb-labs/agent-core';\nimport type {\n ExecuteSessionPlanRequest,\n ExecuteSessionPlanResponse,\n RunRequest,\n RunResponse,\n TaskPlan,\n TaskSpec,\n} from '@kb-labs/agent-contracts';\nimport { promises as fs } from 'node:fs';\nimport runHandler from './run-handler.js';\n\ninterface ExecutePlanRouteParams {\n sessionId?: string;\n}\n\nasync function loadPlan(planPath: string): Promise<TaskPlan> {\n const content = await fs.readFile(planPath, 'utf-8');\n return JSON.parse(content) as TaskPlan;\n}\n\nfunction buildExecutionTask(plan: TaskPlan): string {\n const phaseLines = plan.phases.map((phase, idx) => {\n const steps = phase.steps\n .map((step, stepIdx) => {\n const tool = step.tool || 'n/a';\n return ` ${stepIdx + 1}. ${step.action} [tool: ${tool}]`;\n })\n .join('\\n');\n return `${idx + 1}. ${phase.name}\\n${steps || ' (no steps)'}`;\n }).join('\\n');\n\n return [\n `Execute the approved implementation plan for task: ${plan.task}`,\n '',\n 'Follow phase order and dependencies. Update progress with concrete results.',\n '',\n `Plan ID: ${plan.id}`,\n `Complexity: ${plan.complexity}`,\n `Estimated Duration: ${plan.estimatedDuration || 'Unknown'}`,\n '',\n 'Phases:',\n phaseLines,\n '',\n 'Requirements:',\n '- Execute plan steps pragmatically; adapt only when blocked.',\n '- Keep outputs concrete: changed files, commands run, verification results.',\n ].join('\\n');\n}\n\nfunction buildExecutionTaskWithSpec(plan: TaskPlan, spec: TaskSpec): string {\n return [\n `Execute the approved implementation plan for task: ${plan.task}`,\n '',\n `Plan ID: ${plan.id}`,\n `Complexity: ${plan.complexity}`,\n '',\n '## DETAILED SPECIFICATION (exact changes)',\n '',\n 'A detailed spec was generated and verified. Apply these exact changes:',\n '',\n spec.markdown || '(no spec markdown available)',\n '',\n 'Requirements:',\n '- Apply the before/after diffs from the spec as precisely as possible.',\n '- Verify each change after applying it.',\n '- If the spec code doesn\\'t match the current file (file was modified since spec), adapt minimally.',\n '- Keep outputs concrete: changed files, commands run, verification results.',\n ].join('\\n');\n}\n\nexport default defineHandler({\n async execute(\n ctx: PluginContextV3,\n input: RestInput<ExecuteSessionPlanRequest, unknown, ExecutePlanRouteParams>\n ): Promise<ExecuteSessionPlanResponse> {\n const params = input.params as Record<string, string> | undefined;\n const sessionId = params?.sessionId;\n const body = (input.body ?? {}) as ExecuteSessionPlanRequest;\n\n if (!sessionId) {\n throw new Error('Session ID is required');\n }\n\n const baseManager = new SessionManager(ctx.cwd);\n const session = await baseManager.loadSession(sessionId);\n if (!session) {\n throw new Error(`Session not found: ${sessionId}`);\n }\n\n const workingDir = session.workingDir || ctx.cwd;\n const sessionManager = new SessionManager(workingDir);\n const planPath = sessionManager.getSessionPlanPath(sessionId);\n\n let plan: TaskPlan;\n try {\n plan = await loadPlan(planPath);\n } catch {\n throw new Error(`Plan not found for session ${sessionId}`);\n }\n\n if (plan.status !== 'approved' && plan.status !== 'spec_ready') {\n throw new Error(`Plan must be approved before execution (current status: ${plan.status})`);\n }\n\n // Load spec if available — provides exact diffs for the execution agent\n let spec: TaskSpec | null = null;\n try {\n const specPath = sessionManager.getSessionSpecPath(sessionId);\n const specContent = await fs.readFile(specPath, 'utf-8');\n spec = JSON.parse(specContent) as TaskSpec;\n } catch {\n // No spec — execute from plan only\n }\n\n const executionTask = spec?.markdown\n ? buildExecutionTaskWithSpec(plan, spec)\n : buildExecutionTask(plan);\n const runInput: RestInput<unknown, RunRequest> = {\n body: {\n task: executionTask,\n sessionId,\n workingDir,\n tier: body.tier,\n responseMode: body.responseMode,\n verbose: body.verbose,\n enableEscalation: body.enableEscalation,\n },\n };\n\n const runResponse = await (runHandler as unknown as {\n execute: (ctx: PluginContextV3, input: RestInput<unknown, RunRequest>) => Promise<RunResponse>;\n }).execute(ctx, runInput);\n\n const inProgressPlan: TaskPlan = {\n ...plan,\n status: 'in_progress',\n updatedAt: new Date().toISOString(),\n };\n await fs.writeFile(planPath, JSON.stringify(inProgressPlan, null, 2), 'utf-8');\n\n const documentService = new PlanDocumentService(workingDir);\n const markdownPath = documentService.getPlanPath(plan);\n await documentService.appendExecutionLog(\n markdownPath,\n `- ${new Date().toISOString()}: Execution started (runId: ${runResponse.runId}).`\n );\n\n return {\n sessionId,\n planId: plan.id,\n runId: runResponse.runId,\n eventsPath: runResponse.eventsPath,\n status: runResponse.status,\n startedAt: runResponse.startedAt,\n };\n },\n});\n"]}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import * as _kb_labs_shared_command_kit from '@kb-labs/shared-command-kit';
|
|
2
|
+
import { RestInput } from '@kb-labs/sdk';
|
|
3
|
+
import { GenerateSpecRequest, GenerateSpecResponse } from '@kb-labs/agent-contracts';
|
|
4
|
+
|
|
5
|
+
interface SpecRouteParams {
|
|
6
|
+
sessionId?: string;
|
|
7
|
+
}
|
|
8
|
+
declare const _default: _kb_labs_shared_command_kit.Handler<unknown, RestInput<GenerateSpecRequest, unknown, SpecRouteParams>, GenerateSpecResponse>;
|
|
9
|
+
|
|
10
|
+
export { _default as default };
|
|
@@ -0,0 +1,389 @@
|
|
|
1
|
+
import { defineHandler, useCache, usePlatform } from '@kb-labs/sdk';
|
|
2
|
+
import { SessionManager, SpecModeHandler, createSessionMemoryBridge } from '@kb-labs/agent-core';
|
|
3
|
+
import { createDefaultResponseRequirementsSelector } from '@kb-labs/agent-runtime';
|
|
4
|
+
import { IncrementalTraceWriter } from '@kb-labs/agent-tracing';
|
|
5
|
+
import { createToolRegistry } from '@kb-labs/agent-tools';
|
|
6
|
+
import { promises } from 'fs';
|
|
7
|
+
import path from 'path';
|
|
8
|
+
|
|
9
|
+
// src/rest/handlers/generate-spec-handler.ts
|
|
10
|
+
var CACHE_PREFIX = "agent:run:";
|
|
11
|
+
var EVENT_TOPIC_PREFIX = "agent:events:";
|
|
12
|
+
var CACHE_TTL = 36e5;
|
|
13
|
+
var RunManagerImpl = class {
|
|
14
|
+
/** Live agents and listeners (not cacheable) */
|
|
15
|
+
activeRuns = /* @__PURE__ */ new Map();
|
|
16
|
+
/** Session-level listeners: sessionId → Set<callback> — receive events from ALL runs in session */
|
|
17
|
+
sessionListeners = /* @__PURE__ */ new Map();
|
|
18
|
+
/** sessionId per runId — set when run is registered */
|
|
19
|
+
runSessionMap = /* @__PURE__ */ new Map();
|
|
20
|
+
/**
|
|
21
|
+
* Generate unique run ID
|
|
22
|
+
*/
|
|
23
|
+
generateRunId() {
|
|
24
|
+
return `run-${Date.now()}-${Math.random().toString(36).slice(2, 7)}`;
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Register a new run
|
|
28
|
+
*/
|
|
29
|
+
async register(runId, task, agent, sessionManager, sessionId) {
|
|
30
|
+
const now = (/* @__PURE__ */ new Date()).toISOString();
|
|
31
|
+
const run = {
|
|
32
|
+
runId,
|
|
33
|
+
task,
|
|
34
|
+
status: "pending",
|
|
35
|
+
agent,
|
|
36
|
+
sessionManager,
|
|
37
|
+
startedAt: now,
|
|
38
|
+
listeners: /* @__PURE__ */ new Set(),
|
|
39
|
+
lastSeq: 0,
|
|
40
|
+
eventBuffer: []
|
|
41
|
+
};
|
|
42
|
+
this.activeRuns.set(runId, run);
|
|
43
|
+
if (sessionId) {
|
|
44
|
+
this.runSessionMap.set(runId, sessionId);
|
|
45
|
+
}
|
|
46
|
+
await this.saveToCache(run);
|
|
47
|
+
return run;
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Get run by ID (from memory first, then cache for state)
|
|
51
|
+
*/
|
|
52
|
+
get(runId) {
|
|
53
|
+
return this.activeRuns.get(runId);
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Check if run exists (in memory or cache)
|
|
57
|
+
*/
|
|
58
|
+
async exists(runId) {
|
|
59
|
+
if (this.activeRuns.has(runId)) {
|
|
60
|
+
return true;
|
|
61
|
+
}
|
|
62
|
+
const state = await this.getState(runId);
|
|
63
|
+
return state !== null;
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* Get run state from cache (for completed runs or cross-process access)
|
|
67
|
+
*/
|
|
68
|
+
async getState(runId) {
|
|
69
|
+
const cache = useCache();
|
|
70
|
+
if (!cache) {
|
|
71
|
+
return null;
|
|
72
|
+
}
|
|
73
|
+
return cache.get(`${CACHE_PREFIX}${runId}`);
|
|
74
|
+
}
|
|
75
|
+
/**
|
|
76
|
+
* Update run status
|
|
77
|
+
*/
|
|
78
|
+
async updateStatus(runId, status, extra) {
|
|
79
|
+
const run = this.activeRuns.get(runId);
|
|
80
|
+
if (run) {
|
|
81
|
+
run.status = status;
|
|
82
|
+
if (extra) {
|
|
83
|
+
Object.assign(run, extra);
|
|
84
|
+
}
|
|
85
|
+
await this.saveToCache(run);
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* Save run state to cache
|
|
90
|
+
*/
|
|
91
|
+
async saveToCache(run) {
|
|
92
|
+
const cache = useCache();
|
|
93
|
+
if (!cache) {
|
|
94
|
+
return;
|
|
95
|
+
}
|
|
96
|
+
const state = {
|
|
97
|
+
runId: run.runId,
|
|
98
|
+
task: run.task,
|
|
99
|
+
status: run.status,
|
|
100
|
+
startedAt: run.startedAt,
|
|
101
|
+
completedAt: run.completedAt,
|
|
102
|
+
durationMs: run.durationMs,
|
|
103
|
+
summary: run.summary,
|
|
104
|
+
error: run.error
|
|
105
|
+
};
|
|
106
|
+
await cache.set(`${CACHE_PREFIX}${run.runId}`, state, CACHE_TTL);
|
|
107
|
+
}
|
|
108
|
+
/** Track subscriptions for cleanup */
|
|
109
|
+
subscriptions = /* @__PURE__ */ new Map();
|
|
110
|
+
/**
|
|
111
|
+
* Add event listener to run (uses eventBus for cross-process)
|
|
112
|
+
*/
|
|
113
|
+
addListener(runId, callback) {
|
|
114
|
+
const platform = usePlatform();
|
|
115
|
+
if (!platform?.eventBus) {
|
|
116
|
+
const run2 = this.activeRuns.get(runId);
|
|
117
|
+
if (run2) {
|
|
118
|
+
run2.listeners.add(callback);
|
|
119
|
+
return true;
|
|
120
|
+
}
|
|
121
|
+
return false;
|
|
122
|
+
}
|
|
123
|
+
const topic = `${EVENT_TOPIC_PREFIX}${runId}`;
|
|
124
|
+
const unsubscribe = platform.eventBus.subscribe(topic, async (event) => {
|
|
125
|
+
try {
|
|
126
|
+
callback(event);
|
|
127
|
+
} catch {
|
|
128
|
+
}
|
|
129
|
+
});
|
|
130
|
+
if (!this.subscriptions.has(runId)) {
|
|
131
|
+
this.subscriptions.set(runId, /* @__PURE__ */ new Map());
|
|
132
|
+
}
|
|
133
|
+
this.subscriptions.get(runId).set(callback, unsubscribe);
|
|
134
|
+
const run = this.activeRuns.get(runId);
|
|
135
|
+
if (run) {
|
|
136
|
+
run.listeners.add(callback);
|
|
137
|
+
}
|
|
138
|
+
return true;
|
|
139
|
+
}
|
|
140
|
+
/**
|
|
141
|
+
* Remove event listener from run
|
|
142
|
+
*/
|
|
143
|
+
removeListener(runId, callback) {
|
|
144
|
+
const runSubs = this.subscriptions.get(runId);
|
|
145
|
+
if (runSubs) {
|
|
146
|
+
const unsubscribe = runSubs.get(callback);
|
|
147
|
+
if (unsubscribe) {
|
|
148
|
+
unsubscribe();
|
|
149
|
+
runSubs.delete(callback);
|
|
150
|
+
}
|
|
151
|
+
if (runSubs.size === 0) {
|
|
152
|
+
this.subscriptions.delete(runId);
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
const run = this.activeRuns.get(runId);
|
|
156
|
+
if (run) {
|
|
157
|
+
run.listeners.delete(callback);
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
/**
|
|
161
|
+
* Broadcast event to all listeners of a run (uses eventBus for cross-process)
|
|
162
|
+
* Assigns monotonic sequence number for reliable ordering
|
|
163
|
+
* @returns The event with seq assigned (for persistence)
|
|
164
|
+
*/
|
|
165
|
+
broadcast(runId, event) {
|
|
166
|
+
const platform = usePlatform();
|
|
167
|
+
const run = this.activeRuns.get(runId);
|
|
168
|
+
let seqEvent = event;
|
|
169
|
+
if (run) {
|
|
170
|
+
run.lastSeq++;
|
|
171
|
+
seqEvent = { ...event, seq: run.lastSeq, runId };
|
|
172
|
+
run.eventBuffer.push(seqEvent);
|
|
173
|
+
}
|
|
174
|
+
if (platform?.eventBus) {
|
|
175
|
+
const topic = `${EVENT_TOPIC_PREFIX}${runId}`;
|
|
176
|
+
platform.eventBus.publish(topic, seqEvent).catch(() => {
|
|
177
|
+
});
|
|
178
|
+
}
|
|
179
|
+
if (run) {
|
|
180
|
+
for (const listener of run.listeners) {
|
|
181
|
+
try {
|
|
182
|
+
listener(seqEvent);
|
|
183
|
+
} catch {
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
const sessionId = this.runSessionMap.get(runId);
|
|
188
|
+
if (sessionId) {
|
|
189
|
+
const sListeners = this.sessionListeners.get(sessionId);
|
|
190
|
+
if (sListeners) {
|
|
191
|
+
for (const listener of sListeners) {
|
|
192
|
+
try {
|
|
193
|
+
listener(seqEvent);
|
|
194
|
+
} catch {
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
return seqEvent;
|
|
200
|
+
}
|
|
201
|
+
/**
|
|
202
|
+
* Add a session-level listener — receives events from ALL runs in this session.
|
|
203
|
+
*/
|
|
204
|
+
addSessionListener(sessionId, callback) {
|
|
205
|
+
if (!this.sessionListeners.has(sessionId)) {
|
|
206
|
+
this.sessionListeners.set(sessionId, /* @__PURE__ */ new Set());
|
|
207
|
+
}
|
|
208
|
+
this.sessionListeners.get(sessionId).add(callback);
|
|
209
|
+
}
|
|
210
|
+
/**
|
|
211
|
+
* Remove a session-level listener.
|
|
212
|
+
*/
|
|
213
|
+
removeSessionListener(sessionId, callback) {
|
|
214
|
+
const listeners = this.sessionListeners.get(sessionId);
|
|
215
|
+
if (listeners) {
|
|
216
|
+
listeners.delete(callback);
|
|
217
|
+
if (listeners.size === 0) {
|
|
218
|
+
this.sessionListeners.delete(sessionId);
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
/**
|
|
223
|
+
* Get replay buffer for a run (all events emitted since start).
|
|
224
|
+
* Used by WS handler to send missed events on late connection.
|
|
225
|
+
* Optionally filter by afterSeq to only get events the client hasn't seen.
|
|
226
|
+
*/
|
|
227
|
+
getEventBuffer(runId, afterSeq) {
|
|
228
|
+
const run = this.activeRuns.get(runId);
|
|
229
|
+
if (!run) {
|
|
230
|
+
return [];
|
|
231
|
+
}
|
|
232
|
+
if (afterSeq != null) {
|
|
233
|
+
return run.eventBuffer.filter((e) => e.seq != null && e.seq > afterSeq);
|
|
234
|
+
}
|
|
235
|
+
return [...run.eventBuffer];
|
|
236
|
+
}
|
|
237
|
+
/**
|
|
238
|
+
* List all active runs
|
|
239
|
+
*/
|
|
240
|
+
listActive() {
|
|
241
|
+
return Array.from(this.activeRuns.values()).map((r) => ({
|
|
242
|
+
runId: r.runId,
|
|
243
|
+
task: r.task,
|
|
244
|
+
status: r.status,
|
|
245
|
+
startedAt: r.startedAt
|
|
246
|
+
}));
|
|
247
|
+
}
|
|
248
|
+
/**
|
|
249
|
+
* Request graceful stop of a running agent (and its child agents via propagated AbortSignal).
|
|
250
|
+
* Agent finishes its current tool call then exits at the next iteration boundary.
|
|
251
|
+
*/
|
|
252
|
+
requestStop(runId) {
|
|
253
|
+
const run = this.activeRuns.get(runId);
|
|
254
|
+
if (!run || run.status !== "running" || !run.agent) {
|
|
255
|
+
return false;
|
|
256
|
+
}
|
|
257
|
+
run.agent.requestStop();
|
|
258
|
+
return true;
|
|
259
|
+
}
|
|
260
|
+
/**
|
|
261
|
+
* Clean up completed runs from memory (cache handles its own TTL)
|
|
262
|
+
*/
|
|
263
|
+
cleanup() {
|
|
264
|
+
for (const [runId, run] of this.activeRuns) {
|
|
265
|
+
if (run.status === "completed" || run.status === "failed" || run.status === "stopped") {
|
|
266
|
+
this.activeRuns.delete(runId);
|
|
267
|
+
}
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
};
|
|
271
|
+
var GLOBAL_KEY = "__kb_agent_run_manager__";
|
|
272
|
+
if (!globalThis[GLOBAL_KEY]) {
|
|
273
|
+
globalThis[GLOBAL_KEY] = new RunManagerImpl();
|
|
274
|
+
}
|
|
275
|
+
var RunManager = globalThis[GLOBAL_KEY];
|
|
276
|
+
|
|
277
|
+
// src/rest/handlers/generate-spec-handler.ts
|
|
278
|
+
async function loadPlan(planPath) {
|
|
279
|
+
const content = await promises.readFile(planPath, "utf-8");
|
|
280
|
+
return JSON.parse(content);
|
|
281
|
+
}
|
|
282
|
+
var generate_spec_handler_default = defineHandler({
|
|
283
|
+
async execute(ctx, input) {
|
|
284
|
+
const params = input.params;
|
|
285
|
+
const sessionId = params?.sessionId;
|
|
286
|
+
const body = input.body ?? {};
|
|
287
|
+
if (!sessionId) {
|
|
288
|
+
throw new Error("Session ID is required");
|
|
289
|
+
}
|
|
290
|
+
const baseManager = new SessionManager(ctx.cwd);
|
|
291
|
+
const session = await baseManager.loadSession(sessionId);
|
|
292
|
+
if (!session) {
|
|
293
|
+
throw new Error(`Session not found: ${sessionId}`);
|
|
294
|
+
}
|
|
295
|
+
const workingDir = session.workingDir || ctx.cwd;
|
|
296
|
+
const sessionManager = new SessionManager(workingDir);
|
|
297
|
+
const planPath = sessionManager.getSessionPlanPath(sessionId);
|
|
298
|
+
let plan;
|
|
299
|
+
try {
|
|
300
|
+
plan = await loadPlan(planPath);
|
|
301
|
+
} catch {
|
|
302
|
+
throw new Error(`Plan not found for session ${sessionId}`);
|
|
303
|
+
}
|
|
304
|
+
if (plan.status !== "approved") {
|
|
305
|
+
throw new Error(`Plan must be approved before spec generation (current status: ${plan.status})`);
|
|
306
|
+
}
|
|
307
|
+
const runId = `run-spec-${Date.now()}-${Math.random().toString(36).slice(2, 9)}`;
|
|
308
|
+
const startedAt = (/* @__PURE__ */ new Date()).toISOString();
|
|
309
|
+
const traceDir = path.join(workingDir, ".kb", "traces", "incremental");
|
|
310
|
+
const traceWriter = new IncrementalTraceWriter(runId, {}, traceDir);
|
|
311
|
+
await RunManager.register(
|
|
312
|
+
runId,
|
|
313
|
+
`Generate spec for plan ${plan.id}`,
|
|
314
|
+
void 0,
|
|
315
|
+
sessionManager,
|
|
316
|
+
sessionId
|
|
317
|
+
);
|
|
318
|
+
await RunManager.updateStatus(runId, "running");
|
|
319
|
+
const specHandler = new SpecModeHandler();
|
|
320
|
+
const sessionMemory = createSessionMemoryBridge(workingDir, sessionId);
|
|
321
|
+
const responseRequirementsSelector = createDefaultResponseRequirementsSelector();
|
|
322
|
+
const toolRegistry = createToolRegistry({
|
|
323
|
+
workingDir,
|
|
324
|
+
currentTask: `Generate spec for plan ${plan.id}`,
|
|
325
|
+
sessionId,
|
|
326
|
+
sessionMemory,
|
|
327
|
+
responseRequirementsResolver: async ({ task, kernel }) => responseRequirementsSelector.select({
|
|
328
|
+
state: kernel,
|
|
329
|
+
messages: [],
|
|
330
|
+
task: task ?? `Generate spec for plan ${plan.id}`
|
|
331
|
+
})
|
|
332
|
+
});
|
|
333
|
+
(async () => {
|
|
334
|
+
const configOnEvent = (event) => {
|
|
335
|
+
traceWriter.trace(event);
|
|
336
|
+
const seqEvent = RunManager.broadcast(runId, event);
|
|
337
|
+
void sessionManager.addEvent(sessionId, {
|
|
338
|
+
...seqEvent,
|
|
339
|
+
sessionId,
|
|
340
|
+
runId
|
|
341
|
+
});
|
|
342
|
+
};
|
|
343
|
+
try {
|
|
344
|
+
const result = await specHandler.execute(plan, {
|
|
345
|
+
workingDir,
|
|
346
|
+
sessionId,
|
|
347
|
+
agentId: `spec-${sessionId}`,
|
|
348
|
+
maxIterations: plan.phases.length * 8,
|
|
349
|
+
tier: body.tier || "medium",
|
|
350
|
+
temperature: 0.1,
|
|
351
|
+
onEvent: configOnEvent
|
|
352
|
+
}, toolRegistry);
|
|
353
|
+
await RunManager.updateStatus(runId, result.success ? "completed" : "failed", {
|
|
354
|
+
completedAt: (/* @__PURE__ */ new Date()).toISOString(),
|
|
355
|
+
summary: result.summary,
|
|
356
|
+
error: result.success ? void 0 : result.summary
|
|
357
|
+
});
|
|
358
|
+
return result;
|
|
359
|
+
} catch (error) {
|
|
360
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
361
|
+
await RunManager.updateStatus(runId, "failed", {
|
|
362
|
+
completedAt: (/* @__PURE__ */ new Date()).toISOString(),
|
|
363
|
+
summary: message,
|
|
364
|
+
error: message
|
|
365
|
+
});
|
|
366
|
+
throw error;
|
|
367
|
+
} finally {
|
|
368
|
+
const detailedTrace = traceWriter.getEntries();
|
|
369
|
+
await traceWriter.finalize?.();
|
|
370
|
+
if (detailedTrace.length > 0) {
|
|
371
|
+
await sessionManager.storeTraceArtifacts(sessionId, runId, detailedTrace);
|
|
372
|
+
}
|
|
373
|
+
}
|
|
374
|
+
})();
|
|
375
|
+
return {
|
|
376
|
+
sessionId,
|
|
377
|
+
planId: plan.id,
|
|
378
|
+
specId: `spec-${runId}`,
|
|
379
|
+
runId,
|
|
380
|
+
eventsPath: `/ws/plugins/agents/session/${sessionId}`,
|
|
381
|
+
status: "generating",
|
|
382
|
+
startedAt
|
|
383
|
+
};
|
|
384
|
+
}
|
|
385
|
+
});
|
|
386
|
+
|
|
387
|
+
export { generate_spec_handler_default as default };
|
|
388
|
+
//# sourceMappingURL=generate-spec-handler.js.map
|
|
389
|
+
//# sourceMappingURL=generate-spec-handler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/rest/run-manager.ts","../../../src/rest/handlers/generate-spec-handler.ts"],"names":["run","fs"],"mappings":"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","file":"generate-spec-handler.js","sourcesContent":["/**\n * Run Manager - tracks active agent runs for REST/WS API\n *\n * Uses platform cache for persistence and in-memory Map for active agents.\n * Cache stores serializable run state, Map stores live agent references.\n * Uses platform eventBus for cross-process event broadcasting.\n */\n\nimport type { IAgentRunner } from '@kb-labs/agent-sdk';\nimport type { SessionManager } from '@kb-labs/agent-core';\nimport type { AgentEvent, AgentEventCallback } from '@kb-labs/agent-contracts';\nimport { useCache, usePlatform } from '@kb-labs/sdk';\n\nconst CACHE_PREFIX = 'agent:run:';\nconst EVENT_TOPIC_PREFIX = 'agent:events:';\nconst CACHE_TTL = 3600000; // 1 hour\n\n/**\n * Run status\n */\nexport type RunStatus = 'pending' | 'running' | 'completed' | 'failed' | 'stopped';\n\n/**\n * Serializable run state (stored in cache)\n */\nexport interface RunState {\n runId: string;\n task: string;\n status: RunStatus;\n startedAt: string;\n completedAt?: string;\n durationMs?: number;\n summary?: string;\n error?: string;\n}\n\n/**\n * Active run with live agent (in-memory only)\n */\nexport interface ActiveRun extends RunState {\n agent?: IAgentRunner;\n sessionManager: SessionManager;\n listeners: Set<AgentEventCallback>;\n /** Monotonic sequence counter for event ordering */\n lastSeq: number;\n /** Replay buffer: all events emitted since run start (for late WS connections) */\n eventBuffer: AgentEvent[];\n}\n\n/**\n * Run Manager implementation\n */\nclass RunManagerImpl {\n /** Live agents and listeners (not cacheable) */\n private activeRuns: Map<string, ActiveRun> = new Map();\n\n /** Session-level listeners: sessionId → Set<callback> — receive events from ALL runs in session */\n private sessionListeners: Map<string, Set<AgentEventCallback>> = new Map();\n\n /** sessionId per runId — set when run is registered */\n private runSessionMap: Map<string, string> = new Map();\n\n /**\n * Generate unique run ID\n */\n generateRunId(): string {\n return `run-${Date.now()}-${Math.random().toString(36).slice(2, 7)}`;\n }\n\n /**\n * Register a new run\n */\n async register(\n runId: string,\n task: string,\n agent: IAgentRunner | undefined,\n sessionManager: SessionManager,\n sessionId?: string\n ): Promise<ActiveRun> {\n const now = new Date().toISOString();\n\n const run: ActiveRun = {\n runId,\n task,\n status: 'pending',\n agent,\n sessionManager,\n startedAt: now,\n listeners: new Set(),\n lastSeq: 0,\n eventBuffer: [],\n };\n\n // Store in memory (for live agent)\n this.activeRuns.set(runId, run);\n\n // Track sessionId → runId mapping for session-level listeners\n if (sessionId) {\n this.runSessionMap.set(runId, sessionId);\n }\n\n // Store serializable state in cache\n await this.saveToCache(run);\n\n return run;\n }\n\n /**\n * Get run by ID (from memory first, then cache for state)\n */\n get(runId: string): ActiveRun | undefined {\n return this.activeRuns.get(runId);\n }\n\n /**\n * Check if run exists (in memory or cache)\n */\n async exists(runId: string): Promise<boolean> {\n // Check memory first\n if (this.activeRuns.has(runId)) {\n return true;\n }\n // Fallback to cache\n const state = await this.getState(runId);\n return state !== null;\n }\n\n /**\n * Get run state from cache (for completed runs or cross-process access)\n */\n async getState(runId: string): Promise<RunState | null> {\n const cache = useCache();\n if (!cache) {return null;}\n\n return cache.get<RunState>(`${CACHE_PREFIX}${runId}`);\n }\n\n /**\n * Update run status\n */\n async updateStatus(runId: string, status: RunStatus, extra?: Partial<RunState>): Promise<void> {\n const run = this.activeRuns.get(runId);\n if (run) {\n run.status = status;\n if (extra) {\n Object.assign(run, extra);\n }\n await this.saveToCache(run);\n }\n }\n\n /**\n * Save run state to cache\n */\n private async saveToCache(run: ActiveRun): Promise<void> {\n const cache = useCache();\n if (!cache) {return;}\n\n const state: RunState = {\n runId: run.runId,\n task: run.task,\n status: run.status,\n startedAt: run.startedAt,\n completedAt: run.completedAt,\n durationMs: run.durationMs,\n summary: run.summary,\n error: run.error,\n };\n\n await cache.set(`${CACHE_PREFIX}${run.runId}`, state, CACHE_TTL);\n }\n\n /** Track subscriptions for cleanup */\n private subscriptions: Map<string, Map<AgentEventCallback, () => void>> = new Map();\n\n /**\n * Add event listener to run (uses eventBus for cross-process)\n */\n addListener(runId: string, callback: AgentEventCallback): boolean {\n const platform = usePlatform();\n if (!platform?.eventBus) {\n // Fallback to in-memory only\n const run = this.activeRuns.get(runId);\n if (run) {\n run.listeners.add(callback);\n return true;\n }\n return false;\n }\n\n // Subscribe to eventBus topic for this run\n const topic = `${EVENT_TOPIC_PREFIX}${runId}`;\n const unsubscribe = platform.eventBus.subscribe<AgentEvent>(topic, async (event) => {\n try {\n callback(event);\n } catch {\n // Ignore callback errors\n }\n });\n\n // Track subscription for cleanup\n if (!this.subscriptions.has(runId)) {\n this.subscriptions.set(runId, new Map());\n }\n this.subscriptions.get(runId)!.set(callback, unsubscribe);\n\n // Also add to in-memory if run exists locally\n const run = this.activeRuns.get(runId);\n if (run) {\n run.listeners.add(callback);\n }\n\n return true;\n }\n\n /**\n * Remove event listener from run\n */\n removeListener(runId: string, callback: AgentEventCallback): void {\n // Unsubscribe from eventBus\n const runSubs = this.subscriptions.get(runId);\n if (runSubs) {\n const unsubscribe = runSubs.get(callback);\n if (unsubscribe) {\n unsubscribe();\n runSubs.delete(callback);\n }\n if (runSubs.size === 0) {\n this.subscriptions.delete(runId);\n }\n }\n\n // Also remove from in-memory\n const run = this.activeRuns.get(runId);\n if (run) {\n run.listeners.delete(callback);\n }\n }\n\n /**\n * Broadcast event to all listeners of a run (uses eventBus for cross-process)\n * Assigns monotonic sequence number for reliable ordering\n * @returns The event with seq assigned (for persistence)\n */\n broadcast(runId: string, event: AgentEvent): AgentEvent {\n const platform = usePlatform();\n const run = this.activeRuns.get(runId);\n\n // Assign sequence number for ordering\n let seqEvent = event;\n if (run) {\n run.lastSeq++;\n seqEvent = { ...event, seq: run.lastSeq, runId };\n\n // Store in replay buffer (for late WS connections)\n run.eventBuffer.push(seqEvent);\n }\n\n // Publish to eventBus for cross-process delivery\n if (platform?.eventBus) {\n const topic = `${EVENT_TOPIC_PREFIX}${runId}`;\n platform.eventBus.publish(topic, seqEvent).catch(() => {\n // Ignore publish errors\n });\n }\n\n // Also notify local in-memory listeners (for same-process)\n if (run) {\n for (const listener of run.listeners) {\n try {\n listener(seqEvent);\n } catch {\n // Ignore listener errors\n }\n }\n }\n\n // Notify session-level listeners (persistent connections)\n const sessionId = this.runSessionMap.get(runId);\n if (sessionId) {\n const sListeners = this.sessionListeners.get(sessionId);\n if (sListeners) {\n for (const listener of sListeners) {\n try {\n listener(seqEvent);\n } catch {\n // Ignore listener errors\n }\n }\n }\n }\n\n return seqEvent;\n }\n\n /**\n * Add a session-level listener — receives events from ALL runs in this session.\n */\n addSessionListener(sessionId: string, callback: AgentEventCallback): void {\n if (!this.sessionListeners.has(sessionId)) {\n this.sessionListeners.set(sessionId, new Set());\n }\n this.sessionListeners.get(sessionId)!.add(callback);\n }\n\n /**\n * Remove a session-level listener.\n */\n removeSessionListener(sessionId: string, callback: AgentEventCallback): void {\n const listeners = this.sessionListeners.get(sessionId);\n if (listeners) {\n listeners.delete(callback);\n if (listeners.size === 0) {\n this.sessionListeners.delete(sessionId);\n }\n }\n }\n\n /**\n * Get replay buffer for a run (all events emitted since start).\n * Used by WS handler to send missed events on late connection.\n * Optionally filter by afterSeq to only get events the client hasn't seen.\n */\n getEventBuffer(runId: string, afterSeq?: number): AgentEvent[] {\n const run = this.activeRuns.get(runId);\n if (!run) {return [];}\n\n if (afterSeq != null) {\n return run.eventBuffer.filter((e) => e.seq != null && e.seq > afterSeq);\n }\n return [...run.eventBuffer];\n }\n\n /**\n * List all active runs\n */\n listActive(): Array<{ runId: string; task: string; status: RunStatus; startedAt: string }> {\n return Array.from(this.activeRuns.values()).map(r => ({\n runId: r.runId,\n task: r.task,\n status: r.status,\n startedAt: r.startedAt,\n }));\n }\n\n /**\n * Request graceful stop of a running agent (and its child agents via propagated AbortSignal).\n * Agent finishes its current tool call then exits at the next iteration boundary.\n */\n requestStop(runId: string): boolean {\n const run = this.activeRuns.get(runId);\n if (!run || run.status !== 'running' || !run.agent) {\n return false;\n }\n run.agent.requestStop();\n return true;\n }\n\n /**\n * Clean up completed runs from memory (cache handles its own TTL)\n */\n cleanup(): void {\n for (const [runId, run] of this.activeRuns) {\n if (run.status === 'completed' || run.status === 'failed' || run.status === 'stopped') {\n // Remove from memory but keep in cache\n this.activeRuns.delete(runId);\n }\n }\n }\n}\n\n/**\n * Singleton instance — stored on globalThis so all bundled modules share one instance.\n * When tsup compiles multiple entry points, each gets its own module scope,\n * so a plain `export const RunManager = new RunManagerImpl()` creates separate instances.\n * Using globalThis ensures run-handler.js and session-stream-handler.js share one RunManager.\n */\nconst GLOBAL_KEY = '__kb_agent_run_manager__';\nif (!(globalThis as Record<string, unknown>)[GLOBAL_KEY]) {\n (globalThis as Record<string, unknown>)[GLOBAL_KEY] = new RunManagerImpl();\n}\nexport const RunManager = (globalThis as Record<string, unknown>)[GLOBAL_KEY] as RunManagerImpl;\n","/**\n * POST /sessions/:sessionId/plan/spec\n * Generate a detailed specification from an approved session plan.\n */\n\nimport { defineHandler, type RestInput, type PluginContextV3 } from '@kb-labs/sdk';\nimport { SessionManager, SpecModeHandler, createSessionMemoryBridge } from '@kb-labs/agent-core';\nimport { createDefaultResponseRequirementsSelector } from '@kb-labs/agent-runtime';\nimport { IncrementalTraceWriter } from '@kb-labs/agent-tracing';\nimport { createToolRegistry } from '@kb-labs/agent-tools';\nimport type {\n AgentEvent,\n GenerateSpecRequest,\n GenerateSpecResponse,\n KernelState,\n TaskPlan,\n} from '@kb-labs/agent-contracts';\nimport { promises as fs } from 'node:fs';\nimport path from 'node:path';\nimport { RunManager } from '../run-manager.js';\n\ninterface SpecRouteParams {\n sessionId?: string;\n}\n\nasync function loadPlan(planPath: string): Promise<TaskPlan> {\n const content = await fs.readFile(planPath, 'utf-8');\n return JSON.parse(content) as TaskPlan;\n}\n\nexport default defineHandler({\n async execute(\n ctx: PluginContextV3,\n input: RestInput<GenerateSpecRequest, unknown, SpecRouteParams>\n ): Promise<GenerateSpecResponse> {\n const params = input.params as Record<string, string> | undefined;\n const sessionId = params?.sessionId;\n const body = (input.body ?? {}) as GenerateSpecRequest;\n\n if (!sessionId) {\n throw new Error('Session ID is required');\n }\n\n const baseManager = new SessionManager(ctx.cwd);\n const session = await baseManager.loadSession(sessionId);\n if (!session) {\n throw new Error(`Session not found: ${sessionId}`);\n }\n\n const workingDir = session.workingDir || ctx.cwd;\n const sessionManager = new SessionManager(workingDir);\n const planPath = sessionManager.getSessionPlanPath(sessionId);\n\n let plan: TaskPlan;\n try {\n plan = await loadPlan(planPath);\n } catch {\n throw new Error(`Plan not found for session ${sessionId}`);\n }\n\n if (plan.status !== 'approved') {\n throw new Error(`Plan must be approved before spec generation (current status: ${plan.status})`);\n }\n\n // Run spec generation asynchronously via RunManager\n const runId = `run-spec-${Date.now()}-${Math.random().toString(36).slice(2, 9)}`;\n const startedAt = new Date().toISOString();\n const traceDir = path.join(workingDir, '.kb', 'traces', 'incremental');\n const traceWriter = new IncrementalTraceWriter(runId, {}, traceDir);\n await RunManager.register(\n runId,\n `Generate spec for plan ${plan.id}`,\n undefined,\n sessionManager,\n sessionId,\n );\n await RunManager.updateStatus(runId, 'running');\n\n // Start spec generation in background\n const specHandler = new SpecModeHandler();\n const sessionMemory = createSessionMemoryBridge(workingDir, sessionId);\n const responseRequirementsSelector = createDefaultResponseRequirementsSelector();\n const toolRegistry = createToolRegistry({\n workingDir,\n currentTask: `Generate spec for plan ${plan.id}`,\n sessionId,\n sessionMemory,\n responseRequirementsResolver: async ({ task, kernel }: {\n task?: string;\n answer: string;\n kernel: KernelState | null;\n }) =>\n responseRequirementsSelector.select({\n state: kernel,\n messages: [],\n task: task ?? `Generate spec for plan ${plan.id}`,\n }),\n });\n\n const specPromise = (async () => {\n const configOnEvent = (event: AgentEvent) => {\n traceWriter.trace(event);\n const seqEvent = RunManager.broadcast(runId, event);\n void sessionManager.addEvent(sessionId, {\n ...seqEvent,\n sessionId,\n runId,\n } as unknown as AgentEvent);\n };\n\n try {\n const result = await specHandler.execute(plan, {\n workingDir,\n sessionId,\n agentId: `spec-${sessionId}`,\n maxIterations: plan.phases.length * 8,\n tier: body.tier || 'medium',\n temperature: 0.1,\n onEvent: configOnEvent,\n }, toolRegistry);\n await RunManager.updateStatus(runId, result.success ? 'completed' : 'failed', {\n completedAt: new Date().toISOString(),\n summary: result.summary,\n error: result.success ? undefined : result.summary,\n });\n return result;\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n await RunManager.updateStatus(runId, 'failed', {\n completedAt: new Date().toISOString(),\n summary: message,\n error: message,\n });\n throw error;\n } finally {\n const detailedTrace = traceWriter.getEntries() as Array<Record<string, unknown>>;\n await traceWriter.finalize?.();\n if (detailedTrace.length > 0) {\n await sessionManager.storeTraceArtifacts(sessionId, runId, detailedTrace);\n }\n }\n })();\n\n void specPromise;\n\n return {\n sessionId,\n planId: plan.id,\n specId: `spec-${runId}`,\n runId,\n eventsPath: `/ws/plugins/agents/session/${sessionId}`,\n status: 'generating',\n startedAt,\n };\n },\n});\n"]}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import * as _kb_labs_shared_command_kit from '@kb-labs/shared-command-kit';
|
|
2
|
+
import { RestInput } from '@kb-labs/sdk';
|
|
3
|
+
|
|
4
|
+
interface GetFileDiffResponse {
|
|
5
|
+
changeId: string;
|
|
6
|
+
filePath: string;
|
|
7
|
+
operation: 'write' | 'patch' | 'delete';
|
|
8
|
+
diff: string;
|
|
9
|
+
before?: {
|
|
10
|
+
hash: string;
|
|
11
|
+
size: number;
|
|
12
|
+
};
|
|
13
|
+
after: {
|
|
14
|
+
hash: string;
|
|
15
|
+
size: number;
|
|
16
|
+
};
|
|
17
|
+
linesAdded: number;
|
|
18
|
+
linesRemoved: number;
|
|
19
|
+
isNew: boolean;
|
|
20
|
+
timestamp: string;
|
|
21
|
+
}
|
|
22
|
+
declare const _default: _kb_labs_shared_command_kit.Handler<unknown, RestInput<unknown, unknown, unknown>, GetFileDiffResponse>;
|
|
23
|
+
|
|
24
|
+
export { _default as default };
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { defineHandler } from '@kb-labs/sdk';
|
|
2
|
+
import { SessionManager } from '@kb-labs/agent-core';
|
|
3
|
+
import { ChangeStore, generateUnifiedDiff, countDiffLines } from '@kb-labs/agent-history';
|
|
4
|
+
|
|
5
|
+
// src/rest/handlers/get-file-diff-handler.ts
|
|
6
|
+
var get_file_diff_handler_default = defineHandler({
|
|
7
|
+
async execute(ctx, input) {
|
|
8
|
+
const params = input.params;
|
|
9
|
+
const sessionId = params?.sessionId;
|
|
10
|
+
const changeId = params?.changeId;
|
|
11
|
+
if (!sessionId) {
|
|
12
|
+
throw new Error("Session ID is required");
|
|
13
|
+
}
|
|
14
|
+
if (!changeId) {
|
|
15
|
+
throw new Error("Change ID is required");
|
|
16
|
+
}
|
|
17
|
+
const sessionManager = new SessionManager(ctx.cwd);
|
|
18
|
+
const session = await sessionManager.loadSession(sessionId);
|
|
19
|
+
const workingDir = session?.workingDir || ctx.cwd;
|
|
20
|
+
const store = new ChangeStore(workingDir);
|
|
21
|
+
const change = await store.get(sessionId, changeId);
|
|
22
|
+
if (!change) {
|
|
23
|
+
throw new Error(`Change not found: ${changeId} in session ${sessionId}`);
|
|
24
|
+
}
|
|
25
|
+
const diff = generateUnifiedDiff(change.filePath, change.before?.content, change.after.content, change.operation);
|
|
26
|
+
const { added, removed } = countDiffLines(diff);
|
|
27
|
+
return {
|
|
28
|
+
changeId: change.id,
|
|
29
|
+
filePath: change.filePath,
|
|
30
|
+
operation: change.operation,
|
|
31
|
+
diff,
|
|
32
|
+
before: change.before ? { hash: change.before.hash, size: change.before.size } : void 0,
|
|
33
|
+
after: { hash: change.after.hash, size: change.after.size },
|
|
34
|
+
linesAdded: added,
|
|
35
|
+
linesRemoved: removed,
|
|
36
|
+
isNew: !change.before,
|
|
37
|
+
timestamp: change.timestamp
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
|
|
42
|
+
export { get_file_diff_handler_default as default };
|
|
43
|
+
//# sourceMappingURL=get-file-diff-handler.js.map
|
|
44
|
+
//# sourceMappingURL=get-file-diff-handler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/rest/handlers/get-file-diff-handler.ts"],"names":[],"mappings":";;;;;AAqBA,IAAO,gCAAQ,aAAA,CAAc;AAAA,EAC3B,MAAM,OAAA,CAAQ,GAAA,EAAsB,KAAA,EAAgD;AAClF,IAAA,MAAM,SAAS,KAAA,CAAM,MAAA;AACrB,IAAA,MAAM,YAAY,MAAA,EAAQ,SAAA;AAC1B,IAAA,MAAM,WAAW,MAAA,EAAQ,QAAA;AACzB,IAAA,IAAI,CAAC,SAAA,EAAW;AAAC,MAAA,MAAM,IAAI,MAAM,wBAAwB,CAAA;AAAA,IAAE;AAC3D,IAAA,IAAI,CAAC,QAAA,EAAU;AAAC,MAAA,MAAM,IAAI,MAAM,uBAAuB,CAAA;AAAA,IAAE;AAEzD,IAAA,MAAM,cAAA,GAAiB,IAAI,cAAA,CAAe,GAAA,CAAI,GAAG,CAAA;AACjD,IAAA,MAAM,OAAA,GAAU,MAAM,cAAA,CAAe,WAAA,CAAY,SAAS,CAAA;AAC1D,IAAA,MAAM,UAAA,GAAa,OAAA,EAAS,UAAA,IAAc,GAAA,CAAI,GAAA;AAE9C,IAAA,MAAM,KAAA,GAAQ,IAAI,WAAA,CAAY,UAAU,CAAA;AACxC,IAAA,MAAM,MAAA,GAAS,MAAM,KAAA,CAAM,GAAA,CAAI,WAAW,QAAQ,CAAA;AAClD,IAAA,IAAI,CAAC,MAAA,EAAQ;AAAC,MAAA,MAAM,IAAI,KAAA,CAAM,CAAA,kBAAA,EAAqB,QAAQ,CAAA,YAAA,EAAe,SAAS,CAAA,CAAE,CAAA;AAAA,IAAE;AAEvF,IAAA,MAAM,IAAA,GAAO,mBAAA,CAAoB,MAAA,CAAO,QAAA,EAAU,MAAA,CAAO,MAAA,EAAQ,OAAA,EAAS,MAAA,CAAO,KAAA,CAAM,OAAA,EAAS,MAAA,CAAO,SAAS,CAAA;AAChH,IAAA,MAAM,EAAE,KAAA,EAAO,OAAA,EAAQ,GAAI,eAAe,IAAI,CAAA;AAE9C,IAAA,OAAO;AAAA,MACL,UAAU,MAAA,CAAO,EAAA;AAAA,MACjB,UAAU,MAAA,CAAO,QAAA;AAAA,MACjB,WAAW,MAAA,CAAO,SAAA;AAAA,MAClB,IAAA;AAAA,MACA,MAAA,EAAQ,MAAA,CAAO,MAAA,GAAS,EAAE,IAAA,EAAM,MAAA,CAAO,MAAA,CAAO,IAAA,EAAM,IAAA,EAAM,MAAA,CAAO,MAAA,CAAO,IAAA,EAAK,GAAI,MAAA;AAAA,MACjF,KAAA,EAAO,EAAE,IAAA,EAAM,MAAA,CAAO,MAAM,IAAA,EAAM,IAAA,EAAM,MAAA,CAAO,KAAA,CAAM,IAAA,EAAK;AAAA,MAC1D,UAAA,EAAY,KAAA;AAAA,MACZ,YAAA,EAAc,OAAA;AAAA,MACd,KAAA,EAAO,CAAC,MAAA,CAAO,MAAA;AAAA,MACf,WAAW,MAAA,CAAO;AAAA,KACpB;AAAA,EACF;AACF,CAAC","file":"get-file-diff-handler.js","sourcesContent":["/**\n * GET /sessions/:sessionId/changes/:changeId/diff — Unified diff for a file change snapshot.\n */\n\nimport { defineHandler, type RestInput, type PluginContextV3 } from '@kb-labs/sdk';\nimport { SessionManager } from '@kb-labs/agent-core';\nimport { ChangeStore, generateUnifiedDiff, countDiffLines } from '@kb-labs/agent-history';\n\ninterface GetFileDiffResponse {\n changeId: string;\n filePath: string;\n operation: 'write' | 'patch' | 'delete';\n diff: string;\n before?: { hash: string; size: number };\n after: { hash: string; size: number };\n linesAdded: number;\n linesRemoved: number;\n isNew: boolean;\n timestamp: string;\n}\n\nexport default defineHandler({\n async execute(ctx: PluginContextV3, input: RestInput): Promise<GetFileDiffResponse> {\n const params = input.params as Record<string, string> | undefined;\n const sessionId = params?.sessionId;\n const changeId = params?.changeId;\n if (!sessionId) {throw new Error('Session ID is required');}\n if (!changeId) {throw new Error('Change ID is required');}\n\n const sessionManager = new SessionManager(ctx.cwd);\n const session = await sessionManager.loadSession(sessionId);\n const workingDir = session?.workingDir || ctx.cwd;\n\n const store = new ChangeStore(workingDir);\n const change = await store.get(sessionId, changeId);\n if (!change) {throw new Error(`Change not found: ${changeId} in session ${sessionId}`);}\n\n const diff = generateUnifiedDiff(change.filePath, change.before?.content, change.after.content, change.operation);\n const { added, removed } = countDiffLines(diff);\n\n return {\n changeId: change.id,\n filePath: change.filePath,\n operation: change.operation,\n diff,\n before: change.before ? { hash: change.before.hash, size: change.before.size } : undefined,\n after: { hash: change.after.hash, size: change.after.size },\n linesAdded: added,\n linesRemoved: removed,\n isNew: !change.before,\n timestamp: change.timestamp,\n };\n },\n});\n"]}
|