@howlil/ez-agents 2.0.0 → 3.0.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 (145) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +157 -110
  3. package/README.zh-CN.md +84 -84
  4. package/agents/ez-plan-checker.md +2 -2
  5. package/agents/ez-research-synthesizer.md +1 -1
  6. package/agents/ez-ui-auditor.md +0 -2
  7. package/agents/ez-ui-checker.md +2 -4
  8. package/agents/ez-ui-researcher.md +0 -2
  9. package/agents/ez-verifier.md +1 -1
  10. package/bin/install.js +211 -211
  11. package/commands/ez/debug.md +1 -1
  12. package/commands/ez/map-codebase.md +1 -1
  13. package/commands/ez/reapply-patches.md +3 -3
  14. package/commands/ez/research-phase.md +1 -1
  15. package/{get-shit-done → ez-agents}/bin/ez-tools.cjs +1 -1
  16. package/{get-shit-done → ez-agents}/bin/lib/assistant-adapter.cjs +205 -205
  17. package/{get-shit-done → ez-agents}/bin/lib/audit-exec.cjs +150 -150
  18. package/{get-shit-done → ez-agents}/bin/lib/auth.cjs +175 -175
  19. package/{get-shit-done → ez-agents}/bin/lib/circuit-breaker.cjs +118 -118
  20. package/{get-shit-done → ez-agents}/bin/lib/commands.cjs +666 -666
  21. package/{get-shit-done → ez-agents}/bin/lib/config.cjs +183 -183
  22. package/{get-shit-done → ez-agents}/bin/lib/core.cjs +495 -495
  23. package/{get-shit-done → ez-agents}/bin/lib/file-lock.cjs +236 -236
  24. package/{get-shit-done → ez-agents}/bin/lib/frontmatter.cjs +299 -299
  25. package/{get-shit-done → ez-agents}/bin/lib/fs-utils.cjs +153 -153
  26. package/{get-shit-done → ez-agents}/bin/lib/git-utils.cjs +203 -203
  27. package/{get-shit-done → ez-agents}/bin/lib/health-check.cjs +163 -163
  28. package/{get-shit-done → ez-agents}/bin/lib/index.cjs +113 -113
  29. package/{get-shit-done → ez-agents}/bin/lib/init.cjs +710 -710
  30. package/{get-shit-done → ez-agents}/bin/lib/logger.cjs +117 -117
  31. package/{get-shit-done → ez-agents}/bin/lib/milestone.cjs +241 -241
  32. package/{get-shit-done → ez-agents}/bin/lib/model-provider.cjs +146 -146
  33. package/{get-shit-done → ez-agents}/bin/lib/phase.cjs +908 -908
  34. package/{get-shit-done → ez-agents}/bin/lib/retry.cjs +119 -119
  35. package/{get-shit-done → ez-agents}/bin/lib/roadmap.cjs +305 -305
  36. package/{get-shit-done → ez-agents}/bin/lib/safe-exec.cjs +128 -128
  37. package/{get-shit-done → ez-agents}/bin/lib/safe-path.cjs +130 -130
  38. package/{get-shit-done → ez-agents}/bin/lib/state.cjs +721 -721
  39. package/{get-shit-done → ez-agents}/bin/lib/temp-file.cjs +239 -239
  40. package/{get-shit-done → ez-agents}/bin/lib/template.cjs +222 -222
  41. package/{get-shit-done → ez-agents}/bin/lib/test-file-lock.cjs +112 -112
  42. package/{get-shit-done → ez-agents}/bin/lib/test-graceful.cjs +93 -93
  43. package/{get-shit-done → ez-agents}/bin/lib/test-logger.cjs +60 -60
  44. package/{get-shit-done → ez-agents}/bin/lib/test-safe-exec.cjs +38 -38
  45. package/{get-shit-done → ez-agents}/bin/lib/test-safe-path.cjs +33 -33
  46. package/{get-shit-done → ez-agents}/bin/lib/test-temp-file.cjs +125 -125
  47. package/{get-shit-done → ez-agents}/bin/lib/timeout-exec.cjs +62 -62
  48. package/{get-shit-done → ez-agents}/bin/lib/verify.cjs +820 -820
  49. package/{get-shit-done → ez-agents}/references/checkpoints.md +776 -776
  50. package/{get-shit-done → ez-agents}/references/questioning.md +162 -162
  51. package/{get-shit-done → ez-agents}/references/tdd.md +263 -263
  52. package/{get-shit-done → ez-agents}/templates/codebase/concerns.md +310 -310
  53. package/{get-shit-done → ez-agents}/templates/codebase/conventions.md +307 -307
  54. package/{get-shit-done → ez-agents}/templates/codebase/integrations.md +280 -280
  55. package/{get-shit-done → ez-agents}/templates/codebase/stack.md +186 -186
  56. package/{get-shit-done → ez-agents}/templates/codebase/testing.md +480 -480
  57. package/{get-shit-done → ez-agents}/templates/config.json +37 -37
  58. package/{get-shit-done → ez-agents}/templates/continue-here.md +78 -78
  59. package/{get-shit-done → ez-agents}/templates/milestone-archive.md +123 -123
  60. package/{get-shit-done → ez-agents}/templates/milestone.md +115 -115
  61. package/{get-shit-done → ez-agents}/templates/requirements.md +231 -231
  62. package/{get-shit-done → ez-agents}/templates/research-project/ARCHITECTURE.md +204 -204
  63. package/{get-shit-done → ez-agents}/templates/research-project/FEATURES.md +147 -147
  64. package/{get-shit-done → ez-agents}/templates/research-project/PITFALLS.md +200 -200
  65. package/{get-shit-done → ez-agents}/templates/research-project/STACK.md +120 -120
  66. package/{get-shit-done → ez-agents}/templates/research-project/SUMMARY.md +170 -170
  67. package/{get-shit-done → ez-agents}/templates/retrospective.md +54 -54
  68. package/{get-shit-done → ez-agents}/templates/roadmap.md +202 -202
  69. package/{get-shit-done → ez-agents}/templates/summary-minimal.md +41 -41
  70. package/{get-shit-done → ez-agents}/templates/summary-standard.md +48 -48
  71. package/{get-shit-done → ez-agents}/templates/summary.md +248 -248
  72. package/{get-shit-done → ez-agents}/templates/user-setup.md +311 -311
  73. package/{get-shit-done → ez-agents}/templates/verification-report.md +322 -322
  74. package/{get-shit-done → ez-agents}/workflows/add-phase.md +112 -112
  75. package/{get-shit-done → ez-agents}/workflows/add-tests.md +351 -351
  76. package/{get-shit-done → ez-agents}/workflows/add-todo.md +158 -158
  77. package/{get-shit-done → ez-agents}/workflows/audit-milestone.md +332 -332
  78. package/{get-shit-done → ez-agents}/workflows/autonomous.md +743 -743
  79. package/{get-shit-done → ez-agents}/workflows/check-todos.md +177 -177
  80. package/{get-shit-done → ez-agents}/workflows/cleanup.md +152 -152
  81. package/{get-shit-done → ez-agents}/workflows/complete-milestone.md +766 -766
  82. package/ez-agents/workflows/debug.md +0 -0
  83. package/{get-shit-done → ez-agents}/workflows/diagnose-issues.md +219 -219
  84. package/{get-shit-done → ez-agents}/workflows/discovery-phase.md +289 -289
  85. package/{get-shit-done → ez-agents}/workflows/discuss-phase.md +762 -762
  86. package/{get-shit-done → ez-agents}/workflows/execute-phase.md +468 -468
  87. package/{get-shit-done → ez-agents}/workflows/execute-plan.md +483 -483
  88. package/{get-shit-done → ez-agents}/workflows/health.md +159 -159
  89. package/{get-shit-done → ez-agents}/workflows/help.md +492 -492
  90. package/{get-shit-done → ez-agents}/workflows/insert-phase.md +130 -130
  91. package/{get-shit-done → ez-agents}/workflows/list-phase-assumptions.md +178 -178
  92. package/{get-shit-done → ez-agents}/workflows/map-codebase.md +316 -316
  93. package/{get-shit-done → ez-agents}/workflows/new-milestone.md +384 -384
  94. package/{get-shit-done → ez-agents}/workflows/new-project.md +1111 -1111
  95. package/{get-shit-done → ez-agents}/workflows/node-repair.md +92 -92
  96. package/{get-shit-done → ez-agents}/workflows/pause-work.md +122 -122
  97. package/{get-shit-done → ez-agents}/workflows/plan-milestone-gaps.md +274 -274
  98. package/{get-shit-done → ez-agents}/workflows/plan-phase.md +651 -651
  99. package/{get-shit-done → ez-agents}/workflows/progress.md +382 -382
  100. package/{get-shit-done → ez-agents}/workflows/quick.md +610 -610
  101. package/{get-shit-done → ez-agents}/workflows/remove-phase.md +155 -155
  102. package/{get-shit-done → ez-agents}/workflows/research-phase.md +74 -74
  103. package/{get-shit-done → ez-agents}/workflows/resume-project.md +307 -307
  104. package/{get-shit-done → ez-agents}/workflows/set-profile.md +81 -81
  105. package/{get-shit-done → ez-agents}/workflows/settings.md +242 -242
  106. package/{get-shit-done → ez-agents}/workflows/stats.md +57 -57
  107. package/{get-shit-done → ez-agents}/workflows/transition.md +544 -544
  108. package/{get-shit-done → ez-agents}/workflows/ui-phase.md +290 -290
  109. package/{get-shit-done → ez-agents}/workflows/ui-review.md +157 -157
  110. package/{get-shit-done → ez-agents}/workflows/update.md +320 -320
  111. package/{get-shit-done → ez-agents}/workflows/validate-phase.md +167 -167
  112. package/{get-shit-done → ez-agents}/workflows/verify-phase.md +243 -243
  113. package/{get-shit-done → ez-agents}/workflows/verify-work.md +5 -5
  114. package/hooks/dist/ez-check-update.js +81 -0
  115. package/hooks/dist/ez-context-monitor.js +141 -0
  116. package/hooks/dist/ez-statusline.js +115 -0
  117. package/package.json +13 -3
  118. package/scripts/build-hooks.js +43 -43
  119. package/scripts/run-tests.cjs +29 -29
  120. /package/{get-shit-done → ez-agents}/references/continuation-format.md +0 -0
  121. /package/{get-shit-done → ez-agents}/references/decimal-phase-calculation.md +0 -0
  122. /package/{get-shit-done → ez-agents}/references/git-integration.md +0 -0
  123. /package/{get-shit-done → ez-agents}/references/git-planning-commit.md +0 -0
  124. /package/{get-shit-done → ez-agents}/references/model-profile-resolution.md +0 -0
  125. /package/{get-shit-done → ez-agents}/references/model-profiles.md +0 -0
  126. /package/{get-shit-done → ez-agents}/references/phase-argument-parsing.md +0 -0
  127. /package/{get-shit-done → ez-agents}/references/planning-config.md +0 -0
  128. /package/{get-shit-done → ez-agents}/references/ui-brand.md +0 -0
  129. /package/{get-shit-done → ez-agents}/references/verification-patterns.md +0 -0
  130. /package/{get-shit-done → ez-agents}/templates/DEBUG.md +0 -0
  131. /package/{get-shit-done → ez-agents}/templates/UAT.md +0 -0
  132. /package/{get-shit-done → ez-agents}/templates/UI-SPEC.md +0 -0
  133. /package/{get-shit-done → ez-agents}/templates/VALIDATION.md +0 -0
  134. /package/{get-shit-done → ez-agents}/templates/codebase/architecture.md +0 -0
  135. /package/{get-shit-done → ez-agents}/templates/codebase/structure.md +0 -0
  136. /package/{get-shit-done → ez-agents}/templates/context.md +0 -0
  137. /package/{get-shit-done → ez-agents}/templates/copilot-instructions.md +0 -0
  138. /package/{get-shit-done → ez-agents}/templates/debug-subagent-prompt.md +0 -0
  139. /package/{get-shit-done → ez-agents}/templates/discovery.md +0 -0
  140. /package/{get-shit-done → ez-agents}/templates/phase-prompt.md +0 -0
  141. /package/{get-shit-done → ez-agents}/templates/planner-subagent-prompt.md +0 -0
  142. /package/{get-shit-done → ez-agents}/templates/project.md +0 -0
  143. /package/{get-shit-done → ez-agents}/templates/research.md +0 -0
  144. /package/{get-shit-done → ez-agents}/templates/state.md +0 -0
  145. /package/{get-shit-done → ez-agents}/templates/summary-complex.md +0 -0
