@opengsd/gsd-pi 1.2.0-dev.fb12b103 → 1.2.0-dev.fbdca60b

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 (580) hide show
  1. package/dist/cli-model-override.d.ts +15 -0
  2. package/dist/cli-model-override.js +21 -0
  3. package/dist/cli.js +1 -18
  4. package/dist/headless-events.js +7 -5
  5. package/dist/loader.js +6 -4
  6. package/dist/mcp-server.js +2 -1
  7. package/dist/register-agent-bundles.d.ts +11 -2
  8. package/dist/register-agent-bundles.js +18 -4
  9. package/dist/resource-loader.d.ts +10 -5
  10. package/dist/resource-loader.js +121 -6
  11. package/dist/resources/.managed-resources-content-hash +1 -1
  12. package/dist/resources/GSD-WORKFLOW.md +5 -4
  13. package/dist/resources/extensions/ask-user-questions.js +3 -2
  14. package/dist/resources/extensions/claude-code-cli/stream-adapter.js +447 -215
  15. package/dist/resources/extensions/claude-code-cli/turn-assembler.js +33 -1
  16. package/dist/resources/extensions/gsd/auto/closeout.js +215 -0
  17. package/dist/resources/extensions/gsd/auto/custom-verify-retry-store.js +17 -2
  18. package/dist/resources/extensions/gsd/auto/detect-stuck.js +33 -13
  19. package/dist/resources/extensions/gsd/auto/dispatch-history.js +120 -0
  20. package/dist/resources/extensions/gsd/auto/dispatch-key.js +37 -0
  21. package/dist/resources/extensions/gsd/auto/dispatch.js +365 -0
  22. package/dist/resources/extensions/gsd/auto/finalize.js +347 -0
  23. package/dist/resources/extensions/gsd/auto/loop.js +7 -1
  24. package/dist/resources/extensions/gsd/auto/milestone-lease-reclaim.js +56 -0
  25. package/dist/resources/extensions/gsd/auto/orchestrator.js +167 -64
  26. package/dist/resources/extensions/gsd/auto/phase-helpers.js +146 -0
  27. package/dist/resources/extensions/gsd/auto/phases.js +17 -2329
  28. package/dist/resources/extensions/gsd/auto/pre-dispatch.js +534 -0
  29. package/dist/resources/extensions/gsd/auto/session.js +3 -0
  30. package/dist/resources/extensions/gsd/auto/unit-phase.js +694 -0
  31. package/dist/resources/extensions/gsd/auto/workflow-unit-dispatch.js +1 -1
  32. package/dist/resources/extensions/gsd/auto/worktree-safety-phase.js +125 -0
  33. package/dist/resources/extensions/gsd/auto-direct-dispatch.js +11 -34
  34. package/dist/resources/extensions/gsd/auto-dispatch.js +39 -58
  35. package/dist/resources/extensions/gsd/auto-model-selection.js +11 -7
  36. package/dist/resources/extensions/gsd/auto-post-unit.js +30 -12
  37. package/dist/resources/extensions/gsd/auto-prompts.js +66 -9
  38. package/dist/resources/extensions/gsd/auto-start.js +26 -8
  39. package/dist/resources/extensions/gsd/auto-unit-closeout.js +45 -21
  40. package/dist/resources/extensions/gsd/auto-unit-tool-scope.js +5 -4
  41. package/dist/resources/extensions/gsd/auto-verification.js +23 -30
  42. package/dist/resources/extensions/gsd/auto-worktree.js +15 -2
  43. package/dist/resources/extensions/gsd/auto.js +52 -2
  44. package/dist/resources/extensions/gsd/blocked-models.js +28 -0
  45. package/dist/resources/extensions/gsd/bootstrap/agent-end-recovery.js +26 -6
  46. package/dist/resources/extensions/gsd/bootstrap/dynamic-tools.js +37 -7
  47. package/dist/resources/extensions/gsd/bootstrap/exec-tools.js +2 -2
  48. package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +107 -45
  49. package/dist/resources/extensions/gsd/bootstrap/write-gate.js +302 -80
  50. package/dist/resources/extensions/gsd/closeout-wizard.js +92 -0
  51. package/dist/resources/extensions/gsd/commands/context.js +16 -2
  52. package/dist/resources/extensions/gsd/commands-handlers.js +46 -3
  53. package/dist/resources/extensions/gsd/commands-mcp-status.js +2 -2
  54. package/dist/resources/extensions/gsd/commands-workflow-templates.js +9 -2
  55. package/dist/resources/extensions/gsd/consent-question.js +353 -0
  56. package/dist/resources/extensions/gsd/consent-verdict.js +63 -0
  57. package/dist/resources/extensions/gsd/crash-recovery.js +8 -3
  58. package/dist/resources/extensions/gsd/db/engine.js +24 -6
  59. package/dist/resources/extensions/gsd/db/queries.js +56 -0
  60. package/dist/resources/extensions/gsd/db-migration-backup.js +51 -8
  61. package/dist/resources/extensions/gsd/db-transaction.js +27 -23
  62. package/dist/resources/extensions/gsd/db-writer.js +8 -17
  63. package/dist/resources/extensions/gsd/dispatch-guard.js +10 -35
  64. package/dist/resources/extensions/gsd/doctor-engine-checks.js +5 -5
  65. package/dist/resources/extensions/gsd/doctor-environment.js +256 -125
  66. package/dist/resources/extensions/gsd/doctor-git-checks.js +2 -18
  67. package/dist/resources/extensions/gsd/engine-hook-contract.js +70 -0
  68. package/dist/resources/extensions/gsd/files.js +33 -19
  69. package/dist/resources/extensions/gsd/gsd-command-home.js +22 -12
  70. package/dist/resources/extensions/gsd/gsd-db.js +17 -21
  71. package/dist/resources/extensions/gsd/guidance.js +60 -0
  72. package/dist/resources/extensions/gsd/guided-flow.js +93 -4
  73. package/dist/resources/extensions/gsd/health-widget.js +87 -28
  74. package/dist/resources/extensions/gsd/markdown-renderer.js +10 -0
  75. package/dist/resources/extensions/gsd/mcp-bridge.js +10 -0
  76. package/dist/resources/extensions/gsd/memory-relations.js +1 -1
  77. package/dist/resources/extensions/gsd/milestone-closeout.js +85 -24
  78. package/dist/resources/extensions/gsd/milestone-planning-persistence.js +2 -2
  79. package/dist/resources/extensions/gsd/milestone-reopen-events.js +3 -5
  80. package/dist/resources/extensions/gsd/milestone-settlement.js +2 -2
  81. package/dist/resources/extensions/gsd/notifications.js +12 -7
  82. package/dist/resources/extensions/gsd/parsers-legacy.js +16 -4
  83. package/dist/resources/extensions/gsd/projection-flush.js +7 -0
  84. package/dist/resources/extensions/gsd/prompts/complete-slice.md +3 -3
  85. package/dist/resources/extensions/gsd/prompts/execute-task.md +3 -2
  86. package/dist/resources/extensions/gsd/prompts/plan-milestone.md +1 -1
  87. package/dist/resources/extensions/gsd/prompts/plan-slice.md +1 -1
  88. package/dist/resources/extensions/gsd/prompts/quick-task.md +1 -1
  89. package/dist/resources/extensions/gsd/prompts/reassess-roadmap.md +1 -1
  90. package/dist/resources/extensions/gsd/prompts/refine-slice.md +1 -1
  91. package/dist/resources/extensions/gsd/prompts/replan-slice.md +1 -1
  92. package/dist/resources/extensions/gsd/prompts/research-milestone.md +1 -1
  93. package/dist/resources/extensions/gsd/prompts/research-slice.md +1 -1
  94. package/dist/resources/extensions/gsd/prompts/rewrite-docs.md +1 -1
  95. package/dist/resources/extensions/gsd/prompts/run-uat.md +8 -4
  96. package/dist/resources/extensions/gsd/prompts/triage-captures.md +1 -1
  97. package/dist/resources/extensions/gsd/prompts/validate-milestone.md +1 -1
  98. package/dist/resources/extensions/gsd/prompts/workflow-start.md +2 -1
  99. package/dist/resources/extensions/gsd/reactive-graph.js +8 -1
  100. package/dist/resources/extensions/gsd/roadmap-slices.js +25 -3
  101. package/dist/resources/extensions/gsd/session-lock.js +1 -1
  102. package/dist/resources/extensions/gsd/skill-activation.js +3 -6
  103. package/dist/resources/extensions/gsd/state.js +11 -2
  104. package/dist/resources/extensions/gsd/tool-contract.js +14 -3
  105. package/dist/resources/extensions/gsd/tool-presentation-plan.js +4 -4
  106. package/dist/resources/extensions/gsd/tool-surface-readiness.js +83 -31
  107. package/dist/resources/extensions/gsd/tools/complete-milestone.js +3 -2
  108. package/dist/resources/extensions/gsd/tools/complete-slice.js +22 -12
  109. package/dist/resources/extensions/gsd/tools/complete-task.js +65 -2
  110. package/dist/resources/extensions/gsd/tools/plan-slice.js +2 -2
  111. package/dist/resources/extensions/gsd/tools/plan-task.js +2 -2
  112. package/dist/resources/extensions/gsd/tools/reassess-roadmap.js +2 -2
  113. package/dist/resources/extensions/gsd/tools/reopen-milestone.js +2 -2
  114. package/dist/resources/extensions/gsd/tools/reopen-slice.js +2 -2
  115. package/dist/resources/extensions/gsd/tools/reopen-task.js +2 -2
  116. package/dist/resources/extensions/gsd/tools/replan-slice.js +2 -2
  117. package/dist/resources/extensions/gsd/tools/workflow-tool-executors.js +67 -2
  118. package/dist/resources/extensions/gsd/uat-policy.js +40 -15
  119. package/dist/resources/extensions/gsd/unit-context-composer.js +1 -1
  120. package/dist/resources/extensions/gsd/unit-registry.js +34 -4
  121. package/dist/resources/extensions/gsd/verdict-parser.js +1 -1
  122. package/dist/resources/extensions/gsd/verification-verdict.js +2 -1
  123. package/dist/resources/extensions/gsd/workflow-event-ledger.js +91 -0
  124. package/dist/resources/extensions/gsd/workflow-event-vocabulary.js +46 -0
  125. package/dist/resources/extensions/gsd/workflow-events.js +6 -18
  126. package/dist/resources/extensions/gsd/workflow-mcp-auto-prep.js +2 -0
  127. package/dist/resources/extensions/gsd/workflow-mcp-readiness-cache.js +105 -0
  128. package/dist/resources/extensions/gsd/workflow-reconcile.js +21 -56
  129. package/dist/resources/extensions/gsd/worktree-lifecycle.js +3 -2
  130. package/dist/resources/extensions/gsd/worktree-manager.js +7 -1
  131. package/dist/resources/extensions/gsd/worktree-safety.js +28 -26
  132. package/dist/resources/extensions/gsd/worktree.js +8 -1
  133. package/dist/resources/extensions/mcp-client/manager.js +6 -1
  134. package/dist/resources/extensions/shared/gsd-browser-cli.js +21 -2
  135. package/dist/resources/shared/gsd-browser-path-sync.js +214 -0
  136. package/dist/resources/shared/package-manager-detection.js +1 -1
  137. package/dist/resources/skills/create-skill/SKILL.md +3 -0
  138. package/dist/resources/skills/create-skill/references/skill-structure.md +1 -0
  139. package/dist/runtime-checks.d.ts +10 -0
  140. package/dist/runtime-checks.js +27 -0
  141. package/dist/tsconfig.extensions.tsbuildinfo +1 -1
  142. package/dist/update-check.d.ts +2 -0
  143. package/dist/update-check.js +24 -1
  144. package/dist/update-cmd.js +20 -3
  145. package/dist/web/standalone/.next/BUILD_ID +1 -1
  146. package/dist/web/standalone/.next/app-path-routes-manifest.json +6 -6
  147. package/dist/web/standalone/.next/build-manifest.json +2 -2
  148. package/dist/web/standalone/.next/prerender-manifest.json +3 -3
  149. package/dist/web/standalone/.next/server/app/_global-error.html +1 -1
  150. package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
  151. package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  152. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  153. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  154. package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  155. package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  156. package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  157. package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
  158. package/dist/web/standalone/.next/server/app/_not-found.rsc +1 -1
  159. package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +1 -1
  160. package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  161. package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
  162. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  163. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  164. package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
  165. package/dist/web/standalone/.next/server/app/api/boot/route.js.nft.json +1 -1
  166. package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route.js.nft.json +1 -1
  167. package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route.js.nft.json +1 -1
  168. package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route.js.nft.json +1 -1
  169. package/dist/web/standalone/.next/server/app/api/captures/route.js.nft.json +1 -1
  170. package/dist/web/standalone/.next/server/app/api/cleanup/route.js.nft.json +1 -1
  171. package/dist/web/standalone/.next/server/app/api/doctor/route.js.nft.json +1 -1
  172. package/dist/web/standalone/.next/server/app/api/export-data/route.js.nft.json +1 -1
  173. package/dist/web/standalone/.next/server/app/api/files/route.js.nft.json +1 -1
  174. package/dist/web/standalone/.next/server/app/api/forensics/route.js.nft.json +1 -1
  175. package/dist/web/standalone/.next/server/app/api/git/route.js.nft.json +1 -1
  176. package/dist/web/standalone/.next/server/app/api/history/route.js.nft.json +1 -1
  177. package/dist/web/standalone/.next/server/app/api/hooks/route.js.nft.json +1 -1
  178. package/dist/web/standalone/.next/server/app/api/inspect/route.js.nft.json +1 -1
  179. package/dist/web/standalone/.next/server/app/api/knowledge/route.js.nft.json +1 -1
  180. package/dist/web/standalone/.next/server/app/api/live-state/route.js.nft.json +1 -1
  181. package/dist/web/standalone/.next/server/app/api/mcp-connections/route.js.nft.json +1 -1
  182. package/dist/web/standalone/.next/server/app/api/notifications/route.js.nft.json +1 -1
  183. package/dist/web/standalone/.next/server/app/api/onboarding/route.js.nft.json +1 -1
  184. package/dist/web/standalone/.next/server/app/api/projects/route.js.nft.json +1 -1
  185. package/dist/web/standalone/.next/server/app/api/recovery/route.js.nft.json +1 -1
  186. package/dist/web/standalone/.next/server/app/api/session/browser/route.js.nft.json +1 -1
  187. package/dist/web/standalone/.next/server/app/api/session/command/route.js.nft.json +1 -1
  188. package/dist/web/standalone/.next/server/app/api/session/events/route.js.nft.json +1 -1
  189. package/dist/web/standalone/.next/server/app/api/session/manage/route.js.nft.json +1 -1
  190. package/dist/web/standalone/.next/server/app/api/settings-data/route.js.nft.json +1 -1
  191. package/dist/web/standalone/.next/server/app/api/shutdown/route.js.nft.json +1 -1
  192. package/dist/web/standalone/.next/server/app/api/skill-health/route.js.nft.json +1 -1
  193. package/dist/web/standalone/.next/server/app/api/steer/route.js.nft.json +1 -1
  194. package/dist/web/standalone/.next/server/app/api/switch-root/route.js.nft.json +1 -1
  195. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js.nft.json +1 -1
  196. package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js.nft.json +1 -1
  197. package/dist/web/standalone/.next/server/app/api/undo/route.js.nft.json +1 -1
  198. package/dist/web/standalone/.next/server/app/api/visualizer/route.js.nft.json +1 -1
  199. package/dist/web/standalone/.next/server/app/index.html +1 -1
  200. package/dist/web/standalone/.next/server/app/index.rsc +1 -1
  201. package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
  202. package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +1 -1
  203. package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
  204. package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +1 -1
  205. package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
  206. package/dist/web/standalone/.next/server/app-paths-manifest.json +6 -6
  207. package/dist/web/standalone/.next/server/chunks/{5942.js → 1128.js} +1 -1
  208. package/dist/web/standalone/.next/server/chunks/8357.js +2 -2
  209. package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
  210. package/dist/web/standalone/.next/server/pages/404.html +1 -1
  211. package/dist/web/standalone/.next/server/pages/500.html +1 -1
  212. package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
  213. package/dist/web/standalone/node_modules/node-pty/build/Makefile +1 -1
  214. package/dist/web/standalone/node_modules/postcss/lib/container.js +26 -18
  215. package/dist/web/standalone/node_modules/postcss/lib/css-syntax-error.js +47 -14
  216. package/dist/web/standalone/node_modules/postcss/lib/declaration.js +4 -4
  217. package/dist/web/standalone/node_modules/postcss/lib/fromJSON.js +3 -3
  218. package/dist/web/standalone/node_modules/postcss/lib/input.js +54 -29
  219. package/dist/web/standalone/node_modules/postcss/lib/lazy-result.js +47 -37
  220. package/dist/web/standalone/node_modules/postcss/lib/map-generator.js +26 -9
  221. package/dist/web/standalone/node_modules/postcss/lib/no-work-result.js +57 -55
  222. package/dist/web/standalone/node_modules/postcss/lib/node.js +99 -31
  223. package/dist/web/standalone/node_modules/postcss/lib/parse.js +1 -1
  224. package/dist/web/standalone/node_modules/postcss/lib/parser.js +10 -9
  225. package/dist/web/standalone/node_modules/postcss/lib/postcss.js +12 -12
  226. package/dist/web/standalone/node_modules/postcss/lib/previous-map.js +30 -11
  227. package/dist/web/standalone/node_modules/postcss/lib/processor.js +7 -7
  228. package/dist/web/standalone/node_modules/postcss/lib/result.js +5 -5
  229. package/dist/web/standalone/node_modules/postcss/lib/rule.js +6 -6
  230. package/dist/web/standalone/node_modules/postcss/lib/stringifier.js +69 -28
  231. package/dist/web/standalone/node_modules/postcss/lib/tokenize.js +6 -2
  232. package/dist/web/standalone/node_modules/postcss/package.json +48 -48
  233. package/package.json +3 -3
  234. package/packages/cloud-mcp-gateway/package.json +2 -2
  235. package/packages/contracts/package.json +1 -1
  236. package/packages/daemon/package.json +4 -4
  237. package/packages/gsd-agent-core/dist/sdk.d.ts.map +1 -1
  238. package/packages/gsd-agent-core/dist/sdk.js +6 -4
  239. package/packages/gsd-agent-core/dist/sdk.js.map +1 -1
  240. package/packages/gsd-agent-core/package.json +5 -5
  241. package/packages/gsd-agent-modes/dist/modes/interactive/components/settings-selector.d.ts +2 -0
  242. package/packages/gsd-agent-modes/dist/modes/interactive/components/settings-selector.d.ts.map +1 -1
  243. package/packages/gsd-agent-modes/dist/modes/interactive/components/settings-selector.js +10 -0
  244. package/packages/gsd-agent-modes/dist/modes/interactive/components/settings-selector.js.map +1 -1
  245. package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.d.ts +8 -0
  246. package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.d.ts.map +1 -1
  247. package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.js +50 -6
  248. package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.js.map +1 -1
  249. package/packages/gsd-agent-modes/dist/modes/interactive/components/transcript-design.d.ts +2 -0
  250. package/packages/gsd-agent-modes/dist/modes/interactive/components/transcript-design.d.ts.map +1 -1
  251. package/packages/gsd-agent-modes/dist/modes/interactive/components/transcript-design.js +34 -5
  252. package/packages/gsd-agent-modes/dist/modes/interactive/components/transcript-design.js.map +1 -1
  253. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode.d.ts +1 -0
  254. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode.d.ts.map +1 -1
  255. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode.js +17 -0
  256. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode.js.map +1 -1
  257. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-settings.d.ts.map +1 -1
  258. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-settings.js +4 -0
  259. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-settings.js.map +1 -1
  260. package/packages/gsd-agent-modes/package.json +7 -7
  261. package/packages/mcp-server/README.md +12 -3
  262. package/packages/mcp-server/dist/cli-runner.d.ts +40 -0
  263. package/packages/mcp-server/dist/cli-runner.d.ts.map +1 -0
  264. package/packages/mcp-server/dist/cli-runner.js +137 -0
  265. package/packages/mcp-server/dist/cli-runner.js.map +1 -0
  266. package/packages/mcp-server/dist/cli.js +2 -53
  267. package/packages/mcp-server/dist/cli.js.map +1 -1
  268. package/packages/mcp-server/dist/moonshot-tool-schema.d.ts +29 -0
  269. package/packages/mcp-server/dist/moonshot-tool-schema.d.ts.map +1 -0
  270. package/packages/mcp-server/dist/moonshot-tool-schema.js +50 -0
  271. package/packages/mcp-server/dist/moonshot-tool-schema.js.map +1 -0
  272. package/packages/mcp-server/dist/pid-registry.d.ts +46 -0
  273. package/packages/mcp-server/dist/pid-registry.d.ts.map +1 -0
  274. package/packages/mcp-server/dist/pid-registry.js +459 -0
  275. package/packages/mcp-server/dist/pid-registry.js.map +1 -0
  276. package/packages/mcp-server/dist/probe-mode.d.ts +4 -0
  277. package/packages/mcp-server/dist/probe-mode.d.ts.map +1 -0
  278. package/packages/mcp-server/dist/probe-mode.js +10 -0
  279. package/packages/mcp-server/dist/probe-mode.js.map +1 -0
  280. package/packages/mcp-server/dist/server.d.ts.map +1 -1
  281. package/packages/mcp-server/dist/server.js +4 -0
  282. package/packages/mcp-server/dist/server.js.map +1 -1
  283. package/packages/mcp-server/dist/stdio-watchdog.d.ts +8 -0
  284. package/packages/mcp-server/dist/stdio-watchdog.d.ts.map +1 -0
  285. package/packages/mcp-server/dist/stdio-watchdog.js +40 -0
  286. package/packages/mcp-server/dist/stdio-watchdog.js.map +1 -0
  287. package/packages/mcp-server/dist/workflow-tools.d.ts +18 -18
  288. package/packages/mcp-server/dist/workflow-tools.d.ts.map +1 -1
  289. package/packages/mcp-server/dist/workflow-tools.js +161 -81
  290. package/packages/mcp-server/dist/workflow-tools.js.map +1 -1
  291. package/packages/mcp-server/package.json +5 -4
  292. package/packages/native/package.json +1 -1
  293. package/packages/pi-agent-core/dist/agent-loop.js +43 -2
  294. package/packages/pi-agent-core/dist/agent-loop.js.map +1 -1
  295. package/packages/pi-agent-core/package.json +1 -1
  296. package/packages/pi-ai/README.md +1 -0
  297. package/packages/pi-ai/dist/image-models.generated.d.ts +2 -2
  298. package/packages/pi-ai/dist/image-models.generated.js +6 -6
  299. package/packages/pi-ai/dist/image-models.generated.js.map +1 -1
  300. package/packages/pi-ai/dist/index.d.ts +2 -0
  301. package/packages/pi-ai/dist/index.d.ts.map +1 -1
  302. package/packages/pi-ai/dist/index.js +2 -0
  303. package/packages/pi-ai/dist/index.js.map +1 -1
  304. package/packages/pi-ai/dist/models.generated.d.ts +419 -221
  305. package/packages/pi-ai/dist/models.generated.d.ts.map +1 -1
  306. package/packages/pi-ai/dist/models.generated.js +468 -269
  307. package/packages/pi-ai/dist/models.generated.js.map +1 -1
  308. package/packages/pi-ai/dist/providers/anthropic.d.ts.map +1 -1
  309. package/packages/pi-ai/dist/providers/anthropic.js +12 -7
  310. package/packages/pi-ai/dist/providers/anthropic.js.map +1 -1
  311. package/packages/pi-ai/dist/providers/google-shared.d.ts +5 -0
  312. package/packages/pi-ai/dist/providers/google-shared.d.ts.map +1 -1
  313. package/packages/pi-ai/dist/providers/google-shared.js +12 -3
  314. package/packages/pi-ai/dist/providers/google-shared.js.map +1 -1
  315. package/packages/pi-ai/dist/providers/openai-completions.d.ts.map +1 -1
  316. package/packages/pi-ai/dist/providers/openai-completions.js +7 -3
  317. package/packages/pi-ai/dist/providers/openai-completions.js.map +1 -1
  318. package/packages/pi-ai/dist/utils/moonshot-tool-schema.d.ts +9 -0
  319. package/packages/pi-ai/dist/utils/moonshot-tool-schema.d.ts.map +1 -0
  320. package/packages/pi-ai/dist/utils/moonshot-tool-schema.js +34 -0
  321. package/packages/pi-ai/dist/utils/moonshot-tool-schema.js.map +1 -0
  322. package/packages/pi-ai/dist/utils/oauth/github-copilot.d.ts.map +1 -1
  323. package/packages/pi-ai/dist/utils/oauth/github-copilot.js +6 -2
  324. package/packages/pi-ai/dist/utils/oauth/github-copilot.js.map +1 -1
  325. package/packages/pi-ai/package.json +3 -2
  326. package/packages/pi-coding-agent/dist/core/settings-manager.d.ts +3 -0
  327. package/packages/pi-coding-agent/dist/core/settings-manager.d.ts.map +1 -1
  328. package/packages/pi-coding-agent/dist/core/settings-manager.js +11 -0
  329. package/packages/pi-coding-agent/dist/core/settings-manager.js.map +1 -1
  330. package/packages/pi-coding-agent/dist/theme/theme.d.ts.map +1 -1
  331. package/packages/pi-coding-agent/dist/theme/theme.js +45 -17
  332. package/packages/pi-coding-agent/dist/theme/theme.js.map +1 -1
  333. package/packages/pi-coding-agent/package.json +7 -7
  334. package/packages/pi-tui/README.md +15 -0
  335. package/packages/pi-tui/dist/index.d.ts +2 -2
  336. package/packages/pi-tui/dist/index.d.ts.map +1 -1
  337. package/packages/pi-tui/dist/index.js +2 -2
  338. package/packages/pi-tui/dist/index.js.map +1 -1
  339. package/packages/pi-tui/dist/terminal-image.d.ts +33 -0
  340. package/packages/pi-tui/dist/terminal-image.d.ts.map +1 -1
  341. package/packages/pi-tui/dist/terminal-image.js +54 -2
  342. package/packages/pi-tui/dist/terminal-image.js.map +1 -1
  343. package/packages/pi-tui/dist/terminal.d.ts +12 -0
  344. package/packages/pi-tui/dist/terminal.d.ts.map +1 -1
  345. package/packages/pi-tui/dist/terminal.js +70 -25
  346. package/packages/pi-tui/dist/terminal.js.map +1 -1
  347. package/packages/pi-tui/dist/tui.d.ts +15 -0
  348. package/packages/pi-tui/dist/tui.d.ts.map +1 -1
  349. package/packages/pi-tui/dist/tui.js +106 -21
  350. package/packages/pi-tui/dist/tui.js.map +1 -1
  351. package/packages/pi-tui/dist/utils.d.ts.map +1 -1
  352. package/packages/pi-tui/dist/utils.js +110 -36
  353. package/packages/pi-tui/dist/utils.js.map +1 -1
  354. package/packages/pi-tui/package.json +2 -2
  355. package/packages/rpc-client/package.json +2 -2
  356. package/pkg/dist/theme/theme.d.ts.map +1 -1
  357. package/pkg/dist/theme/theme.js +45 -17
  358. package/pkg/dist/theme/theme.js.map +1 -1
  359. package/pkg/package.json +1 -1
  360. package/src/resources/GSD-WORKFLOW.md +5 -4
  361. package/src/resources/extensions/ask-user-questions.ts +7 -2
  362. package/src/resources/extensions/browser-tools/tests/gsd-browser-launch-config.test.mjs +11 -0
  363. package/src/resources/extensions/claude-code-cli/stream-adapter.ts +531 -226
  364. package/src/resources/extensions/claude-code-cli/tests/stream-adapter.test.ts +672 -7
  365. package/src/resources/extensions/claude-code-cli/turn-assembler.ts +38 -1
  366. package/src/resources/extensions/gsd/auto/closeout.ts +309 -0
  367. package/src/resources/extensions/gsd/auto/custom-verify-retry-store.ts +21 -3
  368. package/src/resources/extensions/gsd/auto/detect-stuck.ts +32 -9
  369. package/src/resources/extensions/gsd/auto/dispatch-history.ts +168 -0
  370. package/src/resources/extensions/gsd/auto/dispatch-key.ts +39 -0
  371. package/src/resources/extensions/gsd/auto/dispatch.ts +449 -0
  372. package/src/resources/extensions/gsd/auto/finalize.ts +445 -0
  373. package/src/resources/extensions/gsd/auto/loop.ts +7 -1
  374. package/src/resources/extensions/gsd/auto/milestone-lease-reclaim.ts +74 -0
  375. package/src/resources/extensions/gsd/auto/orchestrator.ts +186 -66
  376. package/src/resources/extensions/gsd/auto/phase-helpers.ts +199 -0
  377. package/src/resources/extensions/gsd/auto/phases.ts +58 -3022
  378. package/src/resources/extensions/gsd/auto/pre-dispatch.ts +704 -0
  379. package/src/resources/extensions/gsd/auto/session.ts +3 -0
  380. package/src/resources/extensions/gsd/auto/unit-phase.ts +910 -0
  381. package/src/resources/extensions/gsd/auto/workflow-unit-dispatch.ts +1 -1
  382. package/src/resources/extensions/gsd/auto/worktree-safety-phase.ts +149 -0
  383. package/src/resources/extensions/gsd/auto-direct-dispatch.ts +18 -48
  384. package/src/resources/extensions/gsd/auto-dispatch.ts +37 -62
  385. package/src/resources/extensions/gsd/auto-model-selection.ts +16 -7
  386. package/src/resources/extensions/gsd/auto-post-unit.ts +33 -12
  387. package/src/resources/extensions/gsd/auto-prompts.ts +78 -9
  388. package/src/resources/extensions/gsd/auto-start.ts +27 -11
  389. package/src/resources/extensions/gsd/auto-unit-closeout.ts +83 -28
  390. package/src/resources/extensions/gsd/auto-unit-tool-scope.ts +4 -4
  391. package/src/resources/extensions/gsd/auto-verification.ts +26 -28
  392. package/src/resources/extensions/gsd/auto-worktree.ts +15 -2
  393. package/src/resources/extensions/gsd/auto.ts +64 -2
  394. package/src/resources/extensions/gsd/blocked-models.ts +49 -0
  395. package/src/resources/extensions/gsd/bootstrap/agent-end-recovery.ts +34 -5
  396. package/src/resources/extensions/gsd/bootstrap/dynamic-tools.ts +56 -6
  397. package/src/resources/extensions/gsd/bootstrap/exec-tools.ts +2 -2
  398. package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +118 -50
  399. package/src/resources/extensions/gsd/bootstrap/write-gate.ts +350 -86
  400. package/src/resources/extensions/gsd/closeout-wizard.ts +102 -0
  401. package/src/resources/extensions/gsd/commands/context.ts +16 -2
  402. package/src/resources/extensions/gsd/commands-handlers.ts +46 -3
  403. package/src/resources/extensions/gsd/commands-mcp-status.ts +2 -2
  404. package/src/resources/extensions/gsd/commands-workflow-templates.ts +11 -4
  405. package/src/resources/extensions/gsd/consent-question.ts +431 -0
  406. package/src/resources/extensions/gsd/consent-verdict.ts +86 -0
  407. package/src/resources/extensions/gsd/crash-recovery.ts +10 -2
  408. package/src/resources/extensions/gsd/db/engine.ts +26 -6
  409. package/src/resources/extensions/gsd/db/queries.ts +66 -0
  410. package/src/resources/extensions/gsd/db-migration-backup.ts +56 -7
  411. package/src/resources/extensions/gsd/db-transaction.ts +37 -20
  412. package/src/resources/extensions/gsd/db-writer.ts +11 -19
  413. package/src/resources/extensions/gsd/dispatch-guard.ts +8 -31
  414. package/src/resources/extensions/gsd/doctor-engine-checks.ts +5 -4
  415. package/src/resources/extensions/gsd/doctor-environment.ts +267 -142
  416. package/src/resources/extensions/gsd/doctor-git-checks.ts +2 -19
  417. package/src/resources/extensions/gsd/engine-hook-contract.ts +79 -0
  418. package/src/resources/extensions/gsd/files.ts +33 -12
  419. package/src/resources/extensions/gsd/gsd-command-home.ts +13 -3
  420. package/src/resources/extensions/gsd/gsd-db.ts +19 -22
  421. package/src/resources/extensions/gsd/guidance.ts +78 -0
  422. package/src/resources/extensions/gsd/guided-flow.ts +145 -24
  423. package/src/resources/extensions/gsd/health-widget.ts +91 -27
  424. package/src/resources/extensions/gsd/markdown-renderer.ts +11 -0
  425. package/src/resources/extensions/gsd/mcp-bridge.ts +39 -0
  426. package/src/resources/extensions/gsd/memory-relations.ts +1 -1
  427. package/src/resources/extensions/gsd/milestone-closeout.ts +109 -24
  428. package/src/resources/extensions/gsd/milestone-planning-persistence.ts +2 -2
  429. package/src/resources/extensions/gsd/milestone-reopen-events.ts +3 -6
  430. package/src/resources/extensions/gsd/milestone-settlement.ts +2 -2
  431. package/src/resources/extensions/gsd/notifications.ts +13 -6
  432. package/src/resources/extensions/gsd/parsers-legacy.ts +16 -4
  433. package/src/resources/extensions/gsd/projection-flush.ts +20 -0
  434. package/src/resources/extensions/gsd/prompts/complete-slice.md +3 -3
  435. package/src/resources/extensions/gsd/prompts/execute-task.md +3 -2
  436. package/src/resources/extensions/gsd/prompts/plan-milestone.md +1 -1
  437. package/src/resources/extensions/gsd/prompts/plan-slice.md +1 -1
  438. package/src/resources/extensions/gsd/prompts/quick-task.md +1 -1
  439. package/src/resources/extensions/gsd/prompts/reassess-roadmap.md +1 -1
  440. package/src/resources/extensions/gsd/prompts/refine-slice.md +1 -1
  441. package/src/resources/extensions/gsd/prompts/replan-slice.md +1 -1
  442. package/src/resources/extensions/gsd/prompts/research-milestone.md +1 -1
  443. package/src/resources/extensions/gsd/prompts/research-slice.md +1 -1
  444. package/src/resources/extensions/gsd/prompts/rewrite-docs.md +1 -1
  445. package/src/resources/extensions/gsd/prompts/run-uat.md +8 -4
  446. package/src/resources/extensions/gsd/prompts/triage-captures.md +1 -1
  447. package/src/resources/extensions/gsd/prompts/validate-milestone.md +1 -1
  448. package/src/resources/extensions/gsd/prompts/workflow-start.md +2 -1
  449. package/src/resources/extensions/gsd/reactive-graph.ts +11 -1
  450. package/src/resources/extensions/gsd/roadmap-slices.ts +28 -3
  451. package/src/resources/extensions/gsd/session-lock.ts +1 -1
  452. package/src/resources/extensions/gsd/skill-activation.ts +3 -6
  453. package/src/resources/extensions/gsd/state.ts +12 -1
  454. package/src/resources/extensions/gsd/tests/auto-abort-pause-regression.test.ts +1 -1
  455. package/src/resources/extensions/gsd/tests/auto-blocked-remediation-message.test.ts +1 -1
  456. package/src/resources/extensions/gsd/tests/auto-loop.test.ts +206 -22
  457. package/src/resources/extensions/gsd/tests/auto-model-selection.test.ts +75 -1
  458. package/src/resources/extensions/gsd/tests/auto-orchestrator.test.ts +257 -18
  459. package/src/resources/extensions/gsd/tests/auto-pause-double-entry-guard.test.ts +1 -1
  460. package/src/resources/extensions/gsd/tests/auto-paused-ui-cleanup.test.ts +77 -1
  461. package/src/resources/extensions/gsd/tests/auto-phases-lifecycle.test.ts +2 -1
  462. package/src/resources/extensions/gsd/tests/auto-remote-session-lock-cleanup.test.ts +65 -3
  463. package/src/resources/extensions/gsd/tests/auto-start-orphan-bootstrap.test.ts +236 -0
  464. package/src/resources/extensions/gsd/tests/auto-unit-closeout.test.ts +169 -1
  465. package/src/resources/extensions/gsd/tests/blocked-models.test.ts +19 -0
  466. package/src/resources/extensions/gsd/tests/complete-slice-verification-gate.test.ts +42 -0
  467. package/src/resources/extensions/gsd/tests/complete-task.test.ts +141 -5
  468. package/src/resources/extensions/gsd/tests/consent-question.test.ts +351 -0
  469. package/src/resources/extensions/gsd/tests/custom-verify-retry-store.test.ts +67 -0
  470. package/src/resources/extensions/gsd/tests/db-migration-backup.test.ts +68 -19
  471. package/src/resources/extensions/gsd/tests/db-transaction.test.ts +59 -0
  472. package/src/resources/extensions/gsd/tests/db-writer.test.ts +15 -4
  473. package/src/resources/extensions/gsd/tests/deep-project-auto-loop.test.ts +12 -11
  474. package/src/resources/extensions/gsd/tests/derive-state-helpers.test.ts +62 -0
  475. package/src/resources/extensions/gsd/tests/discuss-routing-fixes.test.ts +12 -2
  476. package/src/resources/extensions/gsd/tests/dispatch-history.test.ts +328 -0
  477. package/src/resources/extensions/gsd/tests/dist-redirect.mjs +8 -0
  478. package/src/resources/extensions/gsd/tests/doctor-git-checks-terminal.test.ts +73 -0
  479. package/src/resources/extensions/gsd/tests/engine-hook-contract.test.ts +148 -0
  480. package/src/resources/extensions/gsd/tests/engine-interfaces-contract.test.ts +117 -91
  481. package/src/resources/extensions/gsd/tests/ensure-db-open.test.ts +113 -0
  482. package/src/resources/extensions/gsd/tests/gsd-command-home.test.ts +120 -0
  483. package/src/resources/extensions/gsd/tests/gsd-db.test.ts +46 -0
  484. package/src/resources/extensions/gsd/tests/guidance.test.ts +23 -0
  485. package/src/resources/extensions/gsd/tests/guided-dispatch-root.test.ts +18 -6
  486. package/src/resources/extensions/gsd/tests/integration/auto-worktree.test.ts +15 -0
  487. package/src/resources/extensions/gsd/tests/integration/doctor-environment-async.test.ts +104 -0
  488. package/src/resources/extensions/gsd/tests/integration/run-uat.test.ts +217 -0
  489. package/src/resources/extensions/gsd/tests/journal-integration.test.ts +47 -16
  490. package/src/resources/extensions/gsd/tests/mcp-readiness-preflight.test.ts +205 -0
  491. package/src/resources/extensions/gsd/tests/mcp-status.test.ts +6 -5
  492. package/src/resources/extensions/gsd/tests/milestone-closeout.test.ts +95 -4
  493. package/src/resources/extensions/gsd/tests/milestone-merge-stash-restore.test.ts +1 -1
  494. package/src/resources/extensions/gsd/tests/milestone-report-path.test.ts +1 -1
  495. package/src/resources/extensions/gsd/tests/milestone-settlement.test.ts +92 -0
  496. package/src/resources/extensions/gsd/tests/milestone-transition-state-rebuild.test.ts +1 -1
  497. package/src/resources/extensions/gsd/tests/notifications.test.ts +64 -9
  498. package/src/resources/extensions/gsd/tests/parallel-research-dispatch.test.ts +18 -0
  499. package/src/resources/extensions/gsd/tests/parallel-skill-prompt-integration.test.ts +2 -2
  500. package/src/resources/extensions/gsd/tests/parsers-legacy-importers.test.ts +143 -0
  501. package/src/resources/extensions/gsd/tests/phases-merge-error-stops-auto.test.ts +1 -1
  502. package/src/resources/extensions/gsd/tests/phases-terminal-complete-idempotent.test.ts +242 -0
  503. package/src/resources/extensions/gsd/tests/plan-gate-failed-doctor-heal-hint.test.ts +3 -3
  504. package/src/resources/extensions/gsd/tests/post-exec-retry-bypass.test.ts +63 -2
  505. package/src/resources/extensions/gsd/tests/prompt-contracts.test.ts +10 -2
  506. package/src/resources/extensions/gsd/tests/prompt-db.test.ts +124 -6
  507. package/src/resources/extensions/gsd/tests/provider-errors.test.ts +2 -4
  508. package/src/resources/extensions/gsd/tests/remote-notification-from-desktop.test.ts +31 -81
  509. package/src/resources/extensions/gsd/tests/roadmap-slices.test.ts +68 -0
  510. package/src/resources/extensions/gsd/tests/runtime-invariant-modules.test.ts +26 -2
  511. package/src/resources/extensions/gsd/tests/single-writer-invariant.test.ts +170 -48
  512. package/src/resources/extensions/gsd/tests/skill-activation.test.ts +20 -17
  513. package/src/resources/extensions/gsd/tests/start-auto-detached.test.ts +7 -3
  514. package/src/resources/extensions/gsd/tests/stop-auto-race-null-unit.test.ts +1 -1
  515. package/src/resources/extensions/gsd/tests/teardown-chdir-failure-clears-registry.test.ts +17 -0
  516. package/src/resources/extensions/gsd/tests/token-tool-gating.test.ts +4 -2
  517. package/src/resources/extensions/gsd/tests/tool-surface-readiness.test.ts +184 -10
  518. package/src/resources/extensions/gsd/tests/tool-unavailable-retry.test.ts +33 -0
  519. package/src/resources/extensions/gsd/tests/transport-gate-double-complete.test.ts +139 -0
  520. package/src/resources/extensions/gsd/tests/uat-policy.test.ts +88 -0
  521. package/src/resources/extensions/gsd/tests/uok-audit-unified.test.ts +8 -0
  522. package/src/resources/extensions/gsd/tests/uok-plan-v2-wiring.test.ts +1 -1
  523. package/src/resources/extensions/gsd/tests/verification-verdict.test.ts +2 -0
  524. package/src/resources/extensions/gsd/tests/workflow-events.test.ts +19 -0
  525. package/src/resources/extensions/gsd/tests/workflow-mcp-readiness-cache.test.ts +119 -0
  526. package/src/resources/extensions/gsd/tests/workflow-mcp.test.ts +65 -2
  527. package/src/resources/extensions/gsd/tests/workflow-phase-contract-matrix.test.ts +332 -0
  528. package/src/resources/extensions/gsd/tests/workflow-reconcile.test.ts +20 -0
  529. package/src/resources/extensions/gsd/tests/workflow-templates.test.ts +92 -0
  530. package/src/resources/extensions/gsd/tests/workflow-tool-executors.test.ts +273 -38
  531. package/src/resources/extensions/gsd/tests/worktree-health-dispatch.test.ts +1 -1
  532. package/src/resources/extensions/gsd/tests/worktree-project-root-degrade.test.ts +1 -1
  533. package/src/resources/extensions/gsd/tests/worktree-safety-phase.test.ts +100 -0
  534. package/src/resources/extensions/gsd/tests/worktree-safety.test.ts +72 -0
  535. package/src/resources/extensions/gsd/tests/worktree-teardown-safety.test.ts +22 -0
  536. package/src/resources/extensions/gsd/tests/worktree.test.ts +18 -0
  537. package/src/resources/extensions/gsd/tests/write-gate-seam.test.ts +358 -0
  538. package/src/resources/extensions/gsd/tests/write-gate.test.ts +67 -1
  539. package/src/resources/extensions/gsd/tool-contract.ts +38 -3
  540. package/src/resources/extensions/gsd/tool-presentation-plan.ts +4 -4
  541. package/src/resources/extensions/gsd/tool-surface-readiness.ts +126 -19
  542. package/src/resources/extensions/gsd/tools/complete-milestone.ts +3 -2
  543. package/src/resources/extensions/gsd/tools/complete-slice.ts +22 -12
  544. package/src/resources/extensions/gsd/tools/complete-task.ts +90 -2
  545. package/src/resources/extensions/gsd/tools/plan-slice.ts +2 -2
  546. package/src/resources/extensions/gsd/tools/plan-task.ts +2 -2
  547. package/src/resources/extensions/gsd/tools/reassess-roadmap.ts +2 -2
  548. package/src/resources/extensions/gsd/tools/reopen-milestone.ts +2 -2
  549. package/src/resources/extensions/gsd/tools/reopen-slice.ts +2 -2
  550. package/src/resources/extensions/gsd/tools/reopen-task.ts +2 -2
  551. package/src/resources/extensions/gsd/tools/replan-slice.ts +2 -2
  552. package/src/resources/extensions/gsd/tools/workflow-tool-executors.ts +81 -2
  553. package/src/resources/extensions/gsd/uat-policy.ts +60 -15
  554. package/src/resources/extensions/gsd/unit-context-composer.ts +1 -1
  555. package/src/resources/extensions/gsd/unit-registry.ts +34 -4
  556. package/src/resources/extensions/gsd/verdict-parser.ts +1 -1
  557. package/src/resources/extensions/gsd/verification-verdict.ts +4 -2
  558. package/src/resources/extensions/gsd/workflow-event-ledger.ts +131 -0
  559. package/src/resources/extensions/gsd/workflow-event-vocabulary.ts +59 -0
  560. package/src/resources/extensions/gsd/workflow-events.ts +12 -20
  561. package/src/resources/extensions/gsd/workflow-mcp-auto-prep.ts +2 -0
  562. package/src/resources/extensions/gsd/workflow-mcp-readiness-cache.ts +150 -0
  563. package/src/resources/extensions/gsd/workflow-reconcile.ts +29 -62
  564. package/src/resources/extensions/gsd/worktree-lifecycle.ts +3 -8
  565. package/src/resources/extensions/gsd/worktree-manager.ts +6 -1
  566. package/src/resources/extensions/gsd/worktree-safety.ts +41 -39
  567. package/src/resources/extensions/gsd/worktree.ts +7 -1
  568. package/src/resources/extensions/mcp-client/manager.ts +7 -1
  569. package/src/resources/extensions/shared/gsd-browser-cli.ts +23 -2
  570. package/src/resources/shared/gsd-browser-path-sync.ts +273 -0
  571. package/src/resources/shared/package-manager-detection.ts +1 -1
  572. package/src/resources/skills/create-skill/SKILL.md +3 -0
  573. package/src/resources/skills/create-skill/references/skill-structure.md +1 -0
  574. package/dist/resources/extensions/gsd/user-input-boundary.js +0 -218
  575. package/dist/resources/skills/gsd-browser/SKILL.md +0 -41
  576. package/src/resources/extensions/gsd/tests/user-input-boundary.test.ts +0 -173
  577. package/src/resources/extensions/gsd/user-input-boundary.ts +0 -216
  578. package/src/resources/skills/gsd-browser/SKILL.md +0 -41
  579. /package/dist/web/standalone/.next/static/{mU4QIDlpVHDdjDpeEKh5W → 2T9IOdiiM3o3gZ4UbPi8E}/_buildManifest.js +0 -0
  580. /package/dist/web/standalone/.next/static/{mU4QIDlpVHDdjDpeEKh5W → 2T9IOdiiM3o3gZ4UbPi8E}/_ssgManifest.js +0 -0
