@howlil/ez-agents 3.4.2 → 4.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 (365) hide show
  1. package/README.md +735 -462
  2. package/agents/ez-architect-agent.md +267 -0
  3. package/agents/ez-backend-agent.md +303 -0
  4. package/agents/ez-chief-strategist.md +271 -0
  5. package/agents/ez-codebase-mapper.md +770 -770
  6. package/agents/ez-context-manager.md +319 -0
  7. package/agents/ez-debugger.md +1255 -1255
  8. package/agents/ez-design-expert.md +347 -0
  9. package/agents/ez-devops-agent.md +331 -0
  10. package/agents/ez-executor.md +487 -487
  11. package/agents/ez-frontend-agent.md +322 -0
  12. package/agents/ez-phase-researcher.md +553 -553
  13. package/agents/ez-planner.md +1307 -1307
  14. package/agents/ez-product-engineer.md +435 -0
  15. package/agents/ez-project-researcher.md +629 -629
  16. package/agents/ez-qa-agent.md +320 -0
  17. package/agents/ez-release-agent.md +333 -0
  18. package/agents/ez-requirements-agent.md +377 -0
  19. package/agents/ez-roadmapper.md +650 -650
  20. package/agents/ez-technical-writer.md +551 -0
  21. package/agents/ez-ux-expert.md +393 -0
  22. package/agents/ez-verifier.md +579 -579
  23. package/bin/guards/autonomy-guard.cjs +346 -0
  24. package/bin/guards/context-budget-guard.cjs +278 -0
  25. package/bin/guards/hallucination-guard.cjs +380 -0
  26. package/bin/guards/hidden-state-guard.cjs +182 -0
  27. package/bin/guards/team-overhead-guard.cjs +266 -0
  28. package/bin/guards/tool-sprawl-guard.cjs +271 -0
  29. package/bin/install.js +3221 -3272
  30. package/bin/lib/analytics/analytics-collector.cjs +86 -0
  31. package/bin/lib/analytics/analytics-reporter.cjs +130 -0
  32. package/bin/lib/analytics/cohort-analyzer.cjs +138 -0
  33. package/bin/lib/analytics/funnel-analyzer.cjs +147 -0
  34. package/bin/lib/analytics/nps-tracker.cjs +147 -0
  35. package/bin/lib/archetype-detector.cjs +289 -0
  36. package/bin/lib/assistant-adapter.cjs +361 -0
  37. package/bin/lib/audit-exec.cjs +175 -0
  38. package/bin/lib/auth.cjs +176 -0
  39. package/bin/lib/backup-service.cjs +422 -0
  40. package/bin/lib/bdd-validator.cjs +622 -0
  41. package/bin/lib/business-flow-mapper.cjs +429 -0
  42. package/bin/lib/circuit-breaker.cjs +276 -0
  43. package/bin/lib/code-complexity-analyzer.cjs +360 -0
  44. package/bin/lib/codebase-analyzer.cjs +241 -0
  45. package/bin/lib/commands.cjs +691 -0
  46. package/bin/lib/config.cjs +236 -0
  47. package/bin/lib/constraint-extractor.cjs +526 -0
  48. package/bin/lib/content-scanner.cjs +238 -0
  49. package/bin/lib/context-cache.cjs +154 -0
  50. package/bin/lib/context-compressor.cjs +102 -0
  51. package/bin/lib/context-deduplicator.cjs +105 -0
  52. package/bin/lib/context-errors.cjs +78 -0
  53. package/bin/lib/context-manager.cjs +338 -0
  54. package/bin/lib/context-metadata-tracker.cjs +140 -0
  55. package/bin/lib/context-relevance-scorer.cjs +99 -0
  56. package/bin/lib/core.cjs +507 -0
  57. package/bin/lib/cost-alerts.cjs +174 -0
  58. package/bin/lib/cost-tracker.cjs +275 -0
  59. package/bin/lib/crash-recovery.cjs +220 -0
  60. package/bin/lib/dependency-graph.cjs +319 -0
  61. package/bin/lib/deploy/deploy-audit-log.cjs +76 -0
  62. package/bin/lib/deploy/deploy-detector.cjs +69 -0
  63. package/bin/lib/deploy/deploy-env-manager.cjs +109 -0
  64. package/bin/lib/deploy/deploy-health-check.cjs +88 -0
  65. package/bin/lib/deploy/deploy-pre-flight.cjs +57 -0
  66. package/bin/lib/deploy/deploy-rollback.cjs +72 -0
  67. package/bin/lib/deploy/deploy-runner.cjs +97 -0
  68. package/bin/lib/deploy/deploy-status.cjs +74 -0
  69. package/bin/lib/discussion-synthesizer.cjs +439 -0
  70. package/bin/lib/error-cache.cjs +114 -0
  71. package/bin/lib/error-registry.cjs +177 -0
  72. package/bin/lib/file-access.cjs +207 -0
  73. package/bin/lib/file-lock.cjs +236 -0
  74. package/bin/lib/finops/budget-enforcer.cjs +126 -0
  75. package/bin/lib/finops/cost-reporter.cjs +132 -0
  76. package/bin/lib/finops/finops-analyzer.cjs +112 -0
  77. package/bin/lib/finops/spot-manager.cjs +118 -0
  78. package/bin/lib/framework-detector.cjs +396 -0
  79. package/bin/lib/frontmatter.cjs +313 -0
  80. package/bin/lib/fs-utils.cjs +153 -0
  81. package/bin/lib/gate-executor.cjs +272 -0
  82. package/bin/lib/gates/README.md +374 -0
  83. package/bin/lib/gates/gate-01-requirement.cjs +303 -0
  84. package/bin/lib/gates/gate-02-architecture.cjs +555 -0
  85. package/bin/lib/gates/gate-03-code.cjs +635 -0
  86. package/bin/lib/gates/gate-04-security.cjs +829 -0
  87. package/bin/lib/git-errors.cjs +83 -0
  88. package/bin/lib/git-utils.cjs +321 -0
  89. package/bin/lib/git-workflow-engine.cjs +1157 -0
  90. package/bin/lib/health-check.cjs +227 -0
  91. package/bin/lib/index.cjs +279 -0
  92. package/bin/lib/init.cjs +725 -0
  93. package/bin/lib/lock-logger.cjs +194 -0
  94. package/bin/lib/lock-state.cjs +263 -0
  95. package/bin/lib/lockfile-validator.cjs +227 -0
  96. package/bin/lib/log-rotation.cjs +71 -0
  97. package/bin/lib/logger.cjs +125 -0
  98. package/bin/lib/memory-compression.cjs +256 -0
  99. package/bin/lib/milestone.cjs +247 -0
  100. package/bin/lib/model-provider.cjs +241 -0
  101. package/bin/lib/package-manager-detector.cjs +203 -0
  102. package/bin/lib/package-manager-executor.cjs +385 -0
  103. package/bin/lib/package-manager-service.cjs +216 -0
  104. package/bin/lib/perf/api-monitor.cjs +88 -0
  105. package/bin/lib/perf/db-optimizer.cjs +78 -0
  106. package/bin/lib/perf/frontend-performance.cjs +56 -0
  107. package/bin/lib/perf/perf-analyzer.cjs +77 -0
  108. package/bin/lib/perf/perf-baseline.cjs +102 -0
  109. package/bin/lib/perf/perf-reporter.cjs +117 -0
  110. package/bin/lib/perf/regression-detector.cjs +92 -0
  111. package/bin/lib/phase.cjs +963 -0
  112. package/bin/lib/planning-write.cjs +123 -0
  113. package/bin/lib/project-reporter.cjs +565 -0
  114. package/bin/lib/quality-gate.cjs +332 -0
  115. package/bin/lib/quality-metrics.cjs +324 -0
  116. package/bin/lib/recovery-manager.cjs +98 -0
  117. package/bin/lib/release-validator.cjs +617 -0
  118. package/bin/lib/retry.cjs +119 -0
  119. package/bin/lib/roadmap.cjs +309 -0
  120. package/bin/lib/safe-exec.cjs +173 -0
  121. package/bin/lib/safe-path.cjs +130 -0
  122. package/bin/lib/security-errors.cjs +62 -0
  123. package/bin/lib/session-chain.cjs +304 -0
  124. package/bin/lib/session-errors.cjs +81 -0
  125. package/bin/lib/session-export.cjs +251 -0
  126. package/bin/lib/session-import.cjs +262 -0
  127. package/bin/lib/session-manager.cjs +280 -0
  128. package/bin/lib/skill-context.cjs +148 -0
  129. package/bin/lib/skill-matcher.cjs +236 -0
  130. package/bin/lib/skill-registry.cjs +360 -0
  131. package/bin/lib/skill-resolver.cjs +449 -0
  132. package/bin/lib/skill-triggers.cjs +90 -0
  133. package/bin/lib/skill-validator.cjs +270 -0
  134. package/bin/lib/skill-versioning.cjs +355 -0
  135. package/bin/lib/stack-detector.cjs +399 -0
  136. package/bin/lib/state.cjs +736 -0
  137. package/bin/lib/tech-debt-analyzer.cjs +309 -0
  138. package/bin/lib/temp-file.cjs +239 -0
  139. package/bin/lib/template.cjs +223 -0
  140. package/bin/lib/test-file-lock.cjs +112 -0
  141. package/bin/lib/test-graceful.cjs +93 -0
  142. package/bin/lib/test-logger.cjs +60 -0
  143. package/bin/lib/test-safe-exec.cjs +38 -0
  144. package/bin/lib/test-safe-path.cjs +33 -0
  145. package/bin/lib/test-temp-file.cjs +125 -0
  146. package/bin/lib/tier-manager.cjs +428 -0
  147. package/bin/lib/timeout-exec.cjs +63 -0
  148. package/bin/lib/tradeoff-analyzer.cjs +284 -0
  149. package/bin/lib/url-fetch.cjs +170 -0
  150. package/bin/lib/verify.cjs +863 -0
  151. package/bin/update.js +217 -214
  152. package/commands/deploy.cjs +53 -0
  153. package/commands/ez/add-tests.md +41 -41
  154. package/commands/ez/audit-milestone.md +36 -36
  155. package/commands/ez/complete-milestone.md +136 -136
  156. package/commands/ez/discuss-phase.md +90 -90
  157. package/commands/ez/execute-phase.md +52 -41
  158. package/commands/ez/help.md +22 -22
  159. package/commands/ez/map-codebase.md +71 -71
  160. package/commands/ez/new-milestone.md +44 -44
  161. package/commands/ez/new-project.md +51 -42
  162. package/commands/ez/plan-phase.md +53 -45
  163. package/commands/ez/progress.md +36 -24
  164. package/commands/ez/quick.md +45 -45
  165. package/commands/ez/resume-work.md +40 -40
  166. package/commands/ez/run-phase.md +580 -0
  167. package/commands/ez/settings.md +36 -36
  168. package/commands/ez/update.md +37 -37
  169. package/commands/ez/verify-work.md +402 -38
  170. package/commands/health-check.cjs +44 -0
  171. package/commands/rollback.cjs +47 -0
  172. package/ez-agents/bin/ez-tools.cjs +1692 -716
  173. package/ez-agents/bin/guards/autonomy-guard.cjs +346 -0
  174. package/ez-agents/bin/guards/context-budget-guard.cjs +247 -0
  175. package/ez-agents/bin/guards/hallucination-guard.cjs +271 -0
  176. package/ez-agents/bin/guards/hidden-state-guard.cjs +182 -0
  177. package/ez-agents/bin/guards/team-overhead-guard.cjs +266 -0
  178. package/ez-agents/bin/guards/tool-sprawl-guard.cjs +271 -0
  179. package/ez-agents/bin/lib/analytics/analytics-collector.cjs +86 -0
  180. package/ez-agents/bin/lib/analytics/analytics-reporter.cjs +130 -0
  181. package/ez-agents/bin/lib/analytics/cohort-analyzer.cjs +138 -0
  182. package/ez-agents/bin/lib/analytics/funnel-analyzer.cjs +147 -0
  183. package/ez-agents/bin/lib/analytics/nps-tracker.cjs +147 -0
  184. package/ez-agents/bin/lib/archetype-detector.cjs +289 -0
  185. package/ez-agents/bin/lib/audit-exec.cjs +166 -167
  186. package/ez-agents/bin/lib/auth.cjs +176 -176
  187. package/ez-agents/bin/lib/backup-service.cjs +422 -0
  188. package/ez-agents/bin/lib/bdd-validator.cjs +622 -0
  189. package/ez-agents/bin/lib/business-flow-mapper.cjs +429 -0
  190. package/ez-agents/bin/lib/code-complexity-analyzer.cjs +360 -0
  191. package/ez-agents/bin/lib/codebase-analyzer.cjs +241 -0
  192. package/ez-agents/bin/lib/commands.cjs +685 -685
  193. package/ez-agents/bin/lib/config.cjs +41 -1
  194. package/ez-agents/bin/lib/constraint-extractor.cjs +526 -0
  195. package/ez-agents/bin/lib/content-scanner.cjs +238 -0
  196. package/ez-agents/bin/lib/context-cache.cjs +154 -0
  197. package/ez-agents/bin/lib/context-errors.cjs +71 -0
  198. package/ez-agents/bin/lib/context-manager.cjs +220 -0
  199. package/ez-agents/bin/lib/core.cjs +507 -512
  200. package/ez-agents/bin/lib/cost-tracker.cjs +243 -0
  201. package/ez-agents/bin/lib/crash-recovery.cjs +172 -0
  202. package/ez-agents/bin/lib/dependency-graph.cjs +319 -0
  203. package/ez-agents/bin/lib/deploy/deploy-audit-log.cjs +76 -0
  204. package/ez-agents/bin/lib/deploy/deploy-detector.cjs +69 -0
  205. package/ez-agents/bin/lib/deploy/deploy-env-manager.cjs +109 -0
  206. package/ez-agents/bin/lib/deploy/deploy-health-check.cjs +88 -0
  207. package/ez-agents/bin/lib/deploy/deploy-pre-flight.cjs +57 -0
  208. package/ez-agents/bin/lib/deploy/deploy-rollback.cjs +72 -0
  209. package/ez-agents/bin/lib/deploy/deploy-runner.cjs +97 -0
  210. package/ez-agents/bin/lib/deploy/deploy-status.cjs +74 -0
  211. package/ez-agents/bin/lib/discussion-synthesizer.cjs +458 -0
  212. package/ez-agents/bin/lib/file-access.cjs +207 -0
  213. package/ez-agents/bin/lib/finops/budget-enforcer.cjs +126 -0
  214. package/ez-agents/bin/lib/finops/cost-reporter.cjs +132 -0
  215. package/ez-agents/bin/lib/finops/finops-analyzer.cjs +112 -0
  216. package/ez-agents/bin/lib/finops/spot-manager.cjs +118 -0
  217. package/ez-agents/bin/lib/framework-detector.cjs +396 -0
  218. package/ez-agents/bin/lib/frontmatter.cjs +3 -1
  219. package/ez-agents/bin/lib/gates/README.md +374 -0
  220. package/ez-agents/bin/lib/gates/gate-01-requirement.cjs +303 -0
  221. package/ez-agents/bin/lib/gates/gate-02-architecture.cjs +555 -0
  222. package/ez-agents/bin/lib/gates/gate-03-code.cjs +635 -0
  223. package/ez-agents/bin/lib/gates/gate-04-security.cjs +829 -0
  224. package/ez-agents/bin/lib/git-errors.cjs +83 -0
  225. package/ez-agents/bin/lib/git-utils.cjs +118 -0
  226. package/ez-agents/bin/lib/git-workflow-engine.cjs +1157 -0
  227. package/ez-agents/bin/lib/health-check.cjs +162 -162
  228. package/ez-agents/bin/lib/index.cjs +40 -2
  229. package/ez-agents/bin/lib/init.cjs +0 -2
  230. package/ez-agents/bin/lib/lockfile-validator.cjs +227 -0
  231. package/ez-agents/bin/lib/log-rotation.cjs +71 -0
  232. package/ez-agents/bin/lib/logger.cjs +99 -154
  233. package/ez-agents/bin/lib/memory-compression.cjs +256 -0
  234. package/ez-agents/bin/lib/package-manager-detector.cjs +203 -0
  235. package/ez-agents/bin/lib/package-manager-executor.cjs +385 -0
  236. package/ez-agents/bin/lib/package-manager-service.cjs +216 -0
  237. package/ez-agents/bin/lib/perf/api-monitor.cjs +88 -0
  238. package/ez-agents/bin/lib/perf/db-optimizer.cjs +78 -0
  239. package/ez-agents/bin/lib/perf/frontend-performance.cjs +56 -0
  240. package/ez-agents/bin/lib/perf/perf-analyzer.cjs +77 -0
  241. package/ez-agents/bin/lib/perf/perf-baseline.cjs +102 -0
  242. package/ez-agents/bin/lib/perf/perf-reporter.cjs +117 -0
  243. package/ez-agents/bin/lib/perf/regression-detector.cjs +92 -0
  244. package/ez-agents/bin/lib/project-reporter.cjs +502 -0
  245. package/ez-agents/bin/lib/quality-gate.cjs +332 -0
  246. package/ez-agents/bin/lib/recovery-manager.cjs +98 -0
  247. package/ez-agents/bin/lib/release-validator.cjs +617 -0
  248. package/ez-agents/bin/lib/safe-exec.cjs +128 -214
  249. package/ez-agents/bin/lib/security-errors.cjs +62 -0
  250. package/ez-agents/bin/lib/session-chain.cjs +304 -0
  251. package/ez-agents/bin/lib/session-errors.cjs +81 -0
  252. package/ez-agents/bin/lib/session-export.cjs +251 -0
  253. package/ez-agents/bin/lib/session-import.cjs +262 -0
  254. package/ez-agents/bin/lib/session-manager.cjs +280 -0
  255. package/ez-agents/bin/lib/skill-context.cjs +148 -0
  256. package/ez-agents/bin/lib/skill-matcher.cjs +236 -0
  257. package/ez-agents/bin/lib/skill-registry.cjs +341 -0
  258. package/ez-agents/bin/lib/skill-resolver.cjs +449 -0
  259. package/ez-agents/bin/lib/skill-triggers.cjs +90 -0
  260. package/ez-agents/bin/lib/skill-validator.cjs +270 -0
  261. package/ez-agents/bin/lib/skill-versioning.cjs +355 -0
  262. package/ez-agents/bin/lib/stack-detector.cjs +399 -0
  263. package/ez-agents/bin/lib/tech-debt-analyzer.cjs +309 -0
  264. package/ez-agents/bin/lib/tier-manager.cjs +428 -0
  265. package/ez-agents/bin/lib/tradeoff-analyzer.cjs +284 -0
  266. package/ez-agents/bin/lib/url-fetch.cjs +170 -0
  267. package/ez-agents/bin/lib/verify.cjs +863 -863
  268. package/ez-agents/references/decimal-phase-calculation.md +65 -65
  269. package/ez-agents/references/git-integration.md +248 -248
  270. package/ez-agents/references/git-planning-commit.md +38 -38
  271. package/ez-agents/references/metrics-schema.md +118 -0
  272. package/ez-agents/references/model-profile-resolution.md +34 -34
  273. package/ez-agents/references/model-profiles.md +93 -93
  274. package/ez-agents/references/phase-argument-parsing.md +61 -61
  275. package/ez-agents/references/planning-config.md +340 -200
  276. package/ez-agents/references/tier-strategy.md +103 -0
  277. package/ez-agents/references/ui-brand.md +160 -160
  278. package/ez-agents/references/verification-patterns.md +612 -612
  279. package/ez-agents/templates/DEBUG.md +164 -164
  280. package/ez-agents/templates/UAT.md +247 -247
  281. package/ez-agents/templates/agent-output-format.md +404 -0
  282. package/ez-agents/templates/bdd-feature.md +173 -0
  283. package/ez-agents/templates/codebase/architecture.md +255 -255
  284. package/ez-agents/templates/codebase/structure.md +285 -285
  285. package/ez-agents/templates/copilot-instructions.md +7 -7
  286. package/ez-agents/templates/debug-subagent-prompt.md +91 -91
  287. package/ez-agents/templates/discovery.md +146 -146
  288. package/ez-agents/templates/discussion.md +68 -0
  289. package/ez-agents/templates/handoff-protocol.md +294 -0
  290. package/ez-agents/templates/incident-runbook.md +205 -0
  291. package/ez-agents/templates/mode-workflow-templates.md +301 -0
  292. package/ez-agents/templates/phase-prompt.md +610 -610
  293. package/ez-agents/templates/planner-subagent-prompt.md +117 -117
  294. package/ez-agents/templates/project.md +184 -184
  295. package/ez-agents/templates/release-checklist.md +136 -0
  296. package/ez-agents/templates/research.md +552 -552
  297. package/ez-agents/templates/rollback-plan.md +201 -0
  298. package/ez-agents/templates/security-user-setup.md +244 -0
  299. package/ez-agents/templates/skill-validation-rules.md +476 -0
  300. package/ez-agents/templates/state.md +180 -176
  301. package/ez-agents/templates/summary-complex.md +59 -59
  302. package/ez-agents/tests/gates/gate-01-02.test.cjs +812 -0
  303. package/ez-agents/tests/gates/gate-03-04.test.cjs +762 -0
  304. package/ez-agents/tests/gates/gate-05-validator.test.cjs +145 -0
  305. package/ez-agents/tests/gates/gate-06-docs-validator.test.cjs +244 -0
  306. package/ez-agents/tests/gates/gate-07-release-validator.test.cjs +219 -0
  307. package/ez-agents/tests/guards/context-budget-guard.test.cjs +145 -0
  308. package/ez-agents/tests/guards/edge-case-guards.test.cjs +238 -0
  309. package/ez-agents/tests/guards/hallucination-guard.test.cjs +124 -0
  310. package/ez-agents/workflows/audit-milestone.md +1 -1
  311. package/ez-agents/workflows/autonomous.md +131 -30
  312. package/ez-agents/workflows/complete-milestone.md +1 -1
  313. package/ez-agents/workflows/discuss-phase.md +1 -1
  314. package/ez-agents/workflows/execute-phase.md +169 -3
  315. package/ez-agents/workflows/help.md +86 -133
  316. package/ez-agents/workflows/hotfix.md +291 -0
  317. package/ez-agents/workflows/new-milestone.md +340 -11
  318. package/ez-agents/workflows/new-project.md +294 -318
  319. package/ez-agents/workflows/plan-phase.md +22 -40
  320. package/ez-agents/workflows/progress.md +15 -25
  321. package/ez-agents/workflows/release.md +253 -0
  322. package/ez-agents/workflows/resume-session.md +215 -0
  323. package/ez-agents/workflows/run-phase.md +531 -0
  324. package/ez-agents/workflows/settings.md +2 -35
  325. package/hooks/dist/ez-check-update.js +81 -81
  326. package/hooks/dist/ez-context-monitor.js +148 -141
  327. package/hooks/dist/ez-statusline.js +115 -115
  328. package/package.json +78 -64
  329. package/scripts/fix-qwen-installation.js +144 -144
  330. package/agents/ez-integration-checker.md +0 -443
  331. package/agents/ez-nyquist-auditor.md +0 -176
  332. package/agents/ez-plan-checker.md +0 -706
  333. package/agents/ez-research-synthesizer.md +0 -247
  334. package/agents/ez-ui-auditor.md +0 -439
  335. package/agents/ez-ui-checker.md +0 -300
  336. package/agents/ez-ui-researcher.md +0 -353
  337. package/commands/ez/add-phase.md +0 -43
  338. package/commands/ez/add-todo.md +0 -47
  339. package/commands/ez/auth.md +0 -87
  340. package/commands/ez/autonomous.md +0 -41
  341. package/commands/ez/check-todos.md +0 -45
  342. package/commands/ez/cleanup.md +0 -18
  343. package/commands/ez/debug.md +0 -168
  344. package/commands/ez/health.md +0 -22
  345. package/commands/ez/insert-phase.md +0 -32
  346. package/commands/ez/join-discord.md +0 -18
  347. package/commands/ez/list-phase-assumptions.md +0 -46
  348. package/commands/ez/pause-work.md +0 -38
  349. package/commands/ez/plan-milestone-gaps.md +0 -34
  350. package/commands/ez/reapply-patches.md +0 -124
  351. package/commands/ez/remove-phase.md +0 -31
  352. package/commands/ez/research-phase.md +0 -190
  353. package/commands/ez/set-profile.md +0 -34
  354. package/commands/ez/stats.md +0 -18
  355. package/commands/ez/ui-phase.md +0 -34
  356. package/commands/ez/ui-review.md +0 -32
  357. package/commands/ez/validate-phase.md +0 -35
  358. package/ez-agents/templates/UI-SPEC.md +0 -100
  359. package/ez-agents/templates/VALIDATION.md +0 -76
  360. package/ez-agents/templates/context.md +0 -352
  361. package/ez-agents/templates/verification-report.md +0 -322
  362. package/ez-agents/workflows/research-phase.md +0 -74
  363. package/ez-agents/workflows/ui-phase.md +0 -290
  364. package/ez-agents/workflows/ui-review.md +0 -157
  365. package/ez-agents/workflows/validate-phase.md +0 -167
