agent-bober 0.11.5 → 0.12.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.
Files changed (87) hide show
  1. package/CHANGELOG.md +98 -0
  2. package/README.md +12 -6
  3. package/agents/bober-evaluator.md +38 -0
  4. package/agents/bober-generator.md +54 -0
  5. package/agents/bober-planner.md +256 -34
  6. package/dist/cli/commands/eval.js +6 -6
  7. package/dist/cli/commands/eval.js.map +1 -1
  8. package/dist/cli/commands/init.js +47 -3
  9. package/dist/cli/commands/init.js.map +1 -1
  10. package/dist/cli/commands/plan.d.ts +12 -0
  11. package/dist/cli/commands/plan.d.ts.map +1 -1
  12. package/dist/cli/commands/plan.js +232 -37
  13. package/dist/cli/commands/plan.js.map +1 -1
  14. package/dist/cli/commands/run.js +2 -2
  15. package/dist/cli/commands/run.js.map +1 -1
  16. package/dist/cli/commands/sprint.d.ts.map +1 -1
  17. package/dist/cli/commands/sprint.js +8 -8
  18. package/dist/cli/commands/sprint.js.map +1 -1
  19. package/dist/cli/index.js +23 -2
  20. package/dist/cli/index.js.map +1 -1
  21. package/dist/config/schema.d.ts +40 -40
  22. package/dist/contracts/eval-result.d.ts +38 -38
  23. package/dist/contracts/index.d.ts +2 -2
  24. package/dist/contracts/index.d.ts.map +1 -1
  25. package/dist/contracts/index.js +8 -4
  26. package/dist/contracts/index.js.map +1 -1
  27. package/dist/contracts/spec.d.ts +335 -40
  28. package/dist/contracts/spec.d.ts.map +1 -1
  29. package/dist/contracts/spec.js +210 -18
  30. package/dist/contracts/spec.js.map +1 -1
  31. package/dist/contracts/sprint-contract.d.ts +155 -88
  32. package/dist/contracts/sprint-contract.d.ts.map +1 -1
  33. package/dist/contracts/sprint-contract.js +176 -29
  34. package/dist/contracts/sprint-contract.js.map +1 -1
  35. package/dist/evaluators/builtin/api-check.js +1 -1
  36. package/dist/evaluators/builtin/api-check.js.map +1 -1
  37. package/dist/index.d.ts +2 -2
  38. package/dist/index.d.ts.map +1 -1
  39. package/dist/index.js +2 -2
  40. package/dist/index.js.map +1 -1
  41. package/dist/mcp/tools/contracts.js +2 -2
  42. package/dist/mcp/tools/contracts.js.map +1 -1
  43. package/dist/mcp/tools/eval.js +8 -8
  44. package/dist/mcp/tools/eval.js.map +1 -1
  45. package/dist/mcp/tools/plan.d.ts.map +1 -1
  46. package/dist/mcp/tools/plan.js +40 -14
  47. package/dist/mcp/tools/plan.js.map +1 -1
  48. package/dist/mcp/tools/sprint.d.ts.map +1 -1
  49. package/dist/mcp/tools/sprint.js +11 -11
  50. package/dist/mcp/tools/sprint.js.map +1 -1
  51. package/dist/orchestrator/context-handoff.d.ts +484 -224
  52. package/dist/orchestrator/context-handoff.d.ts.map +1 -1
  53. package/dist/orchestrator/context-handoff.js +32 -12
  54. package/dist/orchestrator/context-handoff.js.map +1 -1
  55. package/dist/orchestrator/curator-agent.d.ts.map +1 -1
  56. package/dist/orchestrator/curator-agent.js +4 -4
  57. package/dist/orchestrator/curator-agent.js.map +1 -1
  58. package/dist/orchestrator/evaluator-agent.js +2 -2
  59. package/dist/orchestrator/evaluator-agent.js.map +1 -1
  60. package/dist/orchestrator/generator-agent.js +3 -3
  61. package/dist/orchestrator/generator-agent.js.map +1 -1
  62. package/dist/orchestrator/model-resolver.js +2 -2
  63. package/dist/orchestrator/model-resolver.js.map +1 -1
  64. package/dist/orchestrator/pipeline.d.ts +7 -0
  65. package/dist/orchestrator/pipeline.d.ts.map +1 -1
  66. package/dist/orchestrator/pipeline.js +67 -28
  67. package/dist/orchestrator/pipeline.js.map +1 -1
  68. package/dist/orchestrator/planner-agent.d.ts +21 -1
  69. package/dist/orchestrator/planner-agent.d.ts.map +1 -1
  70. package/dist/orchestrator/planner-agent.js +11 -2
  71. package/dist/orchestrator/planner-agent.js.map +1 -1
  72. package/dist/state/history.d.ts.map +1 -1
  73. package/dist/state/history.js +3 -3
  74. package/dist/state/history.js.map +1 -1
  75. package/dist/state/plan-state.js +1 -1
  76. package/dist/state/plan-state.js.map +1 -1
  77. package/dist/state/sprint-state.d.ts +9 -2
  78. package/dist/state/sprint-state.d.ts.map +1 -1
  79. package/dist/state/sprint-state.js +25 -11
  80. package/dist/state/sprint-state.js.map +1 -1
  81. package/package.json +2 -1
  82. package/scripts/migrate-specs.mjs +127 -0
  83. package/scripts/sync-skills.mjs +96 -0
  84. package/skills/bober.plan/SKILL.md +41 -0
  85. package/skills/bober.plan/references/spec-schema.md +31 -4
  86. package/skills/bober.run/SKILL.md +41 -7
  87. package/skills/bober.sprint/SKILL.md +6 -259
@@ -64,253 +64,417 @@ export declare const ContextHandoffSchema: z.ZodObject<{
64
64
  currentBranch: string;
65
65
  }>;