@@ -6,9 +6,10 @@ import { loadWriteGateSnapshot, shouldBlockContextArtifactSaveInSnapshot, should
6
6
  import { getActiveRequirements, getAllMilestones, getMilestone, getSliceStatusSummary, getSliceTaskCounts, insertMilestone, insertAssessment, insertGateRun, readTransaction, saveGateResult, upsertQualityGate, } from "../gsd-db.js";
7
7
  import { GATE_REGISTRY } from "../gate-registry.js";
8
8
  import { generateRequirementsMd, saveArtifactToDb } from "../db-writer.js";
9
- import { clearPathCache, relSliceFile, resolveGsdPathContract, resolveMilestoneFile, resolveSliceFile } from "../paths.js";
9
+ import { clearPathCache, normalizeRealPath, relSliceFile, resolveGsdPathContract, resolveMilestoneFile, resolveSliceFile } from "../paths.js";
10
10
  import { saveFile, clearParseCache } from "../files.js";
11
11
  import { unlinkSync } from "node:fs";
12
+ import { hostname } from "node:os";
12
13
  import { join } from "node:path";
13
14
  import { handleCompleteMilestone } from "./complete-milestone.js";
14
15
  import { handleCompleteTask } from "./complete-task.js";
@@ -25,9 +26,11 @@ import { logError, logWarning } from "../workflow-logger.js";
25
26
  import { invalidateStateCache } from "../state.js";
26
27
  import { loadEffectiveGSDPreferences } from "../preferences.js";
27
28
  import { parseProject } from "../schemas/parsers.js";
28
- import { getAutoRuntimeSnapshot } from "../auto-runtime-state.js";
29
+ import { autoSession, getAutoRuntimeSnapshot, isAutoActive } from "../auto-runtime-state.js";
29
30
  import { renderPlanFromDb } from "../markdown-renderer.js";
30
31
  import { prepareUatRun, saveUatAttemptArtifact, } from "../uat-run.js";
32
+ import { registerAutoWorker, markWorkerStopping, getAutoWorker } from "../db/auto-workers.js";
33
+ import { claimMilestoneLease, releaseMilestoneLease, getMilestoneLease, refreshMilestoneLease, milestoneLeaseTtlSeconds, } from "../db/milestone-leases.js";
31
34
  export const SUPPORTED_SUMMARY_ARTIFACT_TYPES = [
32
35
  "SUMMARY",
33
36
  "RESEARCH",
@@ -61,6 +64,19 @@ function blockIfWrongAutoUnit(requiredUnitType, operation) {
61
64
  isError: true,
62
65
  };
63
66
  }
67
+ function milestoneLeaseConflictResult(milestoneId, byWorker, expiresAt) {
68
+ return {
69
+ content: [{ type: "text", text: `Milestone ${milestoneId} is currently leased by ${byWorker}. Retry after ${expiresAt}.` }],
70
+ details: {
71
+ operation: "plan_milestone",
72
+ error: "milestone_lease_conflict",
73
+ milestoneId,
74
+ byWorker,
75
+ expiresAt,
76
+ },
77
+ isError: true,
78
+ };
79
+ }
64
80
  function registerProjectMilestoneSequence(content) {
65
81
  const parsed = parseProject(content);
66
82
  const registered = [];
@@ -1066,7 +1082,45 @@ export async function executePlanMilestone(params, basePath = process.cwd()) {
1066
1082
  isError: true,
1067
1083
  };
1068
1084
  }
1085
+ let workerId = null;
1086
+ let acquiredToken = null;
1087
+ let leaseRefreshTimer;
1069
1088
  try {
1089
+ // Re-read at the gate so a peer-created milestone is not treated as fresh.
1090
+ const milestoneExists = getMilestone(params.milestoneId) !== null;
1091
+ if (milestoneExists) {
1092
+ const heldLease = getMilestoneLease(params.milestoneId);
1093
+ if (heldLease?.status === "held" && Date.parse(heldLease.expires_at) > Date.now()) {
1094
+ const holder = getAutoWorker(heldLease.worker_id);
1095
+ // Let the one-shot claim path recover stale same-process worker rows.
1096
+ const projectRoot = normalizeRealPath(basePath);
1097
+ const isOurAutoLease = isAutoActive() && heldLease.worker_id === autoSession.workerId;
1098
+ const holderIsOneShotReentrantPeer = !isAutoActive()
1099
+ && !!holder
1100
+ && holder.host === hostname()
1101
+ && holder.pid === process.pid
1102
+ && holder.project_root_realpath === projectRoot;
1103
+ if (holder?.status === "active" && !isOurAutoLease && !holderIsOneShotReentrantPeer) {
1104
+ return milestoneLeaseConflictResult(params.milestoneId, heldLease.worker_id, heldLease.expires_at);
1105
+ }
1106
+ }
1107
+ }
1108
+ // Fresh creation cannot claim a lease because the FK row does not exist.
1109
+ // In-process auto already owns its lease; re-claiming would bump its token.
1110
+ if (!isAutoActive() && milestoneExists) {
1111
+ workerId = registerAutoWorker({ projectRootRealpath: normalizeRealPath(basePath) });
1112
+ const lease = claimMilestoneLease(workerId, params.milestoneId);
1113
+ if (!lease.ok) {
1114
+ return milestoneLeaseConflictResult(params.milestoneId, lease.byWorker, lease.expiresAt);
1115
+ }
1116
+ acquiredToken = lease.token;
1117
+ const leaseRefreshMs = (milestoneLeaseTtlSeconds() / 2) * 1000;
1118
+ leaseRefreshTimer = setInterval(() => {
1119
+ if (acquiredToken !== null && workerId !== null) {
1120
+ refreshMilestoneLease(workerId, params.milestoneId, acquiredToken);
1121
+ }
1122
+ }, leaseRefreshMs);
1123
+ }
1070
1124
  const result = await handlePlanMilestone(params, basePath);
1071
1125
  if ("error" in result) {
1072
1126
  return {
@@ -1093,6 +1147,17 @@ export async function executePlanMilestone(params, basePath = process.cwd()) {
1093
1147
  isError: true,
1094
1148
  };
1095
1149
  }
1150
+ finally {
1151
+ if (leaseRefreshTimer !== undefined) {
1152
+ clearInterval(leaseRefreshTimer);
1153
+ }
1154
+ if (workerId !== null && acquiredToken !== null) {
1155
+ releaseMilestoneLease(workerId, params.milestoneId, acquiredToken);
1156
+ }
1157
+ if (workerId !== null) {
1158
+ markWorkerStopping(workerId);
1159
+ }
1160
+ }
1096
1161
  }
1097
1162
  export async function executePlanSlice(params, basePath = process.cwd()) {
1098
1163
  const dbAvailable = await ensureDbOpen(basePath);
@@ -1,17 +1,10 @@
1
1
  // Project/App: gsd-pi
2
2
  // File Purpose: Central UAT mode policy for dispatch, tool presentation, and result validation.
3
3
  import { hasBrowserContractPrefix } from "../shared/browser-contract.js";
4
- import { extractUatType } from "./files.js";
4
+ import { extractUatType, UAT_TYPE_KEYWORDS } from "./files.js";
5
5
  import { hasBrowserRequiredText } from "./browser-evidence.js";
6
6
  import { parseMcpToolName } from "./mcp-tool-name.js";
7
- export const UAT_TYPES = [
8
- "artifact-driven",
9
- "browser-executable",
10
- "runtime-executable",
11
- "live-runtime",
12
- "mixed",
13
- "human-experience",
14
- ];
7
+ export const UAT_TYPES = UAT_TYPE_KEYWORDS;
15
8
  export const UAT_MODE_POLICIES = {
16
9
  "artifact-driven": {
17
10
  browserTools: false,
@@ -56,23 +49,55 @@ export function isUatType(value) {
56
49
  export function getDeclaredUatType(content) {
57
50
  return extractUatType(content) ?? "artifact-driven";
58
51
  }
59
- export function classifyUatContent(content) {
60
- const declaredType = getDeclaredUatType(content);
61
- const browserRequired = hasBrowserRequiredText(content);
62
- const effectiveType = declaredType === "artifact-driven" && browserRequired
52
+ /** Self-contained browser UAT harnesses that manage server lifecycle internally. */
53
+ const SELF_CONTAINED_RUNTIME_UAT_COMMAND_RE = /\b(?:npm run test:uat|node\s+(?:--check\s+\S+\s+&&\s+)*tests\/browser\/search-uat\.mjs|npx playwright test(?:\s+\S+)?)\b/i;
54
+ export function hasSelfContainedRuntimeUatCommand(content) {
55
+ return SELF_CONTAINED_RUNTIME_UAT_COMMAND_RE.test(content);
56
+ }
57
+ function resolveEffectiveUatTypeFromPolicy(declaredType, browserRequired, content) {
58
+ let effectiveType = declaredType === "artifact-driven" && browserRequired
63
59
  ? "browser-executable"
64
60
  : declaredType;
61
+ // M006/S01 regression: specs often declare browser-executable with localhost
62
+ // preconditions while the Evidence section names a runtime harness such as
63
+ // `npm run test:uat`. Interactive browser_* checks then race a fixed port
64
+ // against the script's own ephemeral server — run the harness instead.
65
+ if (effectiveType === "browser-executable" &&
66
+ hasSelfContainedRuntimeUatCommand(content)) {
67
+ effectiveType = "runtime-executable";
68
+ }
69
+ return effectiveType;
70
+ }
71
+ export function classifyUatContent(content) {
72
+ return classifyUatContentForRun(content);
73
+ }
74
+ /**
75
+ * Classify UAT mode for run-uat dispatch. Supplemental context (slice summary,
76
+ * verification excerpts) can name a self-contained harness even when the UAT
77
+ * file only documents a separate server command such as `npm run test:server`.
78
+ */
79
+ export function classifyUatContentForRun(content, supplementalContext = "") {
80
+ const parsedType = extractUatType(content);
81
+ const declaredType = parsedType ?? "artifact-driven";
82
+ const browserRequired = hasBrowserRequiredText(content);
83
+ const combinedForHarness = supplementalContext.trim()
84
+ ? `${content}\n\n${supplementalContext}`
85
+ : content;
86
+ const effectiveType = resolveEffectiveUatTypeFromPolicy(declaredType, browserRequired, combinedForHarness);
65
87
  return {
66
88
  declaredType,
89
+ modeDeclared: parsedType !== undefined,
67
90
  effectiveType,
68
91
  browserRequired,
69
92
  shouldDispatchByDefault: effectiveType !== "artifact-driven" || browserRequired,
70
93
  };
71
94
  }
72
- export function shouldEscalateArtifactUatToBrowser(content) {
73
- const policy = classifyUatContent(content);
95
+ export function escalatesArtifactUatToBrowser(policy) {
74
96
  return policy.declaredType === "artifact-driven" && policy.browserRequired;
75
97
  }
98
+ export function shouldEscalateArtifactUatToBrowser(content) {
99
+ return escalatesArtifactUatToBrowser(classifyUatContent(content));
100
+ }
76
101
  export function resolveEffectiveUatType(content) {
77
102
  return classifyUatContent(content).effectiveType;
78
103
  }
@@ -125,7 +125,7 @@ export function composeContextModeInstructions(unitType, opts) {
125
125
  }
126
126
  const TOOL_SURFACE_GUIDANCE_BY_UNIT = {
127
127
  "run-uat": "Do not call `gsd_exec`, `Bash`, `Write`, or `Edit` — they are unavailable in this unit. Run every automated check through `gsd_uat_exec` with the appropriate `intent`. For browser UAT modes, use `browser_*` tools when presented; if browser automation fails, record the failure honestly and use `gsd_uat_exec` for the best objective substitute.",
128
- "complete-slice": "Run slice-level verification through `gsd_exec` (or MCP-scoped `mcp__…__gsd_exec`), not direct `bash`. Do not call `gsd_uat_result_save` — run-uat owns persisted UAT assessment. On verification failure, do not edit user source files in this unit.",
128
+ "complete-slice": "Run slice-level verification through `gsd_exec` (or MCP-scoped `mcp__…__gsd_exec`), not direct `bash`. Capture learnings through `gsd_capture_thought` (or MCP-scoped `mcp__…__gsd_capture_thought`), not bare `capture_thought`, when workflow MCP tools are presented. Do not call `gsd_uat_result_save` — run-uat owns persisted UAT assessment. On verification failure, do not edit user source files in this unit.",
129
129
  "gate-evaluate": "Dispatch only **tester** subagents via `subagent`. Persist each gate with `gsd_save_gate_result`. Do not use `ToolSearch` — it is not available.",
130
130
  "reactive-execute": "Dispatch only **worker** subagents via `subagent`. Do not call `gsd_task_complete` from this parent batch — each worker owns its task completion. If a failed task left no summary, call `gsd_summary_save` with `blocker_discovered: true`.",
131
131
  "execute-task": "Complete only this task via `gsd_task_complete`. Do not call `gsd_slice_complete`, `gsd_validate_milestone`, or `gsd_complete_milestone` — the orchestrator owns phase transitions.",
@@ -173,15 +173,19 @@ export const UNIT_REGISTRY = {
173
173
  phaseChain: ["completion"],
174
174
  toolContract: {
175
175
  allowedGsdTools: [
176
+ "gsd_exec",
176
177
  "gsd_slice_complete",
177
178
  "gsd_task_reopen",
178
179
  "gsd_replan_slice",
179
180
  "gsd_decision_save",
181
+ "gsd_capture_thought",
180
182
  "gsd_requirement_update",
181
183
  "gsd_summary_save",
182
184
  "subagent",
183
185
  ],
184
186
  requiredWorkflowTools: [
187
+ "gsd_exec",
188
+ "gsd_capture_thought",
185
189
  "gsd_slice_complete",
186
190
  "gsd_task_reopen",
187
191
  "gsd_replan_slice",
@@ -207,8 +211,21 @@ export const UNIT_REGISTRY = {
207
211
  scopeClass: "execute-task",
208
212
  phaseChain: ["execution"],
209
213
  toolContract: {
210
- allowedGsdTools: ["gsd_task_complete", "gsd_decision_save"],
211
- requiredWorkflowTools: ["gsd_task_complete"],
214
+ allowedGsdTools: [
215
+ "gsd_task_complete",
216
+ "gsd_exec",
217
+ "gsd_exec_search",
218
+ "gsd_resume",
219
+ "gsd_capture_thought",
220
+ "gsd_decision_save",
221
+ ],
222
+ requiredWorkflowTools: [
223
+ "gsd_task_complete",
224
+ "gsd_exec",
225
+ "gsd_exec_search",
226
+ "gsd_resume",
227
+ "gsd_capture_thought",
228
+ ],
212
229
  },
213
230
  },
214
231
  "execute-task-simple": {
@@ -216,8 +233,21 @@ export const UNIT_REGISTRY = {
216
233
  scopeClass: "execute-task",
217
234
  phaseChain: ["execution_simple", "execution"],
218
235
  toolContract: {
219
- allowedGsdTools: ["gsd_task_complete", "gsd_decision_save"],
220
- requiredWorkflowTools: ["gsd_task_complete"],
236
+ allowedGsdTools: [
237
+ "gsd_task_complete",
238
+ "gsd_exec",
239
+ "gsd_exec_search",
240
+ "gsd_resume",
241
+ "gsd_capture_thought",
242
+ "gsd_decision_save",
243
+ ],
244
+ requiredWorkflowTools: [
245
+ "gsd_task_complete",
246
+ "gsd_exec",
247
+ "gsd_exec_search",
248
+ "gsd_resume",
249
+ "gsd_capture_thought",
250
+ ],
221
251
  },
222
252
  },
223
253
  "reactive-execute": {
@@ -128,7 +128,7 @@ export function isValidMilestoneVerdict(verdict) {
128
128
  * Extract the UAT type from content, defaulting to `"artifact-driven"`.
129
129
  *
130
130
  * The `"artifact-driven"` fallback is the original default used throughout
131
- * the codebase when a UAT file lacks an explicit `## UAT Type` section.
131
+ * the codebase when a UAT file has no parseable UAT mode declaration.
132
132
  */
133
133
  export function getUatType(content) {
134
134
  return getDeclaredUatType(content);
@@ -1,5 +1,6 @@
1
1
  // Project/App: gsd-pi
2
2
  // File Purpose: Host-owned verification verdict policy for auto-mode units.
3
+ export const NO_HOST_CHECKS_FAILURE_CONTEXT = "No runnable host-owned verification command was discovered. Add project verification_commands in .gsd/PREFERENCES.md or a runnable task-plan Verify command, then resume with /gsd next.";
3
4
  export function decideVerificationVerdict(unitType, result) {
4
5
  if (unitType === "execute-task" && result.discoverySource === "task-plan-prose" && result.checks.length === 0) {
5
6
  return {
@@ -14,7 +15,7 @@ export function decideVerificationVerdict(unitType, result) {
14
15
  passed: false,
15
16
  reason: "no-host-checks",
16
17
  retryable: false,
17
- failureContext: "No runnable host-owned verification command was discovered. Add project verification_commands or a runnable task-plan Verify command before completing this execute-task.",
18
+ failureContext: NO_HOST_CHECKS_FAILURE_CONTEXT,
18
19
  };
19
20
  }
20
21
  if (!result.passed) {
@@ -0,0 +1,91 @@
1
+ import { createHash } from "node:crypto";
2
+ import { appendFileSync, mkdirSync } from "node:fs";
3
+ import { dirname, join } from "node:path";
4
+ import { atomicWriteSync } from "./atomic-write.js";
5
+ import { resolveGsdPathContract } from "./paths.js";
6
+ import { buildAuditEnvelope, emitUokAuditEvent } from "./uok/audit.js";
7
+ import { isUnifiedAuditEnabled } from "./uok/audit-toggle.js";
8
+ import { normalizeWorkflowEventCommand } from "./workflow-event-vocabulary.js";
9
+ export const WORKFLOW_EVENT_LOG_FILENAME = "event-log.jsonl";
10
+ export function resolveWorkflowEventLedgerLocation(basePath, originalProjectRoot) {
11
+ const contract = resolveGsdPathContract(basePath, originalProjectRoot);
12
+ return {
13
+ projectRoot: contract.projectRoot,
14
+ workRoot: contract.workRoot,
15
+ projectGsd: contract.projectGsd,
16
+ worktreeGsd: contract.worktreeGsd,
17
+ projectLogPath: join(contract.projectGsd, WORKFLOW_EVENT_LOG_FILENAME),
18
+ worktreeLogPath: contract.worktreeGsd
19
+ ? join(contract.worktreeGsd, WORKFLOW_EVENT_LOG_FILENAME)
20
+ : null,
21
+ isWorktree: contract.isWorktree,
22
+ };
23
+ }
24
+ export function workflowEventLogPath(basePath) {
25
+ return resolveWorkflowEventLedgerLocation(basePath).projectLogPath;
26
+ }
27
+ export function workflowEventArchivePath(basePath, milestoneId) {
28
+ const location = resolveWorkflowEventLedgerLocation(basePath);
29
+ return join(location.projectGsd, `event-log-${milestoneId}.jsonl.archived`);
30
+ }
31
+ export function readWorktreeEventLogPath(worktreeBasePath) {
32
+ const location = resolveWorkflowEventLedgerLocation(worktreeBasePath);
33
+ return location.worktreeLogPath ?? location.projectLogPath;
34
+ }
35
+ export function buildWorkflowEvent(event, sessionId) {
36
+ const hash = createHash("sha256")
37
+ .update(JSON.stringify({ cmd: event.cmd, params: event.params }))
38
+ .digest("hex")
39
+ .slice(0, 16);
40
+ return {
41
+ v: 2,
42
+ ...event,
43
+ hash,
44
+ session_id: sessionId,
45
+ };
46
+ }
47
+ export function appendWorkflowEvent(basePath, event, sessionId) {
48
+ const fullEvent = buildWorkflowEvent(event, sessionId);
49
+ const location = resolveWorkflowEventLedgerLocation(basePath);
50
+ mkdirSync(location.projectGsd, { recursive: true });
51
+ appendFileSync(location.projectLogPath, `${JSON.stringify(fullEvent)}\n`, "utf-8");
52
+ emitWorkflowEventAudit(location.projectRoot, fullEvent);
53
+ return fullEvent;
54
+ }
55
+ export function writeWorkflowEventLog(basePath, events) {
56
+ const location = resolveWorkflowEventLedgerLocation(basePath);
57
+ mkdirSync(location.projectGsd, { recursive: true });
58
+ const content = events.map((event) => JSON.stringify(event)).join("\n") + (events.length > 0 ? "\n" : "");
59
+ atomicWriteSync(location.projectLogPath, content);
60
+ }
61
+ export function writeWorktreeEventLog(worktreeBasePath, events) {
62
+ const location = resolveWorkflowEventLedgerLocation(worktreeBasePath);
63
+ const logPath = location.worktreeLogPath ?? location.projectLogPath;
64
+ mkdirSync(dirname(logPath), { recursive: true });
65
+ const content = events.map((event) => JSON.stringify(event)).join("\n") + (events.length > 0 ? "\n" : "");
66
+ atomicWriteSync(logPath, content);
67
+ }
68
+ function emitWorkflowEventAudit(basePath, event) {
69
+ if (!isUnifiedAuditEnabled())
70
+ return;
71
+ try {
72
+ const normalized = normalizeWorkflowEventCommand(event.cmd) ?? "unknown";
73
+ emitUokAuditEvent(basePath, buildAuditEnvelope({
74
+ traceId: event.session_id,
75
+ category: "orchestration",
76
+ type: `workflow-event-${normalized}`,
77
+ payload: {
78
+ cmd: event.cmd,
79
+ params: event.params,
80
+ actor: event.actor,
81
+ actorName: event.actor_name,
82
+ triggerReason: event.trigger_reason,
83
+ eventTs: event.ts,
84
+ hash: event.hash,
85
+ },
86
+ }));
87
+ }
88
+ catch {
89
+ // Best-effort: audit projection must never block the workflow event ledger.
90
+ }
91
+ }
@@ -0,0 +1,46 @@
1
+ export function normalizeWorkflowEventCommand(cmd) {
2
+ return typeof cmd === "string" ? cmd.replace(/-/g, "_") : null;
3
+ }
4
+ /**
5
+ * Workflow progress events are keyed by the domain entity they mutate.
6
+ * Keep command aliases and conflict identity in this module so replay,
7
+ * conflict detection, and tests do not each grow their own vocabulary.
8
+ */
9
+ export function workflowEventEntityKey(event) {
10
+ const p = event.params;
11
+ const cmd = normalizeWorkflowEventCommand(event.cmd);
12
+ if (!cmd)
13
+ return null;
14
+ switch (cmd) {
15
+ case "complete_task":
16
+ case "start_task":
17
+ case "skip_task":
18
+ case "report_blocker":
19
+ case "record_verification":
20
+ case "plan_task":
21
+ return typeof p["taskId"] === "string"
22
+ ? { type: "task", id: p["taskId"] }
23
+ : null;
24
+ case "complete_slice":
25
+ case "replan_slice":
26
+ return typeof p["sliceId"] === "string"
27
+ ? { type: "slice", id: p["sliceId"] }
28
+ : null;
29
+ case "plan_slice":
30
+ return typeof p["sliceId"] === "string"
31
+ ? { type: "slice_plan", id: p["sliceId"] }
32
+ : null;
33
+ case "complete_milestone":
34
+ case "plan_milestone":
35
+ return typeof p["milestoneId"] === "string"
36
+ ? { type: "milestone", id: p["milestoneId"] }
37
+ : null;
38
+ case "save_decision":
39
+ if (typeof p["scope"] === "string" && typeof p["decision"] === "string") {
40
+ return { type: "decision", id: `${p["scope"]}:${p["decision"]}` };
41
+ }
42
+ return null;
43
+ default:
44
+ return null;
45
+ }
46
+ }
@@ -1,8 +1,8 @@
1
- import { createHash, randomUUID } from "node:crypto";
2
- import { appendFileSync, readFileSync, existsSync, mkdirSync } from "node:fs";
3
- import { join } from "node:path";
1
+ import { randomUUID } from "node:crypto";
2
+ import { readFileSync, existsSync } from "node:fs";
4
3
  import { atomicWriteSync } from "./atomic-write.js";
5
4
  import { withFileLockSync } from "./file-lock.js";
5
+ import { appendWorkflowEvent, workflowEventArchivePath, workflowEventLogPath, } from "./workflow-event-ledger.js";
6
6
  import { logWarning } from "./workflow-logger.js";
7
7
  // ─── Session ID ───────────────────────────────────────────────────────────
8
8
  /**
@@ -20,19 +20,7 @@ export function getSessionId() {
20
20
  * Creates .gsd directory if needed.
21
21
  */
22
22
  export function appendEvent(basePath, event) {
23
- const hash = createHash("sha256")
24
- .update(JSON.stringify({ cmd: event.cmd, params: event.params }))
25
- .digest("hex")
26
- .slice(0, 16);
27
- const fullEvent = {
28
- v: 2,
29
- ...event,
30
- hash,
31
- session_id: ENGINE_SESSION_ID,
32
- };
33
- const dir = join(basePath, ".gsd");
34
- mkdirSync(dir, { recursive: true });
35
- appendFileSync(join(dir, "event-log.jsonl"), JSON.stringify(fullEvent) + "\n", "utf-8");
23
+ appendWorkflowEvent(basePath, event, ENGINE_SESSION_ID);
36
24
  }
37
25
  // ─── readEvents ──────────────────────────────────────────────────────────
38
26
  /**
@@ -87,8 +75,8 @@ export function findForkPoint(logA, logB) {
87
75
  * @returns { archived: number } — count of events moved to archive
88
76
  */
89
77
  export function compactMilestoneEvents(basePath, milestoneId) {
90
- const logPath = join(basePath, ".gsd", "event-log.jsonl");
91
- const archivePath = join(basePath, ".gsd", `event-log-${milestoneId}.jsonl.archived`);
78
+ const logPath = workflowEventLogPath(basePath);
79
+ const archivePath = workflowEventArchivePath(basePath, milestoneId);
92
80
  return withFileLockSync(logPath, () => {
93
81
  const allEvents = readEvents(logPath);
94
82
  // Single-pass partition to halve the work (per reviewer agent)
@@ -1,4 +1,5 @@
1
1
  import { ensureProjectWorkflowMcpConfig, } from "./mcp-project-config.js";
2
+ import { warmWorkflowMcpProbeInBackground } from "./workflow-mcp-readiness-cache.js";
2
3
  import { usesWorkflowMcpTransport } from "./workflow-mcp.js";
3
4
  function withModelOverride(ctx, modelOverride) {
4
5
  if (!modelOverride)
@@ -46,6 +47,7 @@ export function prepareWorkflowMcpForProject(ctx, projectRoot, modelOverride) {
46
47
  if (result.status !== "unchanged") {
47
48
  prepCtx.ui?.notify?.(`GSD MCP Server Prepared at ${result.configPath}`, "info");
48
49
  }
50
+ warmWorkflowMcpProbeInBackground(projectRoot);
49
51
  return result;
50
52
  }
51
53
  catch (err) {
@@ -0,0 +1,105 @@
1
+ // Project/App: gsd-pi
2
+ // File Purpose: Share recent workflow MCP probe results across guided-flow and Claude Code SDK preflight.
3
+ import { testMcpServerConnection } from "../mcp-client/manager.js";
4
+ import { mcpToolMatchesBaseName } from "./mcp-tool-name.js";
5
+ import { detectWorkflowMcpLaunchConfig, resolveWorkflowMcpProjectRoot, } from "./workflow-mcp.js";
6
+ import { isWorkflowToolSurfaceName } from "./workflow-tool-surface.js";
7
+ /** Reuse a recent successful probe instead of spawning another stdio server. */
8
+ export const WORKFLOW_MCP_PROBE_CACHE_TTL_MS = 120_000;
9
+ /** Per-probe connect + tools/list budget (server typically ready in ~1–2s). */
10
+ export const WORKFLOW_MCP_PROBE_TIMEOUT_MS = 5_000;
11
+ const cacheByProject = new Map();
12
+ const probeInFlightByProject = new Map();
13
+ let activeWorkflowMcpSdkSessions = 0;
14
+ function cacheKey(projectRoot) {
15
+ return resolveWorkflowMcpProjectRoot(projectRoot);
16
+ }
17
+ export function beginWorkflowMcpSdkSession() {
18
+ activeWorkflowMcpSdkSessions++;
19
+ }
20
+ export function endWorkflowMcpSdkSession() {
21
+ activeWorkflowMcpSdkSessions = Math.max(0, activeWorkflowMcpSdkSessions - 1);
22
+ }
23
+ export function getCachedWorkflowMcpProbe(projectRoot) {
24
+ const entry = cacheByProject.get(cacheKey(projectRoot));
25
+ if (!entry)
26
+ return null;
27
+ if (Date.now() - entry.probedAt > WORKFLOW_MCP_PROBE_CACHE_TTL_MS) {
28
+ cacheByProject.delete(cacheKey(projectRoot));
29
+ return null;
30
+ }
31
+ return entry;
32
+ }
33
+ export function recordWorkflowMcpProbe(projectRoot, serverName, tools) {
34
+ cacheByProject.set(cacheKey(projectRoot), {
35
+ serverName,
36
+ tools: [...tools],
37
+ probedAt: Date.now(),
38
+ });
39
+ }
40
+ export function clearWorkflowMcpProbeCache(projectRoot) {
41
+ if (projectRoot === undefined) {
42
+ cacheByProject.clear();
43
+ probeInFlightByProject.clear();
44
+ activeWorkflowMcpSdkSessions = 0;
45
+ return;
46
+ }
47
+ const key = cacheKey(projectRoot);
48
+ cacheByProject.delete(key);
49
+ probeInFlightByProject.delete(key);
50
+ }
51
+ export function workflowMcpProbeAdvertisesSurface(tools) {
52
+ return tools.some((tool) => isWorkflowToolSurfaceName(tool));
53
+ }
54
+ export function cachedWorkflowMcpCoversRequired(projectRoot, serverName, required) {
55
+ const entry = getCachedWorkflowMcpProbe(projectRoot);
56
+ if (!entry || entry.serverName !== serverName)
57
+ return false;
58
+ return required.every((tool) => entry.tools.some((name) => name === tool || mcpToolMatchesBaseName(name, tool)));
59
+ }
60
+ async function runProbeAndCacheWorkflowMcp(projectRoot, options = {}) {
61
+ const root = cacheKey(projectRoot);
62
+ const launch = detectWorkflowMcpLaunchConfig(root);
63
+ const serverName = launch?.name ?? "gsd-workflow";
64
+ const cached = getCachedWorkflowMcpProbe(projectRoot);
65
+ if (cached && workflowMcpProbeAdvertisesSurface(cached.tools)) {
66
+ return { ok: true, tools: cached.tools, serverName: cached.serverName };
67
+ }
68
+ const result = await testMcpServerConnection(serverName, {
69
+ projectDir: root,
70
+ timeoutMs: options.timeoutMs ?? WORKFLOW_MCP_PROBE_TIMEOUT_MS,
71
+ });
72
+ if (result.ok && workflowMcpProbeAdvertisesSurface(result.tools)) {
73
+ recordWorkflowMcpProbe(projectRoot, serverName, result.tools);
74
+ }
75
+ return {
76
+ ok: result.ok,
77
+ tools: result.tools,
78
+ serverName,
79
+ error: result.error,
80
+ };
81
+ }
82
+ export async function probeAndCacheWorkflowMcp(projectRoot, options = {}) {
83
+ const key = cacheKey(projectRoot);
84
+ const inFlight = probeInFlightByProject.get(key);
85
+ if (inFlight)
86
+ return inFlight;
87
+ const promise = runProbeAndCacheWorkflowMcp(projectRoot, options).finally(() => {
88
+ probeInFlightByProject.delete(key);
89
+ });
90
+ probeInFlightByProject.set(key, promise);
91
+ return promise;
92
+ }
93
+ /** Fire-and-forget probe so /gsd dispatch often hits a warm cache. */
94
+ export function warmWorkflowMcpProbeInBackground(projectRoot) {
95
+ if (activeWorkflowMcpSdkSessions > 0)
96
+ return;
97
+ const key = cacheKey(projectRoot);
98
+ if (getCachedWorkflowMcpProbe(projectRoot))
99
+ return;
100
+ if (probeInFlightByProject.has(key))
101
+ return;
102
+ void probeAndCacheWorkflowMcp(projectRoot).catch(() => {
103
+ // Background warm is best-effort.
104
+ });
105
+ }