agileflow 2.94.0 → 2.95.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 (80) hide show
  1. package/CHANGELOG.md +20 -0
  2. package/README.md +6 -6
  3. package/lib/colors.generated.js +117 -0
  4. package/lib/colors.js +59 -109
  5. package/lib/generator-factory.js +333 -0
  6. package/lib/path-utils.js +49 -0
  7. package/lib/session-registry.js +25 -15
  8. package/lib/smart-json-file.js +40 -32
  9. package/lib/state-machine.js +286 -0
  10. package/package.json +1 -1
  11. package/scripts/agileflow-configure.js +7 -6
  12. package/scripts/archive-completed-stories.sh +86 -11
  13. package/scripts/babysit-context-restore.js +89 -0
  14. package/scripts/claude-tmux.sh +186 -7
  15. package/scripts/damage-control/bash-tool-damage-control.js +11 -247
  16. package/scripts/damage-control/edit-tool-damage-control.js +9 -249
  17. package/scripts/damage-control/write-tool-damage-control.js +9 -244
  18. package/scripts/generate-colors.js +314 -0
  19. package/scripts/lib/colors.generated.sh +82 -0
  20. package/scripts/lib/colors.sh +10 -70
  21. package/scripts/lib/configure-features.js +401 -0
  22. package/scripts/lib/context-loader.js +181 -52
  23. package/scripts/precompact-context.sh +54 -17
  24. package/scripts/session-coordinator.sh +2 -2
  25. package/scripts/session-manager.js +677 -11
  26. package/src/core/agents/council-advocate.md +202 -0
  27. package/src/core/agents/council-analyst.md +248 -0
  28. package/src/core/agents/council-optimist.md +166 -0
  29. package/src/core/commands/audit.md +93 -0
  30. package/src/core/commands/auto.md +73 -0
  31. package/src/core/commands/babysit.md +169 -13
  32. package/src/core/commands/baseline.md +73 -0
  33. package/src/core/commands/batch.md +64 -0
  34. package/src/core/commands/blockers.md +60 -0
  35. package/src/core/commands/board.md +66 -0
  36. package/src/core/commands/choose.md +77 -0
  37. package/src/core/commands/ci.md +77 -0
  38. package/src/core/commands/compress.md +27 -1
  39. package/src/core/commands/configure.md +126 -10
  40. package/src/core/commands/council.md +591 -0
  41. package/src/core/commands/debt.md +72 -0
  42. package/src/core/commands/deploy.md +73 -0
  43. package/src/core/commands/deps.md +68 -0
  44. package/src/core/commands/docs.md +60 -0
  45. package/src/core/commands/feedback.md +68 -0
  46. package/src/core/commands/help.md +189 -3
  47. package/src/core/commands/ideate.md +219 -20
  48. package/src/core/commands/impact.md +74 -0
  49. package/src/core/commands/install.md +529 -0
  50. package/src/core/commands/maintain.md +558 -0
  51. package/src/core/commands/metrics.md +75 -0
  52. package/src/core/commands/multi-expert.md +74 -0
  53. package/src/core/commands/packages.md +69 -0
  54. package/src/core/commands/readme-sync.md +64 -0
  55. package/src/core/commands/research/analyze.md +285 -121
  56. package/src/core/commands/research/import.md +281 -109
  57. package/src/core/commands/retro.md +76 -0
  58. package/src/core/commands/review.md +72 -0
  59. package/src/core/commands/rlm.md +83 -0
  60. package/src/core/commands/rpi.md +90 -0
  61. package/src/core/commands/session/cleanup.md +214 -12
  62. package/src/core/commands/session/end.md +229 -17
  63. package/src/core/commands/sprint.md +72 -0
  64. package/src/core/commands/story-validate.md +68 -0
  65. package/src/core/commands/template.md +69 -0
  66. package/src/core/commands/tests.md +83 -0
  67. package/src/core/commands/update.md +59 -0
  68. package/src/core/commands/validate-expertise.md +76 -0
  69. package/src/core/commands/velocity.md +74 -0
  70. package/src/core/commands/verify.md +91 -0
  71. package/src/core/commands/whats-new.md +69 -0
  72. package/src/core/commands/workflow.md +88 -0
  73. package/src/core/council/sessions/.gitkeep +0 -0
  74. package/src/core/council/shared_reasoning.template.md +106 -0
  75. package/src/core/templates/command-documentation.md +187 -0
  76. package/tools/cli/commands/session.js +1171 -0
  77. package/tools/cli/commands/setup.js +2 -81
  78. package/tools/cli/installers/core/installer.js +0 -5
  79. package/tools/cli/installers/ide/claude-code.js +6 -0
  80. package/tools/cli/lib/config-manager.js +42 -5