66
66
  spec: z.ZodObject<{
67
- id: z.ZodString;
67
+ specId: z.ZodString;
68
+ version: z.ZodDefault<z.ZodNumber>;
68
69
  title: z.ZodString;
69
70
  description: z.ZodString;
70
- projectType: z.ZodString;
71
- techStack: z.ZodArray<z.ZodString, "many">;
71
+ status: z.ZodEnum<["draft", "needs-clarification", "ready", "in-progress", "completed", "abandoned"]>;
72
+ mode: z.ZodEnum<["greenfield", "brownfield"]>;
72
73
  features: z.ZodArray<z.ZodObject<{
73
- id: z.ZodString;
74
+ featureId: z.ZodString;
74
75
  title: z.ZodString;
75
76
  description: z.ZodString;
76
- priority: z.ZodEnum<["must", "should", "could"]>;
77
- estimatedSprints: z.ZodNumber;
77
+ priority: z.ZodEnum<["must-have", "should-have", "nice-to-have"]>;
78
78
  acceptanceCriteria: z.ZodArray<z.ZodString, "many">;
79
+ dependencies: z.ZodDefault<z.ZodArray<z.ZodString, "many">>;
80
+ estimatedComplexity: z.ZodOptional<z.ZodEnum<["low", "medium", "high"]>>;
81
+ estimatedSprints: z.ZodOptional<z.ZodNumber>;
79
82
  }, "strip", z.ZodTypeAny, {
80
83
  description: string;
81
- id: string;
82
84
  title: string;
83
- priority: "must" | "should" | "could";
84
- estimatedSprints: number;
85
+ featureId: string;
86
+ priority: "must-have" | "should-have" | "nice-to-have";
85
87
  acceptanceCriteria: string[];
88
+ dependencies: string[];
89
+ estimatedComplexity?: "medium" | "low" | "high" | undefined;
90
+ estimatedSprints?: number | undefined;
86
91
  }, {
87
92
  description: string;
88
- id: string;
89
93
  title: string;
90
- priority: "must" | "should" | "could";
91
- estimatedSprints: number;
94
+ featureId: string;
95
+ priority: "must-have" | "should-have" | "nice-to-have";
92
96
  acceptanceCriteria: string[];
97
+ dependencies?: string[] | undefined;
98
+ estimatedComplexity?: "medium" | "low" | "high" | undefined;
99
+ estimatedSprints?: number | undefined;
93
100
  }>, "many">;
94
- nonFunctional: z.ZodArray<z.ZodString, "many">;
95
- constraints: z.ZodArray<z.ZodString, "many">;
101
+ assumptions: z.ZodDefault<z.ZodArray<z.ZodString, "many">>;
102
+ outOfScope: z.ZodDefault<z.ZodArray<z.ZodString, "many">>;
103
+ ambiguityScore: z.ZodOptional<z.ZodNumber>;
104
+ clarificationQuestions: z.ZodDefault<z.ZodArray<z.ZodObject<{
105
+ questionId: z.ZodString;
106
+ category: z.ZodEnum<["scope", "user-personas", "data-model", "tech-constraints", "design-ux", "integrations", "non-functional", "error-handling", "integration-risk", "pattern-conflict", "regression-risk", "other"]>;
107
+ question: z.ZodString;
108
+ options: z.ZodOptional<z.ZodArray<z.ZodObject<{
109
+ label: z.ZodString;
110
+ description: z.ZodString;
111
+ }, "strip", z.ZodTypeAny, {
112
+ description: string;
113
+ label: string;
114
+ }, {
115
+ description: string;
116
+ label: string;
117
+ }>, "many">>;
118
+ recommendation: z.ZodOptional<z.ZodString>;
119
+ ambiguityWeight: z.ZodOptional<z.ZodNumber>;
120
+ }, "strip", z.ZodTypeAny, {
121
+ questionId: string;
122
+ category: "other" | "scope" | "user-personas" | "data-model" | "tech-constraints" | "design-ux" | "integrations" | "non-functional" | "error-handling" | "integration-risk" | "pattern-conflict" | "regression-risk";
123
+ question: string;
124
+ options?: {
125
+ description: string;
126
+ label: string;
127
+ }[] | undefined;
128
+ recommendation?: string | undefined;
129
+ ambiguityWeight?: number | undefined;
130
+ }, {
131
+ questionId: string;
132
+ category: "other" | "scope" | "user-personas" | "data-model" | "tech-constraints" | "design-ux" | "integrations" | "non-functional" | "error-handling" | "integration-risk" | "pattern-conflict" | "regression-risk";
133
+ question: string;
134
+ options?: {
135
+ description: string;
136
+ label: string;
137
+ }[] | undefined;
138
+ recommendation?: string | undefined;
139
+ ambiguityWeight?: number | undefined;
140
+ }>, "many">>;
141
+ resolvedClarifications: z.ZodDefault<z.ZodArray<z.ZodObject<{
142
+ questionId: z.ZodString;
143
+ answer: z.ZodString;
144
+ resolvedAt: z.ZodString;
145
+ resolvedBy: z.ZodDefault<z.ZodEnum<["user", "planner"]>>;
146
+ }, "strip", z.ZodTypeAny, {
147
+ questionId: string;
148
+ answer: string;
149
+ resolvedAt: string;
150
+ resolvedBy: "planner" | "user";
151
+ }, {
152
+ questionId: string;
153
+ answer: string;
154
+ resolvedAt: string;
155
+ resolvedBy?: "planner" | "user" | undefined;
156
+ }>, "many">>;
157
+ techStack: z.ZodDefault<z.ZodArray<z.ZodString, "many">>;
158
+ techNotes: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodUnknown>>;
159
+ nonFunctionalRequirements: z.ZodDefault<z.ZodArray<z.ZodUnknown, "many">>;
160
+ constraints: z.ZodDefault<z.ZodArray<z.ZodString, "many">>;
161
+ sprints: z.ZodOptional<z.ZodArray<z.ZodUnknown, "many">>;
162
+ metadata: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodUnknown>>;
96
163
  createdAt: z.ZodString;
97
164
  updatedAt: z.ZodString;
165
+ completedAt: z.ZodOptional<z.ZodString>;
98
166
  }, "strip", z.ZodTypeAny, {
167
+ mode: "greenfield" | "brownfield";
168
+ status: "draft" | "needs-clarification" | "ready" | "in-progress" | "completed" | "abandoned";
99
169
  description: string;
100
- id: string;
170
+ specId: string;
171
+ version: number;
101
172
  title: string;
102
- projectType: string;
103
- techStack: string[];
104
173
  features: {
105
174
  description: string;
106
- id: string;
107
175
  title: string;
108
- priority: "must" | "should" | "could";
109
- estimatedSprints: number;
176
+ featureId: string;
177
+ priority: "must-have" | "should-have" | "nice-to-have";
110
178
  acceptanceCriteria: string[];
179
+ dependencies: string[];
180
+ estimatedComplexity?: "medium" | "low" | "high" | undefined;
181
+ estimatedSprints?: number | undefined;
111
182
  }[];
112
- nonFunctional: string[];
183
+ assumptions: string[];
184
+ outOfScope: string[];
185
+ clarificationQuestions: {
186
+ questionId: string;
187
+ category: "other" | "scope" | "user-personas" | "data-model" | "tech-constraints" | "design-ux" | "integrations" | "non-functional" | "error-handling" | "integration-risk" | "pattern-conflict" | "regression-risk";
188
+ question: string;
189
+ options?: {
190
+ description: string;
191
+ label: string;
192
+ }[] | undefined;
193
+ recommendation?: string | undefined;
194
+ ambiguityWeight?: number | undefined;
195
+ }[];
196
+ resolvedClarifications: {
197
+ questionId: string;
198
+ answer: string;
199
+ resolvedAt: string;
200
+ resolvedBy: "planner" | "user";
201
+ }[];
202
+ techStack: string[];
203
+ nonFunctionalRequirements: unknown[];
113
204
  constraints: string[];
114
205
  createdAt: string;
115
206
  updatedAt: string;
207
+ ambiguityScore?: number | undefined;
208
+ techNotes?: Record<string, unknown> | undefined;
209
+ sprints?: unknown[] | undefined;
210
+ metadata?: Record<string, unknown> | undefined;
211
+ completedAt?: string | undefined;
116
212
  }, {
213
+ mode: "greenfield" | "brownfield";
214
+ status: "draft" | "needs-clarification" | "ready" | "in-progress" | "completed" | "abandoned";
117
215
  description: string;
118
- id: string;
216
+ specId: string;
119
217
  title: string;
120
- projectType: string;
121
- techStack: string[];
122
218
  features: {
123
219
  description: string;
124
- id: string;
125
220
  title: string;
126
- priority: "must" | "should" | "could";
127
- estimatedSprints: number;
221
+ featureId: string;
222
+ priority: "must-have" | "should-have" | "nice-to-have";
128
223
  acceptanceCriteria: string[];
224
+ dependencies?: string[] | undefined;
225
+ estimatedComplexity?: "medium" | "low" | "high" | undefined;
226
+ estimatedSprints?: number | undefined;
129
227
  }[];
130
- nonFunctional: string[];
131
- constraints: string[];
132
228
  createdAt: string;
133
229
  updatedAt: string;
230
+ version?: number | undefined;
231
+ assumptions?: string[] | undefined;
232
+ outOfScope?: string[] | undefined;
233
+ ambiguityScore?: number | undefined;
234
+ clarificationQuestions?: {
235
+ questionId: string;
236
+ category: "other" | "scope" | "user-personas" | "data-model" | "tech-constraints" | "design-ux" | "integrations" | "non-functional" | "error-handling" | "integration-risk" | "pattern-conflict" | "regression-risk";
237
+ question: string;
238
+ options?: {
239
+ description: string;
240
+ label: string;
241
+ }[] | undefined;
242
+ recommendation?: string | undefined;
243
+ ambiguityWeight?: number | undefined;
244
+ }[] | undefined;
245
+ resolvedClarifications?: {
246
+ questionId: string;
247
+ answer: string;
248
+ resolvedAt: string;
249
+ resolvedBy?: "planner" | "user" | undefined;
250
+ }[] | undefined;
251
+ techStack?: string[] | undefined;
252
+ techNotes?: Record<string, unknown> | undefined;
253
+ nonFunctionalRequirements?: unknown[] | undefined;
254
+ constraints?: string[] | undefined;
255
+ sprints?: unknown[] | undefined;
256
+ metadata?: Record<string, unknown> | undefined;
257
+ completedAt?: string | undefined;
134
258
  }>;
