@howlil/ez-agents 3.4.1 → 3.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.
Files changed (162) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +84 -20
  3. package/agents/ez-observer-agent.md +260 -0
  4. package/agents/ez-release-agent.md +333 -0
  5. package/agents/ez-requirements-agent.md +377 -0
  6. package/agents/ez-scrum-master-agent.md +242 -0
  7. package/agents/ez-tech-lead-agent.md +267 -0
  8. package/bin/install.js +3221 -3230
  9. package/commands/ez/arch-review.md +102 -0
  10. package/commands/ez/execute-phase.md +11 -0
  11. package/commands/ez/export-session.md +79 -0
  12. package/commands/ez/gather-requirements.md +117 -0
  13. package/commands/ez/git-workflow.md +72 -0
  14. package/commands/ez/hotfix.md +120 -0
  15. package/commands/ez/import-session.md +82 -0
  16. package/commands/ez/join-discord.md +18 -18
  17. package/commands/ez/list-sessions.md +96 -0
  18. package/commands/ez/package-manager.md +316 -0
  19. package/commands/ez/plan-phase.md +9 -1
  20. package/commands/ez/preflight.md +79 -0
  21. package/commands/ez/progress.md +13 -1
  22. package/commands/ez/release.md +153 -0
  23. package/commands/ez/resume.md +107 -0
  24. package/commands/ez/standup.md +85 -0
  25. package/ez-agents/bin/ez-tools.cjs +1095 -716
  26. package/ez-agents/bin/lib/assistant-adapter.cjs +264 -264
  27. package/ez-agents/bin/lib/audit-exec.cjs +7 -2
  28. package/ez-agents/bin/lib/bdd-validator.cjs +622 -0
  29. package/ez-agents/bin/lib/circuit-breaker.cjs +118 -118
  30. package/ez-agents/bin/lib/config.cjs +190 -190
  31. package/ez-agents/bin/lib/content-scanner.cjs +238 -0
  32. package/ez-agents/bin/lib/context-cache.cjs +154 -0
  33. package/ez-agents/bin/lib/context-errors.cjs +71 -0
  34. package/ez-agents/bin/lib/context-manager.cjs +220 -0
  35. package/ez-agents/bin/lib/discussion-synthesizer.cjs +458 -0
  36. package/ez-agents/bin/lib/file-access.cjs +207 -0
  37. package/ez-agents/bin/lib/file-lock.cjs +236 -236
  38. package/ez-agents/bin/lib/frontmatter.cjs +299 -299
  39. package/ez-agents/bin/lib/fs-utils.cjs +153 -153
  40. package/ez-agents/bin/lib/git-errors.cjs +83 -0
  41. package/ez-agents/bin/lib/git-utils.cjs +118 -0
  42. package/ez-agents/bin/lib/git-workflow-engine.cjs +1157 -0
  43. package/ez-agents/bin/lib/index.cjs +157 -113
  44. package/ez-agents/bin/lib/init.cjs +757 -757
  45. package/ez-agents/bin/lib/lockfile-validator.cjs +227 -0
  46. package/ez-agents/bin/lib/logger.cjs +124 -124
  47. package/ez-agents/bin/lib/memory-compression.cjs +256 -0
  48. package/ez-agents/bin/lib/metrics-tracker.cjs +406 -0
  49. package/ez-agents/bin/lib/milestone.cjs +241 -241
  50. package/ez-agents/bin/lib/model-provider.cjs +241 -241
  51. package/ez-agents/bin/lib/package-manager-detector.cjs +203 -0
  52. package/ez-agents/bin/lib/package-manager-executor.cjs +385 -0
  53. package/ez-agents/bin/lib/package-manager-service.cjs +216 -0
  54. package/ez-agents/bin/lib/phase.cjs +925 -925
  55. package/ez-agents/bin/lib/planning-write.cjs +107 -107
  56. package/ez-agents/bin/lib/release-validator.cjs +614 -0
  57. package/ez-agents/bin/lib/retry.cjs +119 -119
  58. package/ez-agents/bin/lib/roadmap.cjs +306 -306
  59. package/ez-agents/bin/lib/safe-exec.cjs +128 -128
  60. package/ez-agents/bin/lib/safe-path.cjs +130 -130
  61. package/ez-agents/bin/lib/session-chain.cjs +304 -0
  62. package/ez-agents/bin/lib/session-errors.cjs +81 -0
  63. package/ez-agents/bin/lib/session-export.cjs +251 -0
  64. package/ez-agents/bin/lib/session-import.cjs +262 -0
  65. package/ez-agents/bin/lib/session-manager.cjs +280 -0
  66. package/ez-agents/bin/lib/state.cjs +736 -736
  67. package/ez-agents/bin/lib/temp-file.cjs +239 -239
  68. package/ez-agents/bin/lib/template.cjs +223 -223
  69. package/ez-agents/bin/lib/test-file-lock.cjs +112 -112
  70. package/ez-agents/bin/lib/test-graceful.cjs +93 -93
  71. package/ez-agents/bin/lib/test-logger.cjs +60 -60
  72. package/ez-agents/bin/lib/test-safe-exec.cjs +38 -38
  73. package/ez-agents/bin/lib/test-safe-path.cjs +33 -33
  74. package/ez-agents/bin/lib/test-temp-file.cjs +125 -125
  75. package/ez-agents/bin/lib/tier-manager.cjs +428 -0
  76. package/ez-agents/bin/lib/timeout-exec.cjs +63 -63
  77. package/ez-agents/bin/lib/url-fetch.cjs +170 -0
  78. package/ez-agents/bin/lib/verify.cjs +15 -1
  79. package/ez-agents/references/checkpoints.md +776 -776
  80. package/ez-agents/references/continuation-format.md +249 -249
  81. package/ez-agents/references/metrics-schema.md +118 -0
  82. package/ez-agents/references/planning-config.md +140 -0
  83. package/ez-agents/references/questioning.md +162 -162
  84. package/ez-agents/references/tdd.md +263 -263
  85. package/ez-agents/references/tier-strategy.md +103 -0
  86. package/ez-agents/templates/bdd-feature.md +173 -0
  87. package/ez-agents/templates/codebase/concerns.md +310 -310
  88. package/ez-agents/templates/codebase/conventions.md +307 -307
  89. package/ez-agents/templates/codebase/integrations.md +280 -280
  90. package/ez-agents/templates/codebase/stack.md +186 -186
  91. package/ez-agents/templates/codebase/testing.md +480 -480
  92. package/ez-agents/templates/config.json +37 -37
  93. package/ez-agents/templates/continue-here.md +78 -78
  94. package/ez-agents/templates/discussion.md +68 -0
  95. package/ez-agents/templates/incident-runbook.md +205 -0
  96. package/ez-agents/templates/milestone-archive.md +123 -123
  97. package/ez-agents/templates/milestone.md +115 -115
  98. package/ez-agents/templates/release-checklist.md +133 -0
  99. package/ez-agents/templates/requirements.md +231 -231
  100. package/ez-agents/templates/research-project/ARCHITECTURE.md +204 -204
  101. package/ez-agents/templates/research-project/FEATURES.md +147 -147
  102. package/ez-agents/templates/research-project/PITFALLS.md +200 -200
  103. package/ez-agents/templates/research-project/STACK.md +120 -120
  104. package/ez-agents/templates/research-project/SUMMARY.md +170 -170
  105. package/ez-agents/templates/retrospective.md +54 -54
  106. package/ez-agents/templates/roadmap.md +202 -202
  107. package/ez-agents/templates/rollback-plan.md +201 -0
  108. package/ez-agents/templates/summary-minimal.md +41 -41
  109. package/ez-agents/templates/summary-standard.md +48 -48
  110. package/ez-agents/templates/summary.md +248 -248
  111. package/ez-agents/templates/user-setup.md +311 -311
  112. package/ez-agents/templates/verification-report.md +322 -322
  113. package/ez-agents/workflows/add-phase.md +112 -112
  114. package/ez-agents/workflows/add-tests.md +351 -351
  115. package/ez-agents/workflows/add-todo.md +158 -158
  116. package/ez-agents/workflows/arch-review.md +54 -0
  117. package/ez-agents/workflows/audit-milestone.md +332 -332
  118. package/ez-agents/workflows/autonomous.md +131 -30
  119. package/ez-agents/workflows/check-todos.md +177 -177
  120. package/ez-agents/workflows/cleanup.md +152 -152
  121. package/ez-agents/workflows/complete-milestone.md +766 -766
  122. package/ez-agents/workflows/diagnose-issues.md +219 -219
  123. package/ez-agents/workflows/discovery-phase.md +289 -289
  124. package/ez-agents/workflows/discuss-phase.md +762 -762
  125. package/ez-agents/workflows/execute-phase.md +513 -468
  126. package/ez-agents/workflows/execute-plan.md +483 -483
  127. package/ez-agents/workflows/export-session.md +255 -0
  128. package/ez-agents/workflows/gather-requirements.md +206 -0
  129. package/ez-agents/workflows/health.md +159 -159
  130. package/ez-agents/workflows/help.md +584 -492
  131. package/ez-agents/workflows/hotfix.md +291 -0
  132. package/ez-agents/workflows/import-session.md +303 -0
  133. package/ez-agents/workflows/insert-phase.md +130 -130
  134. package/ez-agents/workflows/list-phase-assumptions.md +178 -178
  135. package/ez-agents/workflows/map-codebase.md +316 -316
  136. package/ez-agents/workflows/new-milestone.md +339 -10
  137. package/ez-agents/workflows/new-project.md +293 -299
  138. package/ez-agents/workflows/node-repair.md +92 -92
  139. package/ez-agents/workflows/pause-work.md +122 -122
  140. package/ez-agents/workflows/plan-milestone-gaps.md +274 -274
  141. package/ez-agents/workflows/plan-phase.md +673 -651
  142. package/ez-agents/workflows/progress.md +372 -382
  143. package/ez-agents/workflows/quick.md +610 -610
  144. package/ez-agents/workflows/release.md +253 -0
  145. package/ez-agents/workflows/remove-phase.md +155 -155
  146. package/ez-agents/workflows/research-phase.md +74 -74
  147. package/ez-agents/workflows/resume-project.md +307 -307
  148. package/ez-agents/workflows/resume-session.md +215 -0
  149. package/ez-agents/workflows/set-profile.md +81 -81
  150. package/ez-agents/workflows/settings.md +242 -242
  151. package/ez-agents/workflows/standup.md +64 -0
  152. package/ez-agents/workflows/stats.md +57 -57
  153. package/ez-agents/workflows/transition.md +544 -544
  154. package/ez-agents/workflows/ui-phase.md +290 -290
  155. package/ez-agents/workflows/ui-review.md +157 -157
  156. package/ez-agents/workflows/update.md +320 -320
  157. package/ez-agents/workflows/validate-phase.md +167 -167
  158. package/ez-agents/workflows/verify-phase.md +243 -243
  159. package/ez-agents/workflows/verify-work.md +584 -584
  160. package/package.json +10 -4
  161. package/scripts/build-hooks.js +43 -43
  162. package/scripts/run-tests.cjs +29 -29