@@ -1,14 +1,14 @@
1
1
  ---
2
2
  description: Generate categorized improvement ideas using multi-expert analysis
3
- argument-hint: [SCOPE=all|security|perf|code|ux] [DEPTH=quick|deep] [OUTPUT=report|stories|both]
3
+ argument-hint: [SCOPE=all|security|perf|code|ux] [DEPTH=quick|deep|ultradeep] [OUTPUT=report|stories|both]
4
4
  compact_context:
5
5
  priority: high
6
6
  preserve_rules:
7
7
  - "ACTIVE COMMAND: /agileflow:ideate - Ideation orchestrator with multi-expert analysis"
8
8
  - "CRITICAL: Deploy experts IN PARALLEL in ONE message with multiple Task calls"
9
9
  - "CRITICAL: Wait for all results before synthesis (use TaskOutput with block=true)"
10
- - "CRITICAL: Confidence scoring: HIGH (2+ experts agree) | MEDIUM (1 expert with evidence) | LOW (vague, exclude)"
11
- - "MUST parse arguments: SCOPE (all/security/perf/code/ux) | DEPTH (quick/deep) | OUTPUT (report/stories/both)"
10
+ - "CRITICAL: Confidence scoring varies by depth: quick/deep (HIGH=2+ agree) | ultradeep (HIGH=3+ agree)"
11
+ - "MUST parse arguments: SCOPE (all/security/perf/code/ux) | DEPTH (quick/deep/ultradeep) | OUTPUT (report/stories/both)"
12
12
  - "MUST categorize by domain: Security, Performance, Code Quality, UX, Testing, API/Architecture"
13
13
  - "MUST estimate effort for each idea: High/Medium/Low impact"
14
14
  - "Optional: Generate stories for HIGH-confidence items (if OUTPUT=stories or both)"
@@ -44,11 +44,11 @@ node .agileflow/scripts/obtain-context.js ideate
44
44
  /agileflow:ideate SCOPE=all DEPTH=quick OUTPUT=report
45
45
  ```
46
46
 
47
- **What It Does**: Deploy 4-6 domain experts → Each generates 3-5 ideas → Synthesize with confidence scoring → Categorized report
47
+ **What It Does**: Deploy 4-15 domain experts → Each generates 3-5 ideas → Synthesize with confidence scoring → Categorized report
48
48
 
49
49
  **Arguments**:
50
50
  - `SCOPE=all|security|perf|code|ux` (default: all)
51
- - `DEPTH=quick|deep` (default: quick)
51
+ - `DEPTH=quick|deep|ultradeep` (default: quick) — ultradeep uses 13 experts for ~65 ideas
52
52
  - `OUTPUT=report|stories|both` (default: report)
53
53
 
54
54
  ### Tool Usage Examples
@@ -87,7 +87,7 @@ node .agileflow/scripts/obtain-context.js ideate
87
87
  ```
88
88
 
89
89
  **Categories**: Security, Performance, Code Quality, UX/Design, Testing, API/Architecture
90
- **Confidence**: High (2+ experts agree), Medium (1 expert with evidence)
90
+ **Confidence**: High (2+ experts agree; 3+ for ultradeep), Medium (1 expert with evidence)
91
91
  **Output**: `docs/08-project/ideation-<YYYYMMDD>.md` | Optional stories
92
92
  <!-- COMPACT_SUMMARY_END -->
93
93
 
@@ -104,7 +104,7 @@ node .agileflow/scripts/obtain-context.js ideate
104
104
  ┌─────────────────────────────────────────────────────────────┐
105
105
  │ IDEATION ORCHESTRATOR │
106
106
  │ 1. Parse SCOPE to determine which experts │
