@therocketcode/gsd-core 1.4.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 (568) hide show
  1. package/.claude-plugin/plugin.json +23 -0
  2. package/GEMINI.md +53 -0
  3. package/LICENSE +21 -0
  4. package/README.ja-JP.md +125 -0
  5. package/README.ko-KR.md +125 -0
  6. package/README.md +144 -0
  7. package/README.pt-BR.md +125 -0
  8. package/README.zh-CN.md +125 -0
  9. package/agents/gsd-advisor-researcher.md +108 -0
  10. package/agents/gsd-ai-researcher.md +114 -0
  11. package/agents/gsd-assumptions-analyzer.md +105 -0
  12. package/agents/gsd-code-fixer.md +668 -0
  13. package/agents/gsd-code-reviewer.md +387 -0
  14. package/agents/gsd-codebase-mapper.md +853 -0
  15. package/agents/gsd-debug-session-manager.md +314 -0
  16. package/agents/gsd-debugger.md +1452 -0
  17. package/agents/gsd-doc-classifier.md +168 -0
  18. package/agents/gsd-doc-synthesizer.md +204 -0
  19. package/agents/gsd-doc-verifier.md +217 -0
  20. package/agents/gsd-doc-writer.md +616 -0
  21. package/agents/gsd-domain-researcher.md +147 -0
  22. package/agents/gsd-eval-auditor.md +191 -0
  23. package/agents/gsd-eval-planner.md +154 -0
  24. package/agents/gsd-executor.md +785 -0
  25. package/agents/gsd-framework-selector.md +160 -0
  26. package/agents/gsd-integration-checker.md +470 -0
  27. package/agents/gsd-intel-updater.md +342 -0
  28. package/agents/gsd-nyquist-auditor.md +203 -0
  29. package/agents/gsd-pattern-mapper.md +335 -0
  30. package/agents/gsd-phase-researcher.md +867 -0
  31. package/agents/gsd-plan-checker.md +978 -0
  32. package/agents/gsd-planner.md +1204 -0
  33. package/agents/gsd-project-researcher.md +611 -0
  34. package/agents/gsd-research-synthesizer.md +259 -0
  35. package/agents/gsd-roadmapper.md +688 -0
  36. package/agents/gsd-security-auditor.md +155 -0
  37. package/agents/gsd-ui-auditor.md +495 -0
  38. package/agents/gsd-ui-checker.md +309 -0
  39. package/agents/gsd-ui-researcher.md +374 -0
  40. package/agents/gsd-user-profiler.md +171 -0
  41. package/agents/gsd-verifier.md +923 -0
  42. package/assets/gsd-logo-2000-transparent.png +0 -0
  43. package/assets/gsd-logo-2000-transparent.svg +17 -0
  44. package/assets/gsd-logo-2000.png +0 -0
  45. package/assets/gsd-logo-2000.svg +21 -0
  46. package/assets/terminal.svg +68 -0
  47. package/bin/install.js +12726 -0
  48. package/bin/lib/ui-safety-gate.cjs +107 -0
  49. package/commands/gsd/add-tests.md +42 -0
  50. package/commands/gsd/ai-integration-phase.md +37 -0
  51. package/commands/gsd/audit-fix.md +34 -0
  52. package/commands/gsd/audit-milestone.md +37 -0
  53. package/commands/gsd/audit-uat.md +24 -0
  54. package/commands/gsd/autonomous.md +48 -0
  55. package/commands/gsd/capture.md +62 -0
  56. package/commands/gsd/cleanup.md +24 -0
  57. package/commands/gsd/code-review.md +59 -0
  58. package/commands/gsd/complete-milestone.md +143 -0
  59. package/commands/gsd/config.md +56 -0
  60. package/commands/gsd/debug.md +52 -0
  61. package/commands/gsd/discover-product.md +65 -0
  62. package/commands/gsd/discuss-phase.md +77 -0
  63. package/commands/gsd/docs-update.md +49 -0
  64. package/commands/gsd/eval-review.md +33 -0
  65. package/commands/gsd/execute-phase.md +66 -0
  66. package/commands/gsd/explore.md +27 -0
  67. package/commands/gsd/extract-learnings.md +23 -0
  68. package/commands/gsd/fast.md +31 -0
  69. package/commands/gsd/forensics.md +57 -0
  70. package/commands/gsd/graphify.md +204 -0
  71. package/commands/gsd/health.md +31 -0
  72. package/commands/gsd/help.md +28 -0
  73. package/commands/gsd/import.md +45 -0
  74. package/commands/gsd/inbox.md +39 -0
  75. package/commands/gsd/ingest-docs.md +42 -0
  76. package/commands/gsd/manager.md +45 -0
  77. package/commands/gsd/map-codebase.md +83 -0
  78. package/commands/gsd/milestone-summary.md +51 -0
  79. package/commands/gsd/model-domain.md +65 -0
  80. package/commands/gsd/mvp-phase.md +45 -0
  81. package/commands/gsd/new-milestone.md +45 -0
  82. package/commands/gsd/new-project.md +47 -0
  83. package/commands/gsd/ns-context.md +23 -0
  84. package/commands/gsd/ns-ideate.md +24 -0
  85. package/commands/gsd/ns-manage.md +29 -0
  86. package/commands/gsd/ns-project.md +22 -0
  87. package/commands/gsd/ns-review.md +26 -0
  88. package/commands/gsd/ns-workflow.md +28 -0
  89. package/commands/gsd/pause-work.md +43 -0
  90. package/commands/gsd/phase.md +56 -0
  91. package/commands/gsd/plan-phase.md +64 -0
  92. package/commands/gsd/plan-review-convergence.md +59 -0
  93. package/commands/gsd/pr-branch.md +26 -0
  94. package/commands/gsd/profile-user.md +46 -0
  95. package/commands/gsd/progress.md +48 -0
  96. package/commands/gsd/quick.md +174 -0
  97. package/commands/gsd/recommend-architecture.md +64 -0
  98. package/commands/gsd/resume-work.md +30 -0
  99. package/commands/gsd/review-backlog.md +63 -0
  100. package/commands/gsd/review.md +42 -0
  101. package/commands/gsd/secure-phase.md +36 -0
  102. package/commands/gsd/settings.md +29 -0
  103. package/commands/gsd/ship.md +24 -0
  104. package/commands/gsd/sketch.md +60 -0
  105. package/commands/gsd/spec-phase.md +63 -0
  106. package/commands/gsd/spike.md +57 -0
  107. package/commands/gsd/stats.md +20 -0
  108. package/commands/gsd/surface.md +155 -0
  109. package/commands/gsd/testing-strategy.md +65 -0
  110. package/commands/gsd/thread.md +24 -0
  111. package/commands/gsd/ui-phase.md +35 -0
  112. package/commands/gsd/ui-review.md +33 -0
  113. package/commands/gsd/ultraplan-phase.md +34 -0
  114. package/commands/gsd/undo.md +35 -0
  115. package/commands/gsd/update.md +49 -0
  116. package/commands/gsd/validate-phase.md +36 -0
  117. package/commands/gsd/verify-work.md +39 -0
  118. package/commands/gsd/workspace.md +52 -0
  119. package/commands/gsd/workstreams.md +70 -0
  120. package/gemini-extension.json +6 -0
  121. package/gsd-core/bin/check-latest-version.cjs +161 -0
  122. package/gsd-core/bin/gsd-tools.cjs +1928 -0
  123. package/gsd-core/bin/lib/active-workstream-store.cjs +291 -0
  124. package/gsd-core/bin/lib/adr-parser.cjs +399 -0
  125. package/gsd-core/bin/lib/agent-command-router.cjs +68 -0
  126. package/gsd-core/bin/lib/artifacts.cjs +51 -0
  127. package/gsd-core/bin/lib/audit.cjs +743 -0
  128. package/gsd-core/bin/lib/check-command-router.cjs +343 -0
  129. package/gsd-core/bin/lib/cjs-command-router-adapter.cjs +81 -0
  130. package/gsd-core/bin/lib/cli-exit.cjs +42 -0
  131. package/gsd-core/bin/lib/clock.cjs +95 -0
  132. package/gsd-core/bin/lib/clusters.cjs +132 -0
  133. package/gsd-core/bin/lib/code-review-flags.cjs +59 -0
  134. package/gsd-core/bin/lib/command-aliases.cjs +809 -0
  135. package/gsd-core/bin/lib/command-arg-projection.cjs +55 -0
  136. package/gsd-core/bin/lib/command-routing-hub.cjs +300 -0
  137. package/gsd-core/bin/lib/commands.cjs +1203 -0
  138. package/gsd-core/bin/lib/config-schema.cjs +29 -0
  139. package/gsd-core/bin/lib/config-types.cjs +19 -0
  140. package/gsd-core/bin/lib/config.cjs +738 -0
  141. package/gsd-core/bin/lib/configuration.cjs +239 -0
  142. package/gsd-core/bin/lib/context-utilization.cjs +48 -0
  143. package/gsd-core/bin/lib/core.cjs +2051 -0
  144. package/gsd-core/bin/lib/decisions.cjs +118 -0
  145. package/gsd-core/bin/lib/docs.cjs +252 -0
  146. package/gsd-core/bin/lib/drift.cjs +364 -0
  147. package/gsd-core/bin/lib/fallow-runner.cjs +115 -0
  148. package/gsd-core/bin/lib/frontmatter.cjs +442 -0
  149. package/gsd-core/bin/lib/gap-checker.cjs +257 -0
  150. package/gsd-core/bin/lib/graphify.cjs +496 -0
  151. package/gsd-core/bin/lib/gsd2-import.cjs +456 -0
  152. package/gsd-core/bin/lib/init-command-router.cjs +62 -0
  153. package/gsd-core/bin/lib/init.cjs +1815 -0
  154. package/gsd-core/bin/lib/install-profiles.cjs +584 -0
  155. package/gsd-core/bin/lib/installer-migration-authoring.cjs +122 -0
  156. package/gsd-core/bin/lib/installer-migration-report.cjs +350 -0
  157. package/gsd-core/bin/lib/installer-migrations/000-first-time-baseline.cjs +218 -0
  158. package/gsd-core/bin/lib/installer-migrations/001-legacy-orphan-files.cjs +48 -0
  159. package/gsd-core/bin/lib/installer-migrations/002-codex-legacy-hooks-json.cjs +94 -0
  160. package/gsd-core/bin/lib/installer-migrations/003-rename-get-shit-done-to-gsd-core.cjs +108 -0
  161. package/gsd-core/bin/lib/installer-migrations.cjs +823 -0
  162. package/gsd-core/bin/lib/intel.cjs +590 -0
  163. package/gsd-core/bin/lib/learnings.cjs +270 -0
  164. package/gsd-core/bin/lib/legacy-cleanup.cjs +253 -0
  165. package/gsd-core/bin/lib/milestone.cjs +373 -0
  166. package/gsd-core/bin/lib/model-catalog.cjs +154 -0
  167. package/gsd-core/bin/lib/model-profiles.cjs +24 -0
  168. package/gsd-core/bin/lib/observability/event.cjs +51 -0
  169. package/gsd-core/bin/lib/observability/logger.cjs +146 -0
  170. package/gsd-core/bin/lib/observability/redaction.cjs +48 -0
  171. package/gsd-core/bin/lib/package-identity.cjs +35 -0
  172. package/gsd-core/bin/lib/package-legitimacy.cjs +368 -0
  173. package/gsd-core/bin/lib/phase-command-router.cjs +189 -0
  174. package/gsd-core/bin/lib/phase-lifecycle.cjs +74 -0
  175. package/gsd-core/bin/lib/phase.cjs +1307 -0
  176. package/gsd-core/bin/lib/phases-command-router.cjs +43 -0
  177. package/gsd-core/bin/lib/plan-scan.cjs +91 -0
  178. package/gsd-core/bin/lib/planning-workspace.cjs +245 -0
  179. package/gsd-core/bin/lib/profile-output.cjs +1120 -0
  180. package/gsd-core/bin/lib/profile-pipeline.cjs +517 -0
  181. package/gsd-core/bin/lib/project-root.cjs +119 -0
  182. package/gsd-core/bin/lib/prompt-budget.cjs +305 -0
  183. package/gsd-core/bin/lib/research-provider.cjs +137 -0
  184. package/gsd-core/bin/lib/research-store.cjs +167 -0
  185. package/gsd-core/bin/lib/review-reviewer-selection.cjs +121 -0
  186. package/gsd-core/bin/lib/roadmap-command-router.cjs +166 -0
  187. package/gsd-core/bin/lib/roadmap-upgrade.cjs +476 -0
  188. package/gsd-core/bin/lib/roadmap.cjs +600 -0
  189. package/gsd-core/bin/lib/runtime-artifact-layout.cjs +312 -0
  190. package/gsd-core/bin/lib/runtime-config-adapter-registry.cjs +56 -0
  191. package/gsd-core/bin/lib/runtime-homes.cjs +190 -0
  192. package/gsd-core/bin/lib/runtime-name-policy.cjs +96 -0
  193. package/gsd-core/bin/lib/runtime-slash.cjs +119 -0
  194. package/gsd-core/bin/lib/schema-detect.cjs +159 -0
  195. package/gsd-core/bin/lib/secrets.cjs +34 -0
  196. package/gsd-core/bin/lib/security.cjs +480 -0
  197. package/gsd-core/bin/lib/semver-compare.cjs +42 -0
  198. package/gsd-core/bin/lib/shell-command-projection.cjs +533 -0
  199. package/gsd-core/bin/lib/state-command-router.cjs +160 -0
  200. package/gsd-core/bin/lib/state-document.cjs +259 -0
  201. package/gsd-core/bin/lib/state.cjs +2010 -0
  202. package/gsd-core/bin/lib/surface.cjs +449 -0
  203. package/gsd-core/bin/lib/task-command-router.cjs +85 -0
  204. package/gsd-core/bin/lib/template.cjs +237 -0
  205. package/gsd-core/bin/lib/uat.cjs +297 -0
  206. package/gsd-core/bin/lib/ui-safety-gate.cjs +98 -0
  207. package/gsd-core/bin/lib/update-context.cjs +218 -0
  208. package/gsd-core/bin/lib/validate-command-router.cjs +91 -0
  209. package/gsd-core/bin/lib/validate.cjs +112 -0
  210. package/gsd-core/bin/lib/verification-command-router.cjs +31 -0
  211. package/gsd-core/bin/lib/verification.cjs +193 -0
  212. package/gsd-core/bin/lib/verify-command-router.cjs +44 -0
  213. package/gsd-core/bin/lib/verify.cjs +1451 -0
  214. package/gsd-core/bin/lib/workstream-inventory-builder.cjs +81 -0
  215. package/gsd-core/bin/lib/workstream-inventory.cjs +147 -0
  216. package/gsd-core/bin/lib/workstream-name-policy.cjs +91 -0
  217. package/gsd-core/bin/lib/workstream.cjs +380 -0
  218. package/gsd-core/bin/lib/worktree-base-ref.cjs +325 -0
  219. package/gsd-core/bin/lib/worktree-safety.cjs +943 -0
  220. package/gsd-core/bin/shared/config-defaults.manifest.json +98 -0
  221. package/gsd-core/bin/shared/config-schema.manifest.json +192 -0
  222. package/gsd-core/bin/shared/model-catalog.json +149 -0
  223. package/gsd-core/bin/shared/runtime-aliases.manifest.json +75 -0
  224. package/gsd-core/bin/verify-reapply-patches.cjs +349 -0
  225. package/gsd-core/contexts/dev.md +21 -0
  226. package/gsd-core/contexts/research.md +22 -0
  227. package/gsd-core/contexts/review.md +23 -0
  228. package/gsd-core/references/agent-contracts.md +79 -0
  229. package/gsd-core/references/ai-evals.md +156 -0
  230. package/gsd-core/references/ai-frameworks.md +186 -0
  231. package/gsd-core/references/architecture-decision.md +74 -0
  232. package/gsd-core/references/artifact-types.md +131 -0
  233. package/gsd-core/references/auth-in-tests.md +91 -0
  234. package/gsd-core/references/autonomous-smart-discuss.md +277 -0
  235. package/gsd-core/references/checkpoints.md +814 -0
  236. package/gsd-core/references/common-bug-patterns.md +114 -0
  237. package/gsd-core/references/context-budget.md +85 -0
  238. package/gsd-core/references/continuation-format.md +253 -0
  239. package/gsd-core/references/db-test-isolation.md +54 -0
  240. package/gsd-core/references/debugger-philosophy.md +76 -0
  241. package/gsd-core/references/decimal-phase-calculation.md +64 -0
  242. package/gsd-core/references/doc-conflict-engine.md +91 -0
  243. package/gsd-core/references/domain-modeling.md +80 -0
  244. package/gsd-core/references/domain-probes.md +125 -0
  245. package/gsd-core/references/e2e-tiering.md +35 -0
  246. package/gsd-core/references/execute-mvp-tdd.md +81 -0
  247. package/gsd-core/references/executor-examples.md +110 -0
  248. package/gsd-core/references/few-shot-examples/plan-checker.md +73 -0
  249. package/gsd-core/references/few-shot-examples/verifier.md +109 -0
  250. package/gsd-core/references/flaky-test-checklist.md +22 -0
  251. package/gsd-core/references/gate-prompts.md +100 -0
  252. package/gsd-core/references/gates.md +70 -0
  253. package/gsd-core/references/git-integration.md +298 -0
  254. package/gsd-core/references/git-planning-commit.md +40 -0
  255. package/gsd-core/references/ios-scaffold.md +123 -0
  256. package/gsd-core/references/mandatory-initial-read.md +2 -0
  257. package/gsd-core/references/model-profile-resolution.md +38 -0
  258. package/gsd-core/references/model-profiles.md +245 -0
  259. package/gsd-core/references/mvp-concepts.md +49 -0
  260. package/gsd-core/references/phase-argument-parsing.md +61 -0
  261. package/gsd-core/references/planner-antipatterns.md +89 -0
  262. package/gsd-core/references/planner-chunked.md +49 -0
  263. package/gsd-core/references/planner-gap-closure.md +62 -0
  264. package/gsd-core/references/planner-graphify-auto-update.md +67 -0
  265. package/gsd-core/references/planner-human-verify-mode.md +57 -0
  266. package/gsd-core/references/planner-interface-context.md +62 -0
  267. package/gsd-core/references/planner-load-graph-context.md +36 -0
  268. package/gsd-core/references/planner-mvp-mode.md +53 -0
  269. package/gsd-core/references/planner-reviews.md +39 -0
  270. package/gsd-core/references/planner-revision.md +87 -0
  271. package/gsd-core/references/planner-source-audit.md +73 -0
  272. package/gsd-core/references/planning-config.md +473 -0
  273. package/gsd-core/references/product-discovery.md +49 -0
  274. package/gsd-core/references/project-skills-discovery.md +19 -0
  275. package/gsd-core/references/questioning.md +162 -0
  276. package/gsd-core/references/realistic-test-data.md +44 -0
  277. package/gsd-core/references/research-documentation-lookup.md +29 -0
  278. package/gsd-core/references/research-philosophy.md +29 -0
  279. package/gsd-core/references/research-verification-protocol.md +27 -0
  280. package/gsd-core/references/revision-loop.md +97 -0
  281. package/gsd-core/references/scout-codebase.md +51 -0
  282. package/gsd-core/references/skeleton-template.md +48 -0
  283. package/gsd-core/references/sketch-interactivity.md +41 -0
  284. package/gsd-core/references/sketch-theme-system.md +94 -0
  285. package/gsd-core/references/sketch-tooling.md +45 -0
  286. package/gsd-core/references/sketch-variant-patterns.md +81 -0
  287. package/gsd-core/references/spidr-splitting.md +69 -0
  288. package/gsd-core/references/tdd.md +330 -0
  289. package/gsd-core/references/test-containers.md +55 -0
  290. package/gsd-core/references/test-strategy.md +75 -0
  291. package/gsd-core/references/thinking-models-debug.md +44 -0
  292. package/gsd-core/references/thinking-models-execution.md +50 -0
  293. package/gsd-core/references/thinking-models-planning.md +62 -0
  294. package/gsd-core/references/thinking-models-research.md +50 -0
  295. package/gsd-core/references/thinking-models-verification.md +55 -0
  296. package/gsd-core/references/thinking-partner.md +96 -0
  297. package/gsd-core/references/ui-brand.md +162 -0
  298. package/gsd-core/references/universal-anti-patterns.md +63 -0
  299. package/gsd-core/references/user-profiling.md +681 -0
  300. package/gsd-core/references/user-story-template.md +58 -0
  301. package/gsd-core/references/verification-overrides.md +227 -0
  302. package/gsd-core/references/verification-patterns.md +612 -0
  303. package/gsd-core/references/verify-mvp-mode.md +85 -0
  304. package/gsd-core/references/workstream-flag.md +111 -0
  305. package/gsd-core/references/worktree-branch-check.md +38 -0
  306. package/gsd-core/references/worktree-path-safety.md +67 -0
  307. package/gsd-core/templates/AI-SPEC.md +246 -0
  308. package/gsd-core/templates/DEBUG.md +169 -0
  309. package/gsd-core/templates/README.md +77 -0
  310. package/gsd-core/templates/SECURITY.md +61 -0
  311. package/gsd-core/templates/UAT.md +265 -0
  312. package/gsd-core/templates/UI-SPEC.md +100 -0
  313. package/gsd-core/templates/VALIDATION.md +76 -0
  314. package/gsd-core/templates/adr.md +58 -0
  315. package/gsd-core/templates/claude-md.md +145 -0
  316. package/gsd-core/templates/codebase/architecture.md +255 -0
  317. package/gsd-core/templates/codebase/concerns.md +310 -0
  318. package/gsd-core/templates/codebase/conventions.md +307 -0
  319. package/gsd-core/templates/codebase/integrations.md +280 -0
  320. package/gsd-core/templates/codebase/stack.md +186 -0
  321. package/gsd-core/templates/codebase/structure.md +285 -0
  322. package/gsd-core/templates/codebase/testing.md +480 -0
  323. package/gsd-core/templates/config.json +62 -0
  324. package/gsd-core/templates/context.md +352 -0
  325. package/gsd-core/templates/continue-here.md +78 -0
  326. package/gsd-core/templates/copilot-instructions.md +7 -0
  327. package/gsd-core/templates/debug-subagent-prompt.md +91 -0
  328. package/gsd-core/templates/dev-preferences.md +21 -0
  329. package/gsd-core/templates/discovery.md +146 -0
  330. package/gsd-core/templates/discussion-log.md +63 -0
  331. package/gsd-core/templates/domain-model.md +54 -0
  332. package/gsd-core/templates/milestone-archive.md +123 -0
  333. package/gsd-core/templates/milestone.md +115 -0
  334. package/gsd-core/templates/phase-prompt.md +610 -0
  335. package/gsd-core/templates/planner-subagent-prompt.md +117 -0
  336. package/gsd-core/templates/product-brief.md +55 -0
  337. package/gsd-core/templates/project.md +186 -0
  338. package/gsd-core/templates/requirements.md +231 -0
  339. package/gsd-core/templates/research-project/ARCHITECTURE.md +204 -0
  340. package/gsd-core/templates/research-project/FEATURES.md +147 -0
  341. package/gsd-core/templates/research-project/PITFALLS.md +200 -0
  342. package/gsd-core/templates/research-project/STACK.md +120 -0
  343. package/gsd-core/templates/research-project/SUMMARY.md +170 -0
  344. package/gsd-core/templates/research.md +592 -0
  345. package/gsd-core/templates/retrospective.md +54 -0
  346. package/gsd-core/templates/roadmap.md +202 -0
  347. package/gsd-core/templates/spec.md +307 -0
  348. package/gsd-core/templates/state.md +195 -0
  349. package/gsd-core/templates/summary-complex.md +59 -0
  350. package/gsd-core/templates/summary-minimal.md +41 -0
  351. package/gsd-core/templates/summary-standard.md +48 -0
  352. package/gsd-core/templates/summary.md +248 -0
  353. package/gsd-core/templates/test-strategy.md +50 -0
  354. package/gsd-core/templates/user-profile.md +146 -0
  355. package/gsd-core/templates/user-setup.md +311 -0
  356. package/gsd-core/templates/verification-report.md +322 -0
  357. package/gsd-core/workflows/_runtime-launcher.snippet.sh +1 -0
  358. package/gsd-core/workflows/add-backlog.md +91 -0
  359. package/gsd-core/workflows/add-phase.md +113 -0
  360. package/gsd-core/workflows/add-tests.md +355 -0
  361. package/gsd-core/workflows/add-todo.md +161 -0
  362. package/gsd-core/workflows/ai-integration-phase.md +295 -0
  363. package/gsd-core/workflows/analyze-dependencies.md +96 -0
  364. package/gsd-core/workflows/audit-fix.md +178 -0
  365. package/gsd-core/workflows/audit-milestone.md +360 -0
  366. package/gsd-core/workflows/audit-uat.md +110 -0
  367. package/gsd-core/workflows/autonomous.md +797 -0
  368. package/gsd-core/workflows/check-todos.md +180 -0
  369. package/gsd-core/workflows/cleanup.md +195 -0
  370. package/gsd-core/workflows/code-review-fix.md +502 -0
  371. package/gsd-core/workflows/code-review.md +658 -0
  372. package/gsd-core/workflows/complete-milestone.md +855 -0
  373. package/gsd-core/workflows/debug.md +237 -0
  374. package/gsd-core/workflows/diagnose-issues.md +245 -0
  375. package/gsd-core/workflows/discover-product.md +112 -0
  376. package/gsd-core/workflows/discovery-phase.md +291 -0
  377. package/gsd-core/workflows/discuss-phase/modes/advisor.md +176 -0
  378. package/gsd-core/workflows/discuss-phase/modes/all.md +28 -0
  379. package/gsd-core/workflows/discuss-phase/modes/analyze.md +44 -0
  380. package/gsd-core/workflows/discuss-phase/modes/auto.md +57 -0
  381. package/gsd-core/workflows/discuss-phase/modes/batch.md +52 -0
  382. package/gsd-core/workflows/discuss-phase/modes/chain.md +98 -0
  383. package/gsd-core/workflows/discuss-phase/modes/default.md +141 -0
  384. package/gsd-core/workflows/discuss-phase/modes/power.md +44 -0
  385. package/gsd-core/workflows/discuss-phase/modes/text.md +55 -0
  386. package/gsd-core/workflows/discuss-phase/templates/checkpoint.json +18 -0
  387. package/gsd-core/workflows/discuss-phase/templates/context.md +136 -0
  388. package/gsd-core/workflows/discuss-phase/templates/discussion-log.md +50 -0
  389. package/gsd-core/workflows/discuss-phase-assumptions.md +675 -0
  390. package/gsd-core/workflows/discuss-phase-power.md +291 -0
  391. package/gsd-core/workflows/discuss-phase.md +499 -0
  392. package/gsd-core/workflows/do.md +111 -0
  393. package/gsd-core/workflows/docs-update.md +1176 -0
  394. package/gsd-core/workflows/edit-phase.md +295 -0
  395. package/gsd-core/workflows/eval-review.md +156 -0
  396. package/gsd-core/workflows/execute-phase/steps/codebase-drift-gate.md +95 -0
  397. package/gsd-core/workflows/execute-phase/steps/per-plan-worktree-gate.md +94 -0
  398. package/gsd-core/workflows/execute-phase/steps/post-merge-gate.md +117 -0
  399. package/gsd-core/workflows/execute-phase.md +1752 -0
  400. package/gsd-core/workflows/execute-plan.md +526 -0
  401. package/gsd-core/workflows/explore.md +146 -0
  402. package/gsd-core/workflows/extract-learnings.md +243 -0
  403. package/gsd-core/workflows/fast.md +124 -0
  404. package/gsd-core/workflows/forensics.md +279 -0
  405. package/gsd-core/workflows/graduation.md +196 -0
  406. package/gsd-core/workflows/health.md +224 -0
  407. package/gsd-core/workflows/help/modes/brief.md +22 -0
  408. package/gsd-core/workflows/help/modes/default.md +50 -0
  409. package/gsd-core/workflows/help/modes/full.md +789 -0
  410. package/gsd-core/workflows/help/modes/topic.md +74 -0
  411. package/gsd-core/workflows/help.md +24 -0
  412. package/gsd-core/workflows/import.md +256 -0
  413. package/gsd-core/workflows/inbox.md +387 -0
  414. package/gsd-core/workflows/ingest-docs.md +340 -0
  415. package/gsd-core/workflows/insert-phase.md +152 -0
  416. package/gsd-core/workflows/list-phase-assumptions.md +178 -0
  417. package/gsd-core/workflows/list-workspaces.md +57 -0
  418. package/gsd-core/workflows/manager.md +393 -0
  419. package/gsd-core/workflows/map-codebase.md +446 -0
  420. package/gsd-core/workflows/milestone-summary.md +224 -0
  421. package/gsd-core/workflows/model-domain.md +162 -0
  422. package/gsd-core/workflows/mvp-phase.md +222 -0
  423. package/gsd-core/workflows/new-milestone.md +635 -0
  424. package/gsd-core/workflows/new-project.md +1555 -0
  425. package/gsd-core/workflows/new-workspace.md +240 -0
  426. package/gsd-core/workflows/next.md +299 -0
  427. package/gsd-core/workflows/node-repair.md +92 -0
  428. package/gsd-core/workflows/note.md +158 -0
  429. package/gsd-core/workflows/pause-work.md +244 -0
  430. package/gsd-core/workflows/plan-milestone-gaps.md +281 -0
  431. package/gsd-core/workflows/plan-phase.md +1814 -0
  432. package/gsd-core/workflows/plan-review-convergence.md +346 -0
  433. package/gsd-core/workflows/plant-seed.md +230 -0
  434. package/gsd-core/workflows/pr-branch.md +157 -0
  435. package/gsd-core/workflows/profile-user.md +453 -0
  436. package/gsd-core/workflows/progress.md +699 -0
  437. package/gsd-core/workflows/quick.md +1017 -0
  438. package/gsd-core/workflows/reapply-patches.md +426 -0
  439. package/gsd-core/workflows/recommend-architecture.md +135 -0
  440. package/gsd-core/workflows/remove-phase.md +156 -0
  441. package/gsd-core/workflows/remove-workspace.md +108 -0
  442. package/gsd-core/workflows/resume-project.md +332 -0
  443. package/gsd-core/workflows/review.md +748 -0
  444. package/gsd-core/workflows/scan.md +107 -0
  445. package/gsd-core/workflows/secure-phase.md +182 -0
  446. package/gsd-core/workflows/session-report.md +146 -0
  447. package/gsd-core/workflows/settings-advanced.md +810 -0
  448. package/gsd-core/workflows/settings-integrations.md +312 -0
  449. package/gsd-core/workflows/settings.md +566 -0
  450. package/gsd-core/workflows/ship.md +405 -0
  451. package/gsd-core/workflows/sketch-wrap-up.md +286 -0
  452. package/gsd-core/workflows/sketch.md +361 -0
  453. package/gsd-core/workflows/spec-phase.md +263 -0
  454. package/gsd-core/workflows/spike-wrap-up.md +307 -0
  455. package/gsd-core/workflows/spike.md +453 -0
  456. package/gsd-core/workflows/stats.md +80 -0
  457. package/gsd-core/workflows/sync-skills.md +182 -0
  458. package/gsd-core/workflows/testing-strategy.md +122 -0
  459. package/gsd-core/workflows/thread.md +222 -0
  460. package/gsd-core/workflows/transition.md +694 -0
  461. package/gsd-core/workflows/ui-phase.md +328 -0
  462. package/gsd-core/workflows/ui-review.md +193 -0
  463. package/gsd-core/workflows/ultraplan-phase.md +199 -0
  464. package/gsd-core/workflows/undo.md +314 -0
  465. package/gsd-core/workflows/update.md +496 -0
  466. package/gsd-core/workflows/validate-phase.md +181 -0
  467. package/gsd-core/workflows/verify-phase.md +544 -0
  468. package/gsd-core/workflows/verify-work.md +781 -0
  469. package/hooks/dist/gsd-check-update-worker.js +108 -0
  470. package/hooks/dist/gsd-check-update.js +66 -0
  471. package/hooks/dist/gsd-config-reload.js +133 -0
  472. package/hooks/dist/gsd-context-monitor.js +195 -0
  473. package/hooks/dist/gsd-cursor-post-tool.js +75 -0
  474. package/hooks/dist/gsd-cursor-session-start.js +52 -0
  475. package/hooks/dist/gsd-graphify-update.sh +158 -0
  476. package/hooks/dist/gsd-phase-boundary.sh +47 -0
  477. package/hooks/dist/gsd-prompt-guard.js +97 -0
  478. package/hooks/dist/gsd-read-guard.js +101 -0
  479. package/hooks/dist/gsd-read-injection-scanner.js +203 -0
  480. package/hooks/dist/gsd-session-state.sh +59 -0
  481. package/hooks/dist/gsd-statusline.js +566 -0
  482. package/hooks/dist/gsd-update-banner.js +138 -0
  483. package/hooks/dist/gsd-validate-commit.sh +57 -0
  484. package/hooks/dist/gsd-workflow-guard.js +167 -0
  485. package/hooks/dist/gsd-worktree-path-guard.js +169 -0
  486. package/hooks/dist/lib/git-cmd.js +150 -0
  487. package/hooks/dist/lib/gsd-graphify-rebuild.sh +65 -0
  488. package/hooks/dist/managed-hooks-registry.cjs +38 -0
  489. package/hooks/gsd-check-update-worker.js +108 -0
  490. package/hooks/gsd-check-update.js +66 -0
  491. package/hooks/gsd-config-reload.js +133 -0
  492. package/hooks/gsd-context-monitor.js +195 -0
  493. package/hooks/gsd-cursor-post-tool.js +75 -0
  494. package/hooks/gsd-cursor-session-start.js +52 -0
  495. package/hooks/gsd-graphify-update.sh +158 -0
  496. package/hooks/gsd-phase-boundary.sh +47 -0
  497. package/hooks/gsd-prompt-guard.js +97 -0
  498. package/hooks/gsd-read-guard.js +101 -0
  499. package/hooks/gsd-read-injection-scanner.js +203 -0
  500. package/hooks/gsd-session-state.sh +59 -0
  501. package/hooks/gsd-statusline.js +566 -0
  502. package/hooks/gsd-update-banner.js +138 -0
  503. package/hooks/gsd-validate-commit.sh +57 -0
  504. package/hooks/gsd-workflow-guard.js +167 -0
  505. package/hooks/gsd-worktree-path-guard.js +169 -0
  506. package/hooks/hooks.json +69 -0
  507. package/hooks/lib/git-cmd.js +150 -0
  508. package/hooks/lib/gsd-graphify-rebuild.sh +65 -0
  509. package/hooks/managed-hooks-registry.cjs +38 -0
  510. package/package.json +115 -0
  511. package/scripts/affected-tests-lib.cjs +542 -0
  512. package/scripts/audit-workflow-script-paths.cjs +73 -0
  513. package/scripts/base64-scan.sh +351 -0
  514. package/scripts/build-hooks.js +247 -0
  515. package/scripts/changeset/README.md +129 -0
  516. package/scripts/changeset/cli.cjs +590 -0
  517. package/scripts/changeset/github-release-notes.cjs +199 -0
  518. package/scripts/changeset/lint.cjs +111 -0
  519. package/scripts/changeset/new.cjs +137 -0
  520. package/scripts/changeset/parse.cjs +114 -0
  521. package/scripts/changeset/render.cjs +34 -0
  522. package/scripts/changeset/serialize.cjs +130 -0
  523. package/scripts/check-alias-drift.cjs +114 -0
  524. package/scripts/check-env.cjs +312 -0
  525. package/scripts/check-npm-integrity.cjs +215 -0
  526. package/scripts/ci-guard-runner.cjs +22 -0
  527. package/scripts/ci-prepare-test-scope.cjs +51 -0
  528. package/scripts/ci-rebase-check.cjs +86 -0
  529. package/scripts/ci-test-scope.cjs +431 -0
  530. package/scripts/command-contract-helpers.cjs +64 -0
  531. package/scripts/diff-touches-shipped-paths.cjs +155 -0
  532. package/scripts/fix-slash-commands.cjs +147 -0
  533. package/scripts/gen-inventory-manifest.cjs +115 -0
  534. package/scripts/gen-research-agents.cjs +276 -0
  535. package/scripts/generate-package-identity.cjs +125 -0
  536. package/scripts/issue-dedupe.cjs +278 -0
  537. package/scripts/lib/allowlist-ratchet.cjs +136 -0
  538. package/scripts/lib/cli-exit.cjs +56 -0
  539. package/scripts/lint-command-contract.cjs +114 -0
  540. package/scripts/lint-descriptions.cjs +87 -0
  541. package/scripts/lint-docs-required.cjs +222 -0
  542. package/scripts/lint-legacy-dir-name.cjs +160 -0
  543. package/scripts/lint-package-identity-drift.cjs +141 -0
  544. package/scripts/lint-pr-check-project-dir.cjs +99 -0
  545. package/scripts/lint-shell-command-projection-drift.cjs +62 -0
  546. package/scripts/lint-skill-deps.cjs +185 -0
  547. package/scripts/lint-test-file-count.allowlist.json +135 -0
  548. package/scripts/lint-test-file-count.cjs +246 -0
  549. package/scripts/mutation-matrix.cjs +222 -0
  550. package/scripts/pr-template-policy.cjs +268 -0
  551. package/scripts/prompt-injection-scan.sh +207 -0
  552. package/scripts/release-notes/discord-release-summary.cjs +373 -0
  553. package/scripts/release-notes/format-github-release-notes.cjs +261 -0
  554. package/scripts/release-tarball-smoke.cjs +629 -0
  555. package/scripts/research-profiles.cjs +149 -0
  556. package/scripts/run-affected-tests.cjs +7 -0
  557. package/scripts/run-cross-platform-tests.cjs +67 -0
  558. package/scripts/run-tests.cjs +315 -0
  559. package/scripts/secret-scan-lint.sh +231 -0
  560. package/scripts/secret-scan.sh +358 -0
  561. package/scripts/setup-branch-protection.sh +236 -0
  562. package/scripts/strip-prose-atrefs.cjs +106 -0
  563. package/scripts/sync-manifest-versions.cjs +119 -0
  564. package/scripts/sync-rulesets.sh +34 -0
  565. package/scripts/sync-runtime-launcher.cjs +399 -0
  566. package/scripts/test-failure-reasons.cjs +34 -0
  567. package/scripts/verify-npm-publish.cjs +240 -0
  568. package/scripts/workflow-policy.cjs +450 -0
