grimoire-framework 1.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 (1174) hide show
  1. package/.claude/CLAUDE.md +318 -0
  2. package/.claude/hooks/README.md +170 -0
  3. package/.claude/hooks/enforce-architecture-first.py +198 -0
  4. package/.claude/hooks/install-hooks.sh +43 -0
  5. package/.claude/hooks/mind-clone-governance.py +192 -0
  6. package/.claude/hooks/pre-commit-version-check.sh +157 -0
  7. package/.claude/hooks/precompact-session-digest.js +47 -0
  8. package/.claude/hooks/read-protection.py +153 -0
  9. package/.claude/hooks/slug-validation.py +176 -0
  10. package/.claude/hooks/sql-governance.py +182 -0
  11. package/.claude/hooks/synapse-engine.js +77 -0
  12. package/.claude/hooks/write-path-validation.py +196 -0
  13. package/.claude/rules/mcp-usage.md +177 -0
  14. package/.grimoire/cli/commands/config/index.js +609 -0
  15. package/.grimoire/cli/commands/generate/index.js +222 -0
  16. package/.grimoire/cli/commands/manifest/index.js +47 -0
  17. package/.grimoire/cli/commands/manifest/regenerate.js +97 -0
  18. package/.grimoire/cli/commands/manifest/validate.js +66 -0
  19. package/.grimoire/cli/commands/mcp/add.js +235 -0
  20. package/.grimoire/cli/commands/mcp/index.js +77 -0
  21. package/.grimoire/cli/commands/mcp/link.js +218 -0
  22. package/.grimoire/cli/commands/mcp/setup.js +165 -0
  23. package/.grimoire/cli/commands/mcp/status.js +184 -0
  24. package/.grimoire/cli/commands/metrics/cleanup.js +91 -0
  25. package/.grimoire/cli/commands/metrics/index.js +66 -0
  26. package/.grimoire/cli/commands/metrics/record.js +154 -0
  27. package/.grimoire/cli/commands/metrics/seed.js +127 -0
  28. package/.grimoire/cli/commands/metrics/show.js +209 -0
  29. package/.grimoire/cli/commands/migrate/analyze.js +355 -0
  30. package/.grimoire/cli/commands/migrate/backup.js +354 -0
  31. package/.grimoire/cli/commands/migrate/execute.js +294 -0
  32. package/.grimoire/cli/commands/migrate/index.js +443 -0
  33. package/.grimoire/cli/commands/migrate/rollback.js +325 -0
  34. package/.grimoire/cli/commands/migrate/update-imports.js +398 -0
  35. package/.grimoire/cli/commands/migrate/validate.js +454 -0
  36. package/.grimoire/cli/commands/pro/index.js +705 -0
  37. package/.grimoire/cli/commands/qa/index.js +57 -0
  38. package/.grimoire/cli/commands/qa/run.js +163 -0
  39. package/.grimoire/cli/commands/qa/status.js +195 -0
  40. package/.grimoire/cli/commands/validate/index.js +431 -0
  41. package/.grimoire/cli/commands/workers/formatters/info-formatter.js +275 -0
  42. package/.grimoire/cli/commands/workers/formatters/list-table.js +265 -0
  43. package/.grimoire/cli/commands/workers/formatters/list-tree.js +160 -0
  44. package/.grimoire/cli/commands/workers/index.js +57 -0
  45. package/.grimoire/cli/commands/workers/info.js +195 -0
  46. package/.grimoire/cli/commands/workers/list.js +215 -0
  47. package/.grimoire/cli/commands/workers/search-filters.js +185 -0
  48. package/.grimoire/cli/commands/workers/search-keyword.js +310 -0
  49. package/.grimoire/cli/commands/workers/search-semantic.js +294 -0
  50. package/.grimoire/cli/commands/workers/search.js +155 -0
  51. package/.grimoire/cli/commands/workers/utils/pagination.js +102 -0
  52. package/.grimoire/cli/index.js +150 -0
  53. package/.grimoire/cli/utils/output-formatter-cli.js +233 -0
  54. package/.grimoire/cli/utils/score-calculator.js +221 -0
  55. package/.grimoire/constitution.md +172 -0
  56. package/.grimoire/core/README.md +231 -0
  57. package/.grimoire/core/code-intel/code-intel-client.js +280 -0
  58. package/.grimoire/core/code-intel/code-intel-enricher.js +160 -0
  59. package/.grimoire/core/code-intel/index.js +137 -0
  60. package/.grimoire/core/code-intel/providers/code-graph-provider.js +201 -0
  61. package/.grimoire/core/code-intel/providers/provider-interface.js +108 -0
  62. package/.grimoire/core/config/config-cache.js +233 -0
  63. package/.grimoire/core/config/config-loader.js +281 -0
  64. package/.grimoire/core/config/config-resolver.js +609 -0
  65. package/.grimoire/core/config/env-interpolator.js +122 -0
  66. package/.grimoire/core/config/merge-utils.js +101 -0
  67. package/.grimoire/core/config/migrate-config.js +293 -0
  68. package/.grimoire/core/config/schemas/framework-config.schema.json +19 -0
  69. package/.grimoire/core/config/schemas/local-config.schema.json +20 -0
  70. package/.grimoire/core/config/schemas/project-config.schema.json +32 -0
  71. package/.grimoire/core/config/schemas/user-config.schema.json +33 -0
  72. package/.grimoire/core/config/templates/user-config.yaml +24 -0
  73. package/.grimoire/core/docs/SHARD-TRANSLATION-GUIDE.md +337 -0
  74. package/.grimoire/core/docs/component-creation-guide.md +459 -0
  75. package/.grimoire/core/docs/session-update-pattern.md +316 -0
  76. package/.grimoire/core/docs/template-syntax.md +267 -0
  77. package/.grimoire/core/docs/troubleshooting-guide.md +626 -0
  78. package/.grimoire/core/elicitation/agent-elicitation.js +272 -0
  79. package/.grimoire/core/elicitation/elicitation-engine.js +486 -0
  80. package/.grimoire/core/elicitation/session-manager.js +322 -0
  81. package/.grimoire/core/elicitation/task-elicitation.js +281 -0
  82. package/.grimoire/core/elicitation/workflow-elicitation.js +349 -0
  83. package/.grimoire/core/events/dashboard-emitter.js +369 -0
  84. package/.grimoire/core/events/index.js +17 -0
  85. package/.grimoire/core/events/types.js +52 -0
  86. package/.grimoire/core/execution/autonomous-build-loop.js +1068 -0
  87. package/.grimoire/core/execution/build-orchestrator.js +1055 -0
  88. package/.grimoire/core/execution/build-state-manager.js +1530 -0
  89. package/.grimoire/core/execution/context-injector.js +537 -0
  90. package/.grimoire/core/execution/parallel-executor.js +292 -0
  91. package/.grimoire/core/execution/parallel-monitor.js +429 -0
  92. package/.grimoire/core/execution/rate-limit-manager.js +314 -0
  93. package/.grimoire/core/execution/result-aggregator.js +486 -0
  94. package/.grimoire/core/execution/semantic-merge-engine.js +1736 -0
  95. package/.grimoire/core/execution/subagent-dispatcher.js +848 -0
  96. package/.grimoire/core/execution/wave-executor.js +397 -0
  97. package/.grimoire/core/health-check/base-check.js +224 -0
  98. package/.grimoire/core/health-check/check-registry.js +253 -0
  99. package/.grimoire/core/health-check/checks/deployment/build-config.js +111 -0
  100. package/.grimoire/core/health-check/checks/deployment/ci-config.js +125 -0
  101. package/.grimoire/core/health-check/checks/deployment/deployment-readiness.js +152 -0
  102. package/.grimoire/core/health-check/checks/deployment/docker-config.js +122 -0
  103. package/.grimoire/core/health-check/checks/deployment/env-file.js +111 -0
  104. package/.grimoire/core/health-check/checks/deployment/index.js +29 -0
  105. package/.grimoire/core/health-check/checks/index.js +56 -0
  106. package/.grimoire/core/health-check/checks/local/disk-space.js +214 -0
  107. package/.grimoire/core/health-check/checks/local/environment-vars.js +136 -0
  108. package/.grimoire/core/health-check/checks/local/git-install.js +158 -0
  109. package/.grimoire/core/health-check/checks/local/ide-detection.js +148 -0
  110. package/.grimoire/core/health-check/checks/local/index.js +35 -0
  111. package/.grimoire/core/health-check/checks/local/memory.js +138 -0
  112. package/.grimoire/core/health-check/checks/local/network.js +170 -0
  113. package/.grimoire/core/health-check/checks/local/npm-install.js +149 -0
  114. package/.grimoire/core/health-check/checks/local/shell-environment.js +120 -0
  115. package/.grimoire/core/health-check/checks/project/agent-config.js +167 -0
  116. package/.grimoire/core/health-check/checks/project/dependencies.js +150 -0
  117. package/.grimoire/core/health-check/checks/project/framework-config.js +133 -0
  118. package/.grimoire/core/health-check/checks/project/grimoire-directory.js +143 -0
  119. package/.grimoire/core/health-check/checks/project/index.js +35 -0
  120. package/.grimoire/core/health-check/checks/project/node-version.js +163 -0
  121. package/.grimoire/core/health-check/checks/project/package-json.js +107 -0
  122. package/.grimoire/core/health-check/checks/project/task-definitions.js +192 -0
  123. package/.grimoire/core/health-check/checks/project/workflow-dependencies.js +214 -0
  124. package/.grimoire/core/health-check/checks/repository/branch-protection.js +107 -0
  125. package/.grimoire/core/health-check/checks/repository/commit-history.js +144 -0
  126. package/.grimoire/core/health-check/checks/repository/conflicts.js +152 -0
  127. package/.grimoire/core/health-check/checks/repository/git-repo.js +159 -0
  128. package/.grimoire/core/health-check/checks/repository/git-status.js +149 -0
  129. package/.grimoire/core/health-check/checks/repository/gitignore.js +194 -0
  130. package/.grimoire/core/health-check/checks/repository/index.js +35 -0
  131. package/.grimoire/core/health-check/checks/repository/large-files.js +183 -0
  132. package/.grimoire/core/health-check/checks/repository/lockfile-integrity.js +144 -0
  133. package/.grimoire/core/health-check/checks/services/api-endpoints.js +168 -0
  134. package/.grimoire/core/health-check/checks/services/claude-code.js +139 -0
  135. package/.grimoire/core/health-check/checks/services/gemini-cli.js +241 -0
  136. package/.grimoire/core/health-check/checks/services/github-cli.js +117 -0
  137. package/.grimoire/core/health-check/checks/services/index.js +29 -0
  138. package/.grimoire/core/health-check/checks/services/mcp-integration.js +125 -0
  139. package/.grimoire/core/health-check/engine.js +407 -0
  140. package/.grimoire/core/health-check/healers/backup-manager.js +340 -0
  141. package/.grimoire/core/health-check/healers/index.js +330 -0
  142. package/.grimoire/core/health-check/index.js +370 -0
  143. package/.grimoire/core/health-check/reporters/console.js +331 -0
  144. package/.grimoire/core/health-check/reporters/index.js +117 -0
  145. package/.grimoire/core/health-check/reporters/json.js +301 -0
  146. package/.grimoire/core/health-check/reporters/markdown.js +323 -0
  147. package/.grimoire/core/ideation/ideation-engine.js +834 -0
  148. package/.grimoire/core/ids/README.md +123 -0
  149. package/.grimoire/core/ids/circuit-breaker.js +156 -0
  150. package/.grimoire/core/ids/framework-governor.js +567 -0
  151. package/.grimoire/core/ids/gates/g1-epic-creation.js +101 -0
  152. package/.grimoire/core/ids/gates/g2-story-creation.js +133 -0
  153. package/.grimoire/core/ids/gates/g3-story-validation.js +166 -0
  154. package/.grimoire/core/ids/gates/g4-dev-context.js +155 -0
  155. package/.grimoire/core/ids/incremental-decision-engine.js +651 -0
  156. package/.grimoire/core/ids/index.js +157 -0
  157. package/.grimoire/core/ids/registry-healer.js +868 -0
  158. package/.grimoire/core/ids/registry-loader.js +281 -0
  159. package/.grimoire/core/ids/registry-updater.js +703 -0
  160. package/.grimoire/core/ids/verification-gate.js +306 -0
  161. package/.grimoire/core/index.esm.js +44 -0
  162. package/.grimoire/core/index.js +90 -0
  163. package/.grimoire/core/manifest/manifest-generator.js +388 -0
  164. package/.grimoire/core/manifest/manifest-validator.js +431 -0
  165. package/.grimoire/core/mcp/config-migrator.js +341 -0
  166. package/.grimoire/core/mcp/global-config-manager.js +370 -0
  167. package/.grimoire/core/mcp/index.js +34 -0
  168. package/.grimoire/core/mcp/os-detector.js +189 -0
  169. package/.grimoire/core/mcp/symlink-manager.js +415 -0
  170. package/.grimoire/core/memory/__tests__/active-modules.verify.js +254 -0
  171. package/.grimoire/core/memory/gotchas-memory.js +1154 -0
  172. package/.grimoire/core/migration/migration-config.yaml +85 -0
  173. package/.grimoire/core/migration/module-mapping.yaml +91 -0
  174. package/.grimoire/core/orchestration/agent-invoker.js +612 -0
  175. package/.grimoire/core/orchestration/bob-orchestrator.js +1032 -0
  176. package/.grimoire/core/orchestration/bob-status-writer.js +482 -0
  177. package/.grimoire/core/orchestration/bob-surface-criteria.yaml +272 -0
  178. package/.grimoire/core/orchestration/brownfield-handler.js +741 -0
  179. package/.grimoire/core/orchestration/checklist-runner.js +328 -0
  180. package/.grimoire/core/orchestration/cli-commands.js +581 -0
  181. package/.grimoire/core/orchestration/condition-evaluator.js +379 -0
  182. package/.grimoire/core/orchestration/context-manager.js +616 -0
  183. package/.grimoire/core/orchestration/dashboard-integration.js +520 -0
  184. package/.grimoire/core/orchestration/data-lifecycle-manager.js +357 -0
  185. package/.grimoire/core/orchestration/epic-context-accumulator.js +396 -0
  186. package/.grimoire/core/orchestration/execution-profile-resolver.js +107 -0
  187. package/.grimoire/core/orchestration/executor-assignment.js +413 -0
  188. package/.grimoire/core/orchestration/executors/epic-3-executor.js +223 -0
  189. package/.grimoire/core/orchestration/executors/epic-4-executor.js +269 -0
  190. package/.grimoire/core/orchestration/executors/epic-5-executor.js +329 -0
  191. package/.grimoire/core/orchestration/executors/epic-6-executor.js +265 -0
  192. package/.grimoire/core/orchestration/executors/epic-executor.js +237 -0
  193. package/.grimoire/core/orchestration/executors/index.js +86 -0
  194. package/.grimoire/core/orchestration/gate-evaluator.js +495 -0
  195. package/.grimoire/core/orchestration/gemini-model-selector.js +161 -0
  196. package/.grimoire/core/orchestration/greenfield-handler.js +890 -0
  197. package/.grimoire/core/orchestration/index.js +323 -0
  198. package/.grimoire/core/orchestration/lock-manager.js +327 -0
  199. package/.grimoire/core/orchestration/master-orchestrator.js +1544 -0
  200. package/.grimoire/core/orchestration/message-formatter.js +279 -0
  201. package/.grimoire/core/orchestration/parallel-executor.js +225 -0
  202. package/.grimoire/core/orchestration/recovery-handler.js +721 -0
  203. package/.grimoire/core/orchestration/session-state.js +876 -0
  204. package/.grimoire/core/orchestration/skill-dispatcher.js +364 -0
  205. package/.grimoire/core/orchestration/subagent-prompt-builder.js +370 -0
  206. package/.grimoire/core/orchestration/surface-checker.js +403 -0
  207. package/.grimoire/core/orchestration/task-complexity-classifier.js +123 -0
  208. package/.grimoire/core/orchestration/tech-stack-detector.js +599 -0
  209. package/.grimoire/core/orchestration/terminal-spawner.js +1044 -0
  210. package/.grimoire/core/orchestration/workflow-executor.js +1182 -0
  211. package/.grimoire/core/orchestration/workflow-orchestrator.js +907 -0
  212. package/.grimoire/core/permissions/__tests__/permission-mode.test.js +293 -0
  213. package/.grimoire/core/permissions/index.js +140 -0
  214. package/.grimoire/core/permissions/operation-guard.js +395 -0
  215. package/.grimoire/core/permissions/permission-mode.js +271 -0
  216. package/.grimoire/core/quality-gates/base-layer.js +134 -0
  217. package/.grimoire/core/quality-gates/checklist-generator.js +329 -0
  218. package/.grimoire/core/quality-gates/focus-area-recommender.js +361 -0
  219. package/.grimoire/core/quality-gates/human-review-orchestrator.js +530 -0
  220. package/.grimoire/core/quality-gates/layer1-precommit.js +336 -0
  221. package/.grimoire/core/quality-gates/layer2-pr-automation.js +331 -0
  222. package/.grimoire/core/quality-gates/layer3-human-review.js +350 -0
  223. package/.grimoire/core/quality-gates/notification-manager.js +551 -0
  224. package/.grimoire/core/quality-gates/quality-gate-config.yaml +87 -0
  225. package/.grimoire/core/quality-gates/quality-gate-manager.js +603 -0
  226. package/.grimoire/core/registry/README.md +181 -0
  227. package/.grimoire/core/registry/build-registry.js +454 -0
  228. package/.grimoire/core/registry/registry-loader.js +331 -0
  229. package/.grimoire/core/registry/registry-schema.json +168 -0
  230. package/.grimoire/core/registry/service-registry.json +6468 -0
  231. package/.grimoire/core/registry/validate-registry.js +341 -0
  232. package/.grimoire/core/session/context-detector.js +233 -0
  233. package/.grimoire/core/session/context-loader.js +443 -0
  234. package/.grimoire/core/synapse/context/context-builder.js +34 -0
  235. package/.grimoire/core/synapse/context/context-tracker.js +190 -0
  236. package/.grimoire/core/synapse/diagnostics/collectors/consistency-collector.js +168 -0
  237. package/.grimoire/core/synapse/diagnostics/collectors/hook-collector.js +129 -0
  238. package/.grimoire/core/synapse/diagnostics/collectors/manifest-collector.js +82 -0
  239. package/.grimoire/core/synapse/diagnostics/collectors/output-analyzer.js +134 -0
  240. package/.grimoire/core/synapse/diagnostics/collectors/pipeline-collector.js +75 -0
  241. package/.grimoire/core/synapse/diagnostics/collectors/quality-collector.js +252 -0
  242. package/.grimoire/core/synapse/diagnostics/collectors/relevance-matrix.js +174 -0
  243. package/.grimoire/core/synapse/diagnostics/collectors/safe-read-json.js +31 -0
  244. package/.grimoire/core/synapse/diagnostics/collectors/session-collector.js +102 -0
  245. package/.grimoire/core/synapse/diagnostics/collectors/timing-collector.js +126 -0
  246. package/.grimoire/core/synapse/diagnostics/collectors/uap-collector.js +83 -0
  247. package/.grimoire/core/synapse/diagnostics/report-formatter.js +485 -0
  248. package/.grimoire/core/synapse/diagnostics/synapse-diagnostics.js +95 -0
  249. package/.grimoire/core/synapse/domain/domain-loader.js +322 -0
  250. package/.grimoire/core/synapse/engine.js +380 -0
  251. package/.grimoire/core/synapse/layers/l0-constitution.js +80 -0
  252. package/.grimoire/core/synapse/layers/l1-global.js +102 -0
  253. package/.grimoire/core/synapse/layers/l2-agent.js +94 -0
  254. package/.grimoire/core/synapse/layers/l3-workflow.js +94 -0
  255. package/.grimoire/core/synapse/layers/l4-task.js +83 -0
  256. package/.grimoire/core/synapse/layers/l5-squad.js +244 -0
  257. package/.grimoire/core/synapse/layers/l6-keyword.js +154 -0
  258. package/.grimoire/core/synapse/layers/l7-star-command.js +169 -0
  259. package/.grimoire/core/synapse/layers/layer-processor.js +82 -0
  260. package/.grimoire/core/synapse/memory/memory-bridge.js +246 -0
  261. package/.grimoire/core/synapse/output/formatter.js +561 -0
  262. package/.grimoire/core/synapse/runtime/hook-runtime.js +61 -0
  263. package/.grimoire/core/synapse/scripts/generate-constitution.js +205 -0
  264. package/.grimoire/core/synapse/session/session-manager.js +403 -0
  265. package/.grimoire/core/synapse/utils/paths.js +57 -0
  266. package/.grimoire/core/synapse/utils/tokens.js +25 -0
  267. package/.grimoire/core/ui/index.js +43 -0
  268. package/.grimoire/core/ui/observability-panel.js +394 -0
  269. package/.grimoire/core/ui/panel-renderer.js +337 -0
  270. package/.grimoire/core/utils/output-formatter.js +299 -0
  271. package/.grimoire/core/utils/security-utils.js +336 -0
  272. package/.grimoire/core/utils/yaml-validator.js +416 -0
  273. package/.grimoire/core-config.yaml +357 -0
  274. package/.grimoire/data/agent-config-requirements.yaml +409 -0
  275. package/.grimoire/data/entity-registry.yaml +9219 -0
  276. package/.grimoire/data/grimoire-kb.md +918 -0
  277. package/.grimoire/data/learned-patterns.yaml +3 -0
  278. package/.grimoire/data/tech-presets/_template.md +259 -0
  279. package/.grimoire/data/tech-presets/nextjs-react.md +933 -0
  280. package/.grimoire/data/technical-preferences.md +85 -0
  281. package/.grimoire/data/workflow-patterns.yaml +836 -0
  282. package/.grimoire/data/workflow-state-schema.yaml +203 -0
  283. package/.grimoire/development/README.md +143 -0
  284. package/.grimoire/development/agent-teams/team-all.yaml +16 -0
  285. package/.grimoire/development/agent-teams/team-fullstack.yaml +19 -0
  286. package/.grimoire/development/agent-teams/team-ide-minimal.yaml +10 -0
  287. package/.grimoire/development/agent-teams/team-no-ui.yaml +14 -0
  288. package/.grimoire/development/agent-teams/team-qa-focused.yaml +155 -0
  289. package/.grimoire/development/agents/analyst.md +261 -0
  290. package/.grimoire/development/agents/architect.md +461 -0
  291. package/.grimoire/development/agents/caravaggio.md +31 -0
  292. package/.grimoire/development/agents/data-engineer.md +482 -0
  293. package/.grimoire/development/agents/dev.md +548 -0
  294. package/.grimoire/development/agents/devops.md +500 -0
  295. package/.grimoire/development/agents/frida.md +31 -0
  296. package/.grimoire/development/agents/grimoire-master.md +447 -0
  297. package/.grimoire/development/agents/picasso.md +31 -0
  298. package/.grimoire/development/agents/pm.md +365 -0
  299. package/.grimoire/development/agents/po.md +323 -0
  300. package/.grimoire/development/agents/qa.md +437 -0
  301. package/.grimoire/development/agents/salvador.md +31 -0
  302. package/.grimoire/development/agents/sm.md +275 -0
  303. package/.grimoire/development/agents/squad-creator.md +330 -0
  304. package/.grimoire/development/agents/tarsila.md +31 -0
  305. package/.grimoire/development/agents/ux-design-expert.md +482 -0
  306. package/.grimoire/development/agents/van-gogh.md +31 -0
  307. package/.grimoire/development/agents/warhol.md +31 -0
  308. package/.grimoire/development/checklists/agent-quality-gate.md +560 -0
  309. package/.grimoire/development/checklists/brownfield-compatibility-checklist.md +116 -0
  310. package/.grimoire/development/checklists/self-critique-checklist.md +274 -0
  311. package/.grimoire/development/data/decision-heuristics-framework.md +622 -0
  312. package/.grimoire/development/data/quality-dimensions-framework.md +427 -0
  313. package/.grimoire/development/data/tier-system-framework.md +476 -0
  314. package/.grimoire/development/scripts/activation-runtime.js +64 -0
  315. package/.grimoire/development/scripts/agent-assignment-resolver.js +231 -0
  316. package/.grimoire/development/scripts/agent-config-loader.js +628 -0
  317. package/.grimoire/development/scripts/agent-exit-hooks.js +97 -0
  318. package/.grimoire/development/scripts/apply-inline-greeting-all-agents.js +147 -0
  319. package/.grimoire/development/scripts/approval-workflow.js +643 -0
  320. package/.grimoire/development/scripts/audit-agent-config.js +382 -0
  321. package/.grimoire/development/scripts/backlog-manager.js +409 -0
  322. package/.grimoire/development/scripts/backup-manager.js +607 -0
  323. package/.grimoire/development/scripts/batch-update-agents-session-context.js +97 -0
  324. package/.grimoire/development/scripts/branch-manager.js +390 -0
  325. package/.grimoire/development/scripts/code-quality-improver.js +1312 -0
  326. package/.grimoire/development/scripts/commit-message-generator.js +850 -0
  327. package/.grimoire/development/scripts/conflict-resolver.js +675 -0
  328. package/.grimoire/development/scripts/decision-context.js +229 -0
  329. package/.grimoire/development/scripts/decision-log-generator.js +294 -0
  330. package/.grimoire/development/scripts/decision-log-indexer.js +285 -0
  331. package/.grimoire/development/scripts/decision-recorder.js +169 -0
  332. package/.grimoire/development/scripts/dependency-analyzer.js +639 -0
  333. package/.grimoire/development/scripts/dev-context-loader.js +298 -0
  334. package/.grimoire/development/scripts/diff-generator.js +352 -0
  335. package/.grimoire/development/scripts/elicitation-engine.js +385 -0
  336. package/.grimoire/development/scripts/elicitation-session-manager.js +300 -0
  337. package/.grimoire/development/scripts/generate-greeting.js +109 -0
  338. package/.grimoire/development/scripts/git-wrapper.js +462 -0
  339. package/.grimoire/development/scripts/greeting-builder.js +1406 -0
  340. package/.grimoire/development/scripts/greeting-config-cli.js +86 -0
  341. package/.grimoire/development/scripts/greeting-preference-manager.js +170 -0
  342. package/.grimoire/development/scripts/manifest-preview.js +245 -0
  343. package/.grimoire/development/scripts/metrics-tracker.js +776 -0
  344. package/.grimoire/development/scripts/migrate-task-to-v2.js +379 -0
  345. package/.grimoire/development/scripts/modification-validator.js +555 -0
  346. package/.grimoire/development/scripts/pattern-learner.js +1225 -0
  347. package/.grimoire/development/scripts/performance-analyzer.js +758 -0
  348. package/.grimoire/development/scripts/populate-entity-registry.js +281 -0
  349. package/.grimoire/development/scripts/refactoring-suggester.js +1139 -0
  350. package/.grimoire/development/scripts/rollback-handler.js +532 -0
  351. package/.grimoire/development/scripts/security-checker.js +359 -0
  352. package/.grimoire/development/scripts/skill-validator.js +343 -0
  353. package/.grimoire/development/scripts/squad/README.md +114 -0
  354. package/.grimoire/development/scripts/squad/index.js +124 -0
  355. package/.grimoire/development/scripts/squad/squad-analyzer.js +638 -0
  356. package/.grimoire/development/scripts/squad/squad-designer.js +1010 -0
  357. package/.grimoire/development/scripts/squad/squad-downloader.js +511 -0
  358. package/.grimoire/development/scripts/squad/squad-extender.js +872 -0
  359. package/.grimoire/development/scripts/squad/squad-generator.js +1406 -0
  360. package/.grimoire/development/scripts/squad/squad-loader.js +359 -0
  361. package/.grimoire/development/scripts/squad/squad-migrator.js +628 -0
  362. package/.grimoire/development/scripts/squad/squad-publisher.js +630 -0
  363. package/.grimoire/development/scripts/squad/squad-validator.js +857 -0
  364. package/.grimoire/development/scripts/story-index-generator.js +339 -0
  365. package/.grimoire/development/scripts/story-manager.js +375 -0
  366. package/.grimoire/development/scripts/story-update-hook.js +259 -0
  367. package/.grimoire/development/scripts/task-identifier-resolver.js +145 -0
  368. package/.grimoire/development/scripts/template-engine.js +240 -0
  369. package/.grimoire/development/scripts/template-validator.js +279 -0
  370. package/.grimoire/development/scripts/test-generator.js +844 -0
  371. package/.grimoire/development/scripts/test-greeting-system.js +143 -0
  372. package/.grimoire/development/scripts/transaction-manager.js +591 -0
  373. package/.grimoire/development/scripts/unified-activation-pipeline.js +796 -0
  374. package/.grimoire/development/scripts/usage-tracker.js +675 -0
  375. package/.grimoire/development/scripts/validate-filenames.js +228 -0
  376. package/.grimoire/development/scripts/validate-task-v2.js +320 -0
  377. package/.grimoire/development/scripts/verify-workflow-gaps.js +1034 -0
  378. package/.grimoire/development/scripts/version-tracker.js +527 -0
  379. package/.grimoire/development/scripts/workflow-navigator.js +328 -0
  380. package/.grimoire/development/scripts/workflow-state-manager.js +652 -0
  381. package/.grimoire/development/scripts/workflow-validator.js +697 -0
  382. package/.grimoire/development/scripts/yaml-validator.js +397 -0
  383. package/.grimoire/development/tasks/add-mcp.md +437 -0
  384. package/.grimoire/development/tasks/advanced-elicitation.md +320 -0
  385. package/.grimoire/development/tasks/analyst-facilitate-brainstorming.md +343 -0
  386. package/.grimoire/development/tasks/analyze-brownfield.md +458 -0
  387. package/.grimoire/development/tasks/analyze-cross-artifact.md +358 -0
  388. package/.grimoire/development/tasks/analyze-framework.md +698 -0
  389. package/.grimoire/development/tasks/analyze-performance.md +639 -0
  390. package/.grimoire/development/tasks/analyze-project-structure.md +623 -0
  391. package/.grimoire/development/tasks/apply-qa-fixes.md +342 -0
  392. package/.grimoire/development/tasks/architect-analyze-impact.md +828 -0
  393. package/.grimoire/development/tasks/audit-codebase.md +431 -0
  394. package/.grimoire/development/tasks/audit-tailwind-config.md +272 -0
  395. package/.grimoire/development/tasks/audit-utilities.md +360 -0
  396. package/.grimoire/development/tasks/blocks/README.md +180 -0
  397. package/.grimoire/development/tasks/blocks/agent-prompt-template.md +117 -0
  398. package/.grimoire/development/tasks/blocks/context-loading.md +110 -0
  399. package/.grimoire/development/tasks/blocks/execution-pattern.md +122 -0
  400. package/.grimoire/development/tasks/blocks/finalization.md +123 -0
  401. package/.grimoire/development/tasks/bootstrap-shadcn-library.md +288 -0
  402. package/.grimoire/development/tasks/brownfield-create-epic.md +533 -0
  403. package/.grimoire/development/tasks/brownfield-create-story.md +358 -0
  404. package/.grimoire/development/tasks/build-autonomous.md +186 -0
  405. package/.grimoire/development/tasks/build-component.md +480 -0
  406. package/.grimoire/development/tasks/build-resume.md +125 -0
  407. package/.grimoire/development/tasks/build-status.md +155 -0
  408. package/.grimoire/development/tasks/build.md +142 -0
  409. package/.grimoire/development/tasks/calculate-roi.md +457 -0
  410. package/.grimoire/development/tasks/check-docs-links.md +114 -0
  411. package/.grimoire/development/tasks/ci-cd-configuration.md +766 -0
  412. package/.grimoire/development/tasks/cleanup-utilities.md +672 -0
  413. package/.grimoire/development/tasks/cleanup-worktrees.md +39 -0
  414. package/.grimoire/development/tasks/collaborative-edit.md +1110 -0
  415. package/.grimoire/development/tasks/compose-molecule.md +286 -0
  416. package/.grimoire/development/tasks/consolidate-patterns.md +416 -0
  417. package/.grimoire/development/tasks/correct-course.md +281 -0
  418. package/.grimoire/development/tasks/create-agent.md +1199 -0
  419. package/.grimoire/development/tasks/create-brownfield-story.md +728 -0
  420. package/.grimoire/development/tasks/create-deep-research-prompt.md +500 -0
  421. package/.grimoire/development/tasks/create-doc.md +318 -0
  422. package/.grimoire/development/tasks/create-next-story.md +776 -0
  423. package/.grimoire/development/tasks/create-service.md +393 -0
  424. package/.grimoire/development/tasks/create-suite.md +285 -0
  425. package/.grimoire/development/tasks/create-task.md +391 -0
  426. package/.grimoire/development/tasks/create-workflow.md +429 -0
  427. package/.grimoire/development/tasks/create-worktree.md +439 -0
  428. package/.grimoire/development/tasks/db-analyze-hotpaths.md +574 -0
  429. package/.grimoire/development/tasks/db-apply-migration.md +383 -0
  430. package/.grimoire/development/tasks/db-bootstrap.md +644 -0
  431. package/.grimoire/development/tasks/db-domain-modeling.md +695 -0
  432. package/.grimoire/development/tasks/db-dry-run.md +295 -0
  433. package/.grimoire/development/tasks/db-env-check.md +262 -0
  434. package/.grimoire/development/tasks/db-explain.md +633 -0
  435. package/.grimoire/development/tasks/db-impersonate.md +497 -0
  436. package/.grimoire/development/tasks/db-load-csv.md +595 -0
  437. package/.grimoire/development/tasks/db-policy-apply.md +655 -0
  438. package/.grimoire/development/tasks/db-rls-audit.md +413 -0
  439. package/.grimoire/development/tasks/db-rollback.md +741 -0
  440. package/.grimoire/development/tasks/db-run-sql.md +615 -0
  441. package/.grimoire/development/tasks/db-schema-audit.md +1013 -0
  442. package/.grimoire/development/tasks/db-seed.md +392 -0
  443. package/.grimoire/development/tasks/db-smoke-test.md +353 -0
  444. package/.grimoire/development/tasks/db-snapshot.md +571 -0
  445. package/.grimoire/development/tasks/db-squad-integration.md +665 -0
  446. package/.grimoire/development/tasks/db-supabase-setup.md +714 -0
  447. package/.grimoire/development/tasks/db-verify-order.md +517 -0
  448. package/.grimoire/development/tasks/deprecate-component.md +958 -0
  449. package/.grimoire/development/tasks/dev-apply-qa-fixes.md +320 -0
  450. package/.grimoire/development/tasks/dev-backlog-debt.md +471 -0
  451. package/.grimoire/development/tasks/dev-develop-story.md +912 -0
  452. package/.grimoire/development/tasks/dev-improve-code-quality.md +874 -0
  453. package/.grimoire/development/tasks/dev-optimize-performance.md +1035 -0
  454. package/.grimoire/development/tasks/dev-suggest-refactoring.md +872 -0
  455. package/.grimoire/development/tasks/dev-validate-next-story.md +350 -0
  456. package/.grimoire/development/tasks/document-gotchas.md +479 -0
  457. package/.grimoire/development/tasks/document-project.md +554 -0
  458. package/.grimoire/development/tasks/environment-bootstrap.md +1391 -0
  459. package/.grimoire/development/tasks/execute-checklist.md +303 -0
  460. package/.grimoire/development/tasks/execute-epic-plan.md +887 -0
  461. package/.grimoire/development/tasks/export-design-tokens-dtcg.md +276 -0
  462. package/.grimoire/development/tasks/extend-pattern.md +271 -0
  463. package/.grimoire/development/tasks/extract-patterns.md +399 -0
  464. package/.grimoire/development/tasks/extract-tokens.md +469 -0
  465. package/.grimoire/development/tasks/facilitate-brainstorming-session.md +520 -0
  466. package/.grimoire/development/tasks/generate-ai-frontend-prompt.md +262 -0
  467. package/.grimoire/development/tasks/generate-documentation.md +286 -0
  468. package/.grimoire/development/tasks/generate-migration-strategy.md +524 -0
  469. package/.grimoire/development/tasks/generate-shock-report.md +503 -0
  470. package/.grimoire/development/tasks/github-devops-github-pr-automation.md +666 -0
  471. package/.grimoire/development/tasks/github-devops-pre-push-quality-gate.md +791 -0
  472. package/.grimoire/development/tasks/github-devops-repository-cleanup.md +376 -0
  473. package/.grimoire/development/tasks/github-devops-version-management.md +485 -0
  474. package/.grimoire/development/tasks/gotcha.md +138 -0
  475. package/.grimoire/development/tasks/gotchas.md +155 -0
  476. package/.grimoire/development/tasks/health-check.yaml +227 -0
  477. package/.grimoire/development/tasks/ids-governor.md +96 -0
  478. package/.grimoire/development/tasks/ids-health.md +91 -0
  479. package/.grimoire/development/tasks/ids-query.md +156 -0
  480. package/.grimoire/development/tasks/improve-self.md +824 -0
  481. package/.grimoire/development/tasks/index-docs.md +389 -0
  482. package/.grimoire/development/tasks/init-project-status.md +508 -0
  483. package/.grimoire/development/tasks/integrate-squad.md +316 -0
  484. package/.grimoire/development/tasks/kb-mode-interaction.md +285 -0
  485. package/.grimoire/development/tasks/learn-patterns.md +902 -0
  486. package/.grimoire/development/tasks/list-mcps.md +33 -0
  487. package/.grimoire/development/tasks/list-worktrees.md +344 -0
  488. package/.grimoire/development/tasks/mcp-workflow.md +438 -0
  489. package/.grimoire/development/tasks/merge-worktree.md +42 -0
  490. package/.grimoire/development/tasks/modify-agent.md +399 -0
  491. package/.grimoire/development/tasks/modify-task.md +442 -0
  492. package/.grimoire/development/tasks/modify-workflow.md +511 -0
  493. package/.grimoire/development/tasks/next.md +327 -0
  494. package/.grimoire/development/tasks/orchestrate-resume.md +60 -0
  495. package/.grimoire/development/tasks/orchestrate-status.md +64 -0
  496. package/.grimoire/development/tasks/orchestrate-stop.md +55 -0
  497. package/.grimoire/development/tasks/orchestrate.md +66 -0
  498. package/.grimoire/development/tasks/patterns.md +336 -0
  499. package/.grimoire/development/tasks/plan-create-context.md +812 -0
  500. package/.grimoire/development/tasks/plan-create-implementation.md +797 -0
  501. package/.grimoire/development/tasks/plan-execute-subtask.md +962 -0
  502. package/.grimoire/development/tasks/po-backlog-add.md +372 -0
  503. package/.grimoire/development/tasks/po-close-story.md +428 -0
  504. package/.grimoire/development/tasks/po-manage-story-backlog.md +525 -0
  505. package/.grimoire/development/tasks/po-pull-story-from-clickup.md +542 -0
  506. package/.grimoire/development/tasks/po-pull-story.md +318 -0
  507. package/.grimoire/development/tasks/po-stories-index.md +353 -0
  508. package/.grimoire/development/tasks/po-sync-story-to-clickup.md +459 -0
  509. package/.grimoire/development/tasks/po-sync-story.md +305 -0
  510. package/.grimoire/development/tasks/pr-automation.md +703 -0
  511. package/.grimoire/development/tasks/propose-modification.md +844 -0
  512. package/.grimoire/development/tasks/publish-npm.md +259 -0
  513. package/.grimoire/development/tasks/qa-after-creation.md +519 -0
  514. package/.grimoire/development/tasks/qa-backlog-add-followup.md +427 -0
  515. package/.grimoire/development/tasks/qa-browser-console-check.md +343 -0
  516. package/.grimoire/development/tasks/qa-create-fix-request.md +625 -0
  517. package/.grimoire/development/tasks/qa-evidence-requirements.md +314 -0
  518. package/.grimoire/development/tasks/qa-false-positive-detection.md +374 -0
  519. package/.grimoire/development/tasks/qa-fix-issues.md +686 -0
  520. package/.grimoire/development/tasks/qa-gate.md +375 -0
  521. package/.grimoire/development/tasks/qa-generate-tests.md +1176 -0
  522. package/.grimoire/development/tasks/qa-library-validation.md +497 -0
  523. package/.grimoire/development/tasks/qa-migration-validation.md +584 -0
  524. package/.grimoire/development/tasks/qa-nfr-assess.md +559 -0
  525. package/.grimoire/development/tasks/qa-review-build.md +1225 -0
  526. package/.grimoire/development/tasks/qa-review-proposal.md +1159 -0
  527. package/.grimoire/development/tasks/qa-review-story.md +684 -0
  528. package/.grimoire/development/tasks/qa-risk-profile.md +568 -0
  529. package/.grimoire/development/tasks/qa-run-tests.md +279 -0
  530. package/.grimoire/development/tasks/qa-security-checklist.md +552 -0
  531. package/.grimoire/development/tasks/qa-test-design.md +389 -0
  532. package/.grimoire/development/tasks/qa-trace-requirements.md +478 -0
  533. package/.grimoire/development/tasks/release-management.md +754 -0
  534. package/.grimoire/development/tasks/remove-mcp.md +35 -0
  535. package/.grimoire/development/tasks/remove-worktree.md +435 -0
  536. package/.grimoire/development/tasks/run-design-system-pipeline.md +642 -0
  537. package/.grimoire/development/tasks/run-workflow-engine.md +861 -0
  538. package/.grimoire/development/tasks/run-workflow.md +389 -0
  539. package/.grimoire/development/tasks/search-mcp.md +309 -0
  540. package/.grimoire/development/tasks/security-audit.md +556 -0
  541. package/.grimoire/development/tasks/security-scan.md +792 -0
  542. package/.grimoire/development/tasks/session-resume.md +193 -0
  543. package/.grimoire/development/tasks/setup-database.md +743 -0
  544. package/.grimoire/development/tasks/setup-design-system.md +464 -0
  545. package/.grimoire/development/tasks/setup-github.md +876 -0
  546. package/.grimoire/development/tasks/setup-llm-routing.md +231 -0
  547. package/.grimoire/development/tasks/setup-mcp-docker.md +628 -0
  548. package/.grimoire/development/tasks/setup-project-docs.md +442 -0
  549. package/.grimoire/development/tasks/shard-doc.md +539 -0
  550. package/.grimoire/development/tasks/sm-create-next-story.md +482 -0
  551. package/.grimoire/development/tasks/spec-assess-complexity.md +461 -0
  552. package/.grimoire/development/tasks/spec-critique.md +595 -0
  553. package/.grimoire/development/tasks/spec-gather-requirements.md +545 -0
  554. package/.grimoire/development/tasks/spec-research-dependencies.md +446 -0
  555. package/.grimoire/development/tasks/spec-write-spec.md +531 -0
  556. package/.grimoire/development/tasks/squad-creator-analyze.md +318 -0
  557. package/.grimoire/development/tasks/squad-creator-create.md +314 -0
  558. package/.grimoire/development/tasks/squad-creator-design.md +335 -0
  559. package/.grimoire/development/tasks/squad-creator-download.md +169 -0
  560. package/.grimoire/development/tasks/squad-creator-extend.md +413 -0
  561. package/.grimoire/development/tasks/squad-creator-list.md +226 -0
  562. package/.grimoire/development/tasks/squad-creator-migrate.md +245 -0
  563. package/.grimoire/development/tasks/squad-creator-publish.md +231 -0
  564. package/.grimoire/development/tasks/squad-creator-sync-grimoire.md +317 -0
  565. package/.grimoire/development/tasks/squad-creator-sync-ide-command.md +403 -0
  566. package/.grimoire/development/tasks/squad-creator-validate.md +160 -0
  567. package/.grimoire/development/tasks/story-checkpoint.md +361 -0
  568. package/.grimoire/development/tasks/sync-documentation.md +866 -0
  569. package/.grimoire/development/tasks/tailwind-upgrade.md +296 -0
  570. package/.grimoire/development/tasks/test-as-user.md +623 -0
  571. package/.grimoire/development/tasks/test-validation-task.md +172 -0
  572. package/.grimoire/development/tasks/undo-last.md +348 -0
  573. package/.grimoire/development/tasks/update-grimoire.md +153 -0
  574. package/.grimoire/development/tasks/update-manifest.md +411 -0
  575. package/.grimoire/development/tasks/update-source-tree.md +138 -0
  576. package/.grimoire/development/tasks/ux-create-wireframe.md +619 -0
  577. package/.grimoire/development/tasks/ux-ds-scan-artifact.md +674 -0
  578. package/.grimoire/development/tasks/ux-user-research.md +561 -0
  579. package/.grimoire/development/tasks/validate-agents.md +117 -0
  580. package/.grimoire/development/tasks/validate-next-story.md +456 -0
  581. package/.grimoire/development/tasks/validate-tech-preset.md +187 -0
  582. package/.grimoire/development/tasks/validate-workflow.md +323 -0
  583. package/.grimoire/development/tasks/verify-subtask.md +237 -0
  584. package/.grimoire/development/tasks/waves.md +206 -0
  585. package/.grimoire/development/tasks/yolo-toggle.md +115 -0
  586. package/.grimoire/development/templates/grimoire-doc-template.md +496 -0
  587. package/.grimoire/development/templates/research-prompt-tmpl.md +486 -0
  588. package/.grimoire/development/templates/service-template/README.md.hbs +159 -0
  589. package/.grimoire/development/templates/service-template/__tests__/index.test.ts.hbs +238 -0
  590. package/.grimoire/development/templates/service-template/client.ts.hbs +404 -0
  591. package/.grimoire/development/templates/service-template/errors.ts.hbs +183 -0
  592. package/.grimoire/development/templates/service-template/index.ts.hbs +121 -0
  593. package/.grimoire/development/templates/service-template/jest.config.js +89 -0
  594. package/.grimoire/development/templates/service-template/package.json.hbs +88 -0
  595. package/.grimoire/development/templates/service-template/tsconfig.json +45 -0
  596. package/.grimoire/development/templates/service-template/types.ts.hbs +146 -0
  597. package/.grimoire/development/templates/squad/agent-template.md +69 -0
  598. package/.grimoire/development/templates/squad/checklist-template.md +82 -0
  599. package/.grimoire/development/templates/squad/data-template.yaml +105 -0
  600. package/.grimoire/development/templates/squad/script-template.js +179 -0
  601. package/.grimoire/development/templates/squad/task-template.md +125 -0
  602. package/.grimoire/development/templates/squad/template-template.md +98 -0
  603. package/.grimoire/development/templates/squad/tool-template.js +103 -0
  604. package/.grimoire/development/templates/squad/workflow-template.yaml +108 -0
  605. package/.grimoire/development/templates/squad-template/LICENSE +21 -0
  606. package/.grimoire/development/templates/squad-template/README.md +37 -0
  607. package/.grimoire/development/templates/squad-template/agents/example-agent.yaml +36 -0
  608. package/.grimoire/development/templates/squad-template/package.json +20 -0
  609. package/.grimoire/development/templates/squad-template/squad.yaml +26 -0
  610. package/.grimoire/development/templates/squad-template/tasks/example-task.yaml +46 -0
  611. package/.grimoire/development/templates/squad-template/templates/example-template.md +24 -0
  612. package/.grimoire/development/templates/squad-template/tests/example-agent.test.js +54 -0
  613. package/.grimoire/development/templates/squad-template/workflows/example-workflow.yaml +54 -0
  614. package/.grimoire/development/templates/subagent-step-prompt.md +122 -0
  615. package/.grimoire/development/workflows/README.md +82 -0
  616. package/.grimoire/development/workflows/auto-worktree.yaml +423 -0
  617. package/.grimoire/development/workflows/brownfield-discovery.yaml +933 -0
  618. package/.grimoire/development/workflows/brownfield-fullstack.yaml +369 -0
  619. package/.grimoire/development/workflows/brownfield-service.yaml +246 -0
  620. package/.grimoire/development/workflows/brownfield-ui.yaml +260 -0
  621. package/.grimoire/development/workflows/design-system-build-quality.yaml +228 -0
  622. package/.grimoire/development/workflows/development-cycle.yaml +427 -0
  623. package/.grimoire/development/workflows/epic-orchestration.yaml +328 -0
  624. package/.grimoire/development/workflows/greenfield-fullstack.yaml +386 -0
  625. package/.grimoire/development/workflows/greenfield-service.yaml +278 -0
  626. package/.grimoire/development/workflows/greenfield-ui.yaml +284 -0
  627. package/.grimoire/development/workflows/qa-loop.yaml +444 -0
  628. package/.grimoire/development/workflows/spec-pipeline.yaml +577 -0
  629. package/.grimoire/development/workflows/story-development-cycle.yaml +285 -0
  630. package/.grimoire/docs/standards/AGENT-PERSONALIZATION-STANDARD-V1.md +574 -0
  631. package/.grimoire/docs/standards/EXECUTOR-DECISION-TREE.md +698 -0
  632. package/.grimoire/docs/standards/OPEN-SOURCE-VS-SERVICE-DIFFERENCES.md +513 -0
  633. package/.grimoire/docs/standards/QUALITY-GATES-SPECIFICATION.md +558 -0
  634. package/.grimoire/docs/standards/STANDARDS-INDEX.md +212 -0
  635. package/.grimoire/docs/standards/STORY-TEMPLATE-V2-SPECIFICATION.md +551 -0
  636. package/.grimoire/docs/standards/TASK-FORMAT-SPECIFICATION-V1.md +1415 -0
  637. package/.grimoire/docs/standards/grimoire-COLOR-PALETTE-QUICK-REFERENCE.md +186 -0
  638. package/.grimoire/docs/standards/grimoire-COLOR-PALETTE-V2.1.md +354 -0
  639. package/.grimoire/docs/standards/grimoire-LIVRO-DE-OURO-V2.1-COMPLETE.md +839 -0
  640. package/.grimoire/docs/standards/grimoire-LIVRO-DE-OURO-V2.2-SUMMARY.md +1341 -0
  641. package/.grimoire/elicitation/agent-elicitation.js +272 -0
  642. package/.grimoire/elicitation/task-elicitation.js +281 -0
  643. package/.grimoire/elicitation/workflow-elicitation.js +315 -0
  644. package/.grimoire/framework-config.yaml +152 -0
  645. package/.grimoire/hooks/gemini/after-tool.js +78 -0
  646. package/.grimoire/hooks/gemini/before-agent.js +80 -0
  647. package/.grimoire/hooks/gemini/before-tool.js +115 -0
  648. package/.grimoire/hooks/gemini/rewind-handler.js +69 -0
  649. package/.grimoire/hooks/gemini/session-end.js +91 -0
  650. package/.grimoire/hooks/gemini/session-start.js +91 -0
  651. package/.grimoire/hooks/ids-post-commit.js +118 -0
  652. package/.grimoire/hooks/ids-pre-push.js +125 -0
  653. package/.grimoire/hooks/unified/README.md +309 -0
  654. package/.grimoire/hooks/unified/hook-interface.js +161 -0
  655. package/.grimoire/hooks/unified/hook-registry.js +143 -0
  656. package/.grimoire/hooks/unified/index.js +36 -0
  657. package/.grimoire/hooks/unified/runners/precompact-runner.js +98 -0
  658. package/.grimoire/index.esm.js +17 -0
  659. package/.grimoire/index.js +17 -0
  660. package/.grimoire/infrastructure/README.md +128 -0
  661. package/.grimoire/infrastructure/contracts/compatibility/grimoire-4.0.4.yaml +46 -0
  662. package/.grimoire/infrastructure/index.js +200 -0
  663. package/.grimoire/infrastructure/integrations/ai-providers/README.md +103 -0
  664. package/.grimoire/infrastructure/integrations/ai-providers/ai-provider-factory.js +286 -0
  665. package/.grimoire/infrastructure/integrations/ai-providers/ai-provider.js +145 -0
  666. package/.grimoire/infrastructure/integrations/ai-providers/claude-provider.js +170 -0
  667. package/.grimoire/infrastructure/integrations/ai-providers/gemini-provider.js +365 -0
  668. package/.grimoire/infrastructure/integrations/ai-providers/index.js +45 -0
  669. package/.grimoire/infrastructure/integrations/gemini-extensions/cloudrun-adapter.js +129 -0
  670. package/.grimoire/infrastructure/integrations/gemini-extensions/index.js +41 -0
  671. package/.grimoire/infrastructure/integrations/gemini-extensions/policy-sync.js +74 -0
  672. package/.grimoire/infrastructure/integrations/gemini-extensions/security-adapter.js +159 -0
  673. package/.grimoire/infrastructure/integrations/gemini-extensions/supabase-adapter.js +88 -0
  674. package/.grimoire/infrastructure/integrations/gemini-extensions/workspace-adapter.js +100 -0
  675. package/.grimoire/infrastructure/integrations/pm-adapters/README.md +60 -0
  676. package/.grimoire/infrastructure/integrations/pm-adapters/clickup-adapter.js +345 -0
  677. package/.grimoire/infrastructure/integrations/pm-adapters/github-adapter.js +393 -0
  678. package/.grimoire/infrastructure/integrations/pm-adapters/jira-adapter.js +449 -0
  679. package/.grimoire/infrastructure/integrations/pm-adapters/local-adapter.js +176 -0
  680. package/.grimoire/infrastructure/schemas/agent-v3-schema.json +160 -0
  681. package/.grimoire/infrastructure/schemas/build-state.schema.json +158 -0
  682. package/.grimoire/infrastructure/schemas/task-v3-schema.json +152 -0
  683. package/.grimoire/infrastructure/scripts/approach-manager.js +1005 -0
  684. package/.grimoire/infrastructure/scripts/approval-workflow.js +644 -0
  685. package/.grimoire/infrastructure/scripts/asset-inventory.js +622 -0
  686. package/.grimoire/infrastructure/scripts/atomic-layer-classifier.js +309 -0
  687. package/.grimoire/infrastructure/scripts/backup-manager.js +607 -0
  688. package/.grimoire/infrastructure/scripts/batch-creator.js +609 -0
  689. package/.grimoire/infrastructure/scripts/branch-manager.js +391 -0
  690. package/.grimoire/infrastructure/scripts/capability-analyzer.js +535 -0
  691. package/.grimoire/infrastructure/scripts/changelog-generator.js +554 -0
  692. package/.grimoire/infrastructure/scripts/cicd-discovery.js +1269 -0
  693. package/.grimoire/infrastructure/scripts/clickup-helpers.js +227 -0
  694. package/.grimoire/infrastructure/scripts/code-quality-improver.js +1312 -0
  695. package/.grimoire/infrastructure/scripts/codebase-mapper.js +1288 -0
  696. package/.grimoire/infrastructure/scripts/codex-skills-sync/index.js +184 -0
  697. package/.grimoire/infrastructure/scripts/codex-skills-sync/validate.js +174 -0
  698. package/.grimoire/infrastructure/scripts/commit-message-generator.js +850 -0
  699. package/.grimoire/infrastructure/scripts/component-generator.js +738 -0
  700. package/.grimoire/infrastructure/scripts/component-metadata.js +628 -0
  701. package/.grimoire/infrastructure/scripts/component-search.js +278 -0
  702. package/.grimoire/infrastructure/scripts/config-cache.js +322 -0
  703. package/.grimoire/infrastructure/scripts/config-loader.js +351 -0
  704. package/.grimoire/infrastructure/scripts/conflict-resolver.js +675 -0
  705. package/.grimoire/infrastructure/scripts/coverage-analyzer.js +882 -0
  706. package/.grimoire/infrastructure/scripts/dashboard-status-writer.js +310 -0
  707. package/.grimoire/infrastructure/scripts/dependency-analyzer.js +639 -0
  708. package/.grimoire/infrastructure/scripts/dependency-impact-analyzer.js +704 -0
  709. package/.grimoire/infrastructure/scripts/diff-generator.js +129 -0
  710. package/.grimoire/infrastructure/scripts/documentation-integrity/brownfield-analyzer.js +502 -0
  711. package/.grimoire/infrastructure/scripts/documentation-integrity/config-generator.js +369 -0
  712. package/.grimoire/infrastructure/scripts/documentation-integrity/deployment-config-loader.js +309 -0
  713. package/.grimoire/infrastructure/scripts/documentation-integrity/doc-generator.js +331 -0
  714. package/.grimoire/infrastructure/scripts/documentation-integrity/gitignore-generator.js +314 -0
  715. package/.grimoire/infrastructure/scripts/documentation-integrity/index.js +75 -0
  716. package/.grimoire/infrastructure/scripts/documentation-integrity/mode-detector.js +391 -0
  717. package/.grimoire/infrastructure/scripts/documentation-synchronizer.js +1432 -0
  718. package/.grimoire/infrastructure/scripts/framework-analyzer.js +763 -0
  719. package/.grimoire/infrastructure/scripts/git-config-detector.js +293 -0
  720. package/.grimoire/infrastructure/scripts/git-hooks/post-commit.js +75 -0
  721. package/.grimoire/infrastructure/scripts/git-wrapper.js +444 -0
  722. package/.grimoire/infrastructure/scripts/gotchas-documenter.js +1296 -0
  723. package/.grimoire/infrastructure/scripts/grimoire-validator.js +295 -0
  724. package/.grimoire/infrastructure/scripts/ide-sync/README.md +220 -0
  725. package/.grimoire/infrastructure/scripts/ide-sync/agent-parser.js +295 -0
  726. package/.grimoire/infrastructure/scripts/ide-sync/gemini-commands.js +207 -0
  727. package/.grimoire/infrastructure/scripts/ide-sync/index.js +540 -0
  728. package/.grimoire/infrastructure/scripts/ide-sync/redirect-generator.js +179 -0
  729. package/.grimoire/infrastructure/scripts/ide-sync/transformers/antigravity.js +107 -0
  730. package/.grimoire/infrastructure/scripts/ide-sync/transformers/claude-code.js +86 -0
  731. package/.grimoire/infrastructure/scripts/ide-sync/transformers/cursor.js +96 -0
  732. package/.grimoire/infrastructure/scripts/ide-sync/validator.js +273 -0
  733. package/.grimoire/infrastructure/scripts/improvement-engine.js +758 -0
  734. package/.grimoire/infrastructure/scripts/improvement-validator.js +710 -0
  735. package/.grimoire/infrastructure/scripts/llm-routing/install-llm-routing.js +282 -0
  736. package/.grimoire/infrastructure/scripts/llm-routing/templates/claude-free-tracked.cmd +129 -0
  737. package/.grimoire/infrastructure/scripts/llm-routing/templates/claude-free-tracked.sh +108 -0
  738. package/.grimoire/infrastructure/scripts/llm-routing/templates/claude-free.cmd +80 -0
  739. package/.grimoire/infrastructure/scripts/llm-routing/templates/claude-free.sh +62 -0
  740. package/.grimoire/infrastructure/scripts/llm-routing/templates/claude-max.cmd +26 -0
  741. package/.grimoire/infrastructure/scripts/llm-routing/templates/claude-max.sh +18 -0
  742. package/.grimoire/infrastructure/scripts/llm-routing/templates/deepseek-proxy.cmd +73 -0
  743. package/.grimoire/infrastructure/scripts/llm-routing/templates/deepseek-proxy.sh +65 -0
  744. package/.grimoire/infrastructure/scripts/llm-routing/templates/deepseek-usage.cmd +53 -0
  745. package/.grimoire/infrastructure/scripts/llm-routing/templates/deepseek-usage.sh +16 -0
  746. package/.grimoire/infrastructure/scripts/llm-routing/usage-tracker/index.js +551 -0
  747. package/.grimoire/infrastructure/scripts/migrate-agent.js +528 -0
  748. package/.grimoire/infrastructure/scripts/modification-risk-assessment.js +970 -0
  749. package/.grimoire/infrastructure/scripts/modification-validator.js +555 -0
  750. package/.grimoire/infrastructure/scripts/output-formatter.js +298 -0
  751. package/.grimoire/infrastructure/scripts/path-analyzer.js +476 -0
  752. package/.grimoire/infrastructure/scripts/pattern-extractor.js +1563 -0
  753. package/.grimoire/infrastructure/scripts/performance-analyzer.js +758 -0
  754. package/.grimoire/infrastructure/scripts/performance-and-error-resolver.js +258 -0
  755. package/.grimoire/infrastructure/scripts/performance-optimizer.js +1902 -0
  756. package/.grimoire/infrastructure/scripts/performance-tracker.js +454 -0
  757. package/.grimoire/infrastructure/scripts/plan-tracker.js +922 -0
  758. package/.grimoire/infrastructure/scripts/pm-adapter-factory.js +182 -0
  759. package/.grimoire/infrastructure/scripts/pm-adapter.js +134 -0
  760. package/.grimoire/infrastructure/scripts/pr-review-ai.js +1062 -0
  761. package/.grimoire/infrastructure/scripts/project-status-loader.js +850 -0
  762. package/.grimoire/infrastructure/scripts/qa-loop-orchestrator.js +1264 -0
  763. package/.grimoire/infrastructure/scripts/qa-report-generator.js +1154 -0
  764. package/.grimoire/infrastructure/scripts/recovery-tracker.js +965 -0
  765. package/.grimoire/infrastructure/scripts/refactoring-suggester.js +1139 -0
  766. package/.grimoire/infrastructure/scripts/repository-detector.js +66 -0
  767. package/.grimoire/infrastructure/scripts/rollback-manager.js +734 -0
  768. package/.grimoire/infrastructure/scripts/sandbox-tester.js +618 -0
  769. package/.grimoire/infrastructure/scripts/security-checker.js +359 -0
  770. package/.grimoire/infrastructure/scripts/spot-check-validator.js +149 -0
  771. package/.grimoire/infrastructure/scripts/status-mapper.js +116 -0
  772. package/.grimoire/infrastructure/scripts/story-worktree-hooks.js +426 -0
  773. package/.grimoire/infrastructure/scripts/stuck-detector.js +1251 -0
  774. package/.grimoire/infrastructure/scripts/subtask-verifier.js +793 -0
  775. package/.grimoire/infrastructure/scripts/template-engine.js +240 -0
  776. package/.grimoire/infrastructure/scripts/template-validator.js +279 -0
  777. package/.grimoire/infrastructure/scripts/test-discovery.js +1259 -0
  778. package/.grimoire/infrastructure/scripts/test-generator.js +845 -0
  779. package/.grimoire/infrastructure/scripts/test-quality-assessment.js +1082 -0
  780. package/.grimoire/infrastructure/scripts/test-utilities-fast.js +126 -0
  781. package/.grimoire/infrastructure/scripts/test-utilities.js +201 -0
  782. package/.grimoire/infrastructure/scripts/tool-resolver.js +362 -0
  783. package/.grimoire/infrastructure/scripts/transaction-manager.js +590 -0
  784. package/.grimoire/infrastructure/scripts/usage-analytics.js +636 -0
  785. package/.grimoire/infrastructure/scripts/validate-agents.js +527 -0
  786. package/.grimoire/infrastructure/scripts/validate-claude-integration.js +103 -0
  787. package/.grimoire/infrastructure/scripts/validate-codex-integration.js +143 -0
  788. package/.grimoire/infrastructure/scripts/validate-gemini-integration.js +153 -0
  789. package/.grimoire/infrastructure/scripts/validate-output-pattern.js +213 -0
  790. package/.grimoire/infrastructure/scripts/validate-parity.js +357 -0
  791. package/.grimoire/infrastructure/scripts/validate-paths.js +144 -0
  792. package/.grimoire/infrastructure/scripts/validate-user-profile.js +251 -0
  793. package/.grimoire/infrastructure/scripts/visual-impact-generator.js +1056 -0
  794. package/.grimoire/infrastructure/scripts/worktree-manager.js +704 -0
  795. package/.grimoire/infrastructure/scripts/yaml-validator.js +397 -0
  796. package/.grimoire/infrastructure/templates/coderabbit.yaml.template +280 -0
  797. package/.grimoire/infrastructure/templates/core-config/core-config-brownfield.tmpl.yaml +177 -0
  798. package/.grimoire/infrastructure/templates/core-config/core-config-greenfield.tmpl.yaml +169 -0
  799. package/.grimoire/infrastructure/templates/github-workflows/README.md +110 -0
  800. package/.grimoire/infrastructure/templates/github-workflows/ci.yml.template +170 -0
  801. package/.grimoire/infrastructure/templates/github-workflows/pr-automation.yml.template +331 -0
  802. package/.grimoire/infrastructure/templates/github-workflows/release.yml.template +197 -0
  803. package/.grimoire/infrastructure/templates/gitignore/gitignore-brownfield-merge.tmpl +20 -0
  804. package/.grimoire/infrastructure/templates/gitignore/gitignore-grimoire-base.tmpl +65 -0
  805. package/.grimoire/infrastructure/templates/gitignore/gitignore-node.tmpl +86 -0
  806. package/.grimoire/infrastructure/templates/gitignore/gitignore-python.tmpl +146 -0
  807. package/.grimoire/infrastructure/templates/grimoire-sync.yaml.template +183 -0
  808. package/.grimoire/infrastructure/templates/project-docs/coding-standards-tmpl.md +347 -0
  809. package/.grimoire/infrastructure/templates/project-docs/source-tree-tmpl.md +179 -0
  810. package/.grimoire/infrastructure/templates/project-docs/tech-stack-tmpl.md +269 -0
  811. package/.grimoire/infrastructure/tests/project-status-loader.test.js +569 -0
  812. package/.grimoire/infrastructure/tests/regression-suite-v2.md +622 -0
  813. package/.grimoire/infrastructure/tests/validate-module.js +98 -0
  814. package/.grimoire/infrastructure/tests/worktree-manager.test.js +620 -0
  815. package/.grimoire/infrastructure/tools/README.md +224 -0
  816. package/.grimoire/infrastructure/tools/cli/github-cli.yaml +200 -0
  817. package/.grimoire/infrastructure/tools/cli/llm-routing.yaml +128 -0
  818. package/.grimoire/infrastructure/tools/cli/railway-cli.yaml +260 -0
  819. package/.grimoire/infrastructure/tools/cli/supabase-cli.yaml +224 -0
  820. package/.grimoire/infrastructure/tools/local/ffmpeg.yaml +261 -0
  821. package/.grimoire/infrastructure/tools/mcp/21st-dev-magic.yaml +127 -0
  822. package/.grimoire/infrastructure/tools/mcp/browser.yaml +103 -0
  823. package/.grimoire/infrastructure/tools/mcp/clickup.yaml +535 -0
  824. package/.grimoire/infrastructure/tools/mcp/context7.yaml +78 -0
  825. package/.grimoire/infrastructure/tools/mcp/desktop-commander.yaml +180 -0
  826. package/.grimoire/infrastructure/tools/mcp/exa.yaml +103 -0
  827. package/.grimoire/infrastructure/tools/mcp/google-workspace.yaml +930 -0
  828. package/.grimoire/infrastructure/tools/mcp/n8n.yaml +551 -0
  829. package/.grimoire/infrastructure/tools/mcp/supabase.yaml +808 -0
  830. package/.grimoire/install-manifest.yaml +4058 -0
  831. package/.grimoire/local-config.yaml.template +73 -0
  832. package/.grimoire/manifests/schema/manifest-schema.json +191 -0
  833. package/.grimoire/monitor/hooks/lib/__init__.py +2 -0
  834. package/.grimoire/monitor/hooks/lib/enrich.py +59 -0
  835. package/.grimoire/monitor/hooks/lib/send_event.py +48 -0
  836. package/.grimoire/monitor/hooks/notification.py +30 -0
  837. package/.grimoire/monitor/hooks/post_tool_use.py +46 -0
  838. package/.grimoire/monitor/hooks/pre_compact.py +30 -0
  839. package/.grimoire/monitor/hooks/pre_tool_use.py +41 -0
  840. package/.grimoire/monitor/hooks/stop.py +30 -0
  841. package/.grimoire/monitor/hooks/subagent_stop.py +30 -0
  842. package/.grimoire/monitor/hooks/user_prompt_submit.py +39 -0
  843. package/.grimoire/package.json +104 -0
  844. package/.grimoire/presets/README.md +359 -0
  845. package/.grimoire/product/README.md +57 -0
  846. package/.grimoire/product/checklists/accessibility-wcag-checklist.md +80 -0
  847. package/.grimoire/product/checklists/architect-checklist.md +444 -0
  848. package/.grimoire/product/checklists/change-checklist.md +183 -0
  849. package/.grimoire/product/checklists/component-quality-checklist.md +74 -0
  850. package/.grimoire/product/checklists/database-design-checklist.md +119 -0
  851. package/.grimoire/product/checklists/dba-predeploy-checklist.md +97 -0
  852. package/.grimoire/product/checklists/dba-rollback-checklist.md +99 -0
  853. package/.grimoire/product/checklists/migration-readiness-checklist.md +75 -0
  854. package/.grimoire/product/checklists/pattern-audit-checklist.md +88 -0
  855. package/.grimoire/product/checklists/pm-checklist.md +376 -0
  856. package/.grimoire/product/checklists/po-master-checklist.md +442 -0
  857. package/.grimoire/product/checklists/pre-push-checklist.md +108 -0
  858. package/.grimoire/product/checklists/release-checklist.md +122 -0
  859. package/.grimoire/product/checklists/self-critique-checklist.md +387 -0
  860. package/.grimoire/product/checklists/story-dod-checklist.md +102 -0
  861. package/.grimoire/product/checklists/story-draft-checklist.md +216 -0
  862. package/.grimoire/product/data/atomic-design-principles.md +108 -0
  863. package/.grimoire/product/data/brainstorming-techniques.md +37 -0
  864. package/.grimoire/product/data/consolidation-algorithms.md +142 -0
  865. package/.grimoire/product/data/database-best-practices.md +182 -0
  866. package/.grimoire/product/data/design-token-best-practices.md +107 -0
  867. package/.grimoire/product/data/elicitation-methods.md +135 -0
  868. package/.grimoire/product/data/integration-patterns.md +207 -0
  869. package/.grimoire/product/data/migration-safety-guide.md +329 -0
  870. package/.grimoire/product/data/mode-selection-best-practices.md +471 -0
  871. package/.grimoire/product/data/postgres-tuning-guide.md +300 -0
  872. package/.grimoire/product/data/rls-security-patterns.md +333 -0
  873. package/.grimoire/product/data/roi-calculation-guide.md +142 -0
  874. package/.grimoire/product/data/supabase-patterns.md +330 -0
  875. package/.grimoire/product/data/test-levels-framework.md +149 -0
  876. package/.grimoire/product/data/test-priorities-matrix.md +175 -0
  877. package/.grimoire/product/data/wcag-compliance-guide.md +267 -0
  878. package/.grimoire/product/templates/activation-instructions-inline-greeting.yaml +64 -0
  879. package/.grimoire/product/templates/activation-instructions-template.md +260 -0
  880. package/.grimoire/product/templates/adr.hbs +126 -0
  881. package/.grimoire/product/templates/agent-template.yaml +122 -0
  882. package/.grimoire/product/templates/architecture-tmpl.yaml +651 -0
  883. package/.grimoire/product/templates/brainstorming-output-tmpl.yaml +156 -0
  884. package/.grimoire/product/templates/brownfield-architecture-tmpl.yaml +476 -0
  885. package/.grimoire/product/templates/brownfield-prd-tmpl.yaml +280 -0
  886. package/.grimoire/product/templates/brownfield-risk-report-tmpl.yaml +278 -0
  887. package/.grimoire/product/templates/changelog-template.md +134 -0
  888. package/.grimoire/product/templates/command-rationalization-matrix.md +154 -0
  889. package/.grimoire/product/templates/competitor-analysis-tmpl.yaml +293 -0
  890. package/.grimoire/product/templates/component-react-tmpl.tsx +98 -0
  891. package/.grimoire/product/templates/current-approach-tmpl.md +56 -0
  892. package/.grimoire/product/templates/dbdr.hbs +242 -0
  893. package/.grimoire/product/templates/design-story-tmpl.yaml +588 -0
  894. package/.grimoire/product/templates/ds-artifact-analysis.md +70 -0
  895. package/.grimoire/product/templates/engine/elicitation.js +298 -0
  896. package/.grimoire/product/templates/engine/index.js +310 -0
  897. package/.grimoire/product/templates/engine/loader.js +232 -0
  898. package/.grimoire/product/templates/engine/renderer.js +343 -0
  899. package/.grimoire/product/templates/engine/schemas/adr.schema.json +102 -0
  900. package/.grimoire/product/templates/engine/schemas/dbdr.schema.json +205 -0
  901. package/.grimoire/product/templates/engine/schemas/epic.schema.json +175 -0
  902. package/.grimoire/product/templates/engine/schemas/pmdr.schema.json +175 -0
  903. package/.grimoire/product/templates/engine/schemas/prd-v2.schema.json +300 -0
  904. package/.grimoire/product/templates/engine/schemas/prd.schema.json +152 -0
  905. package/.grimoire/product/templates/engine/schemas/story.schema.json +222 -0
  906. package/.grimoire/product/templates/engine/schemas/task.schema.json +154 -0
  907. package/.grimoire/product/templates/engine/validator.js +295 -0
  908. package/.grimoire/product/templates/epic.hbs +213 -0
  909. package/.grimoire/product/templates/eslintrc-security.json +32 -0
  910. package/.grimoire/product/templates/front-end-architecture-tmpl.yaml +206 -0
  911. package/.grimoire/product/templates/front-end-spec-tmpl.yaml +349 -0
  912. package/.grimoire/product/templates/fullstack-architecture-tmpl.yaml +805 -0
  913. package/.grimoire/product/templates/gemini/settings.json +81 -0
  914. package/.grimoire/product/templates/github-actions-cd.yml +213 -0
  915. package/.grimoire/product/templates/github-actions-ci.yml +173 -0
  916. package/.grimoire/product/templates/github-pr-template.md +68 -0
  917. package/.grimoire/product/templates/gordon-mcp.yaml +141 -0
  918. package/.grimoire/product/templates/grimoire-ai-config.yaml +107 -0
  919. package/.grimoire/product/templates/ide-rules/antigravity-rules.md +117 -0
  920. package/.grimoire/product/templates/ide-rules/claude-rules.md +233 -0
  921. package/.grimoire/product/templates/ide-rules/codex-rules.md +67 -0
  922. package/.grimoire/product/templates/ide-rules/copilot-rules.md +94 -0
  923. package/.grimoire/product/templates/ide-rules/cursor-rules.md +116 -0
  924. package/.grimoire/product/templates/ide-rules/gemini-rules.md +89 -0
  925. package/.grimoire/product/templates/index-strategy-tmpl.yaml +53 -0
  926. package/.grimoire/product/templates/market-research-tmpl.yaml +252 -0
  927. package/.grimoire/product/templates/mcp-workflow.js +273 -0
  928. package/.grimoire/product/templates/migration-plan-tmpl.yaml +1022 -0
  929. package/.grimoire/product/templates/migration-strategy-tmpl.md +524 -0
  930. package/.grimoire/product/templates/personalized-agent-template.md +260 -0
  931. package/.grimoire/product/templates/personalized-checklist-template.md +341 -0
  932. package/.grimoire/product/templates/personalized-task-template-v2.md +907 -0
  933. package/.grimoire/product/templates/personalized-task-template.md +345 -0
  934. package/.grimoire/product/templates/personalized-template-file.yaml +323 -0
  935. package/.grimoire/product/templates/personalized-workflow-template.yaml +461 -0
  936. package/.grimoire/product/templates/pmdr.hbs +187 -0
  937. package/.grimoire/product/templates/prd-tmpl.yaml +202 -0
  938. package/.grimoire/product/templates/prd-v2.0.hbs +217 -0
  939. package/.grimoire/product/templates/prd.hbs +202 -0
  940. package/.grimoire/product/templates/project-brief-tmpl.yaml +221 -0
  941. package/.grimoire/product/templates/qa-gate-tmpl.yaml +240 -0
  942. package/.grimoire/product/templates/qa-report-tmpl.md +235 -0
  943. package/.grimoire/product/templates/rls-policies-tmpl.yaml +1203 -0
  944. package/.grimoire/product/templates/schema-design-tmpl.yaml +428 -0
  945. package/.grimoire/product/templates/shock-report-tmpl.html +502 -0
  946. package/.grimoire/product/templates/spec-tmpl.md +235 -0
  947. package/.grimoire/product/templates/state-persistence-tmpl.yaml +219 -0
  948. package/.grimoire/product/templates/statusline/statusline-script.js +190 -0
  949. package/.grimoire/product/templates/statusline/track-agent.sh +70 -0
  950. package/.grimoire/product/templates/story-tmpl.yaml +369 -0
  951. package/.grimoire/product/templates/story.hbs +264 -0
  952. package/.grimoire/product/templates/task-execution-report.md +496 -0
  953. package/.grimoire/product/templates/task-template.md +123 -0
  954. package/.grimoire/product/templates/task.hbs +171 -0
  955. package/.grimoire/product/templates/tmpl-comment-on-examples.sql +158 -0
  956. package/.grimoire/product/templates/tmpl-migration-script.sql +91 -0
  957. package/.grimoire/product/templates/tmpl-rls-granular-policies.sql +104 -0
  958. package/.grimoire/product/templates/tmpl-rls-kiss-policy.sql +10 -0
  959. package/.grimoire/product/templates/tmpl-rls-roles.sql +135 -0
  960. package/.grimoire/product/templates/tmpl-rls-simple.sql +77 -0
  961. package/.grimoire/product/templates/tmpl-rls-tenant.sql +152 -0
  962. package/.grimoire/product/templates/tmpl-rollback-script.sql +77 -0
  963. package/.grimoire/product/templates/tmpl-seed-data.sql +140 -0
  964. package/.grimoire/product/templates/tmpl-smoke-test.sql +16 -0
  965. package/.grimoire/product/templates/tmpl-staging-copy-merge.sql +139 -0
  966. package/.grimoire/product/templates/tmpl-stored-proc.sql +140 -0
  967. package/.grimoire/product/templates/tmpl-trigger.sql +152 -0
  968. package/.grimoire/product/templates/tmpl-view-materialized.sql +133 -0
  969. package/.grimoire/product/templates/tmpl-view.sql +177 -0
  970. package/.grimoire/product/templates/token-exports-css-tmpl.css +240 -0
  971. package/.grimoire/product/templates/token-exports-tailwind-tmpl.js +395 -0
  972. package/.grimoire/product/templates/tokens-schema-tmpl.yaml +305 -0
  973. package/.grimoire/product/templates/workflow-template.yaml +152 -0
  974. package/.grimoire/project-config.yaml +166 -0
  975. package/.grimoire/quality/metrics-collector.js +601 -0
  976. package/.grimoire/quality/metrics-hook.js +261 -0
  977. package/.grimoire/quality/schemas/quality-metrics.schema.json +234 -0
  978. package/.grimoire/quality/seed-metrics.js +336 -0
  979. package/.grimoire/schemas/README.md +405 -0
  980. package/.grimoire/schemas/agent-v3-schema.json +395 -0
  981. package/.grimoire/schemas/squad-design-schema.json +300 -0
  982. package/.grimoire/schemas/squad-schema.json +187 -0
  983. package/.grimoire/schemas/task-v3-schema.json +354 -0
  984. package/.grimoire/schemas/validate-v3-schema.js +431 -0
  985. package/.grimoire/scripts/README.md +124 -0
  986. package/.grimoire/scripts/batch-migrate-phase1.ps1 +37 -0
  987. package/.grimoire/scripts/batch-migrate-phase2.ps1 +89 -0
  988. package/.grimoire/scripts/batch-migrate-phase3.ps1 +46 -0
  989. package/.grimoire/scripts/command-execution-hook.js +202 -0
  990. package/.grimoire/scripts/diagnostics/diagnose-installation.js +276 -0
  991. package/.grimoire/scripts/diagnostics/diagnose-npx-issue.ps1 +98 -0
  992. package/.grimoire/scripts/diagnostics/health-dashboard/README.md +123 -0
  993. package/.grimoire/scripts/diagnostics/health-dashboard/index.html +14 -0
  994. package/.grimoire/scripts/diagnostics/health-dashboard/package-lock.json +5262 -0
  995. package/.grimoire/scripts/diagnostics/health-dashboard/package.json +25 -0
  996. package/.grimoire/scripts/diagnostics/health-dashboard/public/favicon.svg +10 -0
  997. package/.grimoire/scripts/diagnostics/health-dashboard/src/App.jsx +22 -0
  998. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/AutoFixLog.css +122 -0
  999. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/AutoFixLog.jsx +72 -0
  1000. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/DomainCard.css +121 -0
  1001. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/DomainCard.jsx +116 -0
  1002. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/HealthScore.css +80 -0
  1003. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/HealthScore.jsx +81 -0
  1004. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/IssuesList.css +184 -0
  1005. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/IssuesList.jsx +145 -0
  1006. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/TechDebtList.css +114 -0
  1007. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/TechDebtList.jsx +72 -0
  1008. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/index.js +9 -0
  1009. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/shared/Card.css +44 -0
  1010. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/shared/Card.jsx +25 -0
  1011. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/shared/Chart.css +14 -0
  1012. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/shared/Chart.jsx +138 -0
  1013. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/shared/Header.css +54 -0
  1014. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/shared/Header.jsx +22 -0
  1015. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/shared/StatusBadge.css +77 -0
  1016. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/shared/StatusBadge.jsx +45 -0
  1017. package/.grimoire/scripts/diagnostics/health-dashboard/src/components/shared/index.js +4 -0
  1018. package/.grimoire/scripts/diagnostics/health-dashboard/src/hooks/index.js +2 -0
  1019. package/.grimoire/scripts/diagnostics/health-dashboard/src/hooks/useAutoRefresh.js +89 -0
  1020. package/.grimoire/scripts/diagnostics/health-dashboard/src/hooks/useHealthData.js +308 -0
  1021. package/.grimoire/scripts/diagnostics/health-dashboard/src/main.jsx +13 -0
  1022. package/.grimoire/scripts/diagnostics/health-dashboard/src/pages/Dashboard.css +238 -0
  1023. package/.grimoire/scripts/diagnostics/health-dashboard/src/pages/Dashboard.jsx +154 -0
  1024. package/.grimoire/scripts/diagnostics/health-dashboard/src/pages/DomainDetail.css +259 -0
  1025. package/.grimoire/scripts/diagnostics/health-dashboard/src/pages/DomainDetail.jsx +164 -0
  1026. package/.grimoire/scripts/diagnostics/health-dashboard/src/pages/index.js +2 -0
  1027. package/.grimoire/scripts/diagnostics/health-dashboard/src/styles/App.css +19 -0
  1028. package/.grimoire/scripts/diagnostics/health-dashboard/src/styles/index.css +67 -0
  1029. package/.grimoire/scripts/diagnostics/health-dashboard/vite.config.js +23 -0
  1030. package/.grimoire/scripts/diagnostics/quick-diagnose.cmd +86 -0
  1031. package/.grimoire/scripts/diagnostics/quick-diagnose.ps1 +118 -0
  1032. package/.grimoire/scripts/grimoire-doc-template.md +326 -0
  1033. package/.grimoire/scripts/migrate-framework-docs.sh +302 -0
  1034. package/.grimoire/scripts/pm.sh +455 -0
  1035. package/.grimoire/scripts/session-context-loader.js +46 -0
  1036. package/.grimoire/scripts/test-template-system.js +942 -0
  1037. package/.grimoire/scripts/update-grimoire.sh +176 -0
  1038. package/.grimoire/scripts/validate-phase1.ps1 +36 -0
  1039. package/.grimoire/scripts/workflow-management.md +70 -0
  1040. package/.grimoire/user-guide.md +1411 -0
  1041. package/.grimoire/utils/format-duration.js +95 -0
  1042. package/.grimoire/utils/grimoire-validator.js +27 -0
  1043. package/.grimoire/workflow-intelligence/__tests__/confidence-scorer.test.js +334 -0
  1044. package/.grimoire/workflow-intelligence/__tests__/integration.test.js +339 -0
  1045. package/.grimoire/workflow-intelligence/__tests__/suggestion-engine.test.js +437 -0
  1046. package/.grimoire/workflow-intelligence/__tests__/wave-analyzer.test.js +447 -0
  1047. package/.grimoire/workflow-intelligence/__tests__/workflow-registry.test.js +302 -0
  1048. package/.grimoire/workflow-intelligence/engine/confidence-scorer.js +306 -0
  1049. package/.grimoire/workflow-intelligence/engine/output-formatter.js +299 -0
  1050. package/.grimoire/workflow-intelligence/engine/suggestion-engine.js +798 -0
  1051. package/.grimoire/workflow-intelligence/engine/wave-analyzer.js +683 -0
  1052. package/.grimoire/workflow-intelligence/index.js +330 -0
  1053. package/.grimoire/workflow-intelligence/learning/capture-hook.js +148 -0
  1054. package/.grimoire/workflow-intelligence/learning/gotcha-registry.js +654 -0
  1055. package/.grimoire/workflow-intelligence/learning/index.js +306 -0
  1056. package/.grimoire/workflow-intelligence/learning/pattern-capture.js +330 -0
  1057. package/.grimoire/workflow-intelligence/learning/pattern-store.js +497 -0
  1058. package/.grimoire/workflow-intelligence/learning/pattern-validator.js +310 -0
  1059. package/.grimoire/workflow-intelligence/learning/qa-feedback.js +586 -0
  1060. package/.grimoire/workflow-intelligence/learning/semantic-search.js +521 -0
  1061. package/.grimoire/workflow-intelligence/registry/workflow-registry.js +357 -0
  1062. package/.grimoire/working-in-the-brownfield.md +362 -0
  1063. package/LICENSE +25 -0
  1064. package/README.md +59 -0
  1065. package/bin/grimoire-ids.js +560 -0
  1066. package/bin/grimoire-init.js +1232 -0
  1067. package/bin/grimoire-minimal.js +40 -0
  1068. package/bin/grimoire.js +1118 -0
  1069. package/bin/modules/env-config.js +436 -0
  1070. package/bin/modules/mcp-installer.js +384 -0
  1071. package/bin/utils/install-errors.js +340 -0
  1072. package/bin/utils/install-transaction.js +447 -0
  1073. package/bin/utils/pro-detector.js +110 -0
  1074. package/package.json +158 -0
  1075. package/packages/gemini-grimoire-extension/README.md +55 -0
  1076. package/packages/gemini-grimoire-extension/commands/grimoire-agent.js +7 -0
  1077. package/packages/gemini-grimoire-extension/commands/grimoire-agents.js +51 -0
  1078. package/packages/gemini-grimoire-extension/commands/grimoire-analyst.js +6 -0
  1079. package/packages/gemini-grimoire-extension/commands/grimoire-architect.js +6 -0
  1080. package/packages/gemini-grimoire-extension/commands/grimoire-data-engineer.js +6 -0
  1081. package/packages/gemini-grimoire-extension/commands/grimoire-dev.js +6 -0
  1082. package/packages/gemini-grimoire-extension/commands/grimoire-devops.js +6 -0
  1083. package/packages/gemini-grimoire-extension/commands/grimoire-master.js +7 -0
  1084. package/packages/gemini-grimoire-extension/commands/grimoire-menu.js +6 -0
  1085. package/packages/gemini-grimoire-extension/commands/grimoire-pm.js +6 -0
  1086. package/packages/gemini-grimoire-extension/commands/grimoire-po.js +6 -0
  1087. package/packages/gemini-grimoire-extension/commands/grimoire-qa.js +6 -0
  1088. package/packages/gemini-grimoire-extension/commands/grimoire-sm.js +6 -0
  1089. package/packages/gemini-grimoire-extension/commands/grimoire-squad-creator.js +6 -0
  1090. package/packages/gemini-grimoire-extension/commands/grimoire-status.js +68 -0
  1091. package/packages/gemini-grimoire-extension/commands/grimoire-ux-design-expert.js +6 -0
  1092. package/packages/gemini-grimoire-extension/commands/grimoire-validate.js +35 -0
  1093. package/packages/gemini-grimoire-extension/commands/lib/agent-launcher.js +147 -0
  1094. package/packages/gemini-grimoire-extension/extension.json +149 -0
  1095. package/packages/gemini-grimoire-extension/gemini-extension.json +149 -0
  1096. package/packages/gemini-grimoire-extension/hooks/hooks.json +72 -0
  1097. package/packages/grimoire-install/.releaserc.json +39 -0
  1098. package/packages/grimoire-install/CHANGELOG.md +33 -0
  1099. package/packages/grimoire-install/README.md +119 -0
  1100. package/packages/grimoire-install/bin/edmcp.js +80 -0
  1101. package/packages/grimoire-install/bin/grimoire-install.js +51 -0
  1102. package/packages/grimoire-install/jest.config.js +27 -0
  1103. package/packages/grimoire-install/package.json +68 -0
  1104. package/packages/grimoire-install/src/dep-checker.js +306 -0
  1105. package/packages/grimoire-install/src/edmcp/index.js +382 -0
  1106. package/packages/grimoire-install/src/installer.js +487 -0
  1107. package/packages/grimoire-install/src/os-detector.js +280 -0
  1108. package/packages/grimoire-pro-cli/bin/grimoire-pro.js +233 -0
  1109. package/packages/grimoire-pro-cli/package.json +38 -0
  1110. package/packages/grimoire-pro-cli/src/recover.js +101 -0
  1111. package/packages/installer/package.json +40 -0
  1112. package/packages/installer/src/__tests__/performance-benchmark.js +384 -0
  1113. package/packages/installer/src/config/configure-environment.js +373 -0
  1114. package/packages/installer/src/config/ide-configs.js +161 -0
  1115. package/packages/installer/src/config/templates/core-config-template.js +199 -0
  1116. package/packages/installer/src/config/templates/env-template.js +272 -0
  1117. package/packages/installer/src/config/validation/config-validator.js +244 -0
  1118. package/packages/installer/src/detection/detect-project-type.js +83 -0
  1119. package/packages/installer/src/installer/brownfield-upgrader.js +440 -0
  1120. package/packages/installer/src/installer/dependency-installer.js +335 -0
  1121. package/packages/installer/src/installer/file-hasher.js +234 -0
  1122. package/packages/installer/src/installer/grimoire-core-installer.js +428 -0
  1123. package/packages/installer/src/installer/manifest-signature.js +380 -0
  1124. package/packages/installer/src/installer/post-install-validator.js +1524 -0
  1125. package/packages/installer/src/merger/index.js +72 -0
  1126. package/packages/installer/src/merger/parsers/env-parser.js +153 -0
  1127. package/packages/installer/src/merger/parsers/markdown-section-parser.js +199 -0
  1128. package/packages/installer/src/merger/strategies/base-merger.js +61 -0
  1129. package/packages/installer/src/merger/strategies/env-merger.js +138 -0
  1130. package/packages/installer/src/merger/strategies/index.js +105 -0
  1131. package/packages/installer/src/merger/strategies/markdown-merger.js +208 -0
  1132. package/packages/installer/src/merger/strategies/replace-merger.js +68 -0
  1133. package/packages/installer/src/merger/types.js +72 -0
  1134. package/packages/installer/src/pro/pro-scaffolder.js +387 -0
  1135. package/packages/installer/src/updater/index.js +814 -0
  1136. package/packages/installer/src/utils/grimoire-colors.js +235 -0
  1137. package/packages/installer/src/wizard/feedback.js +232 -0
  1138. package/packages/installer/src/wizard/i18n.js +230 -0
  1139. package/packages/installer/src/wizard/ide-config-generator.js +993 -0
  1140. package/packages/installer/src/wizard/ide-selector.js +86 -0
  1141. package/packages/installer/src/wizard/index.js +831 -0
  1142. package/packages/installer/src/wizard/pro-setup.js +1223 -0
  1143. package/packages/installer/src/wizard/questions.js +336 -0
  1144. package/packages/installer/src/wizard/validation/index.js +121 -0
  1145. package/packages/installer/src/wizard/validation/report-generator.js +254 -0
  1146. package/packages/installer/src/wizard/validation/troubleshooting-system.js +348 -0
  1147. package/packages/installer/src/wizard/validation/validators/config-validator.js +364 -0
  1148. package/packages/installer/src/wizard/validation/validators/dependency-validator.js +333 -0
  1149. package/packages/installer/src/wizard/validation/validators/file-structure-validator.js +175 -0
  1150. package/packages/installer/src/wizard/validation/validators/mcp-health-checker.js +310 -0
  1151. package/packages/installer/src/wizard/validators.js +274 -0
  1152. package/packages/installer/src/wizard/wizard.js +246 -0
  1153. package/packages/installer/tests/integration/environment-configuration.test.js +331 -0
  1154. package/packages/installer/tests/integration/wizard-detection.test.js +353 -0
  1155. package/packages/installer/tests/unit/config-validator.test.js +316 -0
  1156. package/packages/installer/tests/unit/detection/detect-project-type.test.js +403 -0
  1157. package/packages/installer/tests/unit/env-template.test.js +189 -0
  1158. package/packages/installer/tests/unit/merger/env-merger.test.js +192 -0
  1159. package/packages/installer/tests/unit/merger/markdown-merger.test.js +262 -0
  1160. package/packages/installer/tests/unit/merger/strategies.test.js +153 -0
  1161. package/scripts/check-markdown-links.py +353 -0
  1162. package/scripts/code-intel-health-check.js +344 -0
  1163. package/scripts/dashboard-parallel-dev.sh +184 -0
  1164. package/scripts/dashboard-parallel-phase3.sh +130 -0
  1165. package/scripts/dashboard-parallel-phase4.sh +131 -0
  1166. package/scripts/ensure-manifest.js +59 -0
  1167. package/scripts/generate-install-manifest.js +368 -0
  1168. package/scripts/install-monitor-hooks.sh +83 -0
  1169. package/scripts/package-synapse.js +325 -0
  1170. package/scripts/semantic-lint.js +191 -0
  1171. package/scripts/sign-manifest.ps1 +132 -0
  1172. package/scripts/sign-manifest.sh +122 -0
  1173. package/scripts/validate-manifest.js +267 -0
  1174. package/scripts/validate-package-completeness.js +319 -0