107
- │ 2. Deploy 4-6 experts IN PARALLEL
107
+ │ 2. Deploy 4-13 experts IN PARALLEL (13 for ultradeep)
108
108
  │ 3. Each expert generates 3-5 improvement ideas │
109
109
  │ 4. Collect and synthesize with confidence scoring │
110
110
  │ 5. Generate categorized report │
@@ -153,17 +153,20 @@ You coordinate multiple domain experts to generate improvement suggestions for t
153
153
  Parse the input arguments:
154
154
 
155
155
  **SCOPE** (which experts to deploy):
156
- | SCOPE | Experts |
157
- |-------|---------|
158
- | `all` (default) | security, performance, refactor, ui, testing, api (6 experts) |
159
- | `security` | security, api, testing (3 experts) |
160
- | `perf` | performance, database, api (3 experts) |
161
- | `code` | refactor, testing, api (3 experts) |
162
- | `ux` | ui, accessibility, api (3 experts) |
156
+ | SCOPE | Experts (quick/deep) | Experts (ultradeep adds) |
157
+ |-------|----------------------|--------------------------|
158
+ | `all` (default) | security, performance, refactor, ui, testing, api (6) | + accessibility, compliance, database, monitoring, qa, analytics, documentation (13 total) |
159
+ | `security` | security, api, testing (3) | + compliance, monitoring (5 total) |
160
+ | `perf` | performance, database, api (3) | + monitoring, analytics (5 total) |
161
+ | `code` | refactor, testing, api (3) | + documentation, qa (5 total) |
162
+ | `ux` | ui, accessibility, api (3) | + design, analytics (5 total) |
163
163
 
164
164
  **DEPTH**:
165
165
  - `quick` (default): Each expert generates 3 ideas, focuses on high-impact only
166
166
  - `deep`: Each expert generates 5 ideas, includes lower-priority items
167
+ - `ultradeep`: Deploy 13 experts (SCOPE=all) with 5 ideas each (~65 ideas), comprehensive coverage
168
+
169
+ > **Note**: `DEPTH=ultradeep` is recommended for comprehensive audits, pre-release reviews, or quarterly codebase assessments. It deploys significantly more experts and takes longer to complete.
167
170
 
168
171
  **OUTPUT**:
169
172
  - `report` (default): Generate ideation report only
@@ -255,6 +258,103 @@ FORMAT each idea as:
255
258
  </invoke>
