@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
package/dist/index.js
ADDED
|
@@ -0,0 +1,473 @@
|
|
|
1
|
+
import { combinePermissions, kbPlatformPreset, defineCommandFlags } from '@kb-labs/sdk';
|
|
2
|
+
import { AGENTS_WS_CHANNELS, AGENTS_ROUTES, AGENTS_WS_BASE_PATH, AGENTS_BASE_PATH } from '@kb-labs/agent-contracts';
|
|
3
|
+
|
|
4
|
+
// src/manifest.ts
|
|
5
|
+
var runFlags = {
|
|
6
|
+
task: {
|
|
7
|
+
type: "string",
|
|
8
|
+
description: "Task description"
|
|
9
|
+
},
|
|
10
|
+
mode: {
|
|
11
|
+
type: "string",
|
|
12
|
+
description: "Agent mode: execute (default), plan, edit, debug",
|
|
13
|
+
default: "execute"
|
|
14
|
+
},
|
|
15
|
+
"session-id": {
|
|
16
|
+
type: "string",
|
|
17
|
+
description: "Session ID (auto-generated if not provided)"
|
|
18
|
+
},
|
|
19
|
+
complexity: {
|
|
20
|
+
type: "string",
|
|
21
|
+
description: "Task complexity (for plan mode): simple, medium, complex"
|
|
22
|
+
},
|
|
23
|
+
approve: {
|
|
24
|
+
type: "boolean",
|
|
25
|
+
description: "Auto-approve generated plan (supported with --mode=plan)",
|
|
26
|
+
default: false
|
|
27
|
+
},
|
|
28
|
+
execute: {
|
|
29
|
+
type: "boolean",
|
|
30
|
+
description: "After plan is approved, immediately execute it (use with --mode=plan --approve)",
|
|
31
|
+
default: false
|
|
32
|
+
},
|
|
33
|
+
files: {
|
|
34
|
+
type: "array",
|
|
35
|
+
description: "Target files (for edit mode)"
|
|
36
|
+
},
|
|
37
|
+
trace: {
|
|
38
|
+
type: "string",
|
|
39
|
+
description: "Trace file path (for debug mode)"
|
|
40
|
+
},
|
|
41
|
+
"dry-run": {
|
|
42
|
+
type: "boolean",
|
|
43
|
+
description: "Preview changes without applying (for edit mode)",
|
|
44
|
+
default: false
|
|
45
|
+
},
|
|
46
|
+
verbose: {
|
|
47
|
+
type: "boolean",
|
|
48
|
+
description: "Verbose output",
|
|
49
|
+
default: false
|
|
50
|
+
},
|
|
51
|
+
debug: {
|
|
52
|
+
type: "boolean",
|
|
53
|
+
description: "Enable debug mode: emit full prompts and responses as llm:debug events",
|
|
54
|
+
default: false
|
|
55
|
+
},
|
|
56
|
+
timeout: {
|
|
57
|
+
type: "number",
|
|
58
|
+
description: "Abort agent execution after this many seconds (exit code 124). No timeout by default."
|
|
59
|
+
},
|
|
60
|
+
budget: {
|
|
61
|
+
type: "number",
|
|
62
|
+
description: "Override token budget (e.g. 300000 for heavy tasks). Overrides config value."
|
|
63
|
+
},
|
|
64
|
+
json: {
|
|
65
|
+
type: "boolean",
|
|
66
|
+
description: "Output structured JSON result instead of human-readable output."
|
|
67
|
+
}
|
|
68
|
+
};
|
|
69
|
+
var pluginPermissions = combinePermissions().with(kbPlatformPreset).withFs({
|
|
70
|
+
mode: "readWrite",
|
|
71
|
+
allow: [".agent-memory/**", "**/*"]
|
|
72
|
+
// Allow filesystem operations in working dir
|
|
73
|
+
}).withPlatform({
|
|
74
|
+
llm: true,
|
|
75
|
+
// Full LLM access for agent execution
|
|
76
|
+
cache: ["agent:"],
|
|
77
|
+
// Cache namespace prefix
|
|
78
|
+
analytics: true
|
|
79
|
+
// Track agent usage
|
|
80
|
+
}).withQuotas({
|
|
81
|
+
timeoutMs: 18e5,
|
|
82
|
+
// 30 min for complex tasks
|
|
83
|
+
memoryMb: 1024
|
|
84
|
+
}).build();
|
|
85
|
+
var manifest = {
|
|
86
|
+
schema: "kb.plugin/3",
|
|
87
|
+
id: "@kb-labs/agent",
|
|
88
|
+
version: "0.1.0",
|
|
89
|
+
display: {
|
|
90
|
+
name: "Agent System",
|
|
91
|
+
description: "Autonomous agent system with LLM tool calling, task orchestration, and tier escalation.",
|
|
92
|
+
tags: ["agent", "autonomous", "llm", "orchestration"]
|
|
93
|
+
},
|
|
94
|
+
// Configuration lives under kb.config.json -> agents
|
|
95
|
+
configSection: "agents",
|
|
96
|
+
platform: {
|
|
97
|
+
requires: ["llm"],
|
|
98
|
+
optional: ["cache", "analytics", "logger"]
|
|
99
|
+
},
|
|
100
|
+
cli: {
|
|
101
|
+
commands: [
|
|
102
|
+
{
|
|
103
|
+
id: "agent:run",
|
|
104
|
+
group: "agent",
|
|
105
|
+
describe: "Run agent with specified mode (execute/plan/edit/debug)",
|
|
106
|
+
longDescription: "Unified agent command with multiple modes: execute (default) - run task immediately, plan - generate execution plan without running, edit - modify existing files, debug - analyze errors with trace context. Supports filesystem, search, shell, memory, and user interaction tools.",
|
|
107
|
+
handler: "./cli/commands/run.js#default",
|
|
108
|
+
handlerPath: "./cli/commands/run.js",
|
|
109
|
+
flags: defineCommandFlags(runFlags),
|
|
110
|
+
examples: [
|
|
111
|
+
'kb agent run --task="Create analytics system"',
|
|
112
|
+
'kb agent run --mode=plan --task="Add auth" --complexity=complex',
|
|
113
|
+
'kb agent run --mode=plan --task="Add auth" --approve',
|
|
114
|
+
'kb agent run --mode=plan --task="Add auth" --approve --execute',
|
|
115
|
+
'kb agent run --mode=edit --task="Fix bug" --files src/auth.ts',
|
|
116
|
+
'kb agent run --mode=debug --task="Why crash?" --trace .kb/traces/trace-123.json',
|
|
117
|
+
'kb agent run --task="Refactor auth module" --timeout=120'
|
|
118
|
+
]
|
|
119
|
+
},
|
|
120
|
+
// Trace debugging commands (AI-friendly)
|
|
121
|
+
{
|
|
122
|
+
id: "agent:trace:stats",
|
|
123
|
+
group: "agent",
|
|
124
|
+
describe: "Show trace statistics with cost and performance metrics",
|
|
125
|
+
longDescription: "Analyze trace file to show comprehensive statistics: iterations, LLM calls, token usage, tool usage, timing, and cost. Supports --json flag for AI agent consumption.",
|
|
126
|
+
handler: "./cli/commands/trace-stats.js#default",
|
|
127
|
+
handlerPath: "./cli/commands/trace-stats.js",
|
|
128
|
+
flags: defineCommandFlags({
|
|
129
|
+
"task-id": { type: "string", description: "Task ID or trace filename" },
|
|
130
|
+
json: { type: "boolean", description: "Output JSON for AI agents", default: false }
|
|
131
|
+
}),
|
|
132
|
+
examples: [
|
|
133
|
+
"kb agent trace stats --task-id=task-2026-01-29",
|
|
134
|
+
"kb agent trace stats --task-id=task-123 --json"
|
|
135
|
+
]
|
|
136
|
+
},
|
|
137
|
+
{
|
|
138
|
+
id: "agent:trace:filter",
|
|
139
|
+
group: "agent",
|
|
140
|
+
describe: "Filter trace events by type for debugging",
|
|
141
|
+
longDescription: "Filter trace events by type (llm:call, tool:execution, error:captured, etc.). Use this to debug specific aspects of agent execution. Supports --json flag for programmatic access.",
|
|
142
|
+
handler: "./cli/commands/trace-filter.js#default",
|
|
143
|
+
handlerPath: "./cli/commands/trace-filter.js",
|
|
144
|
+
flags: defineCommandFlags({
|
|
145
|
+
"task-id": { type: "string", description: "Task ID or trace filename" },
|
|
146
|
+
type: { type: "string", description: "Event type to filter (llm:call, tool:execution, etc.)" },
|
|
147
|
+
json: { type: "boolean", description: "Output JSON for AI agents", default: false }
|
|
148
|
+
}),
|
|
149
|
+
examples: [
|
|
150
|
+
"kb agent trace filter --task-id=task-123 --type=llm:call",
|
|
151
|
+
"kb agent trace filter --task-id=task-123 --type=error:captured --json"
|
|
152
|
+
]
|
|
153
|
+
},
|
|
154
|
+
{
|
|
155
|
+
id: "agent:trace:iteration",
|
|
156
|
+
group: "agent",
|
|
157
|
+
describe: "View all events for a specific iteration",
|
|
158
|
+
longDescription: "Show all trace events for a specific iteration number. Useful for debugging what happened in a particular loop iteration. Includes summary statistics and event timeline.",
|
|
159
|
+
handler: "./cli/commands/trace-iteration.js#default",
|
|
160
|
+
handlerPath: "./cli/commands/trace-iteration.js",
|
|
161
|
+
flags: defineCommandFlags({
|
|
162
|
+
"task-id": { type: "string", description: "Task ID or trace filename" },
|
|
163
|
+
iteration: { type: "number", description: "Iteration number (1-based)" },
|
|
164
|
+
json: { type: "boolean", description: "Output JSON for AI agents", default: false }
|
|
165
|
+
}),
|
|
166
|
+
examples: [
|
|
167
|
+
"kb agent trace iteration --task-id=task-123 --iteration=3",
|
|
168
|
+
"kb agent trace iteration --task-id=task-123 --iteration=5 --json"
|
|
169
|
+
]
|
|
170
|
+
},
|
|
171
|
+
{
|
|
172
|
+
id: "agent:trace:context",
|
|
173
|
+
group: "agent",
|
|
174
|
+
describe: "View what the LLM sees at each iteration \u2014 context window, truncations, responses",
|
|
175
|
+
longDescription: "Shows the full context timeline for debugging agent behavior. For each LLM call: what messages are in the sliding window, what was truncated/dropped, and what the LLM responded with.",
|
|
176
|
+
handler: "./cli/commands/trace-context.js#default",
|
|
177
|
+
handlerPath: "./cli/commands/trace-context.js",
|
|
178
|
+
flags: defineCommandFlags({
|
|
179
|
+
"task-id": { type: "string", description: "Task ID or trace filename" },
|
|
180
|
+
iteration: { type: "number", description: "Filter to specific iteration" },
|
|
181
|
+
json: { type: "boolean", description: "Output JSON for AI agents", default: false }
|
|
182
|
+
}),
|
|
183
|
+
examples: [
|
|
184
|
+
"kb agent trace context --task-id=task-123",
|
|
185
|
+
"kb agent trace context --task-id=task-123 --iteration=3",
|
|
186
|
+
"kb agent trace context --task-id=task-123 --json"
|
|
187
|
+
]
|
|
188
|
+
},
|
|
189
|
+
{
|
|
190
|
+
id: "agent:trace:diagnose",
|
|
191
|
+
group: "agent",
|
|
192
|
+
describe: 'Quick diagnostic analysis \u2014 answers "what went wrong?" in one command',
|
|
193
|
+
longDescription: "Comprehensive diagnostic report for agent execution. Analyzes errors, context window health (drops, truncations), tool failures, LLM reasoning text, loop detection, and quality indicators. One command to understand any agent issue.",
|
|
194
|
+
handler: "./cli/commands/trace-diagnose.js#default",
|
|
195
|
+
handlerPath: "./cli/commands/trace-diagnose.js",
|
|
196
|
+
flags: defineCommandFlags({
|
|
197
|
+
"task-id": { type: "string", description: "Task ID or trace filename" },
|
|
198
|
+
json: { type: "boolean", description: "Output JSON for AI agents", default: false }
|
|
199
|
+
}),
|
|
200
|
+
examples: [
|
|
201
|
+
"kb agent trace diagnose --task-id=task-123",
|
|
202
|
+
"kb agent trace diagnose --task-id=task-123 --json"
|
|
203
|
+
]
|
|
204
|
+
},
|
|
205
|
+
{
|
|
206
|
+
id: "agent:quality:report",
|
|
207
|
+
group: "agent",
|
|
208
|
+
describe: "Show quality control report for recent agent runs",
|
|
209
|
+
longDescription: "Aggregates agent KPI telemetry from analytics buffer and shows quality, token usage, tool efficiency, drift, and regression alerts. Useful for continuous quality control and cost/performance monitoring.",
|
|
210
|
+
handler: "./cli/commands/quality-report.js#default",
|
|
211
|
+
handlerPath: "./cli/commands/quality-report.js",
|
|
212
|
+
flags: defineCommandFlags({
|
|
213
|
+
days: { type: "number", description: "Lookback period in days", default: 1 },
|
|
214
|
+
limit: { type: "number", description: "Max KPI runs to analyze", default: 200 },
|
|
215
|
+
"session-id": { type: "string", description: "Filter by session ID" },
|
|
216
|
+
json: { type: "boolean", description: "Output JSON for automation", default: false }
|
|
217
|
+
}),
|
|
218
|
+
examples: [
|
|
219
|
+
"kb agent quality report",
|
|
220
|
+
"kb agent quality report --days=7",
|
|
221
|
+
"kb agent quality report --session-id=session-123",
|
|
222
|
+
"kb agent quality report --days=3 --json"
|
|
223
|
+
]
|
|
224
|
+
},
|
|
225
|
+
// File change history commands
|
|
226
|
+
{
|
|
227
|
+
id: "agent:history",
|
|
228
|
+
group: "agent",
|
|
229
|
+
describe: "Show file change history for agent sessions",
|
|
230
|
+
longDescription: "View file changes made by agents during execution. Filter by session, file, or agent. Shows timestamps, operations, and change metadata.",
|
|
231
|
+
handler: "./cli/commands/history.js#default",
|
|
232
|
+
handlerPath: "./cli/commands/history.js",
|
|
233
|
+
flags: defineCommandFlags({
|
|
234
|
+
"session-id": { type: "string", description: "Session ID to filter by" },
|
|
235
|
+
file: { type: "string", description: "File path to filter by" },
|
|
236
|
+
"agent-id": { type: "string", description: "Agent ID to filter by" },
|
|
237
|
+
json: { type: "boolean", description: "Output JSON for AI agents", default: false }
|
|
238
|
+
}),
|
|
239
|
+
examples: [
|
|
240
|
+
"kb agent history",
|
|
241
|
+
"kb agent history --session-id=session-123",
|
|
242
|
+
"kb agent history --file=src/index.ts",
|
|
243
|
+
"kb agent history --agent-id=agent-abc --json"
|
|
244
|
+
]
|
|
245
|
+
},
|
|
246
|
+
{
|
|
247
|
+
id: "agent:diff",
|
|
248
|
+
group: "agent",
|
|
249
|
+
describe: "Show diff for specific file change",
|
|
250
|
+
longDescription: "Display line-by-line diff for a specific file change. Shows additions, deletions, and modifications with context.",
|
|
251
|
+
handler: "./cli/commands/diff.js#default",
|
|
252
|
+
handlerPath: "./cli/commands/diff.js",
|
|
253
|
+
flags: defineCommandFlags({
|
|
254
|
+
"change-id": { type: "string", description: "Change ID to show diff for" },
|
|
255
|
+
json: { type: "boolean", description: "Output JSON for AI agents", default: false }
|
|
256
|
+
}),
|
|
257
|
+
examples: [
|
|
258
|
+
"kb agent diff --change-id=change-abc123",
|
|
259
|
+
"kb agent diff --change-id=change-abc123 --json"
|
|
260
|
+
]
|
|
261
|
+
},
|
|
262
|
+
{
|
|
263
|
+
id: "agent:rollback",
|
|
264
|
+
group: "agent",
|
|
265
|
+
describe: "Rollback file changes made by agents",
|
|
266
|
+
longDescription: "Rollback file changes made by agents. Supports rollback by change ID, file path, agent ID, session, or timestamp. Use --dry-run to preview changes before applying.",
|
|
267
|
+
handler: "./cli/commands/rollback.js#default",
|
|
268
|
+
handlerPath: "./cli/commands/rollback.js",
|
|
269
|
+
flags: defineCommandFlags({
|
|
270
|
+
"change-id": { type: "string", description: "Change ID to rollback" },
|
|
271
|
+
file: { type: "string", description: "File path to rollback all changes for" },
|
|
272
|
+
"agent-id": { type: "string", description: "Agent ID to rollback all changes by" },
|
|
273
|
+
"session-id": { type: "string", description: "Session ID to rollback all changes in" },
|
|
274
|
+
after: { type: "string", description: "Rollback all changes after timestamp (ISO 8601)" },
|
|
275
|
+
force: { type: "boolean", description: "Force rollback even with conflicts", default: false },
|
|
276
|
+
"dry-run": { type: "boolean", description: "Preview rollback without applying", default: false },
|
|
277
|
+
json: { type: "boolean", description: "Output JSON for AI agents", default: false }
|
|
278
|
+
}),
|
|
279
|
+
examples: [
|
|
280
|
+
"kb agent rollback --change-id=change-abc123",
|
|
281
|
+
"kb agent rollback --file=src/index.ts --dry-run",
|
|
282
|
+
"kb agent rollback --agent-id=agent-abc",
|
|
283
|
+
"kb agent rollback --session-id=session-123",
|
|
284
|
+
'kb agent rollback --after="2026-02-16T10:00:00Z" --json'
|
|
285
|
+
]
|
|
286
|
+
}
|
|
287
|
+
]
|
|
288
|
+
},
|
|
289
|
+
capabilities: [],
|
|
290
|
+
permissions: pluginPermissions,
|
|
291
|
+
// REST API for Agent UI
|
|
292
|
+
rest: {
|
|
293
|
+
basePath: AGENTS_BASE_PATH,
|
|
294
|
+
defaults: {
|
|
295
|
+
timeoutMs: 18e5
|
|
296
|
+
// 30 min for long-running tasks
|
|
297
|
+
},
|
|
298
|
+
routes: [
|
|
299
|
+
{
|
|
300
|
+
method: "POST",
|
|
301
|
+
path: AGENTS_ROUTES.RUN,
|
|
302
|
+
description: "Start a new agent run",
|
|
303
|
+
handler: "./rest/handlers/run-handler.js",
|
|
304
|
+
security: ["none"]
|
|
305
|
+
},
|
|
306
|
+
{
|
|
307
|
+
method: "GET",
|
|
308
|
+
path: AGENTS_ROUTES.RUN_STATUS,
|
|
309
|
+
description: "Get status of a run",
|
|
310
|
+
handler: "./rest/handlers/status-handler.js",
|
|
311
|
+
security: ["none"]
|
|
312
|
+
},
|
|
313
|
+
{
|
|
314
|
+
method: "POST",
|
|
315
|
+
path: AGENTS_ROUTES.CORRECT,
|
|
316
|
+
description: "Send correction to running agent(s)",
|
|
317
|
+
handler: "./rest/handlers/correct-handler.js",
|
|
318
|
+
security: ["none"]
|
|
319
|
+
},
|
|
320
|
+
{
|
|
321
|
+
method: "POST",
|
|
322
|
+
path: AGENTS_ROUTES.STOP,
|
|
323
|
+
description: "Stop a running agent",
|
|
324
|
+
handler: "./rest/handlers/stop-handler.js",
|
|
325
|
+
security: ["none"]
|
|
326
|
+
},
|
|
327
|
+
// Session management routes
|
|
328
|
+
{
|
|
329
|
+
method: "GET",
|
|
330
|
+
path: AGENTS_ROUTES.SESSIONS_LIST,
|
|
331
|
+
description: "List all sessions",
|
|
332
|
+
handler: "./rest/handlers/list-sessions-handler.js",
|
|
333
|
+
security: ["none"]
|
|
334
|
+
},
|
|
335
|
+
{
|
|
336
|
+
method: "GET",
|
|
337
|
+
path: AGENTS_ROUTES.SESSION_GET,
|
|
338
|
+
description: "Get session details",
|
|
339
|
+
handler: "./rest/handlers/get-session-handler.js",
|
|
340
|
+
security: ["none"]
|
|
341
|
+
},
|
|
342
|
+
{
|
|
343
|
+
method: "POST",
|
|
344
|
+
path: AGENTS_ROUTES.SESSION_CREATE,
|
|
345
|
+
description: "Create a new session",
|
|
346
|
+
handler: "./rest/handlers/create-session-handler.js",
|
|
347
|
+
security: ["none"]
|
|
348
|
+
},
|
|
349
|
+
{
|
|
350
|
+
method: "GET",
|
|
351
|
+
path: AGENTS_ROUTES.SESSION_TURNS,
|
|
352
|
+
description: "Get session turns (turn-based UI)",
|
|
353
|
+
handler: "./rest/handlers/get-session-turns-handler.js",
|
|
354
|
+
security: ["none"]
|
|
355
|
+
},
|
|
356
|
+
{
|
|
357
|
+
method: "GET",
|
|
358
|
+
path: AGENTS_ROUTES.SESSION_PLAN_GET,
|
|
359
|
+
description: "Get current session plan",
|
|
360
|
+
handler: "./rest/handlers/get-session-plan-handler.js",
|
|
361
|
+
security: ["none"]
|
|
362
|
+
},
|
|
363
|
+
{
|
|
364
|
+
method: "POST",
|
|
365
|
+
path: AGENTS_ROUTES.SESSION_PLAN_APPROVE,
|
|
366
|
+
description: "Approve current session plan",
|
|
367
|
+
handler: "./rest/handlers/approve-session-plan-handler.js",
|
|
368
|
+
security: ["none"]
|
|
369
|
+
},
|
|
370
|
+
{
|
|
371
|
+
method: "POST",
|
|
372
|
+
path: AGENTS_ROUTES.SESSION_PLAN_EXECUTE,
|
|
373
|
+
description: "Execute approved session plan",
|
|
374
|
+
handler: "./rest/handlers/execute-session-plan-handler.js",
|
|
375
|
+
security: ["none"]
|
|
376
|
+
},
|
|
377
|
+
{
|
|
378
|
+
method: "POST",
|
|
379
|
+
path: AGENTS_ROUTES.SESSION_PLAN_SPEC,
|
|
380
|
+
description: "Generate detailed spec from approved plan",
|
|
381
|
+
handler: "./rest/handlers/generate-spec-handler.js",
|
|
382
|
+
security: ["none"]
|
|
383
|
+
},
|
|
384
|
+
{
|
|
385
|
+
method: "GET",
|
|
386
|
+
path: AGENTS_ROUTES.SESSION_PLAN_SPEC_GET,
|
|
387
|
+
description: "Get current session spec",
|
|
388
|
+
handler: "./rest/handlers/get-spec-handler.js",
|
|
389
|
+
security: ["none"]
|
|
390
|
+
},
|
|
391
|
+
// File change history routes (rollback & approve)
|
|
392
|
+
{
|
|
393
|
+
method: "GET",
|
|
394
|
+
path: AGENTS_ROUTES.SESSION_CHANGES,
|
|
395
|
+
description: "List file changes for session (optionally filtered by runId)",
|
|
396
|
+
handler: "./rest/handlers/list-file-changes-handler.js",
|
|
397
|
+
security: ["none"]
|
|
398
|
+
},
|
|
399
|
+
{
|
|
400
|
+
method: "GET",
|
|
401
|
+
path: AGENTS_ROUTES.SESSION_CHANGE_DIFF,
|
|
402
|
+
description: "Get unified diff for a specific file change",
|
|
403
|
+
handler: "./rest/handlers/get-file-diff-handler.js",
|
|
404
|
+
security: ["none"]
|
|
405
|
+
},
|
|
406
|
+
{
|
|
407
|
+
method: "POST",
|
|
408
|
+
path: AGENTS_ROUTES.SESSION_ROLLBACK,
|
|
409
|
+
description: "Rollback file changes for a session/run",
|
|
410
|
+
handler: "./rest/handlers/rollback-handler.js",
|
|
411
|
+
security: ["none"]
|
|
412
|
+
},
|
|
413
|
+
{
|
|
414
|
+
method: "POST",
|
|
415
|
+
path: AGENTS_ROUTES.SESSION_APPROVE,
|
|
416
|
+
description: "Approve file changes for a session/run",
|
|
417
|
+
handler: "./rest/handlers/approve-handler.js",
|
|
418
|
+
security: ["none"]
|
|
419
|
+
}
|
|
420
|
+
]
|
|
421
|
+
},
|
|
422
|
+
// WebSocket for real-time event streaming
|
|
423
|
+
ws: {
|
|
424
|
+
basePath: AGENTS_WS_BASE_PATH,
|
|
425
|
+
defaults: {
|
|
426
|
+
auth: "none",
|
|
427
|
+
idleTimeoutMs: 36e5
|
|
428
|
+
// 1 hour
|
|
429
|
+
},
|
|
430
|
+
channels: [
|
|
431
|
+
{
|
|
432
|
+
path: AGENTS_WS_CHANNELS.SESSION_STREAM,
|
|
433
|
+
description: "Persistent session stream (all runs in session)",
|
|
434
|
+
handler: "./ws/session-stream-handler.js",
|
|
435
|
+
auth: "none"
|
|
436
|
+
}
|
|
437
|
+
]
|
|
438
|
+
},
|
|
439
|
+
artifacts: [
|
|
440
|
+
{
|
|
441
|
+
id: "agent.memory.json",
|
|
442
|
+
pathTemplate: ".agent-memory/memory.json",
|
|
443
|
+
description: "Persistent agent memory (facts, sessions, project context)."
|
|
444
|
+
}
|
|
445
|
+
],
|
|
446
|
+
studio: {
|
|
447
|
+
version: 2,
|
|
448
|
+
remoteName: "agentPlugin",
|
|
449
|
+
pages: [
|
|
450
|
+
{
|
|
451
|
+
id: "agent.overview",
|
|
452
|
+
title: "Agent",
|
|
453
|
+
icon: "RobotOutlined",
|
|
454
|
+
route: "/p/agent",
|
|
455
|
+
entry: "./AgentsPage",
|
|
456
|
+
order: 1
|
|
457
|
+
}
|
|
458
|
+
],
|
|
459
|
+
menus: [
|
|
460
|
+
{
|
|
461
|
+
id: "agent",
|
|
462
|
+
label: "Agent",
|
|
463
|
+
icon: "RobotOutlined",
|
|
464
|
+
target: "agent.overview",
|
|
465
|
+
order: 30
|
|
466
|
+
}
|
|
467
|
+
]
|
|
468
|
+
}
|
|
469
|
+
};
|
|
470
|
+
|
|
471
|
+
export { manifest };
|
|
472
|
+
//# sourceMappingURL=index.js.map
|
|
473
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/manifest.ts"],"names":[],"mappings":"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","file":"index.js","sourcesContent":["/**\n * KB Labs Agent Plugin - Manifest V3\n */\n\nimport {\n combinePermissions,\n kbPlatformPreset,\n defineCommandFlags,\n} from '@kb-labs/sdk';\nimport {\n AGENTS_BASE_PATH,\n AGENTS_WS_BASE_PATH,\n AGENTS_ROUTES,\n AGENTS_WS_CHANNELS,\n} from '@kb-labs/agent-contracts';\n\n/**\n * Command flags for agent:run (unified command with modes)\n */\nconst runFlags = {\n task: {\n type: 'string',\n description: 'Task description',\n },\n mode: {\n type: 'string',\n description: 'Agent mode: execute (default), plan, edit, debug',\n default: 'execute',\n },\n 'session-id': {\n type: 'string',\n description: 'Session ID (auto-generated if not provided)',\n },\n complexity: {\n type: 'string',\n description: 'Task complexity (for plan mode): simple, medium, complex',\n },\n approve: {\n type: 'boolean',\n description: 'Auto-approve generated plan (supported with --mode=plan)',\n default: false,\n },\n execute: {\n type: 'boolean',\n description: 'After plan is approved, immediately execute it (use with --mode=plan --approve)',\n default: false,\n },\n files: {\n type: 'array',\n description: 'Target files (for edit mode)',\n },\n trace: {\n type: 'string',\n description: 'Trace file path (for debug mode)',\n },\n 'dry-run': {\n type: 'boolean',\n description: 'Preview changes without applying (for edit mode)',\n default: false,\n },\n verbose: {\n type: 'boolean',\n description: 'Verbose output',\n default: false,\n },\n debug: {\n type: 'boolean',\n description: 'Enable debug mode: emit full prompts and responses as llm:debug events',\n default: false,\n },\n timeout: {\n type: 'number',\n description: 'Abort agent execution after this many seconds (exit code 124). No timeout by default.',\n },\n budget: {\n type: 'number',\n description: 'Override token budget (e.g. 300000 for heavy tasks). Overrides config value.',\n },\n json: {\n type: 'boolean',\n description: 'Output structured JSON result instead of human-readable output.',\n },\n} as const;\n\n/**\n * Plugin permissions\n */\nconst pluginPermissions = combinePermissions()\n .with(kbPlatformPreset)\n .withFs({\n mode: 'readWrite',\n allow: ['.agent-memory/**', '**/*'], // Allow filesystem operations in working dir\n })\n .withPlatform({\n llm: true, // Full LLM access for agent execution\n cache: ['agent:'], // Cache namespace prefix\n analytics: true, // Track agent usage\n })\n .withQuotas({\n timeoutMs: 1800000, // 30 min for complex tasks\n memoryMb: 1024,\n })\n .build();\n\nexport const manifest = {\n schema: 'kb.plugin/3',\n id: '@kb-labs/agent',\n version: '0.1.0',\n\n display: {\n name: 'Agent System',\n description: 'Autonomous agent system with LLM tool calling, task orchestration, and tier escalation.',\n tags: ['agent', 'autonomous', 'llm', 'orchestration'],\n },\n\n // Configuration lives under kb.config.json -> agents\n configSection: 'agents',\n\n platform: {\n requires: ['llm'],\n optional: ['cache', 'analytics', 'logger'],\n },\n\n cli: {\n commands: [\n {\n id: 'agent:run',\n group: 'agent',\n describe: 'Run agent with specified mode (execute/plan/edit/debug)',\n longDescription:\n 'Unified agent command with multiple modes: ' +\n 'execute (default) - run task immediately, ' +\n 'plan - generate execution plan without running, ' +\n 'edit - modify existing files, ' +\n 'debug - analyze errors with trace context. ' +\n 'Supports filesystem, search, shell, memory, and user interaction tools.',\n\n handler: './cli/commands/run.js#default',\n handlerPath: './cli/commands/run.js',\n\n flags: defineCommandFlags(runFlags),\n\n examples: [\n 'kb agent run --task=\"Create analytics system\"',\n 'kb agent run --mode=plan --task=\"Add auth\" --complexity=complex',\n 'kb agent run --mode=plan --task=\"Add auth\" --approve',\n 'kb agent run --mode=plan --task=\"Add auth\" --approve --execute',\n 'kb agent run --mode=edit --task=\"Fix bug\" --files src/auth.ts',\n 'kb agent run --mode=debug --task=\"Why crash?\" --trace .kb/traces/trace-123.json',\n 'kb agent run --task=\"Refactor auth module\" --timeout=120',\n ],\n },\n // Trace debugging commands (AI-friendly)\n {\n id: 'agent:trace:stats',\n group: 'agent',\n describe: 'Show trace statistics with cost and performance metrics',\n longDescription:\n 'Analyze trace file to show comprehensive statistics: ' +\n 'iterations, LLM calls, token usage, tool usage, timing, and cost. ' +\n 'Supports --json flag for AI agent consumption.',\n\n handler: './cli/commands/trace-stats.js#default',\n handlerPath: './cli/commands/trace-stats.js',\n\n flags: defineCommandFlags({\n 'task-id': { type: 'string', description: 'Task ID or trace filename' },\n json: { type: 'boolean', description: 'Output JSON for AI agents', default: false },\n }),\n\n examples: [\n 'kb agent trace stats --task-id=task-2026-01-29',\n 'kb agent trace stats --task-id=task-123 --json',\n ],\n },\n {\n id: 'agent:trace:filter',\n group: 'agent',\n describe: 'Filter trace events by type for debugging',\n longDescription:\n 'Filter trace events by type (llm:call, tool:execution, error:captured, etc.). ' +\n 'Use this to debug specific aspects of agent execution. ' +\n 'Supports --json flag for programmatic access.',\n\n handler: './cli/commands/trace-filter.js#default',\n handlerPath: './cli/commands/trace-filter.js',\n\n flags: defineCommandFlags({\n 'task-id': { type: 'string', description: 'Task ID or trace filename' },\n type: { type: 'string', description: 'Event type to filter (llm:call, tool:execution, etc.)' },\n json: { type: 'boolean', description: 'Output JSON for AI agents', default: false },\n }),\n\n examples: [\n 'kb agent trace filter --task-id=task-123 --type=llm:call',\n 'kb agent trace filter --task-id=task-123 --type=error:captured --json',\n ],\n },\n {\n id: 'agent:trace:iteration',\n group: 'agent',\n describe: 'View all events for a specific iteration',\n longDescription:\n 'Show all trace events for a specific iteration number. ' +\n 'Useful for debugging what happened in a particular loop iteration. ' +\n 'Includes summary statistics and event timeline.',\n\n handler: './cli/commands/trace-iteration.js#default',\n handlerPath: './cli/commands/trace-iteration.js',\n\n flags: defineCommandFlags({\n 'task-id': { type: 'string', description: 'Task ID or trace filename' },\n iteration: { type: 'number', description: 'Iteration number (1-based)' },\n json: { type: 'boolean', description: 'Output JSON for AI agents', default: false },\n }),\n\n examples: [\n 'kb agent trace iteration --task-id=task-123 --iteration=3',\n 'kb agent trace iteration --task-id=task-123 --iteration=5 --json',\n ],\n },\n {\n id: 'agent:trace:context',\n group: 'agent',\n describe: 'View what the LLM sees at each iteration — context window, truncations, responses',\n longDescription:\n 'Shows the full context timeline for debugging agent behavior. ' +\n 'For each LLM call: what messages are in the sliding window, ' +\n 'what was truncated/dropped, and what the LLM responded with.',\n\n handler: './cli/commands/trace-context.js#default',\n handlerPath: './cli/commands/trace-context.js',\n\n flags: defineCommandFlags({\n 'task-id': { type: 'string', description: 'Task ID or trace filename' },\n iteration: { type: 'number', description: 'Filter to specific iteration' },\n json: { type: 'boolean', description: 'Output JSON for AI agents', default: false },\n }),\n\n examples: [\n 'kb agent trace context --task-id=task-123',\n 'kb agent trace context --task-id=task-123 --iteration=3',\n 'kb agent trace context --task-id=task-123 --json',\n ],\n },\n {\n id: 'agent:trace:diagnose',\n group: 'agent',\n describe: 'Quick diagnostic analysis — answers \"what went wrong?\" in one command',\n longDescription:\n 'Comprehensive diagnostic report for agent execution. ' +\n 'Analyzes errors, context window health (drops, truncations), ' +\n 'tool failures, LLM reasoning text, loop detection, and quality indicators. ' +\n 'One command to understand any agent issue.',\n\n handler: './cli/commands/trace-diagnose.js#default',\n handlerPath: './cli/commands/trace-diagnose.js',\n\n flags: defineCommandFlags({\n 'task-id': { type: 'string', description: 'Task ID or trace filename' },\n json: { type: 'boolean', description: 'Output JSON for AI agents', default: false },\n }),\n\n examples: [\n 'kb agent trace diagnose --task-id=task-123',\n 'kb agent trace diagnose --task-id=task-123 --json',\n ],\n },\n {\n id: 'agent:quality:report',\n group: 'agent',\n describe: 'Show quality control report for recent agent runs',\n longDescription:\n 'Aggregates agent KPI telemetry from analytics buffer and shows ' +\n 'quality, token usage, tool efficiency, drift, and regression alerts. ' +\n 'Useful for continuous quality control and cost/performance monitoring.',\n\n handler: './cli/commands/quality-report.js#default',\n handlerPath: './cli/commands/quality-report.js',\n\n flags: defineCommandFlags({\n days: { type: 'number', description: 'Lookback period in days', default: 1 },\n limit: { type: 'number', description: 'Max KPI runs to analyze', default: 200 },\n 'session-id': { type: 'string', description: 'Filter by session ID' },\n json: { type: 'boolean', description: 'Output JSON for automation', default: false },\n }),\n\n examples: [\n 'kb agent quality report',\n 'kb agent quality report --days=7',\n 'kb agent quality report --session-id=session-123',\n 'kb agent quality report --days=3 --json',\n ],\n },\n // File change history commands\n {\n id: 'agent:history',\n group: 'agent',\n describe: 'Show file change history for agent sessions',\n longDescription:\n 'View file changes made by agents during execution. ' +\n 'Filter by session, file, or agent. Shows timestamps, operations, and change metadata.',\n\n handler: './cli/commands/history.js#default',\n handlerPath: './cli/commands/history.js',\n\n flags: defineCommandFlags({\n 'session-id': { type: 'string', description: 'Session ID to filter by' },\n file: { type: 'string', description: 'File path to filter by' },\n 'agent-id': { type: 'string', description: 'Agent ID to filter by' },\n json: { type: 'boolean', description: 'Output JSON for AI agents', default: false },\n }),\n\n examples: [\n 'kb agent history',\n 'kb agent history --session-id=session-123',\n 'kb agent history --file=src/index.ts',\n 'kb agent history --agent-id=agent-abc --json',\n ],\n },\n {\n id: 'agent:diff',\n group: 'agent',\n describe: 'Show diff for specific file change',\n longDescription:\n 'Display line-by-line diff for a specific file change. ' +\n 'Shows additions, deletions, and modifications with context.',\n\n handler: './cli/commands/diff.js#default',\n handlerPath: './cli/commands/diff.js',\n\n flags: defineCommandFlags({\n 'change-id': { type: 'string', description: 'Change ID to show diff for' },\n json: { type: 'boolean', description: 'Output JSON for AI agents', default: false },\n }),\n\n examples: [\n 'kb agent diff --change-id=change-abc123',\n 'kb agent diff --change-id=change-abc123 --json',\n ],\n },\n {\n id: 'agent:rollback',\n group: 'agent',\n describe: 'Rollback file changes made by agents',\n longDescription:\n 'Rollback file changes made by agents. ' +\n 'Supports rollback by change ID, file path, agent ID, session, or timestamp. ' +\n 'Use --dry-run to preview changes before applying.',\n\n handler: './cli/commands/rollback.js#default',\n handlerPath: './cli/commands/rollback.js',\n\n flags: defineCommandFlags({\n 'change-id': { type: 'string', description: 'Change ID to rollback' },\n file: { type: 'string', description: 'File path to rollback all changes for' },\n 'agent-id': { type: 'string', description: 'Agent ID to rollback all changes by' },\n 'session-id': { type: 'string', description: 'Session ID to rollback all changes in' },\n after: { type: 'string', description: 'Rollback all changes after timestamp (ISO 8601)' },\n force: { type: 'boolean', description: 'Force rollback even with conflicts', default: false },\n 'dry-run': { type: 'boolean', description: 'Preview rollback without applying', default: false },\n json: { type: 'boolean', description: 'Output JSON for AI agents', default: false },\n }),\n\n examples: [\n 'kb agent rollback --change-id=change-abc123',\n 'kb agent rollback --file=src/index.ts --dry-run',\n 'kb agent rollback --agent-id=agent-abc',\n 'kb agent rollback --session-id=session-123',\n 'kb agent rollback --after=\"2026-02-16T10:00:00Z\" --json',\n ],\n },\n ],\n },\n\n capabilities: [],\n\n permissions: pluginPermissions,\n\n // REST API for Agent UI\n rest: {\n basePath: AGENTS_BASE_PATH,\n defaults: {\n timeoutMs: 1800000, // 30 min for long-running tasks\n },\n routes: [\n {\n method: 'POST',\n path: AGENTS_ROUTES.RUN,\n description: 'Start a new agent run',\n handler: './rest/handlers/run-handler.js',\n security: ['none'],\n },\n {\n method: 'GET',\n path: AGENTS_ROUTES.RUN_STATUS,\n description: 'Get status of a run',\n handler: './rest/handlers/status-handler.js',\n security: ['none'],\n },\n {\n method: 'POST',\n path: AGENTS_ROUTES.CORRECT,\n description: 'Send correction to running agent(s)',\n handler: './rest/handlers/correct-handler.js',\n security: ['none'],\n },\n {\n method: 'POST',\n path: AGENTS_ROUTES.STOP,\n description: 'Stop a running agent',\n handler: './rest/handlers/stop-handler.js',\n security: ['none'],\n },\n // Session management routes\n {\n method: 'GET',\n path: AGENTS_ROUTES.SESSIONS_LIST,\n description: 'List all sessions',\n handler: './rest/handlers/list-sessions-handler.js',\n security: ['none'],\n },\n {\n method: 'GET',\n path: AGENTS_ROUTES.SESSION_GET,\n description: 'Get session details',\n handler: './rest/handlers/get-session-handler.js',\n security: ['none'],\n },\n {\n method: 'POST',\n path: AGENTS_ROUTES.SESSION_CREATE,\n description: 'Create a new session',\n handler: './rest/handlers/create-session-handler.js',\n security: ['none'],\n },\n {\n method: 'GET',\n path: AGENTS_ROUTES.SESSION_TURNS,\n description: 'Get session turns (turn-based UI)',\n handler: './rest/handlers/get-session-turns-handler.js',\n security: ['none'],\n },\n {\n method: 'GET',\n path: AGENTS_ROUTES.SESSION_PLAN_GET,\n description: 'Get current session plan',\n handler: './rest/handlers/get-session-plan-handler.js',\n security: ['none'],\n },\n {\n method: 'POST',\n path: AGENTS_ROUTES.SESSION_PLAN_APPROVE,\n description: 'Approve current session plan',\n handler: './rest/handlers/approve-session-plan-handler.js',\n security: ['none'],\n },\n {\n method: 'POST',\n path: AGENTS_ROUTES.SESSION_PLAN_EXECUTE,\n description: 'Execute approved session plan',\n handler: './rest/handlers/execute-session-plan-handler.js',\n security: ['none'],\n },\n {\n method: 'POST',\n path: AGENTS_ROUTES.SESSION_PLAN_SPEC,\n description: 'Generate detailed spec from approved plan',\n handler: './rest/handlers/generate-spec-handler.js',\n security: ['none'],\n },\n {\n method: 'GET',\n path: AGENTS_ROUTES.SESSION_PLAN_SPEC_GET,\n description: 'Get current session spec',\n handler: './rest/handlers/get-spec-handler.js',\n security: ['none'],\n },\n // File change history routes (rollback & approve)\n {\n method: 'GET',\n path: AGENTS_ROUTES.SESSION_CHANGES,\n description: 'List file changes for session (optionally filtered by runId)',\n handler: './rest/handlers/list-file-changes-handler.js',\n security: ['none'],\n },\n {\n method: 'GET',\n path: AGENTS_ROUTES.SESSION_CHANGE_DIFF,\n description: 'Get unified diff for a specific file change',\n handler: './rest/handlers/get-file-diff-handler.js',\n security: ['none'],\n },\n {\n method: 'POST',\n path: AGENTS_ROUTES.SESSION_ROLLBACK,\n description: 'Rollback file changes for a session/run',\n handler: './rest/handlers/rollback-handler.js',\n security: ['none'],\n },\n {\n method: 'POST',\n path: AGENTS_ROUTES.SESSION_APPROVE,\n description: 'Approve file changes for a session/run',\n handler: './rest/handlers/approve-handler.js',\n security: ['none'],\n },\n ],\n },\n\n // WebSocket for real-time event streaming\n ws: {\n basePath: AGENTS_WS_BASE_PATH,\n defaults: {\n auth: 'none',\n idleTimeoutMs: 3600000, // 1 hour\n },\n channels: [\n {\n path: AGENTS_WS_CHANNELS.SESSION_STREAM,\n description: 'Persistent session stream (all runs in session)',\n handler: './ws/session-stream-handler.js',\n auth: 'none',\n },\n ],\n },\n\n artifacts: [\n {\n id: 'agent.memory.json',\n pathTemplate: '.agent-memory/memory.json',\n description: 'Persistent agent memory (facts, sessions, project context).',\n },\n ],\n\n studio: {\n version: 2 as const,\n remoteName: 'agentPlugin',\n pages: [\n {\n id: 'agent.overview',\n title: 'Agent',\n icon: 'RobotOutlined',\n route: '/p/agent',\n entry: './AgentsPage',\n order: 1,\n },\n ],\n menus: [\n {\n id: 'agent',\n label: 'Agent',\n icon: 'RobotOutlined',\n target: 'agent.overview',\n order: 30,\n },\n ],\n },\n};\n"]}
|