@@ -1,248 +1,248 @@
1
- # Summary Template
2
-
3
- Template for `.planning/phases/XX-name/{phase}-{plan}-SUMMARY.md` - phase completion documentation.
4
-
5
- ---
6
-
7
- ## File Template
8
-
9
- ```markdown
10
- ---
11
- phase: XX-name
12
- plan: YY
13
- subsystem: [primary category: auth, payments, ui, api, database, infra, testing, etc.]
14
- tags: [searchable tech: jwt, stripe, react, postgres, prisma]
15
-
16
- # Dependency graph
17
- requires:
18
- - phase: [prior phase this depends on]
19
- provides: [what that phase built that this uses]
20
- provides:
21
- - [bullet list of what this phase built/delivered]
22
- affects: [list of phase names or keywords that will need this context]
23
-
24
- # Tech tracking
25
- tech-stack:
26
- added: [libraries/tools added in this phase]
27
- patterns: [architectural/code patterns established]
28
-
29
- key-files:
30
- created: [important files created]
31
- modified: [important files modified]
32
-
33
- key-decisions:
34
- - "Decision 1"
35
- - "Decision 2"
36
-
37
- patterns-established:
38
- - "Pattern 1: description"
39
- - "Pattern 2: description"
40
-
41
- requirements-completed: [] # REQUIRED — Copy ALL requirement IDs from this plan's `requirements` frontmatter field.
42
-
43
- # Metrics
44
- duration: Xmin
45
- completed: YYYY-MM-DD
46
- ---
47
-
48
- # Phase [X]: [Name] Summary
49
-
50
- **[Substantive one-liner describing outcome - NOT "phase complete" or "implementation finished"]**
51
-
52
- ## Performance
53
-
54
- - **Duration:** [time] (e.g., 23 min, 1h 15m)
55
- - **Started:** [ISO timestamp]
56
- - **Completed:** [ISO timestamp]
57
- - **Tasks:** [count completed]
58
- - **Files modified:** [count]
59
-
60
- ## Accomplishments
61
- - [Most important outcome]
62
- - [Second key accomplishment]
63
- - [Third if applicable]
64
-
65
- ## Task Commits
66
-
67
- Each task was committed atomically:
68
-
69
- 1. **Task 1: [task name]** - `abc123f` (feat/fix/test/refactor)
70
- 2. **Task 2: [task name]** - `def456g` (feat/fix/test/refactor)
71
- 3. **Task 3: [task name]** - `hij789k` (feat/fix/test/refactor)
72
-
73
- **Plan metadata:** `lmn012o` (docs: complete plan)
74
-
75
- _Note: TDD tasks may have multiple commits (test → feat → refactor)_
76
-
77
- ## Files Created/Modified
78
- - `path/to/file.ts` - What it does
79
- - `path/to/another.ts` - What it does
80
-
81
- ## Decisions Made
82
- [Key decisions with brief rationale, or "None - followed plan as specified"]
83
-
84
- ## Deviations from Plan
85
-
86
- [If no deviations: "None - plan executed exactly as written"]
87
-
88
- [If deviations occurred:]
89
-
90
- ### Auto-fixed Issues
91
-
92
- **1. [Rule X - Category] Brief description**
93
- - **Found during:** Task [N] ([task name])
94
- - **Issue:** [What was wrong]
95
- - **Fix:** [What was done]
96
- - **Files modified:** [file paths]
97
- - **Verification:** [How it was verified]
98
- - **Committed in:** [hash] (part of task commit)
99
-
100
- [... repeat for each auto-fix ...]
101
-
102
- ---
103
-
104
- **Total deviations:** [N] auto-fixed ([breakdown by rule])
105
- **Impact on plan:** [Brief assessment - e.g., "All auto-fixes necessary for correctness/security. No scope creep."]
106
-
107
- ## Issues Encountered
108
- [Problems and how they were resolved, or "None"]
109
-
110
- [Note: "Deviations from Plan" documents unplanned work that was handled automatically via deviation rules. "Issues Encountered" documents problems during planned work that required problem-solving.]
111
-
112
- ## User Setup Required
113
-
114
- [If USER-SETUP.md was generated:]
115
- **External services require manual configuration.** See [{phase}-USER-SETUP.md](./{phase}-USER-SETUP.md) for:
116
- - Environment variables to add
117
- - Dashboard configuration steps
118
- - Verification commands
119
-
120
- [If no USER-SETUP.md:]
121
- None - no external service configuration required.
122
-
123
- ## Next Phase Readiness
124
- [What's ready for next phase]
125
- [Any blockers or concerns]
126
-
127
- ---
128
- *Phase: XX-name*
129
- *Completed: [date]*
130
- ```
131
-
132
- <frontmatter_guidance>
133
- **Purpose:** Enable automatic context assembly via dependency graph. Frontmatter makes summary metadata machine-readable so plan-phase can scan all summaries quickly and select relevant ones based on dependencies.
134
-
135
- **Fast scanning:** Frontmatter is first ~25 lines, cheap to scan across all summaries without reading full content.
136
-
137
- **Dependency graph:** `requires`/`provides`/`affects` create explicit links between phases, enabling transitive closure for context selection.
138
-
139
- **Subsystem:** Primary categorization (auth, payments, ui, api, database, infra, testing) for detecting related phases.
140
-
141
- **Tags:** Searchable technical keywords (libraries, frameworks, tools) for tech stack awareness.
142
-
143
- **Key-files:** Important files for @context references in PLAN.md.
144
-
145
- **Patterns:** Established conventions future phases should maintain.
146
-
147
- **Population:** Frontmatter is populated during summary creation in execute-plan.md. See `<step name="create_summary">` for field-by-field guidance.
148
- </frontmatter_guidance>
149
-
150
- <one_liner_rules>
151
- The one-liner MUST be substantive:
152
-
153
- **Good:**
154
- - "JWT auth with refresh rotation using jose library"
155
- - "Prisma schema with User, Session, and Product models"
156
- - "Dashboard with real-time metrics via Server-Sent Events"
157
-
158
- **Bad:**
159
- - "Phase complete"
160
- - "Authentication implemented"
161
- - "Foundation finished"
162
- - "All tasks done"
163
-
164
- The one-liner should tell someone what actually shipped.
165
- </one_liner_rules>
166
-
167
- <example>
168
- ```markdown
169
- # Phase 1: Foundation Summary
170
-
171
- **JWT auth with refresh rotation using jose library, Prisma User model, and protected API middleware**
172
-
173
- ## Performance
174
-
175
- - **Duration:** 28 min
176
- - **Started:** 2025-01-15T14:22:10Z
177
- - **Completed:** 2025-01-15T14:50:33Z
178
- - **Tasks:** 5
179
- - **Files modified:** 8
180
-
181
- ## Accomplishments
182
- - User model with email/password auth
183
- - Login/logout endpoints with httpOnly JWT cookies
184
- - Protected route middleware checking token validity
185
- - Refresh token rotation on each request
186
-
187
- ## Files Created/Modified
188
- - `prisma/schema.prisma` - User and Session models
189
- - `src/app/api/auth/login/route.ts` - Login endpoint
190
- - `src/app/api/auth/logout/route.ts` - Logout endpoint
191
- - `src/middleware.ts` - Protected route checks
192
- - `src/lib/auth.ts` - JWT helpers using jose
193
-
194
- ## Decisions Made
195
- - Used jose instead of jsonwebtoken (ESM-native, Edge-compatible)
196
- - 15-min access tokens with 7-day refresh tokens
197
- - Storing refresh tokens in database for revocation capability
198
-
199
- ## Deviations from Plan
200
-
201
- ### Auto-fixed Issues
202
-
203
- **1. [Rule 2 - Missing Critical] Added password hashing with bcrypt**
204
- - **Found during:** Task 2 (Login endpoint implementation)
205
- - **Issue:** Plan didn't specify password hashing - storing plaintext would be critical security flaw
206
- - **Fix:** Added bcrypt hashing on registration, comparison on login with salt rounds 10
207
- - **Files modified:** src/app/api/auth/login/route.ts, src/lib/auth.ts
208
- - **Verification:** Password hash test passes, plaintext never stored
209
- - **Committed in:** abc123f (Task 2 commit)
210
-
211
- **2. [Rule 3 - Blocking] Installed missing jose dependency**
212
- - **Found during:** Task 4 (JWT token generation)
213
- - **Issue:** jose package not in package.json, import failing
214
- - **Fix:** Ran `npm install jose`
215
- - **Files modified:** package.json, package-lock.json
216
- - **Verification:** Import succeeds, build passes
217
- - **Committed in:** def456g (Task 4 commit)
218
-
219
- ---
220
-
221
- **Total deviations:** 2 auto-fixed (1 missing critical, 1 blocking)
222
- **Impact on plan:** Both auto-fixes essential for security and functionality. No scope creep.
223
-
224
- ## Issues Encountered
225
- - jsonwebtoken CommonJS import failed in Edge runtime - switched to jose (planned library change, worked as expected)
226
-
227
- ## Next Phase Readiness
228
- - Auth foundation complete, ready for feature development
229
- - User registration endpoint needed before public launch
230
-
231
- ---
232
- *Phase: 01-foundation*
233
- *Completed: 2025-01-15*
234
- ```
235
- </example>
236
-
237
- <guidelines>
238
- **Frontmatter:** MANDATORY - complete all fields. Enables automatic context assembly for future planning.
239
-
240
- **One-liner:** Must be substantive. "JWT auth with refresh rotation using jose library" not "Authentication implemented".
241
-
242
- **Decisions section:**
243
- - Key decisions made during execution with rationale
244
- - Extracted to STATE.md accumulated context
245
- - Use "None - followed plan as specified" if no deviations
246
-
247
- **After creation:** STATE.md updated with position, decisions, issues.
248
- </guidelines>
1
+ # Summary Template
2
+
3
+ Template for `.planning/phases/XX-name/{phase}-{plan}-SUMMARY.md` - phase completion documentation.
4
+
5
+ ---
6
+
7
+ ## File Template
8
+
9
+ ```markdown
10
+ ---
11
+ phase: XX-name
12
+ plan: YY
13
+ subsystem: [primary category: auth, payments, ui, api, database, infra, testing, etc.]
14
+ tags: [searchable tech: jwt, stripe, react, postgres, prisma]
15
+
16
+ # Dependency graph
17
+ requires:
18
+ - phase: [prior phase this depends on]
19
+ provides: [what that phase built that this uses]
20
+ provides:
21
+ - [bullet list of what this phase built/delivered]
22
+ affects: [list of phase names or keywords that will need this context]
23
+
24
+ # Tech tracking
25
+ tech-stack:
26
+ added: [libraries/tools added in this phase]
27
+ patterns: [architectural/code patterns established]
28
+
29
+ key-files:
30
+ created: [important files created]
31
+ modified: [important files modified]
32
+
33
+ key-decisions:
34
+ - "Decision 1"
35
+ - "Decision 2"
36
+
37
+ patterns-established:
38
+ - "Pattern 1: description"
39
+ - "Pattern 2: description"
40
+
41
+ requirements-completed: [] # REQUIRED — Copy ALL requirement IDs from this plan's `requirements` frontmatter field.
42
+
43
+ # Metrics
44
+ duration: Xmin
45
+ completed: YYYY-MM-DD
46
+ ---
47
+
48
+ # Phase [X]: [Name] Summary
49
+
50
+ **[Substantive one-liner describing outcome - NOT "phase complete" or "implementation finished"]**
51
+
52
+ ## Performance
53
+
54
+ - **Duration:** [time] (e.g., 23 min, 1h 15m)
55
+ - **Started:** [ISO timestamp]
56
+ - **Completed:** [ISO timestamp]
57
+ - **Tasks:** [count completed]
58
+ - **Files modified:** [count]
59
+
60
+ ## Accomplishments
61
+ - [Most important outcome]
62
+ - [Second key accomplishment]
63
+ - [Third if applicable]
64
+
65
+ ## Task Commits
66
+
67
+ Each task was committed atomically:
68
+
69
+ 1. **Task 1: [task name]** - `abc123f` (feat/fix/test/refactor)
70
+ 2. **Task 2: [task name]** - `def456g` (feat/fix/test/refactor)
71
+ 3. **Task 3: [task name]** - `hij789k` (feat/fix/test/refactor)
72
+
73
+ **Plan metadata:** `lmn012o` (docs: complete plan)
74
+
75
+ _Note: TDD tasks may have multiple commits (test → feat → refactor)_
76
+
77
+ ## Files Created/Modified
78
+ - `path/to/file.ts` - What it does
79
+ - `path/to/another.ts` - What it does
80
+
81
+ ## Decisions Made
82
+ [Key decisions with brief rationale, or "None - followed plan as specified"]
83
+
84
+ ## Deviations from Plan
85
+
86
+ [If no deviations: "None - plan executed exactly as written"]
87
+
88
+ [If deviations occurred:]
89
+
90
+ ### Auto-fixed Issues
91
+
92
+ **1. [Rule X - Category] Brief description**
93
+ - **Found during:** Task [N] ([task name])
94
+ - **Issue:** [What was wrong]
95
+ - **Fix:** [What was done]
96
+ - **Files modified:** [file paths]
97
+ - **Verification:** [How it was verified]
98
+ - **Committed in:** [hash] (part of task commit)
99
+
100
+ [... repeat for each auto-fix ...]
101
+
102
+ ---
103
+
104
+ **Total deviations:** [N] auto-fixed ([breakdown by rule])
105
+ **Impact on plan:** [Brief assessment - e.g., "All auto-fixes necessary for correctness/security. No scope creep."]
106
+
107
+ ## Issues Encountered
108
+ [Problems and how they were resolved, or "None"]
109
+
110
+ [Note: "Deviations from Plan" documents unplanned work that was handled automatically via deviation rules. "Issues Encountered" documents problems during planned work that required problem-solving.]
111
+
112
+ ## User Setup Required
113
+
114
+ [If USER-SETUP.md was generated:]
115
+ **External services require manual configuration.** See [{phase}-USER-SETUP.md](./{phase}-USER-SETUP.md) for:
116
+ - Environment variables to add
117
+ - Dashboard configuration steps
118
+ - Verification commands
119
+
120
+ [If no USER-SETUP.md:]
121
+ None - no external service configuration required.
122
+
123
+ ## Next Phase Readiness
124
+ [What's ready for next phase]
125
+ [Any blockers or concerns]
126
+
127
+ ---
128
+ *Phase: XX-name*
129
+ *Completed: [date]*
130
+ ```
131
+
132
+ <frontmatter_guidance>
133
+ **Purpose:** Enable automatic context assembly via dependency graph. Frontmatter makes summary metadata machine-readable so plan-phase can scan all summaries quickly and select relevant ones based on dependencies.
134
+
135
+ **Fast scanning:** Frontmatter is first ~25 lines, cheap to scan across all summaries without reading full content.
136
+
137
+ **Dependency graph:** `requires`/`provides`/`affects` create explicit links between phases, enabling transitive closure for context selection.
138
+
139
+ **Subsystem:** Primary categorization (auth, payments, ui, api, database, infra, testing) for detecting related phases.
140
+
141
+ **Tags:** Searchable technical keywords (libraries, frameworks, tools) for tech stack awareness.
142
+
143
+ **Key-files:** Important files for @context references in PLAN.md.
144
+
145
+ **Patterns:** Established conventions future phases should maintain.
146
+
147
+ **Population:** Frontmatter is populated during summary creation in execute-plan.md. See `<step name="create_summary">` for field-by-field guidance.
148
+ </frontmatter_guidance>
149
+
150
+ <one_liner_rules>
151
+ The one-liner MUST be substantive:
152
+
153
+ **Good:**
154
+ - "JWT auth with refresh rotation using jose library"
155
+ - "Prisma schema with User, Session, and Product models"
156
+ - "Dashboard with real-time metrics via Server-Sent Events"
157
+
158
+ **Bad:**
159
+ - "Phase complete"
160
+ - "Authentication implemented"
161
+ - "Foundation finished"
162
+ - "All tasks done"
163
+
164
+ The one-liner should tell someone what actually shipped.
165
+ </one_liner_rules>
166
+
167
+ <example>
168
+ ```markdown
169
+ # Phase 1: Foundation Summary
170
+
171
+ **JWT auth with refresh rotation using jose library, Prisma User model, and protected API middleware**
172
+
173
+ ## Performance
174
+
175
+ - **Duration:** 28 min
176
+ - **Started:** 2025-01-15T14:22:10Z
177
+ - **Completed:** 2025-01-15T14:50:33Z
178
+ - **Tasks:** 5
179
+ - **Files modified:** 8
180
+
181
+ ## Accomplishments
182
+ - User model with email/password auth
183
+ - Login/logout endpoints with httpOnly JWT cookies
184
+ - Protected route middleware checking token validity
185
+ - Refresh token rotation on each request
186
+
187
+ ## Files Created/Modified
188
+ - `prisma/schema.prisma` - User and Session models
189
+ - `src/app/api/auth/login/route.ts` - Login endpoint
190
+ - `src/app/api/auth/logout/route.ts` - Logout endpoint
191
+ - `src/middleware.ts` - Protected route checks
192
+ - `src/lib/auth.ts` - JWT helpers using jose
193
+
194
+ ## Decisions Made
195
+ - Used jose instead of jsonwebtoken (ESM-native, Edge-compatible)
196
+ - 15-min access tokens with 7-day refresh tokens
197
+ - Storing refresh tokens in database for revocation capability
198
+
199
+ ## Deviations from Plan
200
+
201
+ ### Auto-fixed Issues
202
+
203
+ **1. [Rule 2 - Missing Critical] Added password hashing with bcrypt**
204
+ - **Found during:** Task 2 (Login endpoint implementation)
205
+ - **Issue:** Plan didn't specify password hashing - storing plaintext would be critical security flaw
206
+ - **Fix:** Added bcrypt hashing on registration, comparison on login with salt rounds 10
207
+ - **Files modified:** src/app/api/auth/login/route.ts, src/lib/auth.ts
208
+ - **Verification:** Password hash test passes, plaintext never stored
209
+ - **Committed in:** abc123f (Task 2 commit)
210
+
211
+ **2. [Rule 3 - Blocking] Installed missing jose dependency**
212
+ - **Found during:** Task 4 (JWT token generation)
213
+ - **Issue:** jose package not in package.json, import failing
214
+ - **Fix:** Ran `npm install jose`
215
+ - **Files modified:** package.json, package-lock.json
216
+ - **Verification:** Import succeeds, build passes
217
+ - **Committed in:** def456g (Task 4 commit)
218
+
219
+ ---
220
+
221
+ **Total deviations:** 2 auto-fixed (1 missing critical, 1 blocking)
222
+ **Impact on plan:** Both auto-fixes essential for security and functionality. No scope creep.
223
+
224
+ ## Issues Encountered
225
+ - jsonwebtoken CommonJS import failed in Edge runtime - switched to jose (planned library change, worked as expected)
226
+
227
+ ## Next Phase Readiness
228
+ - Auth foundation complete, ready for feature development
229
+ - User registration endpoint needed before public launch
230
+
231
+ ---
232
+ *Phase: 01-foundation*
233
+ *Completed: 2025-01-15*
234
+ ```
235
+ </example>
236
+
237
+ <guidelines>
238
+ **Frontmatter:** MANDATORY - complete all fields. Enables automatic context assembly for future planning.
239
+
240
+ **One-liner:** Must be substantive. "JWT auth with refresh rotation using jose library" not "Authentication implemented".
241
+
242
+ **Decisions section:**
243
+ - Key decisions made during execution with rationale
244
+ - Extracted to STATE.md accumulated context
245
+ - Use "None - followed plan as specified" if no deviations
246
+
247
+ **After creation:** STATE.md updated with position, decisions, issues.
248
+ </guidelines>