256
259
  ```
257
260
 
261
+ **Example deployment for SCOPE=all DEPTH=ultradeep** (13 experts):
262
+
263
+ ```xml
264
+ <!-- Deploy ALL 13 experts in a SINGLE message -->
265
+ <invoke name="Task">
266
+ <parameter name="description">Security ideation</parameter>
267
+ <parameter name="prompt">[prompt with domain=security]</parameter>
268
+ <parameter name="subagent_type">agileflow-security</parameter>
269
+ <parameter name="run_in_background">true</parameter>
270
+ </invoke>
271
+
272
+ <invoke name="Task">
273
+ <parameter name="description">Performance ideation</parameter>
274
+ <parameter name="prompt">[prompt with domain=performance]</parameter>
275
+ <parameter name="subagent_type">agileflow-performance</parameter>
276
+ <parameter name="run_in_background">true</parameter>
277
+ </invoke>
278
+
279
+ <invoke name="Task">
280
+ <parameter name="description">Code quality ideation</parameter>
281
+ <parameter name="prompt">[prompt with domain=refactor]</parameter>
282
+ <parameter name="subagent_type">agileflow-refactor</parameter>
283
+ <parameter name="run_in_background">true</parameter>
284
+ </invoke>
285
+
286
+ <invoke name="Task">
287
+ <parameter name="description">UX ideation</parameter>
288
+ <parameter name="prompt">[prompt with domain=ui]</parameter>
289
+ <parameter name="subagent_type">agileflow-ui</parameter>
290
+ <parameter name="run_in_background">true</parameter>
291
+ </invoke>
292
+
293
+ <invoke name="Task">
294
+ <parameter name="description">Testing ideation</parameter>
295
+ <parameter name="prompt">[prompt with domain=testing]</parameter>
296
+ <parameter name="subagent_type">agileflow-testing</parameter>
297
+ <parameter name="run_in_background">true</parameter>
298
+ </invoke>
299
+
300
+ <invoke name="Task">
301
+ <parameter name="description">API/Architecture ideation</parameter>
302
+ <parameter name="prompt">[prompt with domain=api]</parameter>
303
+ <parameter name="subagent_type">agileflow-api</parameter>
304
+ <parameter name="run_in_background">true</parameter>
305
+ </invoke>
306
+
307
+ <!-- Additional ultradeep experts (7 more) -->
308
+ <invoke name="Task">
309
+ <parameter name="description">Accessibility ideation</parameter>
310
+ <parameter name="prompt">[prompt with domain=accessibility]</parameter>
311
+ <parameter name="subagent_type">agileflow-accessibility</parameter>
312
+ <parameter name="run_in_background">true</parameter>
313
+ </invoke>
314
+
315
+ <invoke name="Task">
316
+ <parameter name="description">Compliance ideation</parameter>
317
+ <parameter name="prompt">[prompt with domain=compliance]</parameter>
318
+ <parameter name="subagent_type">agileflow-compliance</parameter>
319
+ <parameter name="run_in_background">true</parameter>
320
+ </invoke>
321
+
322
+ <invoke name="Task">
323
+ <parameter name="description">Database ideation</parameter>
324
+ <parameter name="prompt">[prompt with domain=database]</parameter>
325
+ <parameter name="subagent_type">agileflow-database</parameter>
326
+ <parameter name="run_in_background">true</parameter>
327
+ </invoke>
328
+
329
+ <invoke name="Task">
330
+ <parameter name="description">Monitoring ideation</parameter>
331
+ <parameter name="prompt">[prompt with domain=monitoring]</parameter>
332
+ <parameter name="subagent_type">agileflow-monitoring</parameter>
333
+ <parameter name="run_in_background">true</parameter>
334
+ </invoke>
335
+
336
+ <invoke name="Task">
337
+ <parameter name="description">QA ideation</parameter>
338
+ <parameter name="prompt">[prompt with domain=qa]</parameter>
339
+ <parameter name="subagent_type">agileflow-qa</parameter>
340
+ <parameter name="run_in_background">true</parameter>
341
+ </invoke>
342
+
343
+ <invoke name="Task">
344
+ <parameter name="description">Analytics ideation</parameter>
345
+ <parameter name="prompt">[prompt with domain=analytics]</parameter>
346
+ <parameter name="subagent_type">agileflow-analytics</parameter>
347
+ <parameter name="run_in_background">true</parameter>
348
+ </invoke>
349
+
350
+ <invoke name="Task">
351
+ <parameter name="description">Documentation ideation</parameter>
352
+ <parameter name="prompt">[prompt with domain=documentation]</parameter>
353
+ <parameter name="subagent_type">agileflow-documentation</parameter>
354
+ <parameter name="run_in_background">true</parameter>
355
+ </invoke>
356
+ ```
357
+
258
358
  ### STEP 3: COLLECT RESULTS
259
359
 
260
360
  Wait for all experts to complete:
@@ -278,11 +378,13 @@ Analyze all expert ideas and synthesize:
278
378
 
279
379
  **Confidence Scoring**:
280
380
 
281
- | Confidence | Criteria | Action |
282
- |------------|----------|--------|
283
- | **HIGH** | 2+ experts suggest similar idea | Include prominently, recommend immediate action |
284
- | **MEDIUM** | 1 expert with specific evidence (file paths, metrics) | Include as opportunity |
285
- | **LOW** | 1 expert, vague/no evidence | Exclude from report |
381
+ | Confidence | Criteria (quick/deep) | Criteria (ultradeep) | Action |
382
+ |------------|----------------------|----------------------|--------|
383
+ | **HIGH** | 2+ experts suggest similar idea | 3+ experts suggest similar idea | Include prominently, recommend immediate action |
384
+ | **MEDIUM** | 1 expert with specific evidence | 1-2 experts with specific evidence | Include as opportunity |
385
+ | **LOW** | 1 expert, vague/no evidence | 1-2 experts, vague/no evidence | Exclude from report |
386
+
387
+ > For ultradeep mode, the higher threshold (3+) for HIGH confidence prevents noise from having many perspectives and ensures only truly cross-cutting concerns bubble up as top priorities.
286
388
 
287
389
  **Overlap Detection**:
288
390
  - Ideas about the same file/component from different experts = HIGH confidence
@@ -435,18 +537,115 @@ After generating output, present options:
435
537
 
436
538
  ---
437
539
 
540
+ ### Example: Ultradeep Execution
541
+
542
+ **User**: `/agileflow:ideate SCOPE=all DEPTH=ultradeep OUTPUT=both`
543
+
544
+ **Step 1**: Parse → SCOPE=all (13 experts), DEPTH=ultradeep (5 ideas each), OUTPUT=both
545
+
546
+ **Step 2**: Deploy 13 experts in parallel (security, performance, refactor, ui, testing, api, accessibility, compliance, database, monitoring, qa, analytics, documentation)
547
+
548
+ **Step 3**: Collect results (~65 raw ideas)
549
+
550
+ **Step 4**: Synthesize with ultradeep thresholds:
551
+ - 8 ideas mentioned by 3+ experts → HIGH confidence
552
+ - 25 ideas with 1-2 experts + evidence → MEDIUM confidence
553
+ - 32 ideas too vague or single expert without evidence → excluded
554
+
555
+ **Step 5**: Generate report with 33 ideas, saved to `docs/08-project/ideation-20260106.md`
556
+
557
+ **Step 6**: Generate 8 stories for HIGH-confidence items
558
+
559
+ **Step 7**: Present next steps via AskUserQuestion
560
+
561
+ ---
562
+
438
563
  ## Arguments
439
564
 
440
565
  | Argument | Values | Default | Description |
441
566
  |----------|--------|---------|-------------|
442
567
  | SCOPE | all, security, perf, code, ux | all | Which domains to analyze |
443
- | DEPTH | quick, deep | quick | Number of ideas per expert (3 vs 5) |
568
+ | DEPTH | quick, deep, ultradeep | quick | quick (3 ideas, 6 experts), deep (5 ideas, 6 experts), ultradeep (5 ideas, 13 experts) |
444
569
  | OUTPUT | report, stories, both | report | What to generate |
445
570
 
446
571
  {{argument}}
447
572
 
448
573
  ---
449
574
 
575
+ ## Expected Output
576
+
577
+ ### Success - Ideation Report
578
+
579
+ ```
580
+ 💡 Ideation Analysis: SCOPE=all DEPTH=deep
581
+ ══════════════════════════════════════════════════════════════
582
+
583
+ Deploying 6 domain experts...
584
+ ✓ Security Expert
585
+ ✓ Performance Expert
586
+ ✓ Code Quality Expert
587
+ ✓ UX Expert
588
+ ✓ Architecture Expert
589
+ ✓ DevOps Expert
590
+
591
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
592
+
593
+ 🔒 SECURITY (2 ideas)
594
+ ┌──────────────────────────────────────────────────────────────┐
595
+ │ 1. Add rate limiting to /api/auth endpoints │
596
+ │ Impact: HIGH | Effort: LOW | Confidence: 95% │
597
+ │ Experts: Security ✓, DevOps ✓ │
598
+ ├──────────────────────────────────────────────────────────────┤
599
+ │ 2. Implement CSRF protection │
600
+ │ Impact: HIGH | Effort: MEDIUM | Confidence: 90% │
601
+ │ Experts: Security ✓, Code Quality ✓ │
602
+ └──────────────────────────────────────────────────────────────┘
603
+
604
+ ⚡ PERFORMANCE (1 idea)
605
+ │ 1. Add Redis caching for user sessions │
606
+ │ Impact: MEDIUM | Effort: MEDIUM | Confidence: 85% │
607
+
608
+ 🧹 CODE QUALITY (2 ideas)
609
+ │ 1. Extract validation logic to shared module │
610
+ │ 2. Add TypeScript strict mode │
611
+
612
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
613
+ 📊 Summary: 5 ideas from 6 experts
614
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
615
+
616
+ Top recommendation: Rate limiting (#1 - 95% confidence)
617
+ Create stories for these ideas? [Y/n]
618
+ ```
619
+
620
+ ### Success - Stories Created
621
+
622
+ ```
623
+ ✓ Created US-0200: Add rate limiting to auth endpoints
624
+ ✓ Created US-0201: Implement CSRF protection
625
+ ✓ Created US-0202: Add Redis session caching
626
+ ✓ Created US-0203: Extract validation module
627
+ ✓ Created US-0204: Enable TypeScript strict mode
628
+
629
+ 5 stories added to EP-0027 (Ideation Improvements)
630
+ ```
631
+
632
+ ### Error - Scope Invalid
633
+
634
+ ```
635
+ ❌ Error: Invalid scope: network
636
+
637
+ Valid scopes:
638
+ - all: Full codebase analysis
639
+ - security: Security vulnerabilities
640
+ - perf: Performance optimizations
641
+ - code: Code quality improvements
642
+ - ux: User experience enhancements
643
+
644
+ Usage: /agileflow:ideate SCOPE=security DEPTH=deep
645
+ ```
646
+
647
+ ---
648
+
450
649
  ## Related Commands
451
650
 
452
651
  - `/agileflow:multi-expert` - Deploy multiple experts for analysis
@@ -323,6 +323,80 @@ OUTPUT
323
323
 
324
324
  ---
325
325
 
326
+ ## Expected Output
327
+
328
+ ### Success - Impact Analysis
329
+
330
+ ```
331
+ 🔍 Impact Analysis
332
+ ══════════════════════════════════════════════════════════════
333
+
334
+ Analyzing changes in: src/api/auth.js
335
+
336
+ 📁 Files Affected:
337
+ ┌──────────────────────────────────────────────────────────────┐
338
+ │ Direct Changes │
339
+ ├──────────────────────────────────────────────────────────────┤
340
+ │ M src/api/auth.js (modified) │
341
+ └──────────────────────────────────────────────────────────────┘
342
+
343
+ 🔗 Dependent Files (imports auth.js):
344
+ ┌──────────────────────────────────────────────────────────────┐
345
+ │ src/api/users.js │
346
+ │ src/api/sessions.js │
347
+ │ src/middleware/authenticate.js │
348
+ │ src/pages/api/login.js │
349
+ └──────────────────────────────────────────────────────────────┘
350
+
351
+ 🧪 Test Coverage:
352
+ ┌──────────────────────────────────────────────────────────────┐
353
+ │ File │ Tests │ Coverage │ Status │
354
+ ├─────────────────────────────┼──────────┼──────────┼─────────┤
355
+ │ src/api/auth.js │ 15 tests │ 92% │ 🟢 │
356
+ │ src/api/users.js │ 8 tests │ 85% │ 🟢 │
357
+ │ src/middleware/authenticate │ 5 tests │ 78% │ 🟡 │
358
+ │ src/api/sessions.js │ 0 tests │ 0% │ 🔴 │
359
+ └──────────────────────────────────────────────────────────────┘
360
+
361
+ ⚠️ Risk Assessment: MEDIUM
362
+ - sessions.js has no test coverage
363
+ - authenticate.js coverage below 80%
364
+
365
+ Recommendations:
366
+ 🔴 CRITICAL: Add tests for src/api/sessions.js
367
+ 🟡 RECOMMENDED: Improve authenticate.js coverage
368
+
369
+ Run affected tests? [Y/n]
370
+ ```
371
+
372
+ ### Success - Clean Impact
373
+
374
+ ```
375
+ 🔍 Impact Analysis
376
+ ══════════════════════════════════════════════════════════════
377
+
378
+ Analyzing changes in: src/utils/format.js
379
+
380
+ ✅ Low Risk Change
381
+ - 2 files depend on this module
382
+ - All have >80% test coverage
383
+ - No breaking API changes detected
384
+
385
+ Safe to proceed with PR.
386
+ ```
387
+
388
+ ### Error - File Not Found
389
+
390
+ ```
391
+ ❌ Error: File not found: src/api/authh.js
392
+
393
+ Did you mean: src/api/auth.js?
394
+
395
+ Usage: /agileflow:impact FILE=src/api/auth.js
396
+ ```
397
+
398
+ ---
399
+
326
400
  ## Related Commands
327
401
 
328
402
  - `/agileflow:tests` - Set up testing infrastructure