135
259
  currentContract: z.ZodOptional<z.ZodObject<{
136
- id: z.ZodString;
137
- feature: z.ZodString;
260
+ contractId: z.ZodString;
261
+ specId: z.ZodString;
262
+ sprintNumber: z.ZodNumber;
263
+ title: z.ZodString;
138
264
  description: z.ZodString;
265
+ status: z.ZodEnum<["proposed", "negotiating", "agreed", "in-progress", "evaluating", "passed", "failed", "needs-rework", "completed"]>;
266
+ dependsOn: z.ZodDefault<z.ZodArray<z.ZodString, "many">>;
267
+ features: z.ZodDefault<z.ZodArray<z.ZodString, "many">>;
139
268
  successCriteria: z.ZodArray<z.ZodObject<{
140
- id: z.ZodString;
141
- description: z.ZodString;
142
- verificationMethod: z.ZodString;
143
- passed: z.ZodBoolean;
144
- notes: z.ZodOptional<z.ZodString>;
145
- }, "strip", z.ZodTypeAny, {
146
- description: string;
147
- id: string;
148
- verificationMethod: string;
149
- passed: boolean;
150
- notes?: string | undefined;
151
- }, {
152
- description: string;
153
- id: string;
154
- verificationMethod: string;
155
- passed: boolean;
156
- notes?: string | undefined;
157
- }>, "many">;
158
- expectedChanges: z.ZodArray<z.ZodObject<{
159
- path: z.ZodString;
160
- action: z.ZodEnum<["create", "modify", "delete"]>;
269
+ criterionId: z.ZodString;
161
270
  description: z.ZodString;
271
+ verificationMethod: z.ZodEnum<["manual", "typecheck", "lint", "unit-test", "playwright", "api-check", "build", "agent-evaluation"]>;
272
+ required: z.ZodBoolean;
162
273
  }, "strip", z.ZodTypeAny, {
163
- path: string;
164
274
  description: string;
165
- action: "create" | "modify" | "delete";
275
+ required: boolean;
276
+ criterionId: string;
277
+ verificationMethod: "build" | "lint" | "typecheck" | "manual" | "unit-test" | "playwright" | "api-check" | "agent-evaluation";
166
278
  }, {
167
- path: string;
168
279
  description: string;
169
- action: "create" | "modify" | "delete";
280
+ required: boolean;
281
+ criterionId: string;
282
+ verificationMethod: "build" | "lint" | "typecheck" | "manual" | "unit-test" | "playwright" | "api-check" | "agent-evaluation";
170
283
  }>, "many">;
171
- dependsOn: z.ZodArray<z.ZodString, "many">;
172
- status: z.ZodEnum<["proposed", "negotiating", "agreed", "in-progress", "evaluating", "passed", "failed", "needs-rework"]>;
173
- evalResults: z.ZodOptional<z.ZodArray<z.ZodUnknown, "many">>;
284
+ nonGoals: z.ZodArray<z.ZodString, "many">;
285
+ stopConditions: z.ZodArray<z.ZodString, "many">;
286
+ definitionOfDone: z.ZodString;
287
+ assumptions: z.ZodDefault<z.ZodArray<z.ZodString, "many">>;
288
+ outOfScope: z.ZodDefault<z.ZodArray<z.ZodString, "many">>;
289
+ ambiguityScore: z.ZodOptional<z.ZodNumber>;
174
290
  generatorNotes: z.ZodOptional<z.ZodString>;
291
+ evaluatorNotes: z.ZodOptional<z.ZodString>;
292
+ estimatedFiles: z.ZodDefault<z.ZodArray<z.ZodString, "many">>;
293
+ estimatedDuration: z.ZodOptional<z.ZodEnum<["small", "medium", "large"]>>;
175
294
  evaluatorFeedback: z.ZodOptional<z.ZodString>;
295
+ iterationHistory: z.ZodDefault<z.ZodArray<z.ZodUnknown, "many">>;
296
+ lastEvalId: z.ZodOptional<z.ZodNullable<z.ZodString>>;
297
+ evalResults: z.ZodOptional<z.ZodArray<z.ZodUnknown, "many">>;
298
+ createdAt: z.ZodOptional<z.ZodString>;
299
+ updatedAt: z.ZodOptional<z.ZodString>;
176
300
  startedAt: z.ZodOptional<z.ZodString>;
177
301
  completedAt: z.ZodOptional<z.ZodString>;
178
302
  }, "strip", z.ZodTypeAny, {
179
- status: "passed" | "proposed" | "negotiating" | "agreed" | "in-progress" | "evaluating" | "failed" | "needs-rework";
303
+ status: "in-progress" | "completed" | "proposed" | "negotiating" | "agreed" | "evaluating" | "passed" | "failed" | "needs-rework";
180
304
  description: string;
181
- id: string;
182
- feature: string;
305
+ specId: string;
306
+ title: string;
307
+ features: string[];
308
+ assumptions: string[];
309
+ outOfScope: string[];
310
+ contractId: string;
311
+ sprintNumber: number;
312
+ dependsOn: string[];
183
313
  successCriteria: {
184
314
  description: string;
185
- id: string;
186
- verificationMethod: string;
187
- passed: boolean;
188
- notes?: string | undefined;
189
- }[];
190
- expectedChanges: {
191
- path: string;
192
- description: string;
193
- action: "create" | "modify" | "delete";
315
+ required: boolean;
316
+ criterionId: string;
317
+ verificationMethod: "build" | "lint" | "typecheck" | "manual" | "unit-test" | "playwright" | "api-check" | "agent-evaluation";
194
318
  }[];
195
- dependsOn: string[];
196
- evalResults?: unknown[] | undefined;
319
+ nonGoals: string[];
320
+ stopConditions: string[];
321
+ definitionOfDone: string;
322
+ estimatedFiles: string[];
323
+ iterationHistory: unknown[];
324
+ ambiguityScore?: number | undefined;
325
+ createdAt?: string | undefined;
326
+ updatedAt?: string | undefined;
327
+ completedAt?: string | undefined;
197
328
  generatorNotes?: string | undefined;
329
+ evaluatorNotes?: string | undefined;
330
+ estimatedDuration?: "small" | "medium" | "large" | undefined;
198
331
  evaluatorFeedback?: string | undefined;
332
+ lastEvalId?: string | null | undefined;
333
+ evalResults?: unknown[] | undefined;
199
334
  startedAt?: string | undefined;
200
- completedAt?: string | undefined;
201
335
  }, {
202
- status: "passed" | "proposed" | "negotiating" | "agreed" | "in-progress" | "evaluating" | "failed" | "needs-rework";
336
+ status: "in-progress" | "completed" | "proposed" | "negotiating" | "agreed" | "evaluating" | "passed" | "failed" | "needs-rework";
203
337
  description: string;
204
- id: string;
205
- feature: string;
338
+ specId: string;
339
+ title: string;
340
+ contractId: string;
341
+ sprintNumber: number;
206
342
  successCriteria: {
207
343
  description: string;
208
- id: string;
209
- verificationMethod: string;
210
- passed: boolean;
211
- notes?: string | undefined;
212
- }[];
213
- expectedChanges: {
214
- path: string;
215
- description: string;
216
- action: "create" | "modify" | "delete";
344
+ required: boolean;
345
+ criterionId: string;
346
+ verificationMethod: "build" | "lint" | "typecheck" | "manual" | "unit-test" | "playwright" | "api-check" | "agent-evaluation";
217
347
  }[];
218
- dependsOn: string[];
219
- evalResults?: unknown[] | undefined;
348
+ nonGoals: string[];
349
+ stopConditions: string[];
350
+ definitionOfDone: string;
351
+ features?: string[] | undefined;
352
+ assumptions?: string[] | undefined;
353
+ outOfScope?: string[] | undefined;
354
+ ambiguityScore?: number | undefined;
355
+ createdAt?: string | undefined;
356
+ updatedAt?: string | undefined;
357
+ completedAt?: string | undefined;
358
+ dependsOn?: string[] | undefined;
220
359
  generatorNotes?: string | undefined;
360
+ evaluatorNotes?: string | undefined;
361
+ estimatedFiles?: string[] | undefined;
362
+ estimatedDuration?: "small" | "medium" | "large" | undefined;
221
363
  evaluatorFeedback?: string | undefined;
364
+ iterationHistory?: unknown[] | undefined;
365
+ lastEvalId?: string | null | undefined;
366
+ evalResults?: unknown[] | undefined;
222
367
  startedAt?: string | undefined;
223
- completedAt?: string | undefined;
224
368
  }>>;