@@ -0,0 +1,1544 @@
1
+ /**
2
+ * Master Orchestrator - Epic 0: Autonomous Development Engine
3
+ *
4
+ * Story: 0.1 - Master Orchestrator Core
5
+ *
6
+ * Central orchestrator that connects all ADE epics (3→4→5→6) in a unified
7
+ * execution pipeline for truly autonomous development.
8
+ *
9
+ * Features:
10
+ * - AC1: Located in `.grimoire/core/orchestration/`
11
+ * - AC2: constructor(projectRoot, options) with storyId, maxRetries, autoRecovery
12
+ * - AC3: executeFullPipeline() runs Epics 3→4→5→6
13
+ * - AC4: executeEpic(epicNum, options) for individual epic execution
14
+ * - AC5: resumeFromEpic(epicNum) to continue from specific point
15
+ * - AC6: State machine: INITIALIZED, READY, IN_PROGRESS, BLOCKED, COMPLETE
16
+ * - AC7: Integrates with TechStackDetector for pre-flight detection
17
+ *
18
+ * @module core/orchestration/master-orchestrator
19
+ * @version 1.0.0
20
+ * @author @dev (Dex)
21
+ */
22
+
23
+ const fs = require('fs-extra');
24
+ const path = require('path');
25
+ const { EventEmitter } = require('events');
26
+
27
+ // Core dependencies
28
+ const TechStackDetector = require('./tech-stack-detector');
29
+
30
+ // Epic Executors (Story 0.3)
31
+ const { createExecutor, hasExecutor } = require('./executors');
32
+
33
+ // Recovery Handler (Story 0.5)
34
+ const { RecoveryHandler, RecoveryStrategy: _RecoveryStrategy } = require('./recovery-handler');
35
+
36
+ // Gate Evaluator (Story 0.6)
37
+ const { GateEvaluator, GateVerdict } = require('./gate-evaluator');
38
+
39
+ // Agent Invoker (Story 0.7)
40
+ const { AgentInvoker, SUPPORTED_AGENTS: _SUPPORTED_AGENTS } = require('./agent-invoker');
41
+
42
+ // Dashboard Integration (Story 0.8)
43
+ const { DashboardIntegration, NotificationType: _NotificationType } = require('./dashboard-integration');
44
+
45
+ // Optional chalk for colored output
46
+ let chalk;
47
+ try {
48
+ chalk = require('chalk');
49
+ } catch {
50
+ chalk = {
51
+ blue: (s) => s,
52
+ green: (s) => s,
53
+ red: (s) => s,
54
+ yellow: (s) => s,
55
+ cyan: (s) => s,
56
+ gray: (s) => s,
57
+ bold: (s) => s,
58
+ dim: (s) => s,
59
+ magenta: (s) => s,
60
+ };
61
+ }
62
+
63
+ // ═══════════════════════════════════════════════════════════════════════════════════
64
+ // STATE MACHINE (AC6)
65
+ // ═══════════════════════════════════════════════════════════════════════════════════
66
+
67
+ /**
68
+ * Orchestrator state machine states
69
+ * @enum {string}
70
+ */
71
+ const OrchestratorState = {
72
+ /** Initial state after construction */
73
+ INITIALIZED: 'initialized',
74
+ /** Ready to execute after pre-flight checks */
75
+ READY: 'ready',
76
+ /** Currently executing epics */
77
+ IN_PROGRESS: 'in_progress',
78
+ /** Blocked due to error or requiring intervention */
79
+ BLOCKED: 'blocked',
80
+ /** All epics completed successfully */
81
+ COMPLETE: 'complete',
82
+ };
83
+
84
+ /**
85
+ * Epic execution status
86
+ * @enum {string}
87
+ */
88
+ const EpicStatus = {
89
+ PENDING: 'pending',
90
+ IN_PROGRESS: 'in_progress',
91
+ COMPLETED: 'completed',
92
+ FAILED: 'failed',
93
+ SKIPPED: 'skipped',
94
+ };
95
+
96
+ /**
97
+ * Epic configuration - maps epic numbers to their metadata
98
+ */
99
+ const EPIC_CONFIG = {
100
+ 3: {
101
+ name: 'Spec Pipeline',
102
+ description: 'Requirements → Specification generation',
103
+ executor: 'Epic3Executor',
104
+ icon: '📝',
105
+ },
106
+ 4: {
107
+ name: 'Execution Engine',
108
+ description: 'Plan tracking and subtask execution',
109
+ executor: 'Epic4Executor',
110
+ icon: '⚙️',
111
+ },
112
+ 5: {
113
+ name: 'Recovery System',
114
+ description: 'Error detection and recovery',
115
+ executor: 'Epic5Executor',
116
+ icon: '🔄',
117
+ onDemand: true, // Only triggered on errors
118
+ },
119
+ 6: {
120
+ name: 'QA Loop',
121
+ description: 'Quality assurance and validation',
122
+ executor: 'Epic6Executor',
123
+ icon: '🔍',
124
+ },
125
+ };
126
+
127
+ // ═══════════════════════════════════════════════════════════════════════════════════
128
+ // MASTER ORCHESTRATOR CLASS
129
+ // ═══════════════════════════════════════════════════════════════════════════════════
130
+
131
+ /**
132
+ * Master Orchestrator - Coordinates all ADE epics in unified execution
133
+ * @extends EventEmitter
134
+ */
135
+ class MasterOrchestrator extends EventEmitter {
136
+ /**
137
+ * Create a new MasterOrchestrator instance (AC2)
138
+ *
139
+ * @param {string} projectRoot - Project root directory
140
+ * @param {Object} options - Configuration options
141
+ * @param {string} [options.storyId] - Story identifier (e.g., 'STORY-42')
142
+ * @param {number} [options.maxRetries=3] - Maximum retry attempts per epic
143
+ * @param {boolean} [options.autoRecovery=true] - Enable automatic recovery on failures
144
+ * @param {string} [options.source='story'] - Source type: 'story', 'prd', 'prompt'
145
+ * @param {string} [options.prdPath] - Path to PRD if source is 'prd'
146
+ * @param {boolean} [options.strictGates=false] - Fail on any gate failure
147
+ * @param {Function} [options.onEpicStart] - Callback when epic starts
148
+ * @param {Function} [options.onEpicComplete] - Callback when epic completes
149
+ * @param {Function} [options.onStateChange] - Callback on state transitions
150
+ * @param {Function} [options.invokeAgent] - Function to invoke agents for tasks
151
+ */
152
+ constructor(projectRoot, options = {}) {
153
+ super();
154
+
155
+ // Core configuration
156
+ this.projectRoot = projectRoot;
157
+ this.storyId = options.storyId || null;
158
+ this.maxRetries = options.maxRetries ?? 3;
159
+ this.autoRecovery = options.autoRecovery ?? true;
160
+ this.source = options.source || 'story';
161
+ this.prdPath = options.prdPath || null;
162
+ this.strictGates = options.strictGates ?? false;
163
+
164
+ // Callbacks
165
+ this.onEpicStart = options.onEpicStart || this._defaultEpicStart.bind(this);
166
+ this.onEpicComplete = options.onEpicComplete || this._defaultEpicComplete.bind(this);
167
+ this.onStateChange = options.onStateChange || this._defaultStateChange.bind(this);
168
+ this.invokeAgent = options.invokeAgent || null;
169
+
170
+ // State machine (AC6)
171
+ this._state = OrchestratorState.INITIALIZED;
172
+ this._previousState = null;
173
+ this._inFullPipeline = false; // Flag for gate evaluation during full pipeline
174
+
175
+ // Execution state
176
+ this.executionState = {
177
+ workflowId: null,
178
+ storyId: this.storyId,
179
+ status: 'initialized',
180
+ startedAt: null,
181
+ updatedAt: null,
182
+ techStackProfile: null,
183
+ epics: this._initializeEpicsState(),
184
+ currentEpic: null,
185
+ errors: [],
186
+ insights: [],
187
+ retryCount: {},
188
+ };
189
+
190
+ // Components (AC7)
191
+ this.techStackDetector = new TechStackDetector(projectRoot);
192
+ this.executors = {}; // Will be loaded lazily
193
+
194
+ // Recovery Handler (Story 0.5)
195
+ this.recoveryHandler = new RecoveryHandler({
196
+ projectRoot,
197
+ storyId: this.storyId,
198
+ maxRetries: this.maxRetries,
199
+ autoEscalate: this.autoRecovery,
200
+ orchestrator: this,
201
+ });
202
+
203
+ // Gate Evaluator (Story 0.6)
204
+ this.gateEvaluator = new GateEvaluator({
205
+ projectRoot,
206
+ strictMode: this.strictGates,
207
+ });
208
+
209
+ // Agent Invoker (Story 0.7)
210
+ this.agentInvoker = new AgentInvoker({
211
+ projectRoot,
212
+ defaultTimeout: options.taskTimeout || 300000, // 5 min
213
+ maxRetries: this.maxRetries,
214
+ executor: this.invokeAgent, // Use custom executor if provided
215
+ });
216
+
217
+ // Dashboard Integration (Story 0.8)
218
+ this.dashboardIntegration = new DashboardIntegration({
219
+ projectRoot,
220
+ orchestrator: this,
221
+ autoUpdate: options.dashboardAutoUpdate ?? false, // Default off for tests
222
+ updateInterval: options.dashboardUpdateInterval || 5000,
223
+ });
224
+
225
+ // State persistence paths
226
+ this.statePath = path.join(
227
+ projectRoot,
228
+ '.grimoire',
229
+ 'master-orchestrator',
230
+ this.storyId ? `${this.storyId}.json` : 'current.json',
231
+ );
232
+
233
+ // Log initialization
234
+ this._log('MasterOrchestrator initialized', {
235
+ projectRoot,
236
+ storyId: this.storyId,
237
+ maxRetries: this.maxRetries,
238
+ autoRecovery: this.autoRecovery,
239
+ });
240
+ }
241
+
242
+ // ═══════════════════════════════════════════════════════════════════════════════════
243
+ // STATE MACHINE (AC6)
244
+ // ═══════════════════════════════════════════════════════════════════════════════════
245
+
246
+ /**
247
+ * Get current state
248
+ * @returns {OrchestratorState}
249
+ */
250
+ get state() {
251
+ return this._state;
252
+ }
253
+
254
+ /**
255
+ * Transition to a new state
256
+ * @param {OrchestratorState} newState - Target state
257
+ * @param {Object} [context] - Additional context for the transition
258
+ * @private
259
+ */
260
+ _transitionTo(newState, context = {}) {
261
+ const validTransitions = {
262
+ [OrchestratorState.INITIALIZED]: [OrchestratorState.READY, OrchestratorState.BLOCKED],
263
+ [OrchestratorState.READY]: [OrchestratorState.IN_PROGRESS, OrchestratorState.BLOCKED],
264
+ [OrchestratorState.IN_PROGRESS]: [
265
+ OrchestratorState.COMPLETE,
266
+ OrchestratorState.BLOCKED,
267
+ OrchestratorState.IN_PROGRESS, // Allow staying in progress for multiple epics
268
+ ],
269
+ [OrchestratorState.BLOCKED]: [
270
+ OrchestratorState.READY,
271
+ OrchestratorState.IN_PROGRESS,
272
+ OrchestratorState.COMPLETE,
273
+ ],
274
+ [OrchestratorState.COMPLETE]: [], // Terminal state
275
+ };
276
+
277
+ const allowed = validTransitions[this._state] || [];
278
+ if (!allowed.includes(newState) && newState !== this._state) {
279
+ this._log(`Invalid state transition: ${this._state} → ${newState}`, { level: 'warn' });
280
+ return false;
281
+ }
282
+
283
+ this._previousState = this._state;
284
+ this._state = newState;
285
+ this.executionState.status = newState;
286
+ this.executionState.updatedAt = new Date().toISOString();
287
+
288
+ // Emit state change event
289
+ this.emit('stateChange', {
290
+ from: this._previousState,
291
+ to: newState,
292
+ context,
293
+ });
294
+
295
+ this.onStateChange(this._previousState, newState, context);
296
+ this._log(`State transition: ${this._previousState} → ${newState}`, context);
297
+
298
+ return true;
299
+ }
300
+
301
+ /**
302
+ * Initialize epics state structure
303
+ * @private
304
+ */
305
+ _initializeEpicsState() {
306
+ const epics = {};
307
+ for (const epicNum of Object.keys(EPIC_CONFIG)) {
308
+ epics[epicNum] = {
309
+ status: EpicStatus.PENDING,
310
+ startedAt: null,
311
+ completedAt: null,
312
+ result: null,
313
+ attempts: 0,
314
+ errors: [],
315
+ };
316
+ }
317
+ return epics;
318
+ }
319
+
320
+ // ═══════════════════════════════════════════════════════════════════════════════════
321
+ // INITIALIZATION
322
+ // ═══════════════════════════════════════════════════════════════════════════════════
323
+
324
+ /**
325
+ * Initialize the orchestrator - run pre-flight checks (AC7)
326
+ * @returns {Promise<void>}
327
+ */
328
+ async initialize() {
329
+ this._log('Starting initialization...');
330
+
331
+ try {
332
+ // Ensure state directory exists
333
+ await fs.ensureDir(path.dirname(this.statePath));
334
+
335
+ // Try to load existing state
336
+ const existingState = await this._loadState();
337
+ if (existingState && existingState.status !== OrchestratorState.COMPLETE) {
338
+ this._log('Found existing state, resuming...', { storyId: existingState.storyId });
339
+ // Deep merge for nested objects like epics
340
+ this.executionState = {
341
+ ...this.executionState,
342
+ ...existingState,
343
+ epics: {
344
+ ...this.executionState.epics,
345
+ ...existingState.epics,
346
+ },
347
+ retryCount: {
348
+ ...this.executionState.retryCount,
349
+ ...(existingState.retryCount || {}),
350
+ },
351
+ };
352
+ this._state = existingState.status || OrchestratorState.INITIALIZED;
353
+ }
354
+
355
+ // Generate workflow ID if not exists
356
+ if (!this.executionState.workflowId) {
357
+ this.executionState.workflowId = `master-ade-${this.storyId || Date.now()}`;
358
+ }
359
+
360
+ // Record start time if fresh start
361
+ if (!this.executionState.startedAt) {
362
+ this.executionState.startedAt = new Date().toISOString();
363
+ }
364
+
365
+ // Run pre-flight tech stack detection (AC7)
366
+ this._log('Running pre-flight tech stack detection...');
367
+ const techStack = await this._detectTechStack();
368
+ this.executionState.techStackProfile = techStack;
369
+
370
+ // Log detection summary
371
+ const summary = TechStackDetector.getSummary(techStack);
372
+ this._log(`Tech stack detected: ${summary}`, { confidence: techStack.confidence });
373
+
374
+ // Transition to ready
375
+ this._transitionTo(OrchestratorState.READY, { techStack });
376
+
377
+ // Save initial state
378
+ await this._saveState();
379
+
380
+ this._log('Initialization complete');
381
+ } catch (error) {
382
+ this._log(`Initialization failed: ${error.message}`, { level: 'error' });
383
+ this._transitionTo(OrchestratorState.BLOCKED, { error: error.message });
384
+ throw error;
385
+ }
386
+ }
387
+
388
+ /**
389
+ * Detect tech stack using TechStackDetector (AC7)
390
+ * @private
391
+ * @returns {Promise<Object>} Tech stack profile
392
+ */
393
+ async _detectTechStack() {
394
+ return await this.techStackDetector.detect();
395
+ }
396
+
397
+ // ═══════════════════════════════════════════════════════════════════════════════════
398
+ // PIPELINE EXECUTION (AC3)
399
+ // ═══════════════════════════════════════════════════════════════════════════════════
400
+
401
+ /**
402
+ * Execute the full ADE pipeline: Epics 3→4→5→6→7 (AC3)
403
+ *
404
+ * @returns {Promise<Object>} Pipeline execution result
405
+ */
406
+ async executeFullPipeline() {
407
+ this._log('Starting full pipeline execution...');
408
+
409
+ // Ensure initialized
410
+ if (this._state === OrchestratorState.INITIALIZED) {
411
+ await this.initialize();
412
+ }
413
+
414
+ // Validate ready state
415
+ if (this._state !== OrchestratorState.READY && this._state !== OrchestratorState.IN_PROGRESS) {
416
+ throw new Error(`Cannot execute pipeline in state: ${this._state}`);
417
+ }
418
+
419
+ // Transition to in progress
420
+ this._transitionTo(OrchestratorState.IN_PROGRESS, { action: 'executeFullPipeline' });
421
+
422
+ const pipelineResult = {
423
+ success: true,
424
+ epicsExecuted: [],
425
+ epicsFailed: [],
426
+ epicsSkipped: [],
427
+ startTime: Date.now(),
428
+ endTime: null,
429
+ techStack: this.executionState.techStackProfile,
430
+ };
431
+
432
+ // Flag for gate evaluation (only during full pipeline)
433
+ this._inFullPipeline = true;
434
+
435
+ try {
436
+ // Execute epics in sequence: 3 → 4 → 6
437
+ // Note: Epic 5 (Recovery) is triggered on-demand, not sequentially
438
+ const epicSequence = [3, 4, 6];
439
+
440
+ for (const epicNum of epicSequence) {
441
+ // Check if already completed (for resume scenarios)
442
+ if (this.executionState.epics[epicNum]?.status === EpicStatus.COMPLETED) {
443
+ this._log(`Epic ${epicNum} already completed, skipping...`);
444
+ pipelineResult.epicsSkipped.push(epicNum);
445
+ continue;
446
+ }
447
+
448
+ // Check if blocked
449
+ if (this._state === OrchestratorState.BLOCKED) {
450
+ this._log(`Pipeline blocked, cannot continue to Epic ${epicNum}`);
451
+ break;
452
+ }
453
+
454
+ try {
455
+ // Execute epic
456
+ const result = await this.executeEpic(epicNum);
457
+
458
+ if (result.success) {
459
+ pipelineResult.epicsExecuted.push(epicNum);
460
+ } else {
461
+ pipelineResult.epicsFailed.push(epicNum);
462
+
463
+ // In strict mode or if epic is critical, stop pipeline
464
+ if (this.strictGates || this._isEpicCritical(epicNum)) {
465
+ this._log(`Critical epic ${epicNum} failed, halting pipeline`);
466
+ pipelineResult.success = false;
467
+ break;
468
+ }
469
+ }
470
+ } catch (error) {
471
+ this._log(`Epic ${epicNum} threw error: ${error.message}`, { level: 'error' });
472
+ pipelineResult.epicsFailed.push(epicNum);
473
+ pipelineResult.success = false;
474
+
475
+ // Record error
476
+ this.executionState.errors.push({
477
+ epic: epicNum,
478
+ error: error.message,
479
+ timestamp: new Date().toISOString(),
480
+ });
481
+
482
+ // Try recovery if enabled
483
+ if (this.autoRecovery) {
484
+ const recovered = await this._attemptRecovery(epicNum, error);
485
+ if (recovered) {
486
+ pipelineResult.epicsFailed = pipelineResult.epicsFailed.filter((e) => e !== epicNum);
487
+ pipelineResult.epicsExecuted.push(epicNum);
488
+ pipelineResult.success = true;
489
+ }
490
+ }
491
+
492
+ // If not recovered and strict, stop
493
+ if (!pipelineResult.success && this.strictGates) {
494
+ break;
495
+ }
496
+ }
497
+
498
+ // Save state after each epic
499
+ await this._saveState();
500
+ }
501
+
502
+ // Finalize pipeline
503
+ pipelineResult.endTime = Date.now();
504
+ pipelineResult.duration = pipelineResult.endTime - pipelineResult.startTime;
505
+
506
+ // Transition to final state
507
+ if (pipelineResult.success && pipelineResult.epicsFailed.length === 0) {
508
+ this._transitionTo(OrchestratorState.COMPLETE, { result: pipelineResult });
509
+ } else if (pipelineResult.epicsFailed.length > 0) {
510
+ this._transitionTo(OrchestratorState.BLOCKED, {
511
+ failedEpics: pipelineResult.epicsFailed,
512
+ });
513
+ }
514
+
515
+ // Save final state
516
+ await this._saveState();
517
+
518
+ return this.finalize(pipelineResult);
519
+ } catch (error) {
520
+ this._log(`Pipeline execution failed: ${error.message}`, { level: 'error' });
521
+ this._transitionTo(OrchestratorState.BLOCKED, { error: error.message });
522
+ await this._saveState();
523
+ throw error;
524
+ } finally {
525
+ // Reset pipeline flag
526
+ this._inFullPipeline = false;
527
+ }
528
+ }
529
+
530
+ /**
531
+ * Check if an epic is critical (failure should halt pipeline)
532
+ * @private
533
+ */
534
+ _isEpicCritical(epicNum) {
535
+ // Epics 3 (Spec) and 4 (Execution) are critical
536
+ return [3, 4].includes(epicNum);
537
+ }
538
+
539
+ // ═══════════════════════════════════════════════════════════════════════════════════
540
+ // SINGLE EPIC EXECUTION (AC4)
541
+ // ═══════════════════════════════════════════════════════════════════════════════════
542
+
543
+ /**
544
+ * Execute a single epic (AC4)
545
+ *
546
+ * @param {number} epicNum - Epic number (3, 4, 5, 6, or 7)
547
+ * @param {Object} [options] - Epic-specific options
548
+ * @returns {Promise<Object>} Epic execution result
549
+ */
550
+ async executeEpic(epicNum, options = {}) {
551
+ const epicConfig = EPIC_CONFIG[epicNum];
552
+ if (!epicConfig) {
553
+ throw new Error(`Unknown epic number: ${epicNum}`);
554
+ }
555
+
556
+ this._log(`Starting Epic ${epicNum}: ${epicConfig.name}`, { icon: epicConfig.icon });
557
+
558
+ // Update epic state
559
+ this.executionState.currentEpic = epicNum;
560
+ this.executionState.epics[epicNum] = {
561
+ ...this.executionState.epics[epicNum],
562
+ status: EpicStatus.IN_PROGRESS,
563
+ startedAt: new Date().toISOString(),
564
+ attempts: (this.executionState.epics[epicNum]?.attempts || 0) + 1,
565
+ };
566
+
567
+ // Emit epic start event
568
+ this.emit('epicStart', { epicNum, config: epicConfig });
569
+ this.onEpicStart(epicNum, epicConfig);
570
+
571
+ try {
572
+ // Build context for this epic
573
+ const context = this._buildContextForEpic(epicNum);
574
+
575
+ // Get or create executor
576
+ const executor = await this._getExecutor(epicNum);
577
+
578
+ // Execute the epic
579
+ const result = await executor.execute({
580
+ ...context,
581
+ ...options,
582
+ orchestrator: this,
583
+ });
584
+
585
+ // Mark as completed
586
+ this.executionState.epics[epicNum] = {
587
+ ...this.executionState.epics[epicNum],
588
+ status: EpicStatus.COMPLETED,
589
+ completedAt: new Date().toISOString(),
590
+ result,
591
+ };
592
+
593
+ // Evaluate quality gate (Story 0.6) - only in full pipeline mode
594
+ // Skip gate evaluation if result is from stub executor
595
+ let gateResult = null;
596
+ const isStubResult = result && result.status === 'stub';
597
+ if (this._inFullPipeline && result && result.success !== false && !isStubResult) {
598
+ gateResult = await this._evaluateGate(epicNum, result);
599
+
600
+ // Store gate result if exists
601
+ if (gateResult) {
602
+ this.executionState.epics[epicNum].gateResult = gateResult;
603
+ }
604
+ }
605
+
606
+ // Save state after epic completion
607
+ await this._saveState();
608
+
609
+ // Emit epic complete event
610
+ this.emit('epicComplete', { epicNum, result, gateResult });
611
+ this.onEpicComplete(epicNum, result);
612
+
613
+ this._log(`Epic ${epicNum} completed successfully`, { icon: '✅' });
614
+
615
+ // Check gate verdict (only block/warn during full pipeline)
616
+ if (gateResult && this._inFullPipeline) {
617
+ if (this.gateEvaluator.shouldBlock(gateResult.verdict)) {
618
+ this._log(`Gate blocked: ${gateResult.gate}`, { level: 'warn', icon: '🚫' });
619
+ this._transitionTo(OrchestratorState.BLOCKED, {
620
+ reason: 'gate_blocked',
621
+ gate: gateResult.gate,
622
+ issues: gateResult.issues,
623
+ });
624
+ return { success: false, epicNum, result, gateResult, blocked: true };
625
+ }
626
+
627
+ if (this.gateEvaluator.needsRevision(gateResult.verdict)) {
628
+ this._log(`Gate needs revision: ${gateResult.gate}`, { level: 'warn', icon: '⚠️' });
629
+ result.needsRevision = true;
630
+ }
631
+ }
632
+
633
+ return { success: true, epicNum, result, gateResult };
634
+ } catch (error) {
635
+ // Mark as failed
636
+ this.executionState.epics[epicNum] = {
637
+ ...this.executionState.epics[epicNum],
638
+ status: EpicStatus.FAILED,
639
+ errors: [
640
+ ...(this.executionState.epics[epicNum]?.errors || []),
641
+ { message: error.message, timestamp: new Date().toISOString() },
642
+ ],
643
+ };
644
+
645
+ this._log(`Epic ${epicNum} failed: ${error.message}`, { level: 'error', icon: '❌' });
646
+
647
+ // Check retry count
648
+ const retries = this.executionState.retryCount[epicNum] || 0;
649
+ if (retries < this.maxRetries && this.autoRecovery) {
650
+ this.executionState.retryCount[epicNum] = retries + 1;
651
+ this._log(`Retrying Epic ${epicNum} (attempt ${retries + 1}/${this.maxRetries})...`);
652
+ return this.executeEpic(epicNum, options);
653
+ }
654
+
655
+ return { success: false, epicNum, error: error.message };
656
+ }
657
+ }
658
+
659
+ /**
660
+ * Get or create an executor for the epic (Story 0.3)
661
+ * @private
662
+ */
663
+ async _getExecutor(epicNum) {
664
+ if (!this.executors[epicNum]) {
665
+ // Use real executors from Story 0.3
666
+ if (hasExecutor(epicNum)) {
667
+ this.executors[epicNum] = createExecutor(epicNum, this);
668
+ } else {
669
+ // Fallback to stub for unknown epics
670
+ this.executors[epicNum] = new StubEpicExecutor(this, epicNum);
671
+ }
672
+ }
673
+ return this.executors[epicNum];
674
+ }
675
+
676
+ // ═══════════════════════════════════════════════════════════════════════════════════
677
+ // RESUME EXECUTION (AC5)
678
+ // ═══════════════════════════════════════════════════════════════════════════════════
679
+
680
+ /**
681
+ * Resume execution from a specific epic (AC5)
682
+ *
683
+ * @param {number} fromEpic - Epic number to resume from
684
+ * @returns {Promise<Object>} Pipeline execution result
685
+ */
686
+ async resumeFromEpic(fromEpic) {
687
+ this._log(`Resuming from Epic ${fromEpic}...`);
688
+
689
+ // Load existing state
690
+ const existingState = await this._loadState();
691
+ if (existingState) {
692
+ Object.assign(this.executionState, existingState);
693
+ }
694
+
695
+ // Reset state for epics >= fromEpic
696
+ for (const epicNumStr of Object.keys(this.executionState.epics)) {
697
+ const epicNum = parseInt(epicNumStr, 10);
698
+ if (epicNum >= fromEpic) {
699
+ this.executionState.epics[epicNum] = {
700
+ status: EpicStatus.PENDING,
701
+ startedAt: null,
702
+ completedAt: null,
703
+ result: null,
704
+ attempts: 0,
705
+ errors: [],
706
+ };
707
+ this.executionState.retryCount[epicNum] = 0;
708
+ }
709
+ }
710
+
711
+ // Clear blocked state if set
712
+ if (this._state === OrchestratorState.BLOCKED) {
713
+ this._transitionTo(OrchestratorState.READY, { action: 'resume', fromEpic });
714
+ }
715
+
716
+ // Execute pipeline from this point
717
+ return this.executeFullPipeline();
718
+ }
719
+
720
+ // ═══════════════════════════════════════════════════════════════════════════════════
721
+ // CONTEXT BUILDING
722
+ // ═══════════════════════════════════════════════════════════════════════════════════
723
+
724
+ /**
725
+ * Build context for a specific epic
726
+ * This will be expanded in Story 0.4 (Context Threading)
727
+ * @private
728
+ */
729
+ _buildContextForEpic(epicNum) {
730
+ const baseContext = {
731
+ storyId: this.storyId,
732
+ workflowId: this.executionState.workflowId,
733
+ techStack: this.executionState.techStackProfile,
734
+ projectRoot: this.projectRoot,
735
+ previousGates: this._getCompletedGates(),
736
+ };
737
+
738
+ switch (epicNum) {
739
+ case 3: // Spec Pipeline
740
+ return {
741
+ ...baseContext,
742
+ source: this.source,
743
+ prdPath: this.prdPath,
744
+ };
745
+
746
+ case 4: // Execution Engine
747
+ return {
748
+ ...baseContext,
749
+ spec: this.executionState.epics[3]?.result?.specPath,
750
+ complexity: this.executionState.epics[3]?.result?.complexity,
751
+ requirements: this.executionState.epics[3]?.result?.requirements,
752
+ };
753
+
754
+ case 5: // Recovery (on-demand)
755
+ return {
756
+ ...baseContext,
757
+ implementationPath: this.executionState.epics[4]?.result?.implementationPath,
758
+ errors: this.executionState.errors,
759
+ attempts: this.executionState.epics[4]?.attempts,
760
+ };
761
+
762
+ case 6: // QA Loop
763
+ return {
764
+ ...baseContext,
765
+ buildResult: this.executionState.epics[4]?.result,
766
+ testResults: this.executionState.epics[4]?.result?.testResults,
767
+ codeChanges: this.executionState.epics[4]?.result?.codeChanges,
768
+ };
769
+
770
+ case 7: // Memory Layer
771
+ return {
772
+ ...baseContext,
773
+ qaReport: this.executionState.epics[6]?.result,
774
+ patterns: this.executionState.insights,
775
+ sessionInsights: this._collectSessionInsights(),
776
+ };
777
+
778
+ default:
779
+ return baseContext;
780
+ }
781
+ }
782
+
783
+ /**
784
+ * Get list of completed gates/epics
785
+ * @private
786
+ */
787
+ _getCompletedGates() {
788
+ return Object.entries(this.executionState.epics)
789
+ .filter(([_, epic]) => epic.status === EpicStatus.COMPLETED)
790
+ .map(([num, _]) => parseInt(num, 10));
791
+ }
792
+
793
+ /**
794
+ * Collect session insights for memory layer
795
+ * @private
796
+ */
797
+ _collectSessionInsights() {
798
+ return {
799
+ duration: this.executionState.startedAt
800
+ ? Date.now() - new Date(this.executionState.startedAt).getTime()
801
+ : 0,
802
+ errorsEncountered: this.executionState.errors.length,
803
+ recoveryAttempts: Object.values(this.executionState.retryCount).reduce((a, b) => a + b, 0),
804
+ completedEpics: this._getCompletedGates().length,
805
+ };
806
+ }
807
+
808
+ // ═══════════════════════════════════════════════════════════════════════════════════
809
+ // QUALITY GATES (Story 0.6)
810
+ // ═══════════════════════════════════════════════════════════════════════════════════
811
+
812
+ /**
813
+ * Evaluate quality gate after epic completion (AC1)
814
+ * @private
815
+ * @param {number} epicNum - Completed epic number
816
+ * @param {Object} result - Epic result
817
+ * @returns {Promise<Object|null>} Gate result or null if no gate
818
+ */
819
+ async _evaluateGate(epicNum, result) {
820
+ // Determine next epic for gate evaluation
821
+ const epicSequence = [3, 4, 6, 7];
822
+ const currentIndex = epicSequence.indexOf(epicNum);
823
+
824
+ // No gate after last epic or if epic not in sequence
825
+ if (currentIndex === -1 || currentIndex === epicSequence.length - 1) {
826
+ return null;
827
+ }
828
+
829
+ const nextEpic = epicSequence[currentIndex + 1];
830
+
831
+ this._log(`Evaluating gate: Epic ${epicNum} -> Epic ${nextEpic}`, { icon: '🚦' });
832
+
833
+ try {
834
+ const gateResult = await this.gateEvaluator.evaluate(epicNum, nextEpic, result);
835
+
836
+ // Log gate result
837
+ this._log(`Gate verdict: ${gateResult.verdict} (score: ${gateResult.score.toFixed(1)})`, {
838
+ level: gateResult.verdict === GateVerdict.APPROVED ? 'info' : 'warn',
839
+ });
840
+
841
+ return gateResult;
842
+ } catch (error) {
843
+ this._log(`Gate evaluation error: ${error.message}`, { level: 'error' });
844
+ // Return blocked gate on error if strict
845
+ if (this.strictGates) {
846
+ return {
847
+ gate: `epic${epicNum}_to_epic${nextEpic}`,
848
+ verdict: GateVerdict.BLOCKED,
849
+ issues: [{ check: 'evaluation_error', message: error.message, severity: 'critical' }],
850
+ };
851
+ }
852
+ return null;
853
+ }
854
+ }
855
+
856
+ /**
857
+ * Get gate evaluator for external access (AC6)
858
+ * @returns {GateEvaluator}
859
+ */
860
+ getGateEvaluator() {
861
+ return this.gateEvaluator;
862
+ }
863
+
864
+ /**
865
+ * Get all gate results (AC6)
866
+ * @returns {Object[]}
867
+ */
868
+ getGateResults() {
869
+ return this.gateEvaluator.getResults();
870
+ }
871
+
872
+ // ═══════════════════════════════════════════════════════════════════════════════════
873
+ // AGENT INVOCATION (Story 0.7)
874
+ // ═══════════════════════════════════════════════════════════════════════════════════
875
+
876
+ /**
877
+ * Get the agent invoker instance (Story 0.7)
878
+ * @returns {AgentInvoker}
879
+ */
880
+ getAgentInvoker() {
881
+ return this.agentInvoker;
882
+ }
883
+
884
+ /**
885
+ * Invoke an agent to execute a task (Story 0.7 - AC1)
886
+ *
887
+ * @param {string} agentName - Agent name (e.g., 'dev', 'qa', 'architect')
888
+ * @param {string} taskPath - Path to task file or task name
889
+ * @param {Object} [inputs={}] - Inputs to pass to the task
890
+ * @returns {Promise<Object>} Invocation result
891
+ */
892
+ async invokeAgentForTask(agentName, taskPath, inputs = {}) {
893
+ // Add orchestration context to inputs
894
+ const enrichedInputs = {
895
+ ...inputs,
896
+ orchestration: {
897
+ storyId: this.storyId,
898
+ currentEpic: this.executionState.currentEpic,
899
+ techStack: this.executionState.techStackProfile,
900
+ state: this._state,
901
+ },
902
+ };
903
+
904
+ return this.agentInvoker.invokeAgent(agentName, taskPath, enrichedInputs);
905
+ }
906
+
907
+ /**
908
+ * Get supported agents (Story 0.7 - AC2)
909
+ * @returns {Object} Map of supported agents
910
+ */
911
+ getSupportedAgents() {
912
+ return this.agentInvoker.getSupportedAgents();
913
+ }
914
+
915
+ /**
916
+ * Get agent invocation history (Story 0.7 - AC7)
917
+ * @returns {Object[]} Invocation records
918
+ */
919
+ getAgentInvocations() {
920
+ return this.agentInvoker.getInvocations();
921
+ }
922
+
923
+ // ═══════════════════════════════════════════════════════════════════════════════════
924
+ // DASHBOARD INTEGRATION (Story 0.8)
925
+ // ═══════════════════════════════════════════════════════════════════════════════════
926
+
927
+ /**
928
+ * Get the dashboard integration instance (Story 0.8)
929
+ * @returns {DashboardIntegration}
930
+ */
931
+ getDashboardIntegration() {
932
+ return this.dashboardIntegration;
933
+ }
934
+
935
+ /**
936
+ * Start dashboard monitoring (Story 0.8 - AC1)
937
+ */
938
+ async startDashboard() {
939
+ await this.dashboardIntegration.start();
940
+ }
941
+
942
+ /**
943
+ * Stop dashboard monitoring (Story 0.8)
944
+ */
945
+ stopDashboard() {
946
+ this.dashboardIntegration.stop();
947
+ }
948
+
949
+ /**
950
+ * Get dashboard status (Story 0.8 - AC1, AC2)
951
+ * @returns {Object} Dashboard status
952
+ */
953
+ getDashboardStatus() {
954
+ return this.dashboardIntegration.buildStatus();
955
+ }
956
+
957
+ /**
958
+ * Get execution history (Story 0.8 - AC5)
959
+ * @returns {Object[]} History entries
960
+ */
961
+ getExecutionHistory() {
962
+ return this.dashboardIntegration.getHistory();
963
+ }
964
+
965
+ /**
966
+ * Get notifications (Story 0.8 - AC7)
967
+ * @param {boolean} [unreadOnly=false] - Only unread notifications
968
+ * @returns {Object[]} Notifications
969
+ */
970
+ getNotifications(unreadOnly = false) {
971
+ return this.dashboardIntegration.getNotifications(unreadOnly);
972
+ }
973
+
974
+ /**
975
+ * Add notification (Story 0.8 - AC7)
976
+ * @param {Object} notification - Notification object
977
+ */
978
+ addNotification(notification) {
979
+ this.dashboardIntegration.addNotification(notification);
980
+ }
981
+
982
+ // ═══════════════════════════════════════════════════════════════════════════════════
983
+ // RECOVERY (Story 0.5)
984
+ // ═══════════════════════════════════════════════════════════════════════════════════
985
+
986
+ /**
987
+ * Attempt recovery for a failed epic (AC1-AC7 of Story 0.5)
988
+ * Uses RecoveryHandler for intelligent recovery with stuck detection
989
+ * @private
990
+ * @param {number} epicNum - Failed epic number
991
+ * @param {Error} error - Error that caused failure
992
+ * @returns {Promise<boolean>} True if should retry
993
+ */
994
+ async _attemptRecovery(epicNum, error) {
995
+ this._log(`Attempting recovery for Epic ${epicNum}...`, { error: error.message });
996
+
997
+ // Don't try to recover from recovery failures (avoid infinite loop)
998
+ if (epicNum === 5) {
999
+ this._log('Cannot recover from recovery epic failure', { level: 'warn' });
1000
+ return false;
1001
+ }
1002
+
1003
+ // Check if we can still retry (AC5)
1004
+ if (!this.recoveryHandler.canRetry(epicNum)) {
1005
+ this._log(`Max retries reached for Epic ${epicNum}`, { level: 'warn' });
1006
+ return false;
1007
+ }
1008
+
1009
+ try {
1010
+ // Use RecoveryHandler for intelligent recovery (AC1)
1011
+ const result = await this.recoveryHandler.handleEpicFailure(epicNum, error, {
1012
+ approach: this.executionState.epics[epicNum]?.currentApproach || 'default',
1013
+ subtaskId: this.executionState.epics[epicNum]?.currentSubtask,
1014
+ affectedFiles: this.executionState.epics[epicNum]?.result?.codeChanges || [],
1015
+ });
1016
+
1017
+ // Log recovery result (AC7)
1018
+ this._log(
1019
+ `Recovery result: ${JSON.stringify({
1020
+ strategy: result.strategy,
1021
+ success: result.success,
1022
+ shouldRetry: result.shouldRetry,
1023
+ escalated: result.escalated,
1024
+ })}`,
1025
+ { level: result.success ? 'info' : 'warn' },
1026
+ );
1027
+
1028
+ // Track retry count
1029
+ this.executionState.retryCount[epicNum] = (this.executionState.retryCount[epicNum] || 0) + 1;
1030
+
1031
+ // Handle escalation
1032
+ if (result.escalated) {
1033
+ this._transitionTo(OrchestratorState.BLOCKED, {
1034
+ reason: 'escalated_to_human',
1035
+ epicNum,
1036
+ error: error.message,
1037
+ });
1038
+ return false;
1039
+ }
1040
+
1041
+ // Should we retry?
1042
+ return result.shouldRetry;
1043
+ } catch (recoveryError) {
1044
+ this._log(`Recovery handler error: ${recoveryError.message}`, { level: 'error' });
1045
+ return false;
1046
+ }
1047
+ }
1048
+
1049
+ /**
1050
+ * Get recovery handler for external access
1051
+ * @returns {RecoveryHandler}
1052
+ */
1053
+ getRecoveryHandler() {
1054
+ return this.recoveryHandler;
1055
+ }
1056
+
1057
+ // ═══════════════════════════════════════════════════════════════════════════════════
1058
+ // STATE PERSISTENCE (Story 0.2)
1059
+ // ═══════════════════════════════════════════════════════════════════════════════════
1060
+
1061
+ /**
1062
+ * Save current state to disk (AC1, AC3)
1063
+ * Called after each epic completion and state transition
1064
+ * @returns {Promise<boolean>} Success status
1065
+ */
1066
+ async saveState() {
1067
+ try {
1068
+ await fs.ensureDir(path.dirname(this.statePath));
1069
+
1070
+ // Build comprehensive state object (AC2, AC6, AC7)
1071
+ const stateToSave = {
1072
+ // Metadata
1073
+ schemaVersion: '1.0',
1074
+ workflowId: this.executionState.workflowId,
1075
+ storyId: this.storyId,
1076
+ status: this._state,
1077
+
1078
+ // Timestamps (AC6)
1079
+ timestamps: {
1080
+ startedAt: this.executionState.startedAt,
1081
+ updatedAt: new Date().toISOString(),
1082
+ savedAt: new Date().toISOString(),
1083
+ completedAt: this._state === OrchestratorState.COMPLETE ? new Date().toISOString() : null,
1084
+ },
1085
+
1086
+ // Tech stack profile (AC7)
1087
+ techStackProfile: this.executionState.techStackProfile,
1088
+
1089
+ // Epic tracking (AC2)
1090
+ currentEpic: this.executionState.currentEpic,
1091
+ completedEpics: this._getCompletedGates(),
1092
+ failedEpics: this._getFailedEpics(),
1093
+ pendingEpics: this._getPendingEpics(),
1094
+
1095
+ // Full epics state
1096
+ epics: this.executionState.epics,
1097
+
1098
+ // Recovery tracking
1099
+ retryCount: this.executionState.retryCount,
1100
+
1101
+ // Context for resume (AC2)
1102
+ context: {
1103
+ source: this.source,
1104
+ prdPath: this.prdPath,
1105
+ strictGates: this.strictGates,
1106
+ maxRetries: this.maxRetries,
1107
+ autoRecovery: this.autoRecovery,
1108
+ },
1109
+
1110
+ // Errors and insights
1111
+ errors: this.executionState.errors,
1112
+ insights: this.executionState.insights,
1113
+
1114
+ // Session insights
1115
+ sessionInsights: this._collectSessionInsights(),
1116
+ };
1117
+
1118
+ await fs.writeJson(this.statePath, stateToSave, { spaces: 2 });
1119
+ this._log('State saved successfully', { path: this.statePath });
1120
+
1121
+ return true;
1122
+ } catch (error) {
1123
+ this._log(`Failed to save state: ${error.message}`, { level: 'warn' });
1124
+ return false;
1125
+ }
1126
+ }
1127
+
1128
+ /**
1129
+ * Internal save state wrapper (calls public method)
1130
+ * @private
1131
+ */
1132
+ async _saveState() {
1133
+ return this.saveState();
1134
+ }
1135
+
1136
+ /**
1137
+ * Load state for a specific story ID (AC4)
1138
+ * @param {string} [storyId] - Story ID to load (defaults to this.storyId)
1139
+ * @returns {Promise<Object|null>} Loaded state or null
1140
+ */
1141
+ async loadState(storyId = null) {
1142
+ const targetStoryId = storyId || this.storyId;
1143
+ const targetPath = targetStoryId
1144
+ ? path.join(this.projectRoot, '.grimoire', 'master-orchestrator', `${targetStoryId}.json`)
1145
+ : this.statePath;
1146
+
1147
+ try {
1148
+ if (await fs.pathExists(targetPath)) {
1149
+ const state = await fs.readJson(targetPath);
1150
+
1151
+ // Validate state schema
1152
+ if (!this._validateStateSchema(state)) {
1153
+ this._log('Invalid state schema, ignoring saved state', { level: 'warn' });
1154
+ return null;
1155
+ }
1156
+
1157
+ this._log('State loaded successfully', { storyId: targetStoryId });
1158
+ return state;
1159
+ }
1160
+ } catch (error) {
1161
+ this._log(`Failed to load state: ${error.message}`, { level: 'warn' });
1162
+ }
1163
+ return null;
1164
+ }
1165
+
1166
+ /**
1167
+ * Internal load state wrapper (calls public method)
1168
+ * @private
1169
+ */
1170
+ async _loadState() {
1171
+ return this.loadState();
1172
+ }
1173
+
1174
+ /**
1175
+ * Find and load the most recent valid state (AC5)
1176
+ * Searches for any resumable state in the master-orchestrator directory
1177
+ * @returns {Promise<Object|null>} Most recent valid state or null
1178
+ */
1179
+ async findLatestValidState() {
1180
+ const stateDir = path.join(this.projectRoot, '.grimoire', 'master-orchestrator');
1181
+
1182
+ try {
1183
+ if (!(await fs.pathExists(stateDir))) {
1184
+ return null;
1185
+ }
1186
+
1187
+ const files = await fs.readdir(stateDir);
1188
+ const stateFiles = files.filter((f) => f.endsWith('.json'));
1189
+
1190
+ if (stateFiles.length === 0) {
1191
+ return null;
1192
+ }
1193
+
1194
+ // Load all states and find most recent valid one
1195
+ const states = [];
1196
+ for (const file of stateFiles) {
1197
+ try {
1198
+ const filePath = path.join(stateDir, file);
1199
+ const state = await fs.readJson(filePath);
1200
+
1201
+ if (this._validateStateSchema(state) && this._isResumable(state)) {
1202
+ const updatedAt = new Date(state.timestamps?.updatedAt || 0).getTime();
1203
+ states.push({ file, state, updatedAt });
1204
+ }
1205
+ } catch {
1206
+ // Skip invalid files
1207
+ }
1208
+ }
1209
+
1210
+ if (states.length === 0) {
1211
+ return null;
1212
+ }
1213
+
1214
+ // Sort by most recent
1215
+ states.sort((a, b) => b.updatedAt - a.updatedAt);
1216
+
1217
+ this._log(`Found ${states.length} resumable state(s), using most recent`, {
1218
+ storyId: states[0].state.storyId,
1219
+ });
1220
+
1221
+ return states[0].state;
1222
+ } catch (error) {
1223
+ this._log(`Failed to find latest state: ${error.message}`, { level: 'warn' });
1224
+ return null;
1225
+ }
1226
+ }
1227
+
1228
+ /**
1229
+ * Validate state object against expected schema
1230
+ * @private
1231
+ */
1232
+ _validateStateSchema(state) {
1233
+ if (!state || typeof state !== 'object') return false;
1234
+
1235
+ // Required fields
1236
+ const requiredFields = ['workflowId', 'status', 'epics'];
1237
+ for (const field of requiredFields) {
1238
+ if (state[field] === undefined) {
1239
+ return false;
1240
+ }
1241
+ }
1242
+
1243
+ // Validate epics structure
1244
+ if (typeof state.epics !== 'object') return false;
1245
+
1246
+ return true;
1247
+ }
1248
+
1249
+ /**
1250
+ * Check if state is resumable (not complete, not too old)
1251
+ * @private
1252
+ */
1253
+ _isResumable(state) {
1254
+ // Can't resume completed states
1255
+ if (state.status === OrchestratorState.COMPLETE) {
1256
+ return false;
1257
+ }
1258
+
1259
+ // Check if state is not too old (24 hours)
1260
+ const updatedAt = new Date(state.timestamps?.updatedAt || 0).getTime();
1261
+ const maxAge = 24 * 60 * 60 * 1000; // 24 hours
1262
+ if (Date.now() - updatedAt > maxAge) {
1263
+ return false;
1264
+ }
1265
+
1266
+ return true;
1267
+ }
1268
+
1269
+ /**
1270
+ * Get list of failed epics
1271
+ * @private
1272
+ */
1273
+ _getFailedEpics() {
1274
+ return Object.entries(this.executionState.epics)
1275
+ .filter(([_, epic]) => epic.status === EpicStatus.FAILED)
1276
+ .map(([num, _]) => parseInt(num, 10));
1277
+ }
1278
+
1279
+ /**
1280
+ * Get list of pending epics
1281
+ * @private
1282
+ */
1283
+ _getPendingEpics() {
1284
+ return Object.entries(this.executionState.epics)
1285
+ .filter(([_, epic]) => epic.status === EpicStatus.PENDING)
1286
+ .map(([num, _]) => parseInt(num, 10));
1287
+ }
1288
+
1289
+ /**
1290
+ * Clear saved state for current story
1291
+ * @returns {Promise<boolean>} Success status
1292
+ */
1293
+ async clearState() {
1294
+ try {
1295
+ if (await fs.pathExists(this.statePath)) {
1296
+ await fs.remove(this.statePath);
1297
+ this._log('State cleared', { path: this.statePath });
1298
+ return true;
1299
+ }
1300
+ } catch (error) {
1301
+ this._log(`Failed to clear state: ${error.message}`, { level: 'warn' });
1302
+ }
1303
+ return false;
1304
+ }
1305
+
1306
+ /**
1307
+ * List all saved states
1308
+ * @returns {Promise<Array>} List of state summaries
1309
+ */
1310
+ async listSavedStates() {
1311
+ const stateDir = path.join(this.projectRoot, '.grimoire', 'master-orchestrator');
1312
+
1313
+ try {
1314
+ if (!(await fs.pathExists(stateDir))) {
1315
+ return [];
1316
+ }
1317
+
1318
+ const files = await fs.readdir(stateDir);
1319
+ const states = [];
1320
+
1321
+ for (const file of files) {
1322
+ if (!file.endsWith('.json')) continue;
1323
+
1324
+ try {
1325
+ const filePath = path.join(stateDir, file);
1326
+ const state = await fs.readJson(filePath);
1327
+
1328
+ states.push({
1329
+ storyId: state.storyId || file.replace('.json', ''),
1330
+ workflowId: state.workflowId,
1331
+ status: state.status,
1332
+ progress: this._calculateProgressFromState(state),
1333
+ updatedAt: state.timestamps?.updatedAt,
1334
+ resumable: this._isResumable(state),
1335
+ });
1336
+ } catch {
1337
+ // Skip invalid files
1338
+ }
1339
+ }
1340
+
1341
+ return states.sort(
1342
+ (a, b) => new Date(b.updatedAt || 0).getTime() - new Date(a.updatedAt || 0).getTime(),
1343
+ );
1344
+ } catch (error) {
1345
+ this._log(`Failed to list states: ${error.message}`, { level: 'warn' });
1346
+ return [];
1347
+ }
1348
+ }
1349
+
1350
+ /**
1351
+ * Calculate progress percentage from a state object
1352
+ * @private
1353
+ */
1354
+ _calculateProgressFromState(state) {
1355
+ if (!state.epics) return 0;
1356
+
1357
+ const totalEpics = Object.keys(EPIC_CONFIG).filter((num) => !EPIC_CONFIG[num].onDemand).length;
1358
+
1359
+ const completedEpics = Object.values(state.epics).filter(
1360
+ (epic) => epic.status === EpicStatus.COMPLETED,
1361
+ ).length;
1362
+
1363
+ return Math.round((completedEpics / totalEpics) * 100);
1364
+ }
1365
+
1366
+ // ═══════════════════════════════════════════════════════════════════════════════════
1367
+ // FINALIZATION
1368
+ // ═══════════════════════════════════════════════════════════════════════════════════
1369
+
1370
+ /**
1371
+ * Finalize pipeline execution and generate summary
1372
+ * @param {Object} pipelineResult - Raw pipeline result
1373
+ * @returns {Object} Finalized result
1374
+ */
1375
+ finalize(pipelineResult = {}) {
1376
+ const duration =
1377
+ pipelineResult.duration ||
1378
+ (this.executionState.startedAt
1379
+ ? Date.now() - new Date(this.executionState.startedAt).getTime()
1380
+ : 0);
1381
+
1382
+ const minutes = Math.floor(duration / 60000);
1383
+ const seconds = Math.floor((duration % 60000) / 1000);
1384
+
1385
+ return {
1386
+ workflowId: this.executionState.workflowId,
1387
+ storyId: this.storyId,
1388
+ status: this._state,
1389
+ success: pipelineResult.success ?? this._state === OrchestratorState.COMPLETE,
1390
+ duration: `${minutes}m ${seconds}s`,
1391
+ durationMs: duration,
1392
+ techStack: TechStackDetector.getSummary(this.executionState.techStackProfile || {}),
1393
+ epics: {
1394
+ executed: pipelineResult.epicsExecuted || [],
1395
+ failed: pipelineResult.epicsFailed || [],
1396
+ skipped: pipelineResult.epicsSkipped || [],
1397
+ },
1398
+ errors: this.executionState.errors,
1399
+ insights: this.executionState.insights,
1400
+ state: this.executionState,
1401
+ };
1402
+ }
1403
+
1404
+ // ═══════════════════════════════════════════════════════════════════════════════════
1405
+ // UTILITIES
1406
+ // ═══════════════════════════════════════════════════════════════════════════════════
1407
+
1408
+ /**
1409
+ * Calculate overall progress percentage
1410
+ * @returns {number} Progress 0-100
1411
+ */
1412
+ getProgressPercentage() {
1413
+ const totalEpics = Object.keys(EPIC_CONFIG).filter((num) => !EPIC_CONFIG[num].onDemand).length;
1414
+
1415
+ const completedEpics = Object.values(this.executionState.epics).filter(
1416
+ (epic) => epic.status === EpicStatus.COMPLETED,
1417
+ ).length;
1418
+
1419
+ return Math.round((completedEpics / totalEpics) * 100);
1420
+ }
1421
+
1422
+ /**
1423
+ * Get current execution status summary
1424
+ * @returns {Object} Status summary
1425
+ */
1426
+ getStatus() {
1427
+ return {
1428
+ state: this._state,
1429
+ storyId: this.storyId,
1430
+ currentEpic: this.executionState.currentEpic,
1431
+ progress: this.getProgressPercentage(),
1432
+ epics: Object.fromEntries(
1433
+ Object.entries(this.executionState.epics).map(([num, epic]) => [
1434
+ num,
1435
+ { status: epic.status, attempts: epic.attempts },
1436
+ ]),
1437
+ ),
1438
+ errors: this.executionState.errors.length,
1439
+ };
1440
+ }
1441
+
1442
+ // ═══════════════════════════════════════════════════════════════════════════════════
1443
+ // LOGGING & CALLBACKS
1444
+ // ═══════════════════════════════════════════════════════════════════════════════════
1445
+
1446
+ /**
1447
+ * Internal logging
1448
+ * @private
1449
+ */
1450
+ _log(message, options = {}) {
1451
+ const timestamp = new Date().toISOString().split('T')[1].split('.')[0];
1452
+ const level = options.level || 'info';
1453
+ const icon = options.icon || '';
1454
+
1455
+ let coloredMessage;
1456
+ switch (level) {
1457
+ case 'error':
1458
+ coloredMessage = chalk.red(message);
1459
+ break;
1460
+ case 'warn':
1461
+ coloredMessage = chalk.yellow(message);
1462
+ break;
1463
+ case 'success':
1464
+ coloredMessage = chalk.green(message);
1465
+ break;
1466
+ default:
1467
+ coloredMessage = chalk.gray(message);
1468
+ }
1469
+
1470
+ console.log(
1471
+ `${chalk.dim(`[${timestamp}]`)} ${chalk.cyan('[MasterOrchestrator]')} ${icon} ${coloredMessage}`,
1472
+ );
1473
+
1474
+ // Emit log event for external listeners
1475
+ this.emit('log', { timestamp, level, message, ...options });
1476
+ }
1477
+
1478
+ /**
1479
+ * Default epic start callback
1480
+ * @private
1481
+ */
1482
+ _defaultEpicStart(epicNum, config) {
1483
+ console.log(chalk.blue(`\n${config.icon} Starting Epic ${epicNum}: ${config.name}`));
1484
+ console.log(chalk.gray(` ${config.description}`));
1485
+ }
1486
+
1487
+ /**
1488
+ * Default epic complete callback
1489
+ * @private
1490
+ */
1491
+ _defaultEpicComplete(epicNum, result) {
1492
+ const status = result?.success !== false ? '✅' : '❌';
1493
+ console.log(chalk.green(` ${status} Epic ${epicNum} complete`));
1494
+ }
1495
+
1496
+ /**
1497
+ * Default state change callback
1498
+ * @private
1499
+ */
1500
+ _defaultStateChange(from, to, _context) {
1501
+ console.log(chalk.magenta(` 📊 State: ${from} → ${to}`));
1502
+ }
1503
+ }
1504
+
1505
+ // ═══════════════════════════════════════════════════════════════════════════════════
1506
+ // STUB EXECUTOR (placeholder)
1507
+ // ═══════════════════════════════════════════════════════════════════════════════════
1508
+
1509
+ /**
1510
+ * Stub Epic Executor - placeholder for Story 0.3
1511
+ * Real executors will be implemented in Story 0.3
1512
+ */
1513
+ class StubEpicExecutor {
1514
+ constructor(orchestrator, epicNum) {
1515
+ this.orchestrator = orchestrator;
1516
+ this.epicNum = epicNum;
1517
+ this.config = EPIC_CONFIG[epicNum];
1518
+ }
1519
+
1520
+ async execute(_context) {
1521
+ console.log(chalk.yellow(` ⚠️ Using stub executor for Epic ${this.epicNum}`));
1522
+ console.log(chalk.gray(` Real executor (${this.config.executor}) not yet implemented`));
1523
+ console.log(chalk.gray(' See Story 0.3: Epic Executors'));
1524
+
1525
+ // Return minimal success result for pipeline to continue
1526
+ return {
1527
+ status: 'stub',
1528
+ epicNum: this.epicNum,
1529
+ message: `Stub executor for ${this.config.name}`,
1530
+ timestamp: new Date().toISOString(),
1531
+ };
1532
+ }
1533
+ }
1534
+
1535
+ // ═══════════════════════════════════════════════════════════════════════════════════
1536
+ // EXPORTS
1537
+ // ═══════════════════════════════════════════════════════════════════════════════════
1538
+
1539
+ module.exports = MasterOrchestrator;
1540
+ module.exports.OrchestratorState = OrchestratorState;
1541
+ module.exports.EpicStatus = EpicStatus;
1542
+ module.exports.EPIC_CONFIG = EPIC_CONFIG;
1543
+
1544
+