@@ -0,0 +1,218 @@
1
+ "use strict";
2
+ /**
3
+ * Update-context resolver (issue #498, candidate 3).
4
+ *
5
+ * ADR-457 build-at-publish: the hand-written bin/lib/update-context.cjs
6
+ * collapsed to a TypeScript source of truth. Behaviour is preserved
7
+ * byte-for-behaviour from the prior hand-written .cjs; only types are added.
8
+ */
9
+ var __importDefault = (this && this.__importDefault) || function (mod) {
10
+ return (mod && mod.__esModule) ? mod : { "default": mod };
11
+ };
12
+ Object.defineProperty(exports, "__esModule", { value: true });
13
+ exports.RUNTIME_DIRS = void 0;
14
+ exports.inferPreferredRuntime = inferPreferredRuntime;
15
+ exports.envRuntimeDirs = envRuntimeDirs;
16
+ exports.resolveUpdateContext = resolveUpdateContext;
17
+ exports.loadUpdateContext = loadUpdateContext;
18
+ const node_path_1 = __importDefault(require("node:path"));
19
+ const node_fs_1 = __importDefault(require("node:fs"));
20
+ const node_os_1 = __importDefault(require("node:os"));
21
+ // Runtime -> candidate relative dir. Order matters: it is the probe order, and
22
+ // mirrors the RUNTIME_DIRS array the bash used (a runtime may have several
23
+ // candidate dirs). Kept here, not derived from the installer's getDirName,
24
+ // because update detection probes ALL historical dirs per runtime.
25
+ exports.RUNTIME_DIRS = [
26
+ ['claude', '.claude'],
27
+ ['opencode', '.config/opencode'],
28
+ ['opencode', '.opencode'],
29
+ ['antigravity', '.gemini/antigravity-ide'],
30
+ ['antigravity', '.gemini/antigravity-cli'],
31
+ ['antigravity', '.gemini/antigravity'],
32
+ ['antigravity', '.agent'], // local Antigravity install dir (#503; bin/install.js getDirName('antigravity'))
33
+ ['gemini', '.gemini'],
34
+ ['kilo', '.config/kilo'],
35
+ ['kilo', '.kilo'],
36
+ ['codex', '.codex'],
37
+ ];
38
+ const SEMVER_PREFIX = /^\d+\.\d+\.\d+/;
39
+ function expandHome(p, home) {
40
+ if (!p)
41
+ return '';
42
+ return p.startsWith('~/') ? node_path_1.default.join(home, p.slice(2)) : p;
43
+ }
44
+ function versionFile(dir) { return node_path_1.default.join(dir, 'gsd-core', 'VERSION'); }
45
+ function markerFile(dir) { return node_path_1.default.join(dir, 'gsd-core', 'workflows', 'update.md'); }
46
+ // Detection: a dir "has GSD" if it carries a VERSION file or the update.md
47
+ // workflow marker.
48
+ function hasInstall(fs, dir) {
49
+ return fs.exists(versionFile(dir)) || fs.exists(markerFile(dir));
50
+ }
51
+ // Read VERSION at dir; return a trimmed semver string, or null if missing/invalid.
52
+ function validVersionAt(fs, dir) {
53
+ const raw = fs.readFile(versionFile(dir));
54
+ if (raw == null)
55
+ return null;
56
+ const trimmed = String(raw).trim();
57
+ return SEMVER_PREFIX.test(trimmed) ? trimmed : null;
58
+ }
59
+ // A version is TRUSTED only when BOTH the VERSION file and the update.md marker
60
+ // exist (and VERSION is valid semver).
61
+ function trustedVersionAt(fs, dir) {
62
+ return dir && fs.exists(markerFile(dir)) ? validVersionAt(fs, dir) : null;
63
+ }
64
+ // Infer the preferred runtime from preferredConfigDir config files, then env.
65
+ function inferPreferredRuntime({ fs, env, preferredConfigDir }) {
66
+ if (preferredConfigDir) {
67
+ if (fs.exists(node_path_1.default.join(preferredConfigDir, 'kilo.json')) ||
68
+ fs.exists(node_path_1.default.join(preferredConfigDir, 'kilo.jsonc')))
69
+ return 'kilo';
70
+ if (fs.exists(node_path_1.default.join(preferredConfigDir, 'opencode.json')) ||
71
+ fs.exists(node_path_1.default.join(preferredConfigDir, 'opencode.jsonc')))
72
+ return 'opencode';
73
+ if (fs.exists(node_path_1.default.join(preferredConfigDir, 'config.toml')))
74
+ return 'codex';
75
+ }
76
+ if (env['CODEX_HOME'])
77
+ return 'codex';
78
+ if (env['ANTIGRAVITY_CONFIG_DIR'])
79
+ return 'antigravity';
80
+ if (env['GEMINI_CONFIG_DIR'])
81
+ return 'gemini';
82
+ if (env['KILO_CONFIG_DIR'] || env['KILO_CONFIG'])
83
+ return 'kilo';
84
+ if (env['OPENCODE_CONFIG_DIR'] || env['OPENCODE_CONFIG'])
85
+ return 'opencode';
86
+ if (env['CLAUDE_CONFIG_DIR'])
87
+ return 'claude';
88
+ return 'claude';
89
+ }
90
+ // Absolute env-override candidates, mirroring the bash ENV_RUNTIME_DIRS block.
91
+ function envRuntimeDirs({ env, home }) {
92
+ const out = [];
93
+ const ex = (v) => expandHome(v, home);
94
+ if (env['CLAUDE_CONFIG_DIR'])
95
+ out.push(['claude', ex(env['CLAUDE_CONFIG_DIR'])]);
96
+ if (env['ANTIGRAVITY_CONFIG_DIR'])
97
+ out.push(['antigravity', ex(env['ANTIGRAVITY_CONFIG_DIR'])]);
98
+ if (env['GEMINI_CONFIG_DIR'])
99
+ out.push(['gemini', ex(env['GEMINI_CONFIG_DIR'])]);
100
+ if (env['KILO_CONFIG_DIR'])
101
+ out.push(['kilo', ex(env['KILO_CONFIG_DIR'])]);
102
+ else if (env['KILO_CONFIG'])
103
+ out.push(['kilo', node_path_1.default.dirname(ex(env['KILO_CONFIG']))]);
104
+ else if (env['XDG_CONFIG_HOME'])
105
+ out.push(['kilo', node_path_1.default.join(ex(env['XDG_CONFIG_HOME']), 'kilo')]);
106
+ if (env['OPENCODE_CONFIG_DIR'])
107
+ out.push(['opencode', ex(env['OPENCODE_CONFIG_DIR'])]);
108
+ else if (env['OPENCODE_CONFIG'])
109
+ out.push(['opencode', node_path_1.default.dirname(ex(env['OPENCODE_CONFIG']))]);
110
+ else if (env['XDG_CONFIG_HOME'])
111
+ out.push(['opencode', node_path_1.default.join(ex(env['XDG_CONFIG_HOME']), 'opencode')]);
112
+ if (env['CODEX_HOME'])
113
+ out.push(['codex', ex(env['CODEX_HOME'])]);
114
+ return out;
115
+ }
116
+ // Stable reorder: entries whose runtime === preferred first, original order kept.
117
+ function preferFirst(entries, preferred) {
118
+ const pref = entries.filter(([rt]) => rt === preferred);
119
+ const rest = entries.filter(([rt]) => rt !== preferred);
120
+ return [...pref, ...rest];
121
+ }
122
+ /**
123
+ * Pure resolver. Returns { installedVersion, scope, runtime, gsdDir }.
124
+ */
125
+ function resolveUpdateContext({ home, cwd, env = {}, fs, preferredConfigDir = '', preferredRuntime = '', }) {
126
+ // Expand a leading `~/` before any probe.
127
+ preferredConfigDir = expandHome(preferredConfigDir, home);
128
+ const preferred = preferredRuntime || inferPreferredRuntime({ fs, env, preferredConfigDir });
129
+ // Fast path: a validated preferredConfigDir (custom --config-dir install).
130
+ if (preferredConfigDir && hasInstall(fs, preferredConfigDir)) {
131
+ const resolvedPref = node_path_1.default.resolve(preferredConfigDir);
132
+ let scope = 'GLOBAL';
133
+ for (const [, reldir] of exports.RUNTIME_DIRS) {
134
+ if (node_path_1.default.resolve(cwd, reldir) === resolvedPref) {
135
+ scope = 'LOCAL';
136
+ break;
137
+ }
138
+ }
139
+ return {
140
+ installedVersion: trustedVersionAt(fs, preferredConfigDir) ?? '0.0.0',
141
+ scope,
142
+ runtime: preferred,
143
+ gsdDir: preferredConfigDir,
144
+ };
145
+ }
146
+ const orderedEnv = preferFirst(envRuntimeDirs({ env, home }), preferred);
147
+ const orderedRuntime = preferFirst(exports.RUNTIME_DIRS, preferred);
148
+ // LOCAL probe (relative to cwd).
149
+ let localRuntime = '', localDir = '';
150
+ for (const [rt, reldir] of orderedRuntime) {
151
+ const cand = node_path_1.default.resolve(cwd, reldir);
152
+ if (hasInstall(fs, cand)) {
153
+ localRuntime = rt;
154
+ localDir = cand;
155
+ break;
156
+ }
157
+ }
158
+ // GLOBAL probe: absolute env candidates first, then $HOME-relative.
159
+ let globalRuntime = '', globalDir = '';
160
+ for (const [rt, absdir] of orderedEnv) {
161
+ if (hasInstall(fs, absdir)) {
162
+ globalRuntime = rt;
163
+ globalDir = node_path_1.default.resolve(absdir);
164
+ break;
165
+ }
166
+ }
167
+ if (!globalRuntime) {
168
+ for (const [rt, reldir] of orderedRuntime) {
169
+ const cand = node_path_1.default.resolve(home, reldir);
170
+ if (hasInstall(fs, cand)) {
171
+ globalRuntime = rt;
172
+ globalDir = cand;
173
+ break;
174
+ }
175
+ }
176
+ }
177
+ const localValid = trustedVersionAt(fs, localDir);
178
+ const isLocal = !!localValid && (!globalDir || localDir !== globalDir);
179
+ if (isLocal) {
180
+ return { installedVersion: localValid, scope: 'LOCAL', runtime: localRuntime, gsdDir: localDir };
181
+ }
182
+ const globalValid = trustedVersionAt(fs, globalDir);
183
+ if (globalValid) {
184
+ return { installedVersion: globalValid, scope: 'GLOBAL', runtime: globalRuntime, gsdDir: globalDir };
185
+ }
186
+ // A runtime dir was detected (VERSION or marker present) but is not a
187
+ // complete, valid install: keep scope/runtime/dir and report 0.0.0 so the
188
+ // caller re-installs.
189
+ if (localRuntime && (!globalDir || localDir !== globalDir)) {
190
+ return { installedVersion: '0.0.0', scope: 'LOCAL', runtime: localRuntime, gsdDir: localDir };
191
+ }
192
+ if (globalRuntime) {
193
+ return { installedVersion: '0.0.0', scope: 'GLOBAL', runtime: globalRuntime, gsdDir: globalDir };
194
+ }
195
+ return { installedVersion: '0.0.0', scope: 'UNKNOWN', runtime: 'claude', gsdDir: '' };
196
+ }
197
+ /**
198
+ * CLI wiring: resolve against the real filesystem.
199
+ */
200
+ function loadUpdateContext(opts = {}) {
201
+ const fs = {
202
+ exists: (p) => node_fs_1.default.existsSync(p),
203
+ readFile: (p) => { try {
204
+ return node_fs_1.default.readFileSync(p, 'utf8');
205
+ }
206
+ catch {
207
+ return null;
208
+ } },
209
+ };
210
+ return resolveUpdateContext({
211
+ home: opts.home ?? node_os_1.default.homedir(),
212
+ cwd: opts.cwd ?? process.cwd(),
213
+ env: opts.env ?? process.env,
214
+ fs,
215
+ preferredConfigDir: opts.preferredConfigDir ?? '',
216
+ preferredRuntime: opts.preferredRuntime ?? '',
217
+ });
218
+ }
@@ -0,0 +1,91 @@
1
+ "use strict";
2
+ /**
3
+ * Manifest-backed validate subcommand router.
4
+ * Keeps gsd-tools.cjs thin while preserving existing command semantics.
5
+ *
6
+ * Phase 6: validate.consistency, validate.health, validate.agents are
7
+ * dispatched via executeForCjs when the SDK is available. CJS fallback
8
+ * retained when:
9
+ * - GSD_WORKSTREAM is active (workstream-scoped requests fall through to CJS).
10
+ * - SDK is unavailable (build not present).
11
+ *
12
+ * CJS-only subcommands:
13
+ * - context: complex inline logic using classifyContextUtilization and
14
+ * output formatting that has no direct SDK counterpart. Remains CJS-native.
15
+ *
16
+ * SDK-only (unsupported in CJS router): none.
17
+ *
18
+ * ADR-457 build-at-publish: the hand-written bin/lib/validate-command-router.cjs
19
+ * collapsed to a TypeScript source of truth. Behaviour is preserved byte-for-behaviour
20
+ * from the prior hand-written .cjs; only types are added.
21
+ */
22
+ const command_aliases_cjs_1 = require("./command-aliases.cjs");
23
+ const runtime_slash_cjs_1 = require("./runtime-slash.cjs");
24
+ // eslint-disable-next-line @typescript-eslint/no-require-imports
25
+ const cjsCommandRouterAdapter = require("./cjs-command-router-adapter.cjs");
26
+ const { routeCjsCommandFamily } = cjsCommandRouterAdapter;
27
+ const command_arg_projection_cjs_1 = require("./command-arg-projection.cjs");
28
+ const context_utilization_cjs_1 = require("./context-utilization.cjs");
29
+ // ─── Implementation ───────────────────────────────────────────────────────────
30
+ function routeValidateCommand({ verify, args, cwd, raw, output: outputFn, error }) {
31
+ routeCjsCommandFamily({
32
+ args,
33
+ subcommands: command_aliases_cjs_1.VALIDATE_SUBCOMMANDS,
34
+ unsupported: {},
35
+ error,
36
+ unknownMessage: (_subcommand, available) => `Unknown validate subcommand. Available: ${available.join(', ')}`,
37
+ handlers: {
38
+ consistency: () => verify.cmdValidateConsistency(cwd, raw),
39
+ // Keep health on CJS for now so fix hints are rendered via runtime-slash
40
+ // helpers (codex expects $gsd-* command shape).
41
+ health: () => {
42
+ const repairFlag = args.includes('--repair');
43
+ const backfillFlag = args.includes('--backfill');
44
+ verify.cmdValidateHealth(cwd, { repair: repairFlag, backfill: backfillFlag }, raw);
45
+ },
46
+ agents: () => verify.cmdValidateAgents(cwd, raw),
47
+ // context: CJS-only — complex inline logic using classifyContextUtilization
48
+ // with custom output formatting that has no direct SDK counterpart.
49
+ context: () => {
50
+ const opts = (0, command_arg_projection_cjs_1.parseNamedArgs)(args, ['tokens-used', 'context-window']);
51
+ if (opts['tokens-used'] === null) {
52
+ error('--tokens-used <integer> is required for `validate context`');
53
+ return;
54
+ }
55
+ if (opts['context-window'] === null) {
56
+ error('--context-window <integer> is required for `validate context`');
57
+ return;
58
+ }
59
+ const threadCmd = String((0, runtime_slash_cjs_1.formatGsdSlash)('thread', (0, runtime_slash_cjs_1.resolveRuntime)(cwd)));
60
+ const RECOMMENDATIONS = {
61
+ [context_utilization_cjs_1.STATES.HEALTHY]: null,
62
+ [context_utilization_cjs_1.STATES.WARNING]: `Context is approaching the fracture zone — consider ${threadCmd} to continue in a fresh window.`,
63
+ [context_utilization_cjs_1.STATES.CRITICAL]: `Reasoning quality may degrade past 70% utilization (fracture point). Run ${threadCmd} now to preserve output quality.`,
64
+ };
65
+ let classified;
66
+ try {
67
+ classified = (0, context_utilization_cjs_1.classifyContextUtilization)(Number(opts['tokens-used']), Number(opts['context-window']));
68
+ }
69
+ catch (e) {
70
+ const msg = e.message;
71
+ const flag = /tokensUsed/.test(msg) ? '--tokens-used' : '--context-window';
72
+ error(`${flag} must be a non-negative integer (window > 0), got the values supplied`);
73
+ return;
74
+ }
75
+ const result = { ...classified, recommendation: RECOMMENDATIONS[classified.state] };
76
+ if (args.includes('--json')) {
77
+ outputFn(result, raw);
78
+ }
79
+ else {
80
+ const lines = [`Context utilization: ${result.percent}% (${result.state})`];
81
+ if (result.recommendation)
82
+ lines.push(result.recommendation);
83
+ outputFn(result, true, lines.join('\n'));
84
+ }
85
+ },
86
+ },
87
+ });
88
+ }
89
+ module.exports = {
90
+ routeValidateCommand,
91
+ };
@@ -0,0 +1,112 @@
1
+ "use strict";
2
+ /**
3
+ * Validate Helpers — pure computation helpers and regex constants extracted from
4
+ * sdk/src/query/validate.ts (ADR-457 build-at-publish: the hand-written
5
+ * bin/lib/validate.cjs collapsed to a TypeScript source of truth). Behaviour is
6
+ * preserved byte-for-behaviour from the prior hand-written .cjs; only types are
7
+ * added.
8
+ *
9
+ * No I/O. No async. No filesystem operations.
10
+ *
11
+ * Issue #6 drift items (three helpers):
12
+ * 1. phaseVariants() — replaces parseInt-based padded/unpadded check in verify.cjs
13
+ * Check 8 (W006 disk-existence and W007 roadmap-membership checks).
14
+ * 2. buildRoadmapPhaseVariants() — replaces raw roadmapPhases set in W007 loop.
15
+ * 3. buildNotStartedPhaseVariants() — replaces raw+zero-padded notStartedPhases
16
+ * in W006 skip logic.
17
+ *
18
+ * Issue #26 drift items (four constants/helpers):
19
+ * 4. phaseDirNameRe — W005 phase directory naming regex (was inline in verify.cjs Check 6).
20
+ * 5. PHASE_TOKEN_FROM_DIR_RE — extracts phase token from dir name (was inline in
21
+ * verify.cjs forEachArchivedPhaseToken / collectDiskPhases).
22
+ * 6. MILESTONE_ARCHIVE_DIR_RE — identifies milestone archive directories (was inline).
23
+ * 7. canonicalPlanStem() — I001 PLAN/SUMMARY stem canonicalization (was inline in Check 7).
24
+ *
25
+ * I/O adapter pattern (ADR-3524 §4): pure transforms extracted from the SDK.
26
+ *
27
+ * References:
28
+ * - ADR-3524 (docs/adr/3524-cjs-sdk-hard-seam.md)
29
+ * - Issue #6 (TheRocketCodeMX/gsd-core)
30
+ * - Issue #26 (TheRocketCodeMX/gsd-core)
31
+ * - PR #154 (issue #4) — generator pattern precedent
32
+ * - PR #156 (issue #6) — validate.ts generator that #26 extends
33
+ */
34
+ Object.defineProperty(exports, "__esModule", { value: true });
35
+ exports.MILESTONE_ARCHIVE_DIR_RE = exports.PHASE_TOKEN_FROM_DIR_RE = exports.phaseDirNameRe = void 0;
36
+ exports.canonicalPlanStem = canonicalPlanStem;
37
+ exports.phaseVariants = phaseVariants;
38
+ exports.buildRoadmapPhaseVariants = buildRoadmapPhaseVariants;
39
+ exports.buildNotStartedPhaseVariants = buildNotStartedPhaseVariants;
40
+ // ── Issue #26: regex constants (W005, W006-archived) ────────────────────────
41
+ // Matches legacy numeric dirs (01-setup), milestone-prefixed dirs (02-01-setup),
42
+ // deep dirs (02-04-01-deep), and project-code-prefixed variants (GSD-02-01-setup).
43
+ exports.phaseDirNameRe = /^(?:[A-Z]{1,6}-)?\d{2,}(?:-\d+)*(?:\.\d+)*-[\w-]+$/i;
44
+ // Extracts the full phase token from a directory name, including milestone-prefixed
45
+ // multi-segment tokens like "02-01" from "02-01-setup" or "GSD-02-01-setup".
46
+ // Greedily captures all leading all-digit segments before the first letter-start segment.
47
+ exports.PHASE_TOKEN_FROM_DIR_RE = /^(?:[A-Z]{1,6}-)?(\d+(?:-\d+)*[A-Z]?(?:\.\d+)*)(?:-[a-z]|$)/i;
48
+ exports.MILESTONE_ARCHIVE_DIR_RE = /^v\d+.*-phases$/i;
49
+ // ── Issue #26: I001 canonicalization ────────────────────────────────────────
50
+ function canonicalPlanStem(stem) {
51
+ const m = stem.match(/^(\d+[A-Z]?(?:\.\d+)*-\d+)/i);
52
+ return m ? m[1] : stem;
53
+ }
54
+ // ── Issue #6: phase variant helpers (W006/W007) ──────────────────────────────
55
+ function phaseVariants(phase) {
56
+ const variants = new Set([phase]);
57
+ const dotIdx = phase.indexOf('.');
58
+ const head = dotIdx === -1 ? phase : phase.slice(0, dotIdx);
59
+ const tail = dotIdx === -1 ? '' : phase.slice(dotIdx);
60
+ // Milestone-prefixed IDs: M-NN or M-N-N. Add padding-normalized variant.
61
+ // e.g. "2-01" → also "02-01"; "02-01" → also "2-01"
62
+ const milestoneHeadMatch = head.match(/^(\d+)((?:-\d+)+)([A-Z]?)$/i);
63
+ if (milestoneHeadMatch) {
64
+ const major = milestoneHeadMatch[1];
65
+ const subSegs = milestoneHeadMatch[2]; // e.g. "-01" or "-04-01"
66
+ const letter = milestoneHeadMatch[3] || '';
67
+ const paddedMajor = major.padStart(2, '0');
68
+ const unpaddedMajor = String(parseInt(major, 10));
69
+ // Pad/unpad sub-segments individually
70
+ const paddedSubs = subSegs.slice(1).split('-').map(s => s.padStart(2, '0')).join('-');
71
+ const unpaddedSubs = subSegs.slice(1).split('-').map(s => String(parseInt(s, 10))).join('-');
72
+ variants.add(`${paddedMajor}-${paddedSubs}${letter}${tail}`);
73
+ variants.add(`${unpaddedMajor}-${unpaddedSubs}${letter}${tail}`);
74
+ variants.add(`${unpaddedMajor}-${paddedSubs}${letter}${tail}`);
75
+ variants.add(`${paddedMajor}-${unpaddedSubs}${letter}${tail}`);
76
+ return variants;
77
+ }
78
+ // Plain numeric/decimal IDs: "1", "01", "12A", "12.1"
79
+ const headMatch = head.match(/^(\d+)([A-Z]?)$/i);
80
+ if (!headMatch)
81
+ return variants;
82
+ const numericHead = headMatch[1];
83
+ const letterSuffix = headMatch[2] || '';
84
+ variants.add(`${String(parseInt(numericHead, 10))}${letterSuffix}${tail}`);
85
+ variants.add(`${numericHead.padStart(2, '0')}${letterSuffix}${tail}`);
86
+ return variants;
87
+ }
88
+ function buildRoadmapPhaseVariants(roadmapContent) {
89
+ const roadmapPhases = new Set();
90
+ const roadmapPhaseVariants = new Set();
91
+ // Matches both legacy numeric (Phase 1:), decimal (Phase 2.1:), milestone-prefixed (Phase 2-01:),
92
+ // and bracket-prefixed (### [GSD] Phase 2-01:) headings.
93
+ const phasePattern = /#{2,4}\s*(?:\[[^\]]+\]\s*)?Phase\s+([\w][\w.-]*)\s*:/gi;
94
+ let m;
95
+ while ((m = phasePattern.exec(roadmapContent)) !== null) {
96
+ roadmapPhases.add(m[1]);
97
+ for (const variant of phaseVariants(m[1]))
98
+ roadmapPhaseVariants.add(variant);
99
+ }
100
+ return { roadmapPhases, roadmapPhaseVariants };
101
+ }
102
+ function buildNotStartedPhaseVariants(roadmapContent) {
103
+ const notStartedPhases = new Set();
104
+ // Also matches milestone-prefixed and bracket-prefixed checklist items.
105
+ const uncheckedPattern = /-\s*\[\s\]\s*\*{0,2}Phase\s+([\w][\w.-]*)[:\s*]/gi;
106
+ let um;
107
+ while ((um = uncheckedPattern.exec(roadmapContent)) !== null) {
108
+ for (const variant of phaseVariants(um[1]))
109
+ notStartedPhases.add(variant);
110
+ }
111
+ return notStartedPhases;
112
+ }
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+ /**
3
+ * Verification-status subcommand router.
4
+ * Routes `verification.status <phaseDir>` to verification.cmdVerificationStatus.
5
+ *
6
+ * Note: `verification` (reads verifier-emitted status) is distinct from `verify`
7
+ * (runs verification checks like plan-structure/artifacts). Keep them separate.
8
+ *
9
+ * ADR-457 build-at-publish: source in src/verification-command-router.cts,
10
+ * compiled to gsd-core/bin/lib/verification-command-router.cjs (gitignored).
11
+ */
12
+ // eslint-disable-next-line @typescript-eslint/no-require-imports
13
+ const cjsCommandRouterAdapter = require("./cjs-command-router-adapter.cjs");
14
+ const { routeCjsCommandFamily } = cjsCommandRouterAdapter;
15
+ // ─── Implementation ───────────────────────────────────────────────────────────
16
+ const VERIFICATION_SUBCOMMANDS = ['status'];
17
+ function routeVerificationCommand({ verification, args, cwd, raw, error, }) {
18
+ routeCjsCommandFamily({
19
+ args,
20
+ subcommands: VERIFICATION_SUBCOMMANDS,
21
+ unsupported: {},
22
+ error,
23
+ unknownMessage: (_subcommand, available) => `Unknown verification subcommand. Available: ${available.join(', ')}`,
24
+ handlers: {
25
+ status: () => verification.cmdVerificationStatus(cwd, args[2], raw),
26
+ },
27
+ });
28
+ }
29
+ module.exports = {
30
+ routeVerificationCommand,
31
+ };
@@ -0,0 +1,193 @@
1
+ "use strict";
2
+ /**
3
+ * Verification Status — single queryable home for verification-status routing.
4
+ *
5
+ * Issue #651: consolidate the pass/gaps_found/human_needed routing that was
6
+ * previously scattered across ship.md and execute-phase.md into a single
7
+ * tested module. Both workflow files will later consume this module's routing
8
+ * table as the single source of truth.
9
+ *
10
+ * ADR-457 build-at-publish: source in src/verification.cts, compiled to
11
+ * gsd-core/bin/lib/verification.cjs (gitignored).
12
+ *
13
+ * DEFECT.FRONTMATTER-SCALAR-BROAD-GREP fix: status extraction is scoped to
14
+ * the leading YAML frontmatter block only. A `status:` line in the body (e.g.
15
+ * inside a fenced code block) is ignored — this is the exact failure mode that
16
+ * issue #586 / PR #650 identified. The shared extractFrontmatter parser anchors
17
+ * its regex at byte 0 of the document, which provides this guarantee.
18
+ */
19
+ var __importDefault = (this && this.__importDefault) || function (mod) {
20
+ return (mod && mod.__esModule) ? mod : { "default": mod };
21
+ };
22
+ const node_fs_1 = __importDefault(require("node:fs"));
23
+ const node_path_1 = __importDefault(require("node:path"));
24
+ // eslint-disable-next-line @typescript-eslint/no-require-imports -- core.cjs is an export= CommonJS module
25
+ const core = require("./core.cjs");
26
+ // eslint-disable-next-line @typescript-eslint/no-require-imports -- frontmatter.cjs is an export= CommonJS module
27
+ const frontmatterMod = require("./frontmatter.cjs");
28
+ const { output, extractPhaseToken } = core;
29
+ const { extractFrontmatter } = frontmatterMod;
30
+ // ─── Constants ────────────────────────────────────────────────────────────────
31
+ /** The set of status values that the gsd-verifier agent emits. */
32
+ const VERIFIER_STATUSES = ['passed', 'gaps_found', 'human_needed'];
33
+ /**
34
+ * Canonical routing table for verification statuses.
35
+ *
36
+ * This is the single source of truth — ship.md and execute-phase.md will
37
+ * later import from here instead of embedding their own message strings.
38
+ *
39
+ * INTERNAL SENTINELS: 'missing' and 'unknown' are operational states constructed
40
+ * internally — the verifier (gsd-verifier.md) never emits them. The verifier only
41
+ * emits values in VERIFIER_STATUSES (passed|gaps_found|human_needed). The guard in
42
+ * readVerificationStatus excludes 'missing' and 'unknown' from raw-status table
43
+ * lookup so they can only be reached via internal construction paths.
44
+ *
45
+ * For 'gaps_found', next_command is built at call time in readVerificationStatus
46
+ * by substituting the phase number — it is NOT stored as a function in the table.
47
+ */
48
+ const VERIFICATION_ROUTING_TABLE = {
49
+ passed: {
50
+ status: 'passed',
51
+ next_action: 'Verification passed — continue.',
52
+ next_command: '',
53
+ },
54
+ gaps_found: {
55
+ status: 'gaps_found',
56
+ next_action: 'Gaps found. Plan the fixes, then re-run execute-phase before shipping.',
57
+ // next_command is computed at call time; this entry is never returned directly.
58
+ next_command: '',
59
+ },
60
+ human_needed: {
61
+ status: 'human_needed',
62
+ next_action: "Human verification required. Complete the manual tests in the phase's *-UAT.md, then re-run the verify step until status is passed.",
63
+ next_command: '',
64
+ },
65
+ // INTERNAL SENTINEL: constructed when no *-VERIFICATION.md file exists or when
66
+ // the file has no parseable frontmatter status. Never emitted by the verifier.
67
+ missing: {
68
+ status: 'missing',
69
+ next_action: 'No verification report found — the verify step never completed. Re-run execute-phase.',
70
+ next_command: '/gsd:execute-phase',
71
+ },
72
+ // INTERNAL SENTINEL: constructed when the file has a status value not in
73
+ // VERIFIER_STATUSES. Never emitted by the verifier.
74
+ unknown: {
75
+ status: 'unknown',
76
+ next_action: '', // filled in dynamically with the raw value
77
+ next_command: '/gsd:execute-phase',
78
+ },
79
+ };
80
+ /**
81
+ * Build a 'missing' result from the routing table.
82
+ * Used for two early-return paths: no *-VERIFICATION.md file found, and
83
+ * file present but no parseable frontmatter status.
84
+ */
85
+ function missingResult() {
86
+ const route = VERIFICATION_ROUTING_TABLE['missing'];
87
+ return {
88
+ status: route.status,
89
+ next_action: route.next_action,
90
+ next_command: route.next_command,
91
+ };
92
+ }
93
+ /**
94
+ * Read the verification status from the first `*-VERIFICATION.md` file in
95
+ * phaseDir and return the routing result.
96
+ *
97
+ * Behavior:
98
+ * 1. Find the first file matching `*-VERIFICATION.md` (sorted, take first).
99
+ * If none → status 'missing'.
100
+ * 2. Extract `status` from FRONTMATTER ONLY via the shared extractFrontmatter
101
+ * parser (DEFECT.FRONTMATTER-SCALAR-BROAD-GREP fix — parser anchors at byte 0).
102
+ * If no frontmatter block or no `status` key → status 'missing'.
103
+ * 3. Map to routing table. Unknown non-empty value → status 'unknown'.
104
+ *
105
+ * @param phaseDir - Absolute path to the phase directory.
106
+ * @param opts - Options. `opts.fs` allows test injection (defaults to node:fs).
107
+ */
108
+ function readVerificationStatus(phaseDir, opts = {}) {
109
+ const fsImpl = opts.fs ?? node_fs_1.default;
110
+ // Phase token for the gaps_found command
111
+ const baseName = node_path_1.default.basename(phaseDir);
112
+ const phaseToken = extractPhaseToken(baseName);
113
+ const phaseNumber = phaseToken.length > 0 ? phaseToken : baseName;
114
+ // 1. Find *-VERIFICATION.md
115
+ let verificationFile = null;
116
+ try {
117
+ const entries = fsImpl.readdirSync(phaseDir);
118
+ const candidates = entries.filter((f) => f.endsWith('-VERIFICATION.md')).sort();
119
+ verificationFile = candidates.length > 0 ? candidates[0] : null;
120
+ }
121
+ catch {
122
+ // Directory unreadable → treat as missing
123
+ verificationFile = null;
124
+ }
125
+ if (!verificationFile) {
126
+ return missingResult();
127
+ }
128
+ // 2. Read and parse frontmatter using the shared parser.
129
+ // extractFrontmatter anchors at byte 0, so body `status:` lines are ignored.
130
+ const filePath = node_path_1.default.join(phaseDir, verificationFile);
131
+ let rawStatus = null;
132
+ try {
133
+ const content = fsImpl.readFileSync(filePath, 'utf-8');
134
+ const fm = extractFrontmatter(content);
135
+ const statusVal = fm['status'];
136
+ // status is always a scalar string in a well-formed VERIFICATION.md frontmatter;
137
+ // only accept string values — arrays and objects are not valid status values.
138
+ if (typeof statusVal === 'string') {
139
+ const trimmed = statusVal.trim();
140
+ rawStatus = trimmed.length > 0 ? trimmed : null;
141
+ }
142
+ }
143
+ catch {
144
+ rawStatus = null;
145
+ }
146
+ if (!rawStatus) {
147
+ return missingResult();
148
+ }
149
+ // 3. Route — exclude internal sentinels from raw-file lookup (they are
150
+ // constructed internally above, never written by the verifier).
151
+ if (rawStatus in VERIFICATION_ROUTING_TABLE && rawStatus !== 'missing' && rawStatus !== 'unknown') {
152
+ const entry = VERIFICATION_ROUTING_TABLE[rawStatus];
153
+ // gaps_found: build the phase-specific command here rather than in the table.
154
+ const next_command = rawStatus === 'gaps_found'
155
+ ? `/gsd:plan-phase ${phaseNumber} --gaps`
156
+ : entry.next_command;
157
+ return {
158
+ status: entry.status,
159
+ next_action: entry.next_action,
160
+ next_command,
161
+ };
162
+ }
163
+ // Unknown value
164
+ const unknownRoute = VERIFICATION_ROUTING_TABLE['unknown'];
165
+ return {
166
+ status: unknownRoute.status,
167
+ next_action: `Unexpected verification status '${rawStatus}'. Re-run execute-phase verification.`,
168
+ next_command: unknownRoute.next_command,
169
+ };
170
+ }
171
+ /**
172
+ * CLI command handler: resolve phaseDir against cwd, call readVerificationStatus,
173
+ * emit via core.output().
174
+ *
175
+ * @param cwd - Current working directory (used to resolve phaseDirArg).
176
+ * @param phaseDirArg - Phase directory path (absolute or relative to cwd).
177
+ * @param raw - Whether to emit raw (non-JSON) output.
178
+ */
179
+ function cmdVerificationStatus(cwd, phaseDirArg, raw) {
180
+ if (!phaseDirArg) {
181
+ core.error('phase directory required for verification.status');
182
+ return;
183
+ }
184
+ const phaseDir = node_path_1.default.resolve(cwd, phaseDirArg);
185
+ const result = readVerificationStatus(phaseDir);
186
+ output(result, raw);
187
+ }
188
+ module.exports = {
189
+ VERIFIER_STATUSES,
190
+ VERIFICATION_ROUTING_TABLE,
191
+ readVerificationStatus,
192
+ cmdVerificationStatus,
193
+ };