225
369
  sprintHistory: z.ZodArray<z.ZodObject<{
226
- id: z.ZodString;
227
- feature: z.ZodString;
370
+ contractId: z.ZodString;
371
+ specId: z.ZodString;
372
+ sprintNumber: z.ZodNumber;
373
+ title: z.ZodString;
228
374
  description: z.ZodString;
375
+ status: z.ZodEnum<["proposed", "negotiating", "agreed", "in-progress", "evaluating", "passed", "failed", "needs-rework", "completed"]>;
376
+ dependsOn: z.ZodDefault<z.ZodArray<z.ZodString, "many">>;
377
+ features: z.ZodDefault<z.ZodArray<z.ZodString, "many">>;
229
378
  successCriteria: z.ZodArray<z.ZodObject<{
230
- id: z.ZodString;
379
+ criterionId: z.ZodString;
231
380
  description: z.ZodString;
232
- verificationMethod: z.ZodString;
233
- passed: z.ZodBoolean;
234
- notes: z.ZodOptional<z.ZodString>;
381
+ verificationMethod: z.ZodEnum<["manual", "typecheck", "lint", "unit-test", "playwright", "api-check", "build", "agent-evaluation"]>;
382
+ required: z.ZodBoolean;
235
383
  }, "strip", z.ZodTypeAny, {
236
384
  description: string;
237
- id: string;
238
- verificationMethod: string;
239
- passed: boolean;
240
- notes?: string | undefined;
385
+ required: boolean;
386
+ criterionId: string;
387
+ verificationMethod: "build" | "lint" | "typecheck" | "manual" | "unit-test" | "playwright" | "api-check" | "agent-evaluation";
241
388
  }, {
242
389
  description: string;
243
- id: string;
244
- verificationMethod: string;
245
- passed: boolean;
246
- notes?: string | undefined;
390
+ required: boolean;
391
+ criterionId: string;
392
+ verificationMethod: "build" | "lint" | "typecheck" | "manual" | "unit-test" | "playwright" | "api-check" | "agent-evaluation";
247
393
  }>, "many">;
248
- expectedChanges: z.ZodArray<z.ZodObject<{
249
- path: z.ZodString;
250
- action: z.ZodEnum<["create", "modify", "delete"]>;
251
- description: z.ZodString;
252
- }, "strip", z.ZodTypeAny, {
253
- path: string;
254
- description: string;
255
- action: "create" | "modify" | "delete";
256
- }, {
257
- path: string;
258
- description: string;
259
- action: "create" | "modify" | "delete";
260
- }>, "many">;
261
- dependsOn: z.ZodArray<z.ZodString, "many">;
262
- status: z.ZodEnum<["proposed", "negotiating", "agreed", "in-progress", "evaluating", "passed", "failed", "needs-rework"]>;
263
- evalResults: z.ZodOptional<z.ZodArray<z.ZodUnknown, "many">>;
394
+ nonGoals: z.ZodArray<z.ZodString, "many">;
395
+ stopConditions: z.ZodArray<z.ZodString, "many">;
396
+ definitionOfDone: z.ZodString;
397
+ assumptions: z.ZodDefault<z.ZodArray<z.ZodString, "many">>;
398
+ outOfScope: z.ZodDefault<z.ZodArray<z.ZodString, "many">>;
399
+ ambiguityScore: z.ZodOptional<z.ZodNumber>;
264
400
  generatorNotes: z.ZodOptional<z.ZodString>;
401
+ evaluatorNotes: z.ZodOptional<z.ZodString>;
402
+ estimatedFiles: z.ZodDefault<z.ZodArray<z.ZodString, "many">>;
403
+ estimatedDuration: z.ZodOptional<z.ZodEnum<["small", "medium", "large"]>>;
265
404
  evaluatorFeedback: z.ZodOptional<z.ZodString>;
405
+ iterationHistory: z.ZodDefault<z.ZodArray<z.ZodUnknown, "many">>;
406
+ lastEvalId: z.ZodOptional<z.ZodNullable<z.ZodString>>;
407
+ evalResults: z.ZodOptional<z.ZodArray<z.ZodUnknown, "many">>;
408
+ createdAt: z.ZodOptional<z.ZodString>;
409
+ updatedAt: z.ZodOptional<z.ZodString>;
266
410
  startedAt: z.ZodOptional<z.ZodString>;
267
411
  completedAt: z.ZodOptional<z.ZodString>;
268
412
  }, "strip", z.ZodTypeAny, {
269
- status: "passed" | "proposed" | "negotiating" | "agreed" | "in-progress" | "evaluating" | "failed" | "needs-rework";
413
+ status: "in-progress" | "completed" | "proposed" | "negotiating" | "agreed" | "evaluating" | "passed" | "failed" | "needs-rework";
270
414
  description: string;
271
- id: string;
272
- feature: string;
415
+ specId: string;
416
+ title: string;
417
+ features: string[];
418
+ assumptions: string[];
419
+ outOfScope: string[];
420
+ contractId: string;
421
+ sprintNumber: number;
422
+ dependsOn: string[];
273
423
  successCriteria: {
274
424
  description: string;
275
- id: string;
276
- verificationMethod: string;
277
- passed: boolean;
278
- notes?: string | undefined;
425
+ required: boolean;
426
+ criterionId: string;
427
+ verificationMethod: "build" | "lint" | "typecheck" | "manual" | "unit-test" | "playwright" | "api-check" | "agent-evaluation";
279
428
  }[];
280
- expectedChanges: {
281
- path: string;
282
- description: string;
283
- action: "create" | "modify" | "delete";
284
- }[];
285
- dependsOn: string[];
286
- evalResults?: unknown[] | undefined;
429
+ nonGoals: string[];
430
+ stopConditions: string[];
431
+ definitionOfDone: string;
432
+ estimatedFiles: string[];
433
+ iterationHistory: unknown[];
434
+ ambiguityScore?: number | undefined;
435
+ createdAt?: string | undefined;
436
+ updatedAt?: string | undefined;
437
+ completedAt?: string | undefined;
287
438
  generatorNotes?: string | undefined;
439
+ evaluatorNotes?: string | undefined;
440
+ estimatedDuration?: "small" | "medium" | "large" | undefined;
288
441
  evaluatorFeedback?: string | undefined;
442
+ lastEvalId?: string | null | undefined;
443
+ evalResults?: unknown[] | undefined;
289
444
  startedAt?: string | undefined;
290
- completedAt?: string | undefined;
291
445
  }, {
292
- status: "passed" | "proposed" | "negotiating" | "agreed" | "in-progress" | "evaluating" | "failed" | "needs-rework";
446
+ status: "in-progress" | "completed" | "proposed" | "negotiating" | "agreed" | "evaluating" | "passed" | "failed" | "needs-rework";
293
447
  description: string;
294
- id: string;
295
- feature: string;
448
+ specId: string;
449
+ title: string;
450
+ contractId: string;
451
+ sprintNumber: number;
296
452
  successCriteria: {
297
453
  description: string;
298
- id: string;
299
- verificationMethod: string;
300
- passed: boolean;
301
- notes?: string | undefined;
302
- }[];
303
- expectedChanges: {
304
- path: string;
305
- description: string;
306
- action: "create" | "modify" | "delete";
454
+ required: boolean;
455
+ criterionId: string;
456
+ verificationMethod: "build" | "lint" | "typecheck" | "manual" | "unit-test" | "playwright" | "api-check" | "agent-evaluation";
307
457
  }[];
308
- dependsOn: string[];
309
- evalResults?: unknown[] | undefined;
458
+ nonGoals: string[];
459
+ stopConditions: string[];
460
+ definitionOfDone: string;
461
+ features?: string[] | undefined;
462
+ assumptions?: string[] | undefined;
463
+ outOfScope?: string[] | undefined;
464
+ ambiguityScore?: number | undefined;
465
+ createdAt?: string | undefined;
466
+ updatedAt?: string | undefined;
467
+ completedAt?: string | undefined;
468
+ dependsOn?: string[] | undefined;
310
469
  generatorNotes?: string | undefined;
470
+ evaluatorNotes?: string | undefined;
471
+ estimatedFiles?: string[] | undefined;
472
+ estimatedDuration?: "small" | "medium" | "large" | undefined;
311
473
  evaluatorFeedback?: string | undefined;
474
+ iterationHistory?: unknown[] | undefined;
475
+ lastEvalId?: string | null | undefined;
476
+ evalResults?: unknown[] | undefined;
312
477
  startedAt?: string | undefined;
313
- completedAt?: string | undefined;
314
478
  }>, "many">;