@@ -1,316 +1,316 @@
1
- <purpose>
2
- Orchestrate parallel codebase mapper agents to analyze codebase and produce structured documents in .planning/codebase/
3
-
4
- Each agent has fresh context, explores a specific focus area, and **writes documents directly**. The orchestrator only receives confirmation + line counts, then writes a summary.
5
-
6
- Output: .planning/codebase/ folder with 7 structured documents about the codebase state.
7
- </purpose>
8
-
9
- <philosophy>
10
- **Why dedicated mapper agents:**
11
- - Fresh context per domain (no token contamination)
12
- - Agents write documents directly (no context transfer back to orchestrator)
13
- - Orchestrator only summarizes what was created (minimal context usage)
14
- - Faster execution (agents run simultaneously)
15
-
16
- **Document quality over length:**
17
- Include enough detail to be useful as reference. Prioritize practical examples (especially code patterns) over arbitrary brevity.
18
-
19
- **Always include file paths:**
20
- Documents are reference material for Claude when planning/executing. Always include actual file paths formatted with backticks: `src/services/user.ts`.
21
- </philosophy>
22
-
23
- <process>
24
-
25
- <step name="init_context" priority="first">
26
- Load codebase mapping context:
27
-
28
- ```bash
29
- INIT=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" init map-codebase)
30
- if [[ "$INIT" == @file:* ]]; then INIT=$(cat "${INIT#@file:}"); fi
31
- ```
32
-
33
- Extract from init JSON: `mapper_model`, `commit_docs`, `codebase_dir`, `existing_maps`, `has_maps`, `codebase_dir_exists`.
34
- </step>
35
-
36
- <step name="check_existing">
37
- Check if .planning/codebase/ already exists using `has_maps` from init context.
38
-
39
- If `codebase_dir_exists` is true:
40
- ```bash
41
- ls -la .planning/codebase/
42
- ```
43
-
44
- **If exists:**
45
-
46
- ```
47
- .planning/codebase/ already exists with these documents:
48
- [List files found]
49
-
50
- What's next?
51
- 1. Refresh - Delete existing and remap codebase
52
- 2. Update - Keep existing, only update specific documents
53
- 3. Skip - Use existing codebase map as-is
54
- ```
55
-
56
- Wait for user response.
57
-
58
- If "Refresh": Delete .planning/codebase/, continue to create_structure
59
- If "Update": Ask which documents to update, continue to spawn_agents (filtered)
60
- If "Skip": Exit workflow
61
-
62
- **If doesn't exist:**
63
- Continue to create_structure.
64
- </step>
65
-
66
- <step name="create_structure">
67
- Create .planning/codebase/ directory:
68
-
69
- ```bash
70
- mkdir -p .planning/codebase
71
- ```
72
-
73
- **Expected output files:**
74
- - STACK.md (from tech mapper)
75
- - INTEGRATIONS.md (from tech mapper)
76
- - ARCHITECTURE.md (from arch mapper)
77
- - STRUCTURE.md (from arch mapper)
78
- - CONVENTIONS.md (from quality mapper)
79
- - TESTING.md (from quality mapper)
80
- - CONCERNS.md (from concerns mapper)
81
-
82
- Continue to spawn_agents.
83
- </step>
84
-
85
- <step name="spawn_agents">
86
- Spawn 4 parallel ez-codebase-mapper agents.
87
-
88
- Use Task tool with `subagent_type="ez-codebase-mapper"`, `model="{mapper_model}"`, and `run_in_background=true` for parallel execution.
89
-
90
- **CRITICAL:** Use the dedicated `ez-codebase-mapper` agent, NOT `Explore`. The mapper agent writes documents directly.
91
-
92
- **Agent 1: Tech Focus**
93
-
94
- ```
95
- Task(
96
- subagent_type="ez-codebase-mapper",
97
- model="{mapper_model}",
98
- run_in_background=true,
99
- description="Map codebase tech stack",
100
- prompt="Focus: tech
101
-
102
- Analyze this codebase for technology stack and external integrations.
103
-
104
- Write these documents to .planning/codebase/:
105
- - STACK.md - Languages, runtime, frameworks, dependencies, configuration
106
- - INTEGRATIONS.md - External APIs, databases, auth providers, webhooks
107
-
108
- Explore thoroughly. Write documents directly using templates. Return confirmation only."
109
- )
110
- ```
111
-
112
- **Agent 2: Architecture Focus**
113
-
114
- ```
115
- Task(
116
- subagent_type="ez-codebase-mapper",
117
- model="{mapper_model}",
118
- run_in_background=true,
119
- description="Map codebase architecture",
120
- prompt="Focus: arch
121
-
122
- Analyze this codebase architecture and directory structure.
123
-
124
- Write these documents to .planning/codebase/:
125
- - ARCHITECTURE.md - Pattern, layers, data flow, abstractions, entry points
126
- - STRUCTURE.md - Directory layout, key locations, naming conventions
127
-
128
- Explore thoroughly. Write documents directly using templates. Return confirmation only."
129
- )
130
- ```
131
-
132
- **Agent 3: Quality Focus**
133
-
134
- ```
135
- Task(
136
- subagent_type="ez-codebase-mapper",
137
- model="{mapper_model}",
138
- run_in_background=true,
139
- description="Map codebase conventions",
140
- prompt="Focus: quality
141
-
142
- Analyze this codebase for coding conventions and testing patterns.
143
-
144
- Write these documents to .planning/codebase/:
145
- - CONVENTIONS.md - Code style, naming, patterns, error handling
146
- - TESTING.md - Framework, structure, mocking, coverage
147
-
148
- Explore thoroughly. Write documents directly using templates. Return confirmation only."
149
- )
150
- ```
151
-
152
- **Agent 4: Concerns Focus**
153
-
154
- ```
155
- Task(
156
- subagent_type="ez-codebase-mapper",
157
- model="{mapper_model}",
158
- run_in_background=true,
159
- description="Map codebase concerns",
160
- prompt="Focus: concerns
161
-
162
- Analyze this codebase for technical debt, known issues, and areas of concern.
163
-
164
- Write this document to .planning/codebase/:
165
- - CONCERNS.md - Tech debt, bugs, security, performance, fragile areas
166
-
167
- Explore thoroughly. Write document directly using template. Return confirmation only."
168
- )
169
- ```
170
-
171
- Continue to collect_confirmations.
172
- </step>
173
-
174
- <step name="collect_confirmations">
175
- Wait for all 4 agents to complete.
176
-
177
- Read each agent's output file to collect confirmations.
178
-
179
- **Expected confirmation format from each agent:**
180
- ```
181
- ## Mapping Complete
182
-
183
- **Focus:** {focus}
184
- **Documents written:**
185
- - `.planning/codebase/{DOC1}.md` ({N} lines)
186
- - `.planning/codebase/{DOC2}.md` ({N} lines)
187
-
188
- Ready for orchestrator summary.
189
- ```
190
-
191
- **What you receive:** Just file paths and line counts. NOT document contents.
192
-
193
- If any agent failed, note the failure and continue with successful documents.
194
-
195
- Continue to verify_output.
196
- </step>
197
-
198
- <step name="verify_output">
199
- Verify all documents created successfully:
200
-
201
- ```bash
202
- ls -la .planning/codebase/
203
- wc -l .planning/codebase/*.md
204
- ```
205
-
206
- **Verification checklist:**
207
- - All 7 documents exist
208
- - No empty documents (each should have >20 lines)
209
-
210
- If any documents missing or empty, note which agents may have failed.
211
-
212
- Continue to scan_for_secrets.
213
- </step>
214
-
215
- <step name="scan_for_secrets">
216
- **CRITICAL SECURITY CHECK:** Scan output files for accidentally leaked secrets before committing.
217
-
218
- Run secret pattern detection:
219
-
220
- ```bash
221
- # Check for common API key patterns in generated docs
222
- grep -E '(sk-[a-zA-Z0-9]{20,}|sk_live_[a-zA-Z0-9]+|sk_test_[a-zA-Z0-9]+|ghp_[a-zA-Z0-9]{36}|gho_[a-zA-Z0-9]{36}|glpat-[a-zA-Z0-9_-]+|AKIA[A-Z0-9]{16}|xox[baprs]-[a-zA-Z0-9-]+|-----BEGIN.*PRIVATE KEY|eyJ[a-zA-Z0-9_-]+\.eyJ[a-zA-Z0-9_-]+\.)' .planning/codebase/*.md 2>/dev/null && SECRETS_FOUND=true || SECRETS_FOUND=false
223
- ```
224
-
225
- **If SECRETS_FOUND=true:**
226
-
227
- ```
228
- ⚠️ SECURITY ALERT: Potential secrets detected in codebase documents!
229
-
230
- Found patterns that look like API keys or tokens in:
231
- [show grep output]
232
-
233
- This would expose credentials if committed.
234
-
235
- **Action required:**
236
- 1. Review the flagged content above
237
- 2. If these are real secrets, they must be removed before committing
238
- 3. Consider adding sensitive files to Claude Code "Deny" permissions
239
-
240
- Pausing before commit. Reply "safe to proceed" if the flagged content is not actually sensitive, or edit the files first.
241
- ```
242
-
243
- Wait for user confirmation before continuing to commit_codebase_map.
244
-
245
- **If SECRETS_FOUND=false:**
246
-
247
- Continue to commit_codebase_map.
248
- </step>
249
-
250
- <step name="commit_codebase_map">
251
- Commit the codebase map:
252
-
253
- ```bash
254
- node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" commit "docs: map existing codebase" --files .planning/codebase/*.md
255
- ```
256
-
257
- Continue to offer_next.
258
- </step>
259
-
260
- <step name="offer_next">
261
- Present completion summary and next steps.
262
-
263
- **Get line counts:**
264
- ```bash
265
- wc -l .planning/codebase/*.md
266
- ```
267
-
268
- **Output format:**
269
-
270
- ```
271
- Codebase mapping complete.
272
-
273
- Created .planning/codebase/:
274
- - STACK.md ([N] lines) - Technologies and dependencies
275
- - ARCHITECTURE.md ([N] lines) - System design and patterns
276
- - STRUCTURE.md ([N] lines) - Directory layout and organization
277
- - CONVENTIONS.md ([N] lines) - Code style and patterns
278
- - TESTING.md ([N] lines) - Test structure and practices
279
- - INTEGRATIONS.md ([N] lines) - External services and APIs
280
- - CONCERNS.md ([N] lines) - Technical debt and issues
281
-
282
-
283
- ---
284
-
285
- ## ▶ Next Up
286
-
287
- **Initialize project** — use codebase context for planning
288
-
289
- `/ez:new-project`
290
-
291
- <sub>`/clear` first → fresh context window</sub>
292
-
293
- ---
294
-
295
- **Also available:**
296
- - Re-run mapping: `/ez:map-codebase`
297
- - Review specific file: `cat .planning/codebase/STACK.md`
298
- - Edit any document before proceeding
299
-
300
- ---
301
- ```
302
-
303
- End workflow.
304
- </step>
305
-
306
- </process>
307
-
308
- <success_criteria>
309
- - .planning/codebase/ directory created
310
- - 4 parallel ez-codebase-mapper agents spawned with run_in_background=true
311
- - Agents write documents directly (orchestrator doesn't receive document contents)
312
- - Read agent output files to collect confirmations
313
- - All 7 codebase documents exist
314
- - Clear completion summary with line counts
315
- - User offered clear next steps in EZ style
316
- </success_criteria>
1
+ <purpose>
2
+ Orchestrate parallel codebase mapper agents to analyze codebase and produce structured documents in .planning/codebase/
3
+
4
+ Each agent has fresh context, explores a specific focus area, and **writes documents directly**. The orchestrator only receives confirmation + line counts, then writes a summary.
5
+
6
+ Output: .planning/codebase/ folder with 7 structured documents about the codebase state.
7
+ </purpose>
8
+
9
+ <philosophy>
10
+ **Why dedicated mapper agents:**
11
+ - Fresh context per domain (no token contamination)
12
+ - Agents write documents directly (no context transfer back to orchestrator)
13
+ - Orchestrator only summarizes what was created (minimal context usage)
14
+ - Faster execution (agents run simultaneously)
15
+
16
+ **Document quality over length:**
17
+ Include enough detail to be useful as reference. Prioritize practical examples (especially code patterns) over arbitrary brevity.
18
+
19
+ **Always include file paths:**
20
+ Documents are reference material for Claude when planning/executing. Always include actual file paths formatted with backticks: `src/services/user.ts`.
21
+ </philosophy>
22
+
23
+ <process>
24
+
25
+ <step name="init_context" priority="first">
26
+ Load codebase mapping context:
27
+
28
+ ```bash
29
+ INIT=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" init map-codebase)
30
+ if [[ "$INIT" == @file:* ]]; then INIT=$(cat "${INIT#@file:}"); fi
31
+ ```
32
+
33
+ Extract from init JSON: `mapper_model`, `commit_docs`, `codebase_dir`, `existing_maps`, `has_maps`, `codebase_dir_exists`.
34
+ </step>
35
+
36
+ <step name="check_existing">
37
+ Check if .planning/codebase/ already exists using `has_maps` from init context.
38
+
39
+ If `codebase_dir_exists` is true:
40
+ ```bash
41
+ ls -la .planning/codebase/
42
+ ```
43
+
44
+ **If exists:**
45
+
46
+ ```
47
+ .planning/codebase/ already exists with these documents:
48
+ [List files found]
49
+
50
+ What's next?
51
+ 1. Refresh - Delete existing and remap codebase
52
+ 2. Update - Keep existing, only update specific documents
53
+ 3. Skip - Use existing codebase map as-is
54
+ ```
55
+
56
+ Wait for user response.
57
+
58
+ If "Refresh": Delete .planning/codebase/, continue to create_structure
59
+ If "Update": Ask which documents to update, continue to spawn_agents (filtered)
60
+ If "Skip": Exit workflow
61
+
62
+ **If doesn't exist:**
63
+ Continue to create_structure.
64
+ </step>
65
+
66
+ <step name="create_structure">
67
+ Create .planning/codebase/ directory:
68
+
69
+ ```bash
70
+ mkdir -p .planning/codebase
71
+ ```
72
+
73
+ **Expected output files:**
74
+ - STACK.md (from tech mapper)
75
+ - INTEGRATIONS.md (from tech mapper)
76
+ - ARCHITECTURE.md (from arch mapper)
77
+ - STRUCTURE.md (from arch mapper)
78
+ - CONVENTIONS.md (from quality mapper)
79
+ - TESTING.md (from quality mapper)
80
+ - CONCERNS.md (from concerns mapper)
81
+
82
+ Continue to spawn_agents.
83
+ </step>
84
+
85
+ <step name="spawn_agents">
86
+ Spawn 4 parallel ez-codebase-mapper agents.
87
+
88
+ Use Task tool with `subagent_type="ez-codebase-mapper"`, `model="{mapper_model}"`, and `run_in_background=true` for parallel execution.
89
+
90
+ **CRITICAL:** Use the dedicated `ez-codebase-mapper` agent, NOT `Explore`. The mapper agent writes documents directly.
91
+
92
+ **Agent 1: Tech Focus**
93
+
94
+ ```
95
+ Task(
96
+ subagent_type="ez-codebase-mapper",
97
+ model="{mapper_model}",
98
+ run_in_background=true,
99
+ description="Map codebase tech stack",
100
+ prompt="Focus: tech
101
+
102
+ Analyze this codebase for technology stack and external integrations.
103
+
104
+ Write these documents to .planning/codebase/:
105
+ - STACK.md - Languages, runtime, frameworks, dependencies, configuration
106
+ - INTEGRATIONS.md - External APIs, databases, auth providers, webhooks
107
+
108
+ Explore thoroughly. Write documents directly using templates. Return confirmation only."
109
+ )
110
+ ```
111
+
112
+ **Agent 2: Architecture Focus**
113
+
114
+ ```
115
+ Task(
116
+ subagent_type="ez-codebase-mapper",
117
+ model="{mapper_model}",
118
+ run_in_background=true,
119
+ description="Map codebase architecture",
120
+ prompt="Focus: arch
121
+
122
+ Analyze this codebase architecture and directory structure.
123
+
124
+ Write these documents to .planning/codebase/:
125
+ - ARCHITECTURE.md - Pattern, layers, data flow, abstractions, entry points
126
+ - STRUCTURE.md - Directory layout, key locations, naming conventions
127
+
128
+ Explore thoroughly. Write documents directly using templates. Return confirmation only."
129
+ )
130
+ ```
131
+
132
+ **Agent 3: Quality Focus**
133
+
134
+ ```
135
+ Task(
136
+ subagent_type="ez-codebase-mapper",
137
+ model="{mapper_model}",
138
+ run_in_background=true,
139
+ description="Map codebase conventions",
140
+ prompt="Focus: quality
141
+
142
+ Analyze this codebase for coding conventions and testing patterns.
143
+
144
+ Write these documents to .planning/codebase/:
145
+ - CONVENTIONS.md - Code style, naming, patterns, error handling
146
+ - TESTING.md - Framework, structure, mocking, coverage
147
+
148
+ Explore thoroughly. Write documents directly using templates. Return confirmation only."
149
+ )
150
+ ```
151
+
152
+ **Agent 4: Concerns Focus**
153
+
154
+ ```
155
+ Task(
156
+ subagent_type="ez-codebase-mapper",
157
+ model="{mapper_model}",
158
+ run_in_background=true,
159
+ description="Map codebase concerns",
160
+ prompt="Focus: concerns
161
+
162
+ Analyze this codebase for technical debt, known issues, and areas of concern.
163
+
164
+ Write this document to .planning/codebase/:
165
+ - CONCERNS.md - Tech debt, bugs, security, performance, fragile areas
166
+
167
+ Explore thoroughly. Write document directly using template. Return confirmation only."
168
+ )
169
+ ```
170
+
171
+ Continue to collect_confirmations.
172
+ </step>
173
+
174
+ <step name="collect_confirmations">
175
+ Wait for all 4 agents to complete.
176
+
177
+ Read each agent's output file to collect confirmations.
178
+
179
+ **Expected confirmation format from each agent:**
180
+ ```
181
+ ## Mapping Complete
182
+
183
+ **Focus:** {focus}
184
+ **Documents written:**
185
+ - `.planning/codebase/{DOC1}.md` ({N} lines)
186
+ - `.planning/codebase/{DOC2}.md` ({N} lines)
187
+
188
+ Ready for orchestrator summary.
189
+ ```
190
+
191
+ **What you receive:** Just file paths and line counts. NOT document contents.
192
+
193
+ If any agent failed, note the failure and continue with successful documents.
194
+
195
+ Continue to verify_output.
196
+ </step>
197
+
198
+ <step name="verify_output">
199
+ Verify all documents created successfully:
200
+
201
+ ```bash
202
+ ls -la .planning/codebase/
203
+ wc -l .planning/codebase/*.md
204
+ ```
205
+
206
+ **Verification checklist:**
207
+ - All 7 documents exist
208
+ - No empty documents (each should have >20 lines)
209
+
210
+ If any documents missing or empty, note which agents may have failed.
211
+
212
+ Continue to scan_for_secrets.
213
+ </step>
214
+
215
+ <step name="scan_for_secrets">
216
+ **CRITICAL SECURITY CHECK:** Scan output files for accidentally leaked secrets before committing.
217
+
218
+ Run secret pattern detection:
219
+
220
+ ```bash
221
+ # Check for common API key patterns in generated docs
222
+ grep -E '(sk-[a-zA-Z0-9]{20,}|sk_live_[a-zA-Z0-9]+|sk_test_[a-zA-Z0-9]+|ghp_[a-zA-Z0-9]{36}|gho_[a-zA-Z0-9]{36}|glpat-[a-zA-Z0-9_-]+|AKIA[A-Z0-9]{16}|xox[baprs]-[a-zA-Z0-9-]+|-----BEGIN.*PRIVATE KEY|eyJ[a-zA-Z0-9_-]+\.eyJ[a-zA-Z0-9_-]+\.)' .planning/codebase/*.md 2>/dev/null && SECRETS_FOUND=true || SECRETS_FOUND=false
223
+ ```
224
+
225
+ **If SECRETS_FOUND=true:**
226
+
227
+ ```
228
+ ⚠️ SECURITY ALERT: Potential secrets detected in codebase documents!
229
+
230
+ Found patterns that look like API keys or tokens in:
231
+ [show grep output]
232
+
233
+ This would expose credentials if committed.
234
+
235
+ **Action required:**
236
+ 1. Review the flagged content above
237
+ 2. If these are real secrets, they must be removed before committing
238
+ 3. Consider adding sensitive files to Claude Code "Deny" permissions
239
+
240
+ Pausing before commit. Reply "safe to proceed" if the flagged content is not actually sensitive, or edit the files first.
241
+ ```
242
+
243
+ Wait for user confirmation before continuing to commit_codebase_map.
244
+
245
+ **If SECRETS_FOUND=false:**
246
+
247
+ Continue to commit_codebase_map.
248
+ </step>
249
+
250
+ <step name="commit_codebase_map">
251
+ Commit the codebase map:
252
+
253
+ ```bash
254
+ node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" commit "docs: map existing codebase" --files .planning/codebase/*.md
255
+ ```
256
+
257
+ Continue to offer_next.
258
+ </step>
259
+
260
+ <step name="offer_next">
261
+ Present completion summary and next steps.
262
+
263
+ **Get line counts:**
264
+ ```bash
265
+ wc -l .planning/codebase/*.md
266
+ ```
267
+
268
+ **Output format:**
269
+
270
+ ```
271
+ Codebase mapping complete.
272
+
273
+ Created .planning/codebase/:
274
+ - STACK.md ([N] lines) - Technologies and dependencies
275
+ - ARCHITECTURE.md ([N] lines) - System design and patterns
276
+ - STRUCTURE.md ([N] lines) - Directory layout and organization
277
+ - CONVENTIONS.md ([N] lines) - Code style and patterns
278
+ - TESTING.md ([N] lines) - Test structure and practices
279
+ - INTEGRATIONS.md ([N] lines) - External services and APIs
280
+ - CONCERNS.md ([N] lines) - Technical debt and issues
281
+
282
+
283
+ ---
284
+
285
+ ## ▶ Next Up
286
+
287
+ **Initialize project** — use codebase context for planning
288
+
289
+ `/ez:new-project`
290
+
291
+ <sub>`/clear` first → fresh context window</sub>
292
+
293
+ ---
294
+
295
+ **Also available:**
296
+ - Re-run mapping: `/ez:map-codebase`
297
+ - Review specific file: `cat .planning/codebase/STACK.md`
298
+ - Edit any document before proceeding
299
+
300
+ ---
301
+ ```
302
+
303
+ End workflow.
304
+ </step>
305
+
306
+ </process>
307
+
308
+ <success_criteria>
309
+ - .planning/codebase/ directory created
310
+ - 4 parallel ez-codebase-mapper agents spawned with run_in_background=true
311
+ - Agents write documents directly (orchestrator doesn't receive document contents)
312
+ - Read agent output files to collect confirmations
313
+ - All 7 codebase documents exist
314
+ - Clear completion summary with line counts
315
+ - User offered clear next steps in EZ style
316
+ </success_criteria>