package/bin/update.js CHANGED
@@ -1,214 +1,217 @@
1
- #!/usr/bin/env node
2
-
3
- /**
4
- * EZ Agents Update — Check and install updates
5
- *
6
- * Usage:
7
- * ez-agents-update # Check for updates
8
- * ez-agents-update --check # Check only
9
- * ez-agents-update --force # Force reinstall
10
- * ez-agents-update --changelog # Show changelog
11
- */
12
-
13
- const { execSync } = require('child_process');
14
- const path = require('path');
15
-
16
- const PACKAGE_NAME = 'ez-agents';
17
- const REPO_URL = 'https://github.com/howlil/ez-agents.git';
18
-
19
- // Colors for output
20
- const colors = {
21
- reset: '\x1b[0m',
22
- green: '\x1b[32m',
23
- yellow: '\x1b[33m',
24
- blue: '\x1b[34m',
25
- red: '\x1b[31m',
26
- bold: '\x1b[1m'
27
- };
28
-
29
- function log(message, color = 'reset') {
30
- console.log(`${colors[color]}${message}${colors.reset}`);
31
- }
32
-
33
- /**
34
- * Get current installed version
35
- */
36
- function getCurrentVersion() {
37
- try {
38
- const pkg = require('./package.json');
39
- return pkg.version;
40
- } catch {
41
- return 'unknown';
42
- }
43
- }
44
-
45
- /**
46
- * Get latest version from npm
47
- */
48
- function getLatestVersion() {
49
- try {
50
- const output = execSync(`npm view ${PACKAGE_NAME} version`, {
51
- encoding: 'utf-8',
52
- stdio: ['pipe', 'pipe', 'ignore']
53
- });
54
- return output.trim();
55
- } catch {
56
- // Fallback: check GitHub repo
57
- try {
58
- const output = execSync(`npm view git+${REPO_URL} version`, {
59
- encoding: 'utf-8',
60
- stdio: ['pipe', 'pipe', 'ignore']
61
- });
62
- return output.trim();
63
- } catch {
64
- return null;
65
- }
66
- }
67
- }
68
-
69
- /**
70
- * Check if update is available
71
- */
72
- function checkUpdate() {
73
- const current = getCurrentVersion();
74
- const latest = getLatestVersion();
75
-
76
- log('\n━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━', 'blue');
77
- log(' EZ Agents Update Check', 'bold');
78
- log('━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\n', 'blue');
79
-
80
- log(`Current version: ${colors.bold}v${current}${colors.reset}`);
81
-
82
- if (!latest) {
83
- log('Unable to check for updates (no network or repo unavailable)', 'yellow');
84
- return;
85
- }
86
-
87
- log(`Latest version: ${colors.bold}v${latest}${colors.reset}\n`);
88
-
89
- if (current === latest) {
90
- log('✓ You are on the latest version!\n', 'green');
91
- return false;
92
- }
93
-
94
- log(`⚡ Update available: v${current} → v${latest}\n`, 'yellow');
95
- log('To update, run:\n', 'blue');
96
- log(` npm install -g ${PACKAGE_NAME}@latest\n`, 'green');
97
- log('Or force reinstall:\n', 'blue');
98
- log(` ez-agents-update --force\n`, 'green');
99
-
100
- return true;
101
- }
102
-
103
- /**
104
- * Install update
105
- */
106
- function installUpdate(force = false) {
107
- log('\n━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━', 'blue');
108
- log(' EZ Agents Update', 'bold');
109
- log('━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\n', 'blue');
110
-
111
- const current = getCurrentVersion();
112
- const latest = getLatestVersion();
113
-
114
- if (!latest) {
115
- log('Unable to check for updates', 'red');
116
- process.exit(1);
117
- }
118
-
119
- if (current === latest && !force) {
120
- log('Already on latest version', 'green');
121
- return;
122
- }
123
-
124
- log(`Updating: v${current} → v${latest}...\n`, 'blue');
125
-
126
- try {
127
- execSync(`npm install -g ${PACKAGE_NAME}@latest`, {
128
- stdio: 'inherit'
129
- });
130
-
131
- log('\n✓ Update complete!\n', 'green');
132
- log('Restart your terminal or run:\n', 'blue');
133
- log(` ez-agents --version\n`, 'green');
134
- } catch (err) {
135
- log('\n✗ Update failed\n', 'red');
136
- log('Try manual install:\n', 'yellow');
137
- log(` npm install -g ${PACKAGE_NAME}@latest\n`, 'blue');
138
- process.exit(1);
139
- }
140
- }
141
-
142
- /**
143
- * Show changelog
144
- */
145
- function showChangelog() {
146
- log('\n━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━', 'blue');
147
- log(' EZ Agents Changelog', 'bold');
148
- log('━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\n', 'blue');
149
-
150
- try {
151
- const fs = require('fs');
152
- const changelogPath = path.join(__dirname, 'CHANGELOG.md');
153
-
154
- if (fs.existsSync(changelogPath)) {
155
- const content = fs.readFileSync(changelogPath, 'utf-8');
156
- // Show first 50 lines
157
- const lines = content.split('\n').slice(0, 50);
158
- log(lines.join('\n'));
159
- } else {
160
- log('CHANGELOG.md not found', 'yellow');
161
- log(`\nView online: ${REPO_URL}/blob/main/CHANGELOG.md\n`, 'blue');
162
- }
163
- } catch (err) {
164
- log('Unable to read changelog', 'red');
165
- }
166
- }
167
-
168
- /**
169
- * Show help
170
- */
171
- function showHelp() {
172
- log(`
173
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
174
- EZ Agents Update — Check and Install Updates
175
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
176
-
177
- Usage:
178
- ez-agents-update [options]
179
-
180
- Options:
181
- --check Check for updates (don't install)
182
- --force Force reinstall even if up-to-date
183
- --changelog Show changelog
184
- --help Show this help message
185
-
186
- Examples:
187
- ez-agents-update # Check and prompt to update
188
- ez-agents-update --check # Check only
189
- ez-agents-update --force # Force reinstall
190
- ez-agents-update --changelog # View changelog
191
-
192
- Manual Update:
193
- npm install -g ez-agents@latest
194
- `);
195
- }
196
-
197
- // Main
198
- const args = process.argv.slice(2);
199
-
200
- if (args.includes('--help') || args.includes('-h')) {
201
- showHelp();
202
- } else if (args.includes('--changelog')) {
203
- showChangelog();
204
- } else if (args.includes('--check')) {
205
- checkUpdate();
206
- } else if (args.includes('--force')) {
207
- installUpdate(true);
208
- } else {
209
- const hasUpdate = checkUpdate();
210
- if (hasUpdate) {
211
- // Auto-prompt (simple version)
212
- log('Run "ez-agents-update --force" to update now\n');
213
- }
214
- }
1
+ #!/usr/bin/env node
2
+
3
+ /**
4
+ * EZ Agents Update — Check and install updates
5
+ *
6
+ * Usage:
7
+ * ez-agents-update # Check for updates
8
+ * ez-agents-update --check # Check only
9
+ * ez-agents-update --force # Force reinstall
10
+ * ez-agents-update --changelog # Show changelog
11
+ */
12
+
13
+ const { execSync } = require('child_process');
14
+ const path = require('path');
15
+
16
+ const PACKAGE_NAME = 'ez-agents';
17
+ const REPO_URL = 'https://github.com/howlil/ez-agents.git';
18
+
19
+ // Colors for output
20
+ const colors = {
21
+ reset: '\x1b[0m',
22
+ green: '\x1b[32m',
23
+ yellow: '\x1b[33m',
24
+ blue: '\x1b[34m',
25
+ red: '\x1b[31m',
26
+ bold: '\x1b[1m'
27
+ };
28
+
29
+ function log(message, color = 'reset') {
30
+ console.log(`${colors[color]}${message}${colors.reset}`);
31
+ }
32
+
33
+ /**
34
+ * Get current installed version
35
+ */
36
+ function getCurrentVersion() {
37
+ try {
38
+ const pkg = require('./package.json');
39
+ return pkg.version;
40
+ } catch {
41
+ return 'unknown';
42
+ }
43
+ }
44
+
45
+ /**
46
+ * Get latest version from npm
47
+ */
48
+ function getLatestVersion() {
49
+ try {
50
+ const output = execSync(`npm view ${PACKAGE_NAME} version`, {
51
+ encoding: 'utf-8',
52
+ stdio: ['pipe', 'pipe', 'ignore'],
53
+ timeout: 10000 // 10 second timeout
54
+ });
55
+ return output.trim();
56
+ } catch {
57
+ // Fallback: check GitHub repo
58
+ try {
59
+ const output = execSync(`npm view git+${REPO_URL} version`, {
60
+ encoding: 'utf-8',
61
+ stdio: ['pipe', 'pipe', 'ignore'],
62
+ timeout: 10000 // 10 second timeout
63
+ });
64
+ return output.trim();
65
+ } catch {
66
+ return null;
67
+ }
68
+ }
69
+ }
70
+
71
+ /**
72
+ * Check if update is available
73
+ */
74
+ function checkUpdate() {
75
+ const current = getCurrentVersion();
76
+ const latest = getLatestVersion();
77
+
78
+ log('\n━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━', 'blue');
79
+ log(' EZ Agents Update Check', 'bold');
80
+ log('━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\n', 'blue');
81
+
82
+ log(`Current version: ${colors.bold}v${current}${colors.reset}`);
83
+
84
+ if (!latest) {
85
+ log('Unable to check for updates (no network or repo unavailable)', 'yellow');
86
+ return;
87
+ }
88
+
89
+ log(`Latest version: ${colors.bold}v${latest}${colors.reset}\n`);
90
+
91
+ if (current === latest) {
92
+ log('✓ You are on the latest version!\n', 'green');
93
+ return false;
94
+ }
95
+
96
+ log(`⚡ Update available: v${current} → v${latest}\n`, 'yellow');
97
+ log('To update, run:\n', 'blue');
98
+ log(` npm install -g ${PACKAGE_NAME}@latest\n`, 'green');
99
+ log('Or force reinstall:\n', 'blue');
100
+ log(` ez-agents-update --force\n`, 'green');
101
+
102
+ return true;
103
+ }
104
+
105
+ /**
106
+ * Install update
107
+ */
108
+ function installUpdate(force = false) {
109
+ log('\n━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━', 'blue');
110
+ log(' EZ Agents Update', 'bold');
111
+ log('━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\n', 'blue');
112
+
113
+ const current = getCurrentVersion();
114
+ const latest = getLatestVersion();
115
+
116
+ if (!latest) {
117
+ log('Unable to check for updates', 'red');
118
+ process.exit(1);
119
+ }
120
+
121
+ if (current === latest && !force) {
122
+ log('Already on latest version', 'green');
123
+ return;
124
+ }
125
+
126
+ log(`Updating: v${current} → v${latest}...\n`, 'blue');
127
+
128
+ try {
129
+ execSync(`npm install -g ${PACKAGE_NAME}@latest`, {
130
+ stdio: 'inherit',
131
+ timeout: 120000 // 2 minute timeout for npm install
132
+ });
133
+
134
+ log('\n✓ Update complete!\n', 'green');
135
+ log('Restart your terminal or run:\n', 'blue');
136
+ log(` ez-agents --version\n`, 'green');
137
+ } catch (err) {
138
+ log('\n✗ Update failed\n', 'red');
139
+ log('Try manual install:\n', 'yellow');
140
+ log(` npm install -g ${PACKAGE_NAME}@latest\n`, 'blue');
141
+ process.exit(1);
142
+ }
143
+ }
144
+
145
+ /**
146
+ * Show changelog
147
+ */
148
+ function showChangelog() {
149
+ log('\n━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━', 'blue');
150
+ log(' EZ Agents Changelog', 'bold');
151
+ log('━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\n', 'blue');
152
+
153
+ try {
154
+ const fs = require('fs');
155
+ const changelogPath = path.join(__dirname, 'CHANGELOG.md');
156
+
157
+ if (fs.existsSync(changelogPath)) {
158
+ const content = fs.readFileSync(changelogPath, 'utf-8');
159
+ // Show first 50 lines
160
+ const lines = content.split('\n').slice(0, 50);
161
+ log(lines.join('\n'));
162
+ } else {
163
+ log('CHANGELOG.md not found', 'yellow');
164
+ log(`\nView online: ${REPO_URL}/blob/main/CHANGELOG.md\n`, 'blue');
165
+ }
166
+ } catch (err) {
167
+ log('Unable to read changelog', 'red');
168
+ }
169
+ }
170
+
171
+ /**
172
+ * Show help
173
+ */
174
+ function showHelp() {
175
+ log(`
176
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
177
+ EZ Agents Update — Check and Install Updates
178
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
179
+
180
+ Usage:
181
+ ez-agents-update [options]
182
+
183
+ Options:
184
+ --check Check for updates (don't install)
185
+ --force Force reinstall even if up-to-date
186
+ --changelog Show changelog
187
+ --help Show this help message
188
+
189
+ Examples:
190
+ ez-agents-update # Check and prompt to update
191
+ ez-agents-update --check # Check only
192
+ ez-agents-update --force # Force reinstall
193
+ ez-agents-update --changelog # View changelog
194
+
195
+ Manual Update:
196
+ npm install -g ez-agents@latest
197
+ `);
198
+ }
199
+
200
+ // Main
201
+ const args = process.argv.slice(2);
202
+
203
+ if (args.includes('--help') || args.includes('-h')) {
204
+ showHelp();
205
+ } else if (args.includes('--changelog')) {
206
+ showChangelog();
207
+ } else if (args.includes('--check')) {
208
+ checkUpdate();
209
+ } else if (args.includes('--force')) {
210
+ installUpdate(true);
211
+ } else {
212
+ const hasUpdate = checkUpdate();
213
+ if (hasUpdate) {
214
+ // Auto-prompt (simple version)
215
+ log('Run "ez-agents-update --force" to update now\n');
216
+ }
217
+ }
@@ -0,0 +1,53 @@
1
+ #!/usr/bin/env node
2
+
3
+ /**
4
+ * Deploy Command (Phase 19 Placeholder)
5
+ *
6
+ * This is a placeholder script for Phase 19 (Deployment & Operations).
7
+ * It simulates deployment behavior for CI/CD pipeline testing.
8
+ *
9
+ * In Phase 19, this will be implemented with real deployment logic:
10
+ * - Platform detection (Vercel, Netlify, AWS, Docker)
11
+ * - Configuration generation
12
+ * - One-command deployment workflow
13
+ * - Environment variable management
14
+ */
15
+
16
+ const path = require('path');
17
+ const { defaultLogger: logger } = require('../bin/lib/logger.cjs');
18
+
19
+ // Get environment from arguments or default to 'staging'
20
+ const environment = process.argv[2] || 'staging';
21
+
22
+ logger.info(`Starting deployment to environment: ${environment}`);
23
+ logger.info('Placeholder mode - simulating deployment');
24
+
25
+ // Simulate deployment steps
26
+ const steps = [
27
+ 'Detecting deployment platform...',
28
+ 'Validating configuration...',
29
+ 'Installing dependencies...',
30
+ 'Building application...',
31
+ 'Uploading artifacts...',
32
+ 'Activating new version...',
33
+ 'Running post-deployment checks...'
34
+ ];
35
+
36
+ steps.forEach((step, index) => {
37
+ logger.info(`[${index + 1}/${steps.length}] ${step}`);
38
+ });
39
+
40
+ logger.info('Deployment completed successfully!');
41
+ logger.info('Environment: ' + environment);
42
+
43
+ try {
44
+ const pkg = require('../package.json');
45
+ logger.info('Version: ' + pkg.version);
46
+ } catch (err) {
47
+ logger.debug('Could not read package version', { error: err.message });
48
+ }
49
+
50
+ logger.info('Timestamp: ' + new Date().toISOString());
51
+
52
+ // Exit with success code
53
+ process.exit(0);
@@ -1,41 +1,41 @@
1
- ---
2
- name: ez:add-tests
3
- description: Generate tests for a completed phase based on UAT criteria and implementation
4
- argument-hint: "<phase> [additional instructions]"
5
- allowed-tools:
6
- - Read
7
- - Write
8
- - Edit
9
- - Bash
10
- - Glob
11
- - Grep
12
- - Task
13
- - AskUserQuestion
14
- argument-instructions: |
15
- Parse the argument as a phase number (integer, decimal, or letter-suffix), plus optional free-text instructions.
16
- Example: /ez:add-tests 12
17
- Example: /ez:add-tests 12 focus on edge cases in the pricing module
18
- ---
19
- <objective>
20
- Generate unit and E2E tests for a completed phase, using its SUMMARY.md, CONTEXT.md, and VERIFICATION.md as specifications.
21
-
22
- Analyzes implementation files, classifies them into TDD (unit), E2E (browser), or Skip categories, presents a test plan for user approval, then generates tests following RED-GREEN conventions.
23
-
24
- Output: Test files committed with message `test(phase-{N}): add unit and E2E tests from add-tests command`
25
- </objective>
26
-
27
- <execution_context>
28
- @~/.claude/ez-agents/workflows/add-tests.md
29
- </execution_context>
30
-
31
- <context>
32
- Phase: $ARGUMENTS
33
-
34
- @.planning/STATE.md
35
- @.planning/ROADMAP.md
36
- </context>
37
-
38
- <process>
39
- Execute the add-tests workflow from @~/.claude/ez-agents/workflows/add-tests.md end-to-end.
40
- Preserve all workflow gates (classification approval, test plan approval, RED-GREEN verification, gap reporting).
41
- </process>
1
+ ---
2
+ name: ez:add-tests
3
+ description: Generate tests for a completed phase based on UAT criteria and implementation
4
+ argument-hint: "<phase> [additional instructions]"
5
+ allowed-tools:
6
+ - Read
7
+ - Write
8
+ - Edit
9
+ - Bash
10
+ - Glob
11
+ - Grep
12
+ - Task
13
+ - AskUserQuestion
14
+ argument-instructions: |
15
+ Parse the argument as a phase number (integer, decimal, or letter-suffix), plus optional free-text instructions.
16
+ Example: /ez:add-tests 12
17
+ Example: /ez:add-tests 12 focus on edge cases in the pricing module
18
+ ---
19
+ <objective>
20
+ Generate unit and E2E tests for a completed phase, using its SUMMARY.md, CONTEXT.md, and VERIFICATION.md as specifications.
21
+
22
+ Analyzes implementation files, classifies them into TDD (unit), E2E (browser), or Skip categories, presents a test plan for user approval, then generates tests following RED-GREEN conventions.
23
+
24
+ Output: Test files committed with message `test(phase-{N}): add unit and E2E tests from add-tests command`
25
+ </objective>
26
+
27
+ <execution_context>
28
+ @~/.claude/ez-agents/workflows/add-tests.md
29
+ </execution_context>
30
+
31
+ <context>
32
+ Phase: $ARGUMENTS
33
+
34
+ @.planning/STATE.md
35
+ @.planning/ROADMAP.md
36
+ </context>
37
+
38
+ <process>
39
+ Execute the add-tests workflow from @~/.claude/ez-agents/workflows/add-tests.md end-to-end.
40
+ Preserve all workflow gates (classification approval, test plan approval, RED-GREEN verification, gap reporting).
41
+ </process>
@@ -1,36 +1,36 @@
1
- ---
2
- name: ez:audit-milestone
3
- description: Audit milestone completion against original intent before archiving
4
- argument-hint: "[version]"
5
- allowed-tools:
6
- - Read
7
- - Glob
8
- - Grep
9
- - Bash
10
- - Task
11
- - Write
12
- ---
13
- <objective>
14
- Verify milestone achieved its definition of done. Check requirements coverage, cross-phase integration, and end-to-end flows.
15
-
16
- **This command IS the orchestrator.** Reads existing VERIFICATION.md files (phases already verified during execute-phase), aggregates tech debt and deferred gaps, then spawns integration checker for cross-phase wiring.
17
- </objective>
18
-
19
- <execution_context>
20
- @~/.claude/ez-agents/workflows/audit-milestone.md
21
- </execution_context>
22
-
23
- <context>
24
- Version: $ARGUMENTS (optional — defaults to current milestone)
25
-
26
- Core planning files are resolved in-workflow (`init milestone-op`) and loaded only as needed.
27
-
28
- **Completed Work:**
29
- Glob: .planning/phases/*/*-SUMMARY.md
30
- Glob: .planning/phases/*/*-VERIFICATION.md
31
- </context>
32
-
33
- <process>
34
- Execute the audit-milestone workflow from @~/.claude/ez-agents/workflows/audit-milestone.md end-to-end.
35
- Preserve all workflow gates (scope determination, verification reading, integration check, requirements coverage, routing).
36
- </process>
1
+ ---
2
+ name: ez:audit-milestone
3
+ description: Audit milestone completion against original intent before archiving
4
+ argument-hint: "[version]"
5
+ allowed-tools:
6
+ - Read
7
+ - Glob
8
+ - Grep
9
+ - Bash
10
+ - Task
11
+ - Write
12
+ ---
13
+ <objective>
14
+ Verify milestone achieved its definition of done. Check requirements coverage, cross-phase integration, and end-to-end flows.
15
+
16
+ **This command IS the orchestrator.** Reads existing VERIFICATION.md files (phases already verified during execute-phase), aggregates tech debt and deferred gaps, then spawns integration checker for cross-phase wiring.
17
+ </objective>
18
+
19
+ <execution_context>
20
+ @~/.claude/ez-agents/workflows/audit-milestone.md
21
+ </execution_context>
22
+
23
+ <context>
24
+ Version: $ARGUMENTS (optional — defaults to current milestone)
25
+
26
+ Core planning files are resolved in-workflow (`init milestone-op`) and loaded only as needed.
27
+
28
+ **Completed Work:**
29
+ Glob: .planning/phases/*/*-SUMMARY.md
30
+ Glob: .planning/phases/*/*-VERIFICATION.md
31
+ </context>
32
+
33
+ <process>
34
+ Execute the audit-milestone workflow from @~/.claude/ez-agents/workflows/audit-milestone.md end-to-end.
35
+ Preserve all workflow gates (scope determination, verification reading, integration check, requirements coverage, routing).
36
+ </process>