315
479
  instructions: z.ZodString;
316
480
  changedFiles: z.ZodArray<z.ZodString, "many">;
@@ -344,47 +508,85 @@ export declare const ContextHandoffSchema: z.ZodObject<{
344
508
  currentBranch: string;
345
509
  };
346
510
  spec: {
511
+ mode: "greenfield" | "brownfield";
512
+ status: "draft" | "needs-clarification" | "ready" | "in-progress" | "completed" | "abandoned";
347
513
  description: string;
348
- id: string;
514
+ specId: string;
515
+ version: number;
349
516
  title: string;
350
- projectType: string;
351
- techStack: string[];
352
517
  features: {
353
518
  description: string;
354
- id: string;
355
519
  title: string;
356
- priority: "must" | "should" | "could";
357
- estimatedSprints: number;
520
+ featureId: string;
521
+ priority: "must-have" | "should-have" | "nice-to-have";
358
522
  acceptanceCriteria: string[];
523
+ dependencies: string[];
524
+ estimatedComplexity?: "medium" | "low" | "high" | undefined;
525
+ estimatedSprints?: number | undefined;
526
+ }[];
527
+ assumptions: string[];
528
+ outOfScope: string[];
529
+ clarificationQuestions: {
530
+ questionId: string;
531
+ category: "other" | "scope" | "user-personas" | "data-model" | "tech-constraints" | "design-ux" | "integrations" | "non-functional" | "error-handling" | "integration-risk" | "pattern-conflict" | "regression-risk";
532
+ question: string;
533
+ options?: {
534
+ description: string;
535
+ label: string;
536
+ }[] | undefined;
537
+ recommendation?: string | undefined;
538
+ ambiguityWeight?: number | undefined;
359
539
  }[];
360
- nonFunctional: string[];
540
+ resolvedClarifications: {
541
+ questionId: string;
542
+ answer: string;
543
+ resolvedAt: string;
544
+ resolvedBy: "planner" | "user";
545
+ }[];
546
+ techStack: string[];
547
+ nonFunctionalRequirements: unknown[];
361
548
  constraints: string[];
362
549
  createdAt: string;
363
550
  updatedAt: string;
551
+ ambiguityScore?: number | undefined;
552
+ techNotes?: Record<string, unknown> | undefined;
553
+ sprints?: unknown[] | undefined;
554
+ metadata?: Record<string, unknown> | undefined;
555
+ completedAt?: string | undefined;
364
556
  };
