@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
@@ -0,0 +1,215 @@
1
+ # Workflow: resume-session
2
+
3
+ **Purpose:** Resume work from a previous session with full context restoration
4
+
5
+ **Related Commands:** `/ez:resume`
6
+
7
+ ---
8
+
9
+ ## Workflow Steps
10
+
11
+ ### 1. Load and Validate Session
12
+
13
+ ```
14
+ SessionManager mgr = new SessionManager();
15
+ Session session = sessionId ? mgr.loadSession(sessionId) : mgr.getLastSession();
16
+
17
+ if (!session) {
18
+ output("No previous sessions found. Start a new session with your work.");
19
+ exit;
20
+ }
21
+
22
+ logger.info('Resuming session', { sessionId: session.metadata.session_id });
23
+ ```
24
+
25
+ ### 2. Compare with Current State
26
+
27
+ ```
28
+ Load current STATE.md
29
+ Extract current phase, plan, incomplete tasks from STATE.md
30
+
31
+ sessionPhase = session.state.current_phase
32
+ sessionPlan = session.state.current_plan
33
+ statePhase = STATE.md.current_phase
34
+ statePlan = STATE.md.current_plan
35
+
36
+ needsReconciliation = (sessionPhase !== statePhase) || (sessionPlan !== statePlan)
37
+ ```
38
+
39
+ ### 3. If Reconciliation Needed
40
+
41
+ **Display Warning:**
42
+ ```
43
+ ⚠️ Session state differs from current project state
44
+
45
+ Session shows:
46
+ - Phase: {session.state.current_phase}
47
+ - Plan: {session.state.current_plan}
48
+
49
+ Current STATE.md shows:
50
+ - Phase: {state.current_phase}
51
+ - Plan: {state.current_plan}
52
+ ```
53
+
54
+ **Offer Options:**
55
+ ```
56
+ How would you like to reconcile?
57
+
58
+ 1. Use session state (overwrite STATE.md)
59
+ 2. Use current state (ignore session state)
60
+ 3. Manual review (show both, let user decide)
61
+ ```
62
+
63
+ **Handle Choice:**
64
+ - "1": Update STATE.md with session.state values
65
+ - "2": Keep STATE.md unchanged, use session context only
66
+ - "3": Show side-by-side comparison, let user edit
67
+
68
+ ### 4. Load Context
69
+
70
+ ```
71
+ // Load recent transcript for context
72
+ transcript = session.context.transcript
73
+ if (Array.isArray(transcript)) {
74
+ recentMessages = transcript.slice(-20) // Last 20 messages
75
+ }
76
+
77
+ // Load tasks
78
+ completedTasks = session.context.tasks.filter(t => t.status === 'completed')
79
+ incompleteTasks = session.state.incomplete_tasks
80
+
81
+ // Load decisions
82
+ decisions = session.context.decisions
83
+
84
+ // Load file changes
85
+ fileChanges = session.context.file_changes
86
+ ```
87
+
88
+ ### 5. Update STATE.md
89
+
90
+ ```
91
+ ez-tools state record-session \
92
+ --stopped-at "{session.state.last_action}" \
93
+ --resume-file "{session.metadata.session_id}"
94
+
95
+ // Update phase/plan if using session state
96
+ if (useSessionState) {
97
+ ez-tools state update "Current Phase" "{session.metadata.phase}"
98
+ ez-tools state update "Current Plan" "{session.metadata.plan}"
99
+ }
100
+ ```
101
+
102
+ ### 6. Prepare for Continuation
103
+
104
+ ```
105
+ // Identify incomplete work
106
+ incompleteTasks = session.state.incomplete_tasks || []
107
+
108
+ // Identify next action
109
+ nextAction = session.state.next_recommended_action
110
+
111
+ // Load relevant files
112
+ if (session.metadata.phase && session.metadata.plan) {
113
+ planFile = `.planning/phases/${session.metadata.phase}/.../${session.metadata.plan}-PLAN.md`
114
+ summaryFile = `.planning/phases/${session.metadata.phase}/.../${session.metadata.plan}-PLAN-SUMMARY.md`
115
+
116
+ if (fileExists(planFile)) {
117
+ loadFile(planFile)
118
+ }
119
+ }
120
+
121
+ // Load incomplete task files
122
+ for (task of incompleteTasks) {
123
+ if (task.file) {
124
+ loadFile(task.file)
125
+ }
126
+ }
127
+ ```
128
+
129
+ ### 7. Output Resumption Confirmation
130
+
131
+ ```
132
+ ╔══════════════════════════════════════════════════════════════╗
133
+ ║ SESSION RESUMED ║
134
+ ╠══════════════════════════════════════════════════════════════╣
135
+ ║ Session: {session.metadata.session_id} ║
136
+ ║ Phase: {session.metadata.phase} ║
137
+ ║ Plan: {session.metadata.plan} ║
138
+ ║ Next action: {session.state.next_recommended_action} ║
139
+ ╚══════════════════════════════════════════════════════════════╝
140
+
141
+ Context loaded:
142
+ - {incompleteTasks.length} incomplete tasks
143
+ - {decisions.length} decisions recorded
144
+ - {fileChanges.length} file changes
145
+
146
+ Ready to continue. What would you like to do?
147
+
148
+ 1. Continue with recommended action
149
+ 2. Review incomplete tasks
150
+ 3. View session transcript
151
+ 4. Something else
152
+ ```
153
+
154
+ ---
155
+
156
+ ## Error Handling
157
+
158
+ ### Session Not Found
159
+ ```
160
+ if (!session) {
161
+ output(`Session not found: ${sessionId}`);
162
+ output("Use /ez:list-sessions to see available sessions.");
163
+ exit;
164
+ }
165
+ ```
166
+
167
+ ### Corrupted Session File
168
+ ```
169
+ try {
170
+ session = JSON.parse(content);
171
+ } catch (err) {
172
+ logger.error('Corrupted session file', { sessionId, error: err.message });
173
+ output(`Error: Session file is corrupted: ${sessionId}`);
174
+ output("Consider deleting the file or contacting support.");
175
+ exit;
176
+ }
177
+ ```
178
+
179
+ ### Broken Chain Links
180
+ ```
181
+ if (session.metadata.session_chain) {
182
+ for (chainId of session.metadata.session_chain) {
183
+ if (!mgr.loadSession(chainId)) {
184
+ warnings.push(`Missing linked session: ${chainId}`);
185
+ }
186
+ }
187
+
188
+ if (warnings.length > 0) {
189
+ output("⚠️ Session chain has broken links:");
190
+ for (warning of warnings) {
191
+ output(` - ${warning}`);
192
+ }
193
+ }
194
+ }
195
+ ```
196
+
197
+ ---
198
+
199
+ ## State Transitions
200
+
201
+ **Before:** Session ended, STATE.md shows stopped state
202
+
203
+ **After:** Session resumed, STATE.md updated with:
204
+ - `Last session`: Current timestamp
205
+ - `Resume file`: Session ID
206
+ - `Stopped at`: Last action from session
207
+
208
+ ---
209
+
210
+ ## Related Files
211
+
212
+ - `ez-agents/bin/lib/session-manager.cjs` - Session loading
213
+ - `ez-agents/bin/lib/session-chain.cjs` - Chain navigation
214
+ - `ez-agents/bin/lib/state.cjs` - STATE.md updates
215
+ - `.planning/sessions/` - Session storage directory
@@ -1,81 +1,81 @@
1
- <purpose>
2
- Switch the model profile used by EZ agents. Controls which Claude model each agent uses, balancing quality vs token spend.
3
- </purpose>
4
-
5
- <required_reading>
6
- Read all files referenced by the invoking prompt's execution_context before starting.
7
- </required_reading>
8
-
9
- <process>
10
-
11
- <step name="validate">
12
- Validate argument:
13
-
14
- ```
15
- if $ARGUMENTS.profile not in ["quality", "balanced", "budget"]:
16
- Error: Invalid profile "$ARGUMENTS.profile"
17
- Valid profiles: quality, balanced, budget
18
- EXIT
19
- ```
20
- </step>
21
-
22
- <step name="ensure_and_load_config">
23
- Ensure config exists and load current state:
24
-
25
- ```bash
26
- node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" config-ensure-section
27
- INIT=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" state load)
28
- if [[ "$INIT" == @file:* ]]; then INIT=$(cat "${INIT#@file:}"); fi
29
- ```
30
-
31
- This creates `.planning/config.json` with defaults if missing and loads current config.
32
- </step>
33
-
34
- <step name="update_config">
35
- Read current config from state load or directly:
36
-
37
- Update `model_profile` field:
38
- ```json
39
- {
40
- "model_profile": "$ARGUMENTS.profile"
41
- }
42
- ```
43
-
44
- Write updated config back to `.planning/config.json`.
45
- </step>
46
-
47
- <step name="confirm">
48
- Display confirmation with model table for selected profile:
49
-
50
- ```
51
- ✓ Model profile set to: $ARGUMENTS.profile
52
-
53
- Agents will now use:
54
-
55
- [Show table from MODEL_PROFILES in ez-tools.cjs for selected profile]
56
-
57
- Example:
58
- | Agent | Model |
59
- |-------|-------|
60
- | ez-planner | opus |
61
- | ez-executor | sonnet |
62
- | ez-verifier | haiku |
63
- | ... | ... |
64
-
65
- Next spawned agents will use the new profile.
66
- ```
67
-
68
- Map profile names:
69
- - quality: use "quality" column from MODEL_PROFILES
70
- - balanced: use "balanced" column from MODEL_PROFILES
71
- - budget: use "budget" column from MODEL_PROFILES
72
- </step>
73
-
74
- </process>
75
-
76
- <success_criteria>
77
- - [ ] Argument validated
78
- - [ ] Config file ensured
79
- - [ ] Config updated with new model_profile
80
- - [ ] Confirmation displayed with model table
81
- </success_criteria>
1
+ <purpose>
2
+ Switch the model profile used by EZ agents. Controls which Claude model each agent uses, balancing quality vs token spend.
3
+ </purpose>
4
+
5
+ <required_reading>
6
+ Read all files referenced by the invoking prompt's execution_context before starting.
7
+ </required_reading>
8
+
9
+ <process>
10
+
11
+ <step name="validate">
12
+ Validate argument:
13
+
14
+ ```
15
+ if $ARGUMENTS.profile not in ["quality", "balanced", "budget"]:
16
+ Error: Invalid profile "$ARGUMENTS.profile"
17
+ Valid profiles: quality, balanced, budget
18
+ EXIT
19
+ ```
20
+ </step>
21
+
22
+ <step name="ensure_and_load_config">
23
+ Ensure config exists and load current state:
24
+
25
+ ```bash
26
+ node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" config-ensure-section
27
+ INIT=$(node "$HOME/.claude/ez-agents/bin/ez-tools.cjs" state load)
28
+ if [[ "$INIT" == @file:* ]]; then INIT=$(cat "${INIT#@file:}"); fi
29
+ ```
30
+
31
+ This creates `.planning/config.json` with defaults if missing and loads current config.
32
+ </step>
33
+
34
+ <step name="update_config">
35
+ Read current config from state load or directly:
36
+
37
+ Update `model_profile` field:
38
+ ```json
39
+ {
40
+ "model_profile": "$ARGUMENTS.profile"
41
+ }
42
+ ```
43
+
44
+ Write updated config back to `.planning/config.json`.
45
+ </step>
46
+
47
+ <step name="confirm">
48
+ Display confirmation with model table for selected profile:
49
+
50
+ ```
51
+ ✓ Model profile set to: $ARGUMENTS.profile
52
+
53
+ Agents will now use:
54
+
55
+ [Show table from MODEL_PROFILES in ez-tools.cjs for selected profile]
56
+
57
+ Example:
58
+ | Agent | Model |
59
+ |-------|-------|
60
+ | ez-planner | opus |
61
+ | ez-executor | sonnet |
62
+ | ez-verifier | haiku |
63
+ | ... | ... |
64
+
65
+ Next spawned agents will use the new profile.
66
+ ```
67
+
68
+ Map profile names:
69
+ - quality: use "quality" column from MODEL_PROFILES
70
+ - balanced: use "balanced" column from MODEL_PROFILES
71
+ - budget: use "budget" column from MODEL_PROFILES
72
+ </step>
73
+
74
+ </process>
75
+
76
+ <success_criteria>
77
+ - [ ] Argument validated
78
+ - [ ] Config file ensured
79
+ - [ ] Config updated with new model_profile
80
+ - [ ] Confirmation displayed with model table
81
+ </success_criteria>