365
557
  sprintHistory: {
366
- status: "passed" | "proposed" | "negotiating" | "agreed" | "in-progress" | "evaluating" | "failed" | "needs-rework";
558
+ status: "in-progress" | "completed" | "proposed" | "negotiating" | "agreed" | "evaluating" | "passed" | "failed" | "needs-rework";
367
559
  description: string;
368
- id: string;
369
- feature: string;
560
+ specId: string;
561
+ title: string;
562
+ features: string[];
563
+ assumptions: string[];
564
+ outOfScope: string[];
565
+ contractId: string;
566
+ sprintNumber: number;
567
+ dependsOn: string[];
370
568
  successCriteria: {
371
569
  description: string;
372
- id: string;
373
- verificationMethod: string;
374
- passed: boolean;
375
- notes?: string | undefined;
376
- }[];
377
- expectedChanges: {
378
- path: string;
379
- description: string;
380
- action: "create" | "modify" | "delete";
570
+ required: boolean;
571
+ criterionId: string;
572
+ verificationMethod: "build" | "lint" | "typecheck" | "manual" | "unit-test" | "playwright" | "api-check" | "agent-evaluation";
381
573
  }[];
382
- dependsOn: string[];
383
- evalResults?: unknown[] | undefined;
574
+ nonGoals: string[];
575
+ stopConditions: string[];
576
+ definitionOfDone: string;
577
+ estimatedFiles: string[];
578
+ iterationHistory: unknown[];
579
+ ambiguityScore?: number | undefined;
580
+ createdAt?: string | undefined;
581
+ updatedAt?: string | undefined;
582
+ completedAt?: string | undefined;
384
583
  generatorNotes?: string | undefined;
584
+ evaluatorNotes?: string | undefined;
585
+ estimatedDuration?: "small" | "medium" | "large" | undefined;
385
586
  evaluatorFeedback?: string | undefined;
587
+ lastEvalId?: string | null | undefined;
588
+ evalResults?: unknown[] | undefined;
386
589
  startedAt?: string | undefined;
387
- completedAt?: string | undefined;
388
590
  }[];
389
591
  instructions: string;
390
592
  changedFiles: string[];
@@ -395,28 +597,38 @@ export declare const ContextHandoffSchema: z.ZodObject<{
395
597
  madeBy: "planner" | "generator" | "evaluator" | "human";
396
598
  }[];
397
599
  currentContract?: {
398
- status: "passed" | "proposed" | "negotiating" | "agreed" | "in-progress" | "evaluating" | "failed" | "needs-rework";
600
+ status: "in-progress" | "completed" | "proposed" | "negotiating" | "agreed" | "evaluating" | "passed" | "failed" | "needs-rework";
399
601
  description: string;
400
- id: string;
401
- feature: string;
602
+ specId: string;
603
+ title: string;
604
+ features: string[];
605
+ assumptions: string[];
606
+ outOfScope: string[];
607
+ contractId: string;
608
+ sprintNumber: number;
609
+ dependsOn: string[];
402
610
  successCriteria: {
403
611
  description: string;
404
- id: string;
405
- verificationMethod: string;
406
- passed: boolean;
407
- notes?: string | undefined;
408
- }[];
409
- expectedChanges: {
410
- path: string;
411
- description: string;
412
- action: "create" | "modify" | "delete";
612
+ required: boolean;
613
+ criterionId: string;
614
+ verificationMethod: "build" | "lint" | "typecheck" | "manual" | "unit-test" | "playwright" | "api-check" | "agent-evaluation";
413
615
  }[];
414
- dependsOn: string[];
415
- evalResults?: unknown[] | undefined;
616
+ nonGoals: string[];
617
+ stopConditions: string[];
618
+ definitionOfDone: string;
619
+ estimatedFiles: string[];
620
+ iterationHistory: unknown[];
621
+ ambiguityScore?: number | undefined;
622
+ createdAt?: string | undefined;
623
+ updatedAt?: string | undefined;
624
+ completedAt?: string | undefined;
416
625
  generatorNotes?: string | undefined;
626
+ evaluatorNotes?: string | undefined;
627
+ estimatedDuration?: "small" | "medium" | "large" | undefined;
417
628
  evaluatorFeedback?: string | undefined;
629
+ lastEvalId?: string | null | undefined;
630
+ evalResults?: unknown[] | undefined;
418
631
  startedAt?: string | undefined;
419
- completedAt?: string | undefined;
420
632
  } | undefined;
421
633
  }, {
422
634
  issues: string[];
@@ -431,47 +643,85 @@ export declare const ContextHandoffSchema: z.ZodObject<{
431
643
  currentBranch: string;
432
644
  };
433
645
  spec: {
646
+ mode: "greenfield" | "brownfield";
647
+ status: "draft" | "needs-clarification" | "ready" | "in-progress" | "completed" | "abandoned";
434
648
  description: string;
435
- id: string;
649
+ specId: string;
436
650
  title: string;
437
- projectType: string;
438
- techStack: string[];
439
651
  features: {
440
652
  description: string;
441
- id: string;
442
653
  title: string;
443
- priority: "must" | "should" | "could";
444
- estimatedSprints: number;
654
+ featureId: string;
655
+ priority: "must-have" | "should-have" | "nice-to-have";
445
656
  acceptanceCriteria: string[];
657
+ dependencies?: string[] | undefined;
658
+ estimatedComplexity?: "medium" | "low" | "high" | undefined;
659
+ estimatedSprints?: number | undefined;
446
660
  }[];
447
- nonFunctional: string[];
448
- constraints: string[];
449
661
  createdAt: string;
450
662
  updatedAt: string;
663
+ version?: number | undefined;
664
+ assumptions?: string[] | undefined;
665
+ outOfScope?: string[] | undefined;
666
+ ambiguityScore?: number | undefined;
667
+ clarificationQuestions?: {
668
+ questionId: string;
669
+ category: "other" | "scope" | "user-personas" | "data-model" | "tech-constraints" | "design-ux" | "integrations" | "non-functional" | "error-handling" | "integration-risk" | "pattern-conflict" | "regression-risk";
670
+ question: string;
671
+ options?: {
672
+ description: string;
673
+ label: string;
674
+ }[] | undefined;
675
+ recommendation?: string | undefined;
676
+ ambiguityWeight?: number | undefined;
677
+ }[] | undefined;
678
+ resolvedClarifications?: {
679
+ questionId: string;
680
+ answer: string;
681
+ resolvedAt: string;
682
+ resolvedBy?: "planner" | "user" | undefined;
683
+ }[] | undefined;
684
+ techStack?: string[] | undefined;
685
+ techNotes?: Record<string, unknown> | undefined;
686
+ nonFunctionalRequirements?: unknown[] | undefined;
687
+ constraints?: string[] | undefined;
688
+ sprints?: unknown[] | undefined;
689
+ metadata?: Record<string, unknown> | undefined;
690
+ completedAt?: string | undefined;
451
691
  };
452
692
  sprintHistory: {
453
- status: "passed" | "proposed" | "negotiating" | "agreed" | "in-progress" | "evaluating" | "failed" | "needs-rework";
693
+ status: "in-progress" | "completed" | "proposed" | "negotiating" | "agreed" | "evaluating" | "passed" | "failed" | "needs-rework";
454
694
  description: string;
455
- id: string;
456
- feature: string;
695
+ specId: string;
696
+ title: string;
697
+ contractId: string;
698
+ sprintNumber: number;
457
699
  successCriteria: {
458
700
  description: string;
459
- id: string;
460
- verificationMethod: string;
461
- passed: boolean;
462
- notes?: string | undefined;
463
- }[];
464
- expectedChanges: {
465
- path: string;
466
- description: string;
467
- action: "create" | "modify" | "delete";
701
+ required: boolean;
702
+ criterionId: string;
703
+ verificationMethod: "build" | "lint" | "typecheck" | "manual" | "unit-test" | "playwright" | "api-check" | "agent-evaluation";
468
704
  }[];
469
- dependsOn: string[];
470
- evalResults?: unknown[] | undefined;
705
+ nonGoals: string[];
706
+ stopConditions: string[];
707
+ definitionOfDone: string;
708
+ features?: string[] | undefined;
709
+ assumptions?: string[] | undefined;
710
+ outOfScope?: string[] | undefined;
711
+ ambiguityScore?: number | undefined;
712
+ createdAt?: string | undefined;
713
+ updatedAt?: string | undefined;
714
+ completedAt?: string | undefined;
715
+ dependsOn?: string[] | undefined;
471
716
  generatorNotes?: string | undefined;
717
+ evaluatorNotes?: string | undefined;
718
+ estimatedFiles?: string[] | undefined;
719
+ estimatedDuration?: "small" | "medium" | "large" | undefined;
472
720
  evaluatorFeedback?: string | undefined;
721
+ iterationHistory?: unknown[] | undefined;
722
+ lastEvalId?: string | null | undefined;
723
+ evalResults?: unknown[] | undefined;
473
724
  startedAt?: string | undefined;
474
- completedAt?: string | undefined;
475
725
  }[];
476
726
  instructions: string;
477
727
  changedFiles: string[];
@@ -482,28 +732,38 @@ export declare const ContextHandoffSchema: z.ZodObject<{
482
732
  madeBy: "planner" | "generator" | "evaluator" | "human";
483
733
  }[];
484
734
  currentContract?: {
485
- status: "passed" | "proposed" | "negotiating" | "agreed" | "in-progress" | "evaluating" | "failed" | "needs-rework";
735
+ status: "in-progress" | "completed" | "proposed" | "negotiating" | "agreed" | "evaluating" | "passed" | "failed" | "needs-rework";
486
736
  description: string;
487
- id: string;
488
- feature: string;
737
+ specId: string;
738
+ title: string;
739
+ contractId: string;
740
+ sprintNumber: number;
489
741
  successCriteria: {
490
742
  description: string;
491
- id: string;
492
- verificationMethod: string;
493
- passed: boolean;
494
- notes?: string | undefined;
743
+ required: boolean;
744
+ criterionId: string;
745
+ verificationMethod: "build" | "lint" | "typecheck" | "manual" | "unit-test" | "playwright" | "api-check" | "agent-evaluation";
495
746
  }[];
496
- expectedChanges: {
497
- path: string;
498
- description: string;
499
- action: "create" | "modify" | "delete";
500
- }[];
501
- dependsOn: string[];
502
- evalResults?: unknown[] | undefined;
747
+ nonGoals: string[];
748
+ stopConditions: string[];
749
+ definitionOfDone: string;
750
+ features?: string[] | undefined;
751
+ assumptions?: string[] | undefined;
752
+ outOfScope?: string[] | undefined;
753
+ ambiguityScore?: number | undefined;
754
+ createdAt?: string | undefined;
755
+ updatedAt?: string | undefined;
756
+ completedAt?: string | undefined;
757
+ dependsOn?: string[] | undefined;
503
758
  generatorNotes?: string | undefined;
759
+ evaluatorNotes?: string | undefined;
760
+ estimatedFiles?: string[] | undefined;
761
+ estimatedDuration?: "small" | "medium" | "large" | undefined;
504
762
  evaluatorFeedback?: string | undefined;
763
+ iterationHistory?: unknown[] | undefined;
764
+ lastEvalId?: string | null | undefined;
765
+ evalResults?: unknown[] | undefined;
505
766
  startedAt?: string | undefined;
506
- completedAt?: string | undefined;
507
767
  } | undefined;
508
768
  }>;
509
769
  export type ContextHandoff = z.infer<typeof ContextHandoffSchema>;