gsd-pi 2.76.0 → 2.77.0-dev.1d17f366c

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 (932) hide show
  1. package/README.md +32 -30
  2. package/dist/claude-cli-check.js +32 -3
  3. package/dist/cli-web-branch.d.ts +1 -0
  4. package/dist/cli-web-branch.js +3 -0
  5. package/dist/cli.js +38 -2
  6. package/dist/extension-discovery.d.ts +6 -0
  7. package/dist/extension-discovery.js +37 -0
  8. package/dist/extension-registry.d.ts +3 -0
  9. package/dist/extension-sort.d.ts +18 -0
  10. package/dist/extension-sort.js +114 -0
  11. package/dist/extension-validator.d.ts +47 -0
  12. package/dist/extension-validator.js +127 -0
  13. package/dist/loader.js +35 -7
  14. package/dist/mcp-server.d.ts +7 -0
  15. package/dist/mcp-server.js +35 -1
  16. package/dist/onboarding.js +45 -0
  17. package/dist/provider-migrations.d.ts +18 -0
  18. package/dist/provider-migrations.js +14 -0
  19. package/dist/resource-loader.d.ts +1 -1
  20. package/dist/resource-loader.js +2 -8
  21. package/dist/resources/agents/researcher.md +1 -1
  22. package/dist/resources/extensions/claude-code-cli/readiness.js +31 -8
  23. package/dist/resources/extensions/claude-code-cli/stream-adapter.js +144 -63
  24. package/dist/resources/extensions/cmux/index.js +20 -0
  25. package/dist/resources/extensions/github-sync/templates.js +103 -0
  26. package/dist/resources/extensions/google-search/extension-manifest.json +5 -4
  27. package/dist/resources/extensions/google-search/index.js +3 -375
  28. package/dist/resources/extensions/gsd/abandon-detect.js +44 -0
  29. package/dist/resources/extensions/gsd/auto/loop.js +90 -2
  30. package/dist/resources/extensions/gsd/auto/phases.js +145 -28
  31. package/dist/resources/extensions/gsd/auto/resolve.js +24 -0
  32. package/dist/resources/extensions/gsd/auto/run-unit.js +48 -4
  33. package/dist/resources/extensions/gsd/auto/session.js +22 -1
  34. package/dist/resources/extensions/gsd/auto/turn-epoch.js +95 -0
  35. package/dist/resources/extensions/gsd/auto-dispatch.js +115 -17
  36. package/dist/resources/extensions/gsd/auto-loop.js +1 -1
  37. package/dist/resources/extensions/gsd/auto-model-selection.js +53 -16
  38. package/dist/resources/extensions/gsd/auto-post-unit.js +90 -2
  39. package/dist/resources/extensions/gsd/auto-prompts.js +14 -0
  40. package/dist/resources/extensions/gsd/auto-recovery.js +46 -1
  41. package/dist/resources/extensions/gsd/auto-start.js +84 -60
  42. package/dist/resources/extensions/gsd/auto-timeout-recovery.js +11 -5
  43. package/dist/resources/extensions/gsd/auto-unit-closeout.js +11 -2
  44. package/dist/resources/extensions/gsd/auto-verification.js +33 -0
  45. package/dist/resources/extensions/gsd/auto-worktree.js +109 -61
  46. package/dist/resources/extensions/gsd/auto.js +107 -38
  47. package/dist/resources/extensions/gsd/blocked-models.js +68 -0
  48. package/dist/resources/extensions/gsd/bootstrap/agent-end-recovery.js +103 -1
  49. package/dist/resources/extensions/gsd/bootstrap/db-tools.js +39 -9
  50. package/dist/resources/extensions/gsd/bootstrap/exec-tools.js +93 -0
  51. package/dist/resources/extensions/gsd/bootstrap/memory-tools.js +3 -0
  52. package/dist/resources/extensions/gsd/bootstrap/provider-error-resume.js +4 -2
  53. package/dist/resources/extensions/gsd/bootstrap/register-extension.js +23 -0
  54. package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +52 -6
  55. package/dist/resources/extensions/gsd/bootstrap/system-context.js +95 -29
  56. package/dist/resources/extensions/gsd/bootstrap/write-gate.js +34 -2
  57. package/dist/resources/extensions/gsd/clean-root-preflight.js +93 -0
  58. package/dist/resources/extensions/gsd/commands/handlers/workflow.js +31 -4
  59. package/dist/resources/extensions/gsd/commands-cmux.js +9 -6
  60. package/dist/resources/extensions/gsd/commands-extensions.js +634 -43
  61. package/dist/resources/extensions/gsd/commands-extract-learnings.js +54 -89
  62. package/dist/resources/extensions/gsd/commands-prefs-wizard.js +968 -23
  63. package/dist/resources/extensions/gsd/compaction-snapshot.js +121 -0
  64. package/dist/resources/extensions/gsd/complexity-classifier.js +5 -3
  65. package/dist/resources/extensions/gsd/db-writer.js +88 -16
  66. package/dist/resources/extensions/gsd/dispatch-guard.js +29 -3
  67. package/dist/resources/extensions/gsd/doctor-git-checks.js +23 -29
  68. package/dist/resources/extensions/gsd/doctor-providers.js +51 -5
  69. package/dist/resources/extensions/gsd/ecosystem/gsd-extension-api.js +1 -0
  70. package/dist/resources/extensions/gsd/error-classifier.js +31 -3
  71. package/dist/resources/extensions/gsd/exec-history.js +120 -0
  72. package/dist/resources/extensions/gsd/exec-sandbox.js +258 -0
  73. package/dist/resources/extensions/gsd/file-lock.js +49 -9
  74. package/dist/resources/extensions/gsd/git-service.js +1 -0
  75. package/dist/resources/extensions/gsd/gitignore.js +2 -0
  76. package/dist/resources/extensions/gsd/gsd-db.js +168 -23
  77. package/dist/resources/extensions/gsd/guided-flow-queue.js +4 -1
  78. package/dist/resources/extensions/gsd/guided-flow.js +212 -9
  79. package/dist/resources/extensions/gsd/health-widget.js +4 -1
  80. package/dist/resources/extensions/gsd/hook-emitter.js +108 -0
  81. package/dist/resources/extensions/gsd/init-wizard.js +15 -1
  82. package/dist/resources/extensions/gsd/journal.js +17 -2
  83. package/dist/resources/extensions/gsd/key-manager.js +28 -0
  84. package/dist/resources/extensions/gsd/memory-backfill.js +126 -0
  85. package/dist/resources/extensions/gsd/memory-store.js +19 -0
  86. package/dist/resources/extensions/gsd/milestone-actions.js +15 -0
  87. package/dist/resources/extensions/gsd/milestone-summary-classifier.js +37 -0
  88. package/dist/resources/extensions/gsd/model-router.js +36 -3
  89. package/dist/resources/extensions/gsd/notifications.js +30 -16
  90. package/dist/resources/extensions/gsd/pre-execution-checks.js +44 -9
  91. package/dist/resources/extensions/gsd/preferences-types.js +9 -0
  92. package/dist/resources/extensions/gsd/preferences-validation.js +83 -0
  93. package/dist/resources/extensions/gsd/preferences.js +17 -17
  94. package/dist/resources/extensions/gsd/prompt-loader.js +22 -7
  95. package/dist/resources/extensions/gsd/prompts/complete-milestone.md +1 -1
  96. package/dist/resources/extensions/gsd/prompts/complete-slice.md +2 -2
  97. package/dist/resources/extensions/gsd/prompts/debug-diagnose.md +2 -0
  98. package/dist/resources/extensions/gsd/prompts/discuss-headless.md +29 -2
  99. package/dist/resources/extensions/gsd/prompts/discuss.md +29 -2
  100. package/dist/resources/extensions/gsd/prompts/doctor-heal.md +5 -4
  101. package/dist/resources/extensions/gsd/prompts/execute-task.md +3 -2
  102. package/dist/resources/extensions/gsd/prompts/parallel-research-slices.md +5 -2
  103. package/dist/resources/extensions/gsd/prompts/plan-slice.md +1 -0
  104. package/dist/resources/extensions/gsd/prompts/research-slice.md +1 -0
  105. package/dist/resources/extensions/gsd/prompts/system.md +1 -0
  106. package/dist/resources/extensions/gsd/reports.js +5 -4
  107. package/dist/resources/extensions/gsd/safety/evidence-collector.js +96 -0
  108. package/dist/resources/extensions/gsd/safety/file-change-validator.js +13 -5
  109. package/dist/resources/extensions/gsd/safety/safety-harness.js +5 -1
  110. package/dist/resources/extensions/gsd/state-transition-matrix.js +118 -0
  111. package/dist/resources/extensions/gsd/state.js +68 -29
  112. package/dist/resources/extensions/gsd/token-counter.js +22 -5
  113. package/dist/resources/extensions/gsd/tools/complete-milestone.js +16 -10
  114. package/dist/resources/extensions/gsd/tools/complete-slice.js +21 -0
  115. package/dist/resources/extensions/gsd/tools/complete-task.js +31 -0
  116. package/dist/resources/extensions/gsd/tools/exec-search-tool.js +59 -0
  117. package/dist/resources/extensions/gsd/tools/exec-tool.js +126 -0
  118. package/dist/resources/extensions/gsd/tools/memory-tools.js +26 -1
  119. package/dist/resources/extensions/gsd/tools/resume-tool.js +23 -0
  120. package/dist/resources/extensions/gsd/uok/audit.js +18 -2
  121. package/dist/resources/extensions/gsd/uok/dispatch-envelope.js +33 -0
  122. package/dist/resources/extensions/gsd/uok/execution-graph.js +10 -0
  123. package/dist/resources/extensions/gsd/uok/gitops.js +2 -1
  124. package/dist/resources/extensions/gsd/uok/loop-adapter.js +37 -10
  125. package/dist/resources/extensions/gsd/uok/parity-report.js +58 -0
  126. package/dist/resources/extensions/gsd/uok/plan-v2.js +30 -7
  127. package/dist/resources/extensions/gsd/uok/writer.js +82 -0
  128. package/dist/resources/extensions/gsd/workflow-logger.js +10 -2
  129. package/dist/resources/extensions/gsd/workflow-mcp.js +3 -0
  130. package/dist/resources/extensions/gsd/workflow-templates/spike.md +6 -0
  131. package/dist/resources/extensions/gsd/worktree-manager.js +1 -0
  132. package/dist/resources/extensions/gsd/worktree-resolver.js +50 -10
  133. package/dist/resources/extensions/mcp-client/auth.js +10 -1
  134. package/dist/resources/extensions/mcp-client/index.js +118 -9
  135. package/dist/resources/extensions/search-the-web/command-search-provider.js +5 -4
  136. package/dist/resources/extensions/search-the-web/native-search.js +45 -13
  137. package/dist/resources/extensions/shared/cmux-events.js +12 -0
  138. package/dist/resources/extensions/shared/rtk-session-stats.js +1 -2
  139. package/dist/resources/skills/api-design/SKILL.md +190 -0
  140. package/dist/resources/skills/create-mcp-server/SKILL.md +121 -0
  141. package/dist/resources/skills/create-skill/SKILL.md +2 -2
  142. package/dist/resources/skills/create-skill/references/gsd-skill-ecosystem.md +4 -4
  143. package/dist/resources/skills/create-skill/workflows/audit-skill.md +4 -4
  144. package/dist/resources/skills/create-skill/workflows/create-new-skill.md +5 -5
  145. package/dist/resources/skills/decompose-into-slices/SKILL.md +139 -0
  146. package/dist/resources/skills/dependency-upgrade/SKILL.md +158 -0
  147. package/dist/resources/skills/design-an-interface/SKILL.md +102 -0
  148. package/dist/resources/skills/forensics/SKILL.md +153 -0
  149. package/dist/resources/skills/grill-me/SKILL.md +93 -0
  150. package/dist/resources/skills/handoff/SKILL.md +121 -0
  151. package/dist/resources/skills/observability/SKILL.md +174 -0
  152. package/dist/resources/skills/security-review/SKILL.md +181 -0
  153. package/dist/resources/skills/spike-wrap-up/SKILL.md +138 -0
  154. package/dist/resources/skills/tdd/SKILL.md +112 -0
  155. package/dist/resources/skills/verify-before-complete/SKILL.md +98 -0
  156. package/dist/resources/skills/write-docs/SKILL.md +82 -0
  157. package/dist/resources/skills/write-milestone-brief/SKILL.md +135 -0
  158. package/dist/tsconfig.extensions.tsbuildinfo +1 -1
  159. package/dist/web/standalone/.next/BUILD_ID +1 -1
  160. package/dist/web/standalone/.next/app-path-routes-manifest.json +13 -13
  161. package/dist/web/standalone/.next/build-manifest.json +4 -4
  162. package/dist/web/standalone/.next/prerender-manifest.json +3 -3
  163. package/dist/web/standalone/.next/react-loadable-manifest.json +1 -1
  164. package/dist/web/standalone/.next/required-server-files.json +4 -4
  165. package/dist/web/standalone/.next/server/app/_global-error/page.js +3 -3
  166. package/dist/web/standalone/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
  167. package/dist/web/standalone/.next/server/app/_global-error.html +1 -1
  168. package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
  169. package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  170. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  171. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  172. package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  173. package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  174. package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  175. package/dist/web/standalone/.next/server/app/_not-found/page.js +2 -2
  176. package/dist/web/standalone/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  177. package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
  178. package/dist/web/standalone/.next/server/app/_not-found.rsc +3 -3
  179. package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +3 -3
  180. package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  181. package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +3 -3
  182. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  183. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  184. package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
  185. package/dist/web/standalone/.next/server/app/api/boot/route.js +1 -1
  186. package/dist/web/standalone/.next/server/app/api/boot/route.js.nft.json +1 -1
  187. package/dist/web/standalone/.next/server/app/api/boot/route_client-reference-manifest.js +1 -1
  188. package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route.js +1 -1
  189. package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route.js.nft.json +1 -1
  190. package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route_client-reference-manifest.js +1 -1
  191. package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route.js +1 -1
  192. package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route.js.nft.json +1 -1
  193. package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route_client-reference-manifest.js +1 -1
  194. package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route.js +2 -2
  195. package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route.js.nft.json +1 -1
  196. package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route_client-reference-manifest.js +1 -1
  197. package/dist/web/standalone/.next/server/app/api/browse-directories/route.js +1 -1
  198. package/dist/web/standalone/.next/server/app/api/browse-directories/route_client-reference-manifest.js +1 -1
  199. package/dist/web/standalone/.next/server/app/api/captures/route.js +1 -1
  200. package/dist/web/standalone/.next/server/app/api/captures/route.js.nft.json +1 -1
  201. package/dist/web/standalone/.next/server/app/api/captures/route_client-reference-manifest.js +1 -1
  202. package/dist/web/standalone/.next/server/app/api/cleanup/route.js +1 -1
  203. package/dist/web/standalone/.next/server/app/api/cleanup/route.js.nft.json +1 -1
  204. package/dist/web/standalone/.next/server/app/api/cleanup/route_client-reference-manifest.js +1 -1
  205. package/dist/web/standalone/.next/server/app/api/dev-mode/route.js +1 -1
  206. package/dist/web/standalone/.next/server/app/api/dev-mode/route_client-reference-manifest.js +1 -1
  207. package/dist/web/standalone/.next/server/app/api/doctor/route.js +1 -1
  208. package/dist/web/standalone/.next/server/app/api/doctor/route.js.nft.json +1 -1
  209. package/dist/web/standalone/.next/server/app/api/doctor/route_client-reference-manifest.js +1 -1
  210. package/dist/web/standalone/.next/server/app/api/experimental/route.js +2 -2
  211. package/dist/web/standalone/.next/server/app/api/experimental/route_client-reference-manifest.js +1 -1
  212. package/dist/web/standalone/.next/server/app/api/export-data/route.js +1 -1
  213. package/dist/web/standalone/.next/server/app/api/export-data/route.js.nft.json +1 -1
  214. package/dist/web/standalone/.next/server/app/api/export-data/route_client-reference-manifest.js +1 -1
  215. package/dist/web/standalone/.next/server/app/api/files/route.js +1 -1
  216. package/dist/web/standalone/.next/server/app/api/files/route.js.nft.json +1 -1
  217. package/dist/web/standalone/.next/server/app/api/files/route_client-reference-manifest.js +1 -1
  218. package/dist/web/standalone/.next/server/app/api/forensics/route.js +1 -1
  219. package/dist/web/standalone/.next/server/app/api/forensics/route.js.nft.json +1 -1
  220. package/dist/web/standalone/.next/server/app/api/forensics/route_client-reference-manifest.js +1 -1
  221. package/dist/web/standalone/.next/server/app/api/git/route.js +1 -1
  222. package/dist/web/standalone/.next/server/app/api/git/route.js.nft.json +1 -1
  223. package/dist/web/standalone/.next/server/app/api/git/route_client-reference-manifest.js +1 -1
  224. package/dist/web/standalone/.next/server/app/api/history/route.js +1 -1
  225. package/dist/web/standalone/.next/server/app/api/history/route.js.nft.json +1 -1
  226. package/dist/web/standalone/.next/server/app/api/history/route_client-reference-manifest.js +1 -1
  227. package/dist/web/standalone/.next/server/app/api/hooks/route.js +1 -1
  228. package/dist/web/standalone/.next/server/app/api/hooks/route.js.nft.json +1 -1
  229. package/dist/web/standalone/.next/server/app/api/hooks/route_client-reference-manifest.js +1 -1
  230. package/dist/web/standalone/.next/server/app/api/inspect/route.js +1 -1
  231. package/dist/web/standalone/.next/server/app/api/inspect/route.js.nft.json +1 -1
  232. package/dist/web/standalone/.next/server/app/api/inspect/route_client-reference-manifest.js +1 -1
  233. package/dist/web/standalone/.next/server/app/api/knowledge/route.js +1 -1
  234. package/dist/web/standalone/.next/server/app/api/knowledge/route.js.nft.json +1 -1
  235. package/dist/web/standalone/.next/server/app/api/knowledge/route_client-reference-manifest.js +1 -1
  236. package/dist/web/standalone/.next/server/app/api/live-state/route.js +1 -1
  237. package/dist/web/standalone/.next/server/app/api/live-state/route.js.nft.json +1 -1
  238. package/dist/web/standalone/.next/server/app/api/live-state/route_client-reference-manifest.js +1 -1
  239. package/dist/web/standalone/.next/server/app/api/notifications/route.js +2 -2
  240. package/dist/web/standalone/.next/server/app/api/notifications/route.js.nft.json +1 -1
  241. package/dist/web/standalone/.next/server/app/api/notifications/route_client-reference-manifest.js +1 -1
  242. package/dist/web/standalone/.next/server/app/api/onboarding/route.js +1 -1
  243. package/dist/web/standalone/.next/server/app/api/onboarding/route.js.nft.json +1 -1
  244. package/dist/web/standalone/.next/server/app/api/onboarding/route_client-reference-manifest.js +1 -1
  245. package/dist/web/standalone/.next/server/app/api/preferences/route.js +1 -1
  246. package/dist/web/standalone/.next/server/app/api/preferences/route_client-reference-manifest.js +1 -1
  247. package/dist/web/standalone/.next/server/app/api/projects/route.js +1 -1
  248. package/dist/web/standalone/.next/server/app/api/projects/route.js.nft.json +1 -1
  249. package/dist/web/standalone/.next/server/app/api/projects/route_client-reference-manifest.js +1 -1
  250. package/dist/web/standalone/.next/server/app/api/recovery/route.js +1 -1
  251. package/dist/web/standalone/.next/server/app/api/recovery/route.js.nft.json +1 -1
  252. package/dist/web/standalone/.next/server/app/api/recovery/route_client-reference-manifest.js +1 -1
  253. package/dist/web/standalone/.next/server/app/api/remote-questions/route.js +2 -2
  254. package/dist/web/standalone/.next/server/app/api/remote-questions/route_client-reference-manifest.js +1 -1
  255. package/dist/web/standalone/.next/server/app/api/session/browser/route.js +1 -1
  256. package/dist/web/standalone/.next/server/app/api/session/browser/route.js.nft.json +1 -1
  257. package/dist/web/standalone/.next/server/app/api/session/browser/route_client-reference-manifest.js +1 -1
  258. package/dist/web/standalone/.next/server/app/api/session/command/route.js +1 -1
  259. package/dist/web/standalone/.next/server/app/api/session/command/route.js.nft.json +1 -1
  260. package/dist/web/standalone/.next/server/app/api/session/command/route_client-reference-manifest.js +1 -1
  261. package/dist/web/standalone/.next/server/app/api/session/events/route.js +2 -2
  262. package/dist/web/standalone/.next/server/app/api/session/events/route.js.nft.json +1 -1
  263. package/dist/web/standalone/.next/server/app/api/session/events/route_client-reference-manifest.js +1 -1
  264. package/dist/web/standalone/.next/server/app/api/session/manage/route.js +1 -1
  265. package/dist/web/standalone/.next/server/app/api/session/manage/route.js.nft.json +1 -1
  266. package/dist/web/standalone/.next/server/app/api/session/manage/route_client-reference-manifest.js +1 -1
  267. package/dist/web/standalone/.next/server/app/api/settings-data/route.js +1 -1
  268. package/dist/web/standalone/.next/server/app/api/settings-data/route.js.nft.json +1 -1
  269. package/dist/web/standalone/.next/server/app/api/settings-data/route_client-reference-manifest.js +1 -1
  270. package/dist/web/standalone/.next/server/app/api/shutdown/route.js +1 -1
  271. package/dist/web/standalone/.next/server/app/api/shutdown/route_client-reference-manifest.js +1 -1
  272. package/dist/web/standalone/.next/server/app/api/skill-health/route.js +1 -1
  273. package/dist/web/standalone/.next/server/app/api/skill-health/route.js.nft.json +1 -1
  274. package/dist/web/standalone/.next/server/app/api/skill-health/route_client-reference-manifest.js +1 -1
  275. package/dist/web/standalone/.next/server/app/api/steer/route.js +1 -1
  276. package/dist/web/standalone/.next/server/app/api/steer/route.js.nft.json +1 -1
  277. package/dist/web/standalone/.next/server/app/api/steer/route_client-reference-manifest.js +1 -1
  278. package/dist/web/standalone/.next/server/app/api/switch-root/route.js +1 -1
  279. package/dist/web/standalone/.next/server/app/api/switch-root/route.js.nft.json +1 -1
  280. package/dist/web/standalone/.next/server/app/api/switch-root/route_client-reference-manifest.js +1 -1
  281. package/dist/web/standalone/.next/server/app/api/terminal/input/route.js +2 -2
  282. package/dist/web/standalone/.next/server/app/api/terminal/input/route_client-reference-manifest.js +1 -1
  283. package/dist/web/standalone/.next/server/app/api/terminal/resize/route.js +2 -2
  284. package/dist/web/standalone/.next/server/app/api/terminal/resize/route_client-reference-manifest.js +1 -1
  285. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js +2 -2
  286. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js.nft.json +1 -1
  287. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route_client-reference-manifest.js +1 -1
  288. package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js +4 -4
  289. package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js.nft.json +1 -1
  290. package/dist/web/standalone/.next/server/app/api/terminal/stream/route_client-reference-manifest.js +1 -1
  291. package/dist/web/standalone/.next/server/app/api/terminal/upload/route.js +1 -1
  292. package/dist/web/standalone/.next/server/app/api/terminal/upload/route_client-reference-manifest.js +1 -1
  293. package/dist/web/standalone/.next/server/app/api/undo/route.js +1 -1
  294. package/dist/web/standalone/.next/server/app/api/undo/route.js.nft.json +1 -1
  295. package/dist/web/standalone/.next/server/app/api/undo/route_client-reference-manifest.js +1 -1
  296. package/dist/web/standalone/.next/server/app/api/update/route.js +1 -1
  297. package/dist/web/standalone/.next/server/app/api/update/route_client-reference-manifest.js +1 -1
  298. package/dist/web/standalone/.next/server/app/api/visualizer/route.js +1 -1
  299. package/dist/web/standalone/.next/server/app/api/visualizer/route.js.nft.json +1 -1
  300. package/dist/web/standalone/.next/server/app/api/visualizer/route_client-reference-manifest.js +1 -1
  301. package/dist/web/standalone/.next/server/app/index.html +1 -1
  302. package/dist/web/standalone/.next/server/app/index.rsc +4 -4
  303. package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
  304. package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +4 -4
  305. package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
  306. package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +3 -3
  307. package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
  308. package/dist/web/standalone/.next/server/app/page.js +2 -2
  309. package/dist/web/standalone/.next/server/app/page_client-reference-manifest.js +1 -1
  310. package/dist/web/standalone/.next/server/app-paths-manifest.json +13 -13
  311. package/dist/web/standalone/.next/server/chunks/1926.js +1 -0
  312. package/dist/web/standalone/.next/server/chunks/63.js +3 -3
  313. package/dist/web/standalone/.next/server/chunks/6897.js +3 -3
  314. package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
  315. package/dist/web/standalone/.next/server/middleware-manifest.json +5 -5
  316. package/dist/web/standalone/.next/server/middleware-react-loadable-manifest.js +1 -1
  317. package/dist/web/standalone/.next/server/middleware.js +2 -2
  318. package/dist/web/standalone/.next/server/next-font-manifest.js +1 -1
  319. package/dist/web/standalone/.next/server/next-font-manifest.json +1 -1
  320. package/dist/web/standalone/.next/server/pages/404.html +1 -1
  321. package/dist/web/standalone/.next/server/pages/500.html +1 -1
  322. package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
  323. package/dist/web/standalone/.next/static/chunks/2826.e9f5195e91f9cad2.js +11 -0
  324. package/dist/web/standalone/.next/static/chunks/app/_not-found/{page-2f24283c162b6ab3.js → page-f2a7482d42a5614b.js} +1 -1
  325. package/dist/web/standalone/.next/static/chunks/app/{layout-9ecfd95f343793f0.js → layout-a16c7a7ecdf0c2cf.js} +1 -1
  326. package/dist/web/standalone/.next/static/chunks/app/page-5b113fd32bc2a1c3.js +1 -0
  327. package/dist/web/standalone/.next/static/chunks/main-app-fdab67f7802d7832.js +1 -0
  328. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/global-error-459824ffb8c323dd.js +1 -0
  329. package/dist/web/standalone/.next/static/chunks/{webpack-5fc74f13a25fa1bb.js → webpack-2e68521d7c82f7c2.js} +1 -1
  330. package/dist/web/standalone/node_modules/node-pty/build/Makefile +2 -2
  331. package/dist/web/standalone/node_modules/node-pty/build/Release/pty.node +0 -0
  332. package/dist/web/standalone/node_modules/node-pty/build/pty.target.mk +14 -14
  333. package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api.target.mk +14 -14
  334. package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api_except.target.mk +14 -14
  335. package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api_maybe.target.mk +14 -14
  336. package/dist/web/standalone/server.js +1 -1
  337. package/dist/welcome-screen.js +6 -1
  338. package/dist/wizard.js +2 -0
  339. package/package.json +16 -14
  340. package/packages/daemon/package.json +2 -2
  341. package/packages/mcp-server/README.md +3 -3
  342. package/packages/mcp-server/dist/env-writer.d.ts +1 -0
  343. package/packages/mcp-server/dist/env-writer.d.ts.map +1 -1
  344. package/packages/mcp-server/dist/env-writer.js +74 -6
  345. package/packages/mcp-server/dist/env-writer.js.map +1 -1
  346. package/packages/mcp-server/dist/remote-questions.d.ts +45 -0
  347. package/packages/mcp-server/dist/remote-questions.d.ts.map +1 -0
  348. package/packages/mcp-server/dist/remote-questions.js +732 -0
  349. package/packages/mcp-server/dist/remote-questions.js.map +1 -0
  350. package/packages/mcp-server/dist/server.d.ts +7 -0
  351. package/packages/mcp-server/dist/server.d.ts.map +1 -1
  352. package/packages/mcp-server/dist/server.js +95 -10
  353. package/packages/mcp-server/dist/server.js.map +1 -1
  354. package/packages/mcp-server/dist/session-manager.d.ts +14 -0
  355. package/packages/mcp-server/dist/session-manager.d.ts.map +1 -1
  356. package/packages/mcp-server/dist/session-manager.js +49 -1
  357. package/packages/mcp-server/dist/session-manager.js.map +1 -1
  358. package/packages/mcp-server/dist/workflow-tools.d.ts +1 -1
  359. package/packages/mcp-server/dist/workflow-tools.d.ts.map +1 -1
  360. package/packages/mcp-server/dist/workflow-tools.js +178 -31
  361. package/packages/mcp-server/dist/workflow-tools.js.map +1 -1
  362. package/packages/mcp-server/package.json +9 -3
  363. package/packages/mcp-server/src/env-writer.test.ts +79 -1
  364. package/packages/mcp-server/src/env-writer.ts +76 -6
  365. package/packages/mcp-server/src/mcp-server.test.ts +67 -0
  366. package/packages/mcp-server/src/readers/readers.test.ts +5 -1
  367. package/packages/mcp-server/src/remote-questions.test.ts +294 -0
  368. package/packages/mcp-server/src/remote-questions.ts +916 -0
  369. package/packages/mcp-server/src/server.ts +118 -16
  370. package/packages/mcp-server/src/session-manager.ts +43 -1
  371. package/packages/mcp-server/src/workflow-tools.test.ts +190 -1
  372. package/packages/mcp-server/src/workflow-tools.ts +234 -49
  373. package/packages/mcp-server/tsconfig.test.json +19 -0
  374. package/packages/mcp-server/tsconfig.tsbuildinfo +1 -1
  375. package/packages/native/package.json +6 -1
  376. package/packages/native/src/__tests__/clipboard.test.mjs +69 -23
  377. package/packages/native/tsconfig.tsbuildinfo +1 -1
  378. package/packages/pi-agent-core/dist/agent-loop.js +12 -0
  379. package/packages/pi-agent-core/dist/agent-loop.js.map +1 -1
  380. package/packages/pi-agent-core/dist/types.d.ts +30 -0
  381. package/packages/pi-agent-core/dist/types.d.ts.map +1 -1
  382. package/packages/pi-agent-core/dist/types.js.map +1 -1
  383. package/packages/pi-agent-core/package.json +6 -1
  384. package/packages/pi-agent-core/src/agent-loop.test.ts +220 -15
  385. package/packages/pi-agent-core/src/agent-loop.ts +14 -0
  386. package/packages/pi-agent-core/src/types.ts +34 -0
  387. package/packages/pi-agent-core/tsconfig.tsbuildinfo +1 -1
  388. package/packages/pi-ai/dist/models/custom.d.ts +38 -0
  389. package/packages/pi-ai/dist/models/custom.d.ts.map +1 -1
  390. package/packages/pi-ai/dist/models/custom.js +41 -0
  391. package/packages/pi-ai/dist/models/custom.js.map +1 -1
  392. package/packages/pi-ai/dist/providers/anthropic-auth.test.js +1 -1
  393. package/packages/pi-ai/dist/providers/anthropic-auth.test.js.map +1 -1
  394. package/packages/pi-ai/dist/providers/anthropic-bearer-auth.test.d.ts +2 -0
  395. package/packages/pi-ai/dist/providers/anthropic-bearer-auth.test.d.ts.map +1 -0
  396. package/packages/pi-ai/dist/providers/anthropic-bearer-auth.test.js +13 -0
  397. package/packages/pi-ai/dist/providers/anthropic-bearer-auth.test.js.map +1 -0
  398. package/packages/pi-ai/dist/providers/anthropic-shared.d.ts.map +1 -1
  399. package/packages/pi-ai/dist/providers/anthropic-shared.js +27 -4
  400. package/packages/pi-ai/dist/providers/anthropic-shared.js.map +1 -1
  401. package/packages/pi-ai/dist/providers/anthropic.d.ts.map +1 -1
  402. package/packages/pi-ai/dist/providers/anthropic.js +13 -4
  403. package/packages/pi-ai/dist/providers/anthropic.js.map +1 -1
  404. package/packages/pi-ai/dist/providers/minimax-tool-name.test.d.ts +2 -0
  405. package/packages/pi-ai/dist/providers/minimax-tool-name.test.d.ts.map +1 -0
  406. package/packages/pi-ai/dist/providers/minimax-tool-name.test.js +80 -0
  407. package/packages/pi-ai/dist/providers/minimax-tool-name.test.js.map +1 -0
  408. package/packages/pi-ai/dist/providers/openai-completions.d.ts.map +1 -1
  409. package/packages/pi-ai/dist/providers/openai-completions.js +60 -15
  410. package/packages/pi-ai/dist/providers/openai-completions.js.map +1 -1
  411. package/packages/pi-ai/dist/providers/simple-options.d.ts +10 -0
  412. package/packages/pi-ai/dist/providers/simple-options.d.ts.map +1 -1
  413. package/packages/pi-ai/dist/providers/simple-options.js +16 -1
  414. package/packages/pi-ai/dist/providers/simple-options.js.map +1 -1
  415. package/packages/pi-ai/dist/providers/think-tag-parser.d.ts +17 -0
  416. package/packages/pi-ai/dist/providers/think-tag-parser.d.ts.map +1 -0
  417. package/packages/pi-ai/dist/providers/think-tag-parser.js +75 -0
  418. package/packages/pi-ai/dist/providers/think-tag-parser.js.map +1 -0
  419. package/packages/pi-ai/dist/providers/think-tag-parser.test.d.ts +2 -0
  420. package/packages/pi-ai/dist/providers/think-tag-parser.test.d.ts.map +1 -0
  421. package/packages/pi-ai/dist/providers/think-tag-parser.test.js +41 -0
  422. package/packages/pi-ai/dist/providers/think-tag-parser.test.js.map +1 -0
  423. package/packages/pi-ai/dist/utils/oauth/github-copilot.d.ts.map +1 -1
  424. package/packages/pi-ai/dist/utils/oauth/github-copilot.js +12 -2
  425. package/packages/pi-ai/dist/utils/oauth/github-copilot.js.map +1 -1
  426. package/packages/pi-ai/dist/utils/oauth/github-copilot.test.js +164 -14
  427. package/packages/pi-ai/dist/utils/oauth/github-copilot.test.js.map +1 -1
  428. package/packages/pi-ai/dist/utils/oauth/google-antigravity.d.ts.map +1 -1
  429. package/packages/pi-ai/dist/utils/oauth/google-antigravity.js +15 -3
  430. package/packages/pi-ai/dist/utils/oauth/google-antigravity.js.map +1 -1
  431. package/packages/pi-ai/dist/utils/oauth/google-antigravity.test.d.ts +2 -0
  432. package/packages/pi-ai/dist/utils/oauth/google-antigravity.test.d.ts.map +1 -0
  433. package/packages/pi-ai/dist/utils/oauth/google-antigravity.test.js +67 -0
  434. package/packages/pi-ai/dist/utils/oauth/google-antigravity.test.js.map +1 -0
  435. package/packages/pi-ai/dist/utils/oauth/google-gemini-cli.d.ts.map +1 -1
  436. package/packages/pi-ai/dist/utils/oauth/google-gemini-cli.js +16 -3
  437. package/packages/pi-ai/dist/utils/oauth/google-gemini-cli.js.map +1 -1
  438. package/packages/pi-ai/dist/utils/oauth/google-gemini-cli.test.d.ts +2 -0
  439. package/packages/pi-ai/dist/utils/oauth/google-gemini-cli.test.d.ts.map +1 -0
  440. package/packages/pi-ai/dist/utils/oauth/google-gemini-cli.test.js +67 -0
  441. package/packages/pi-ai/dist/utils/oauth/google-gemini-cli.test.js.map +1 -0
  442. package/packages/pi-ai/dist/utils/oauth/oauth-providers.test.d.ts +2 -0
  443. package/packages/pi-ai/dist/utils/oauth/oauth-providers.test.d.ts.map +1 -0
  444. package/packages/pi-ai/dist/utils/oauth/oauth-providers.test.js +289 -0
  445. package/packages/pi-ai/dist/utils/oauth/oauth-providers.test.js.map +1 -0
  446. package/packages/pi-ai/package.json +6 -1
  447. package/packages/pi-ai/src/models/custom.ts +42 -0
  448. package/packages/pi-ai/src/providers/anthropic-auth.test.ts +1 -1
  449. package/packages/pi-ai/src/providers/anthropic-bearer-auth.test.ts +26 -0
  450. package/packages/pi-ai/src/providers/anthropic-shared.ts +26 -5
  451. package/packages/pi-ai/src/providers/anthropic.ts +15 -4
  452. package/packages/pi-ai/src/providers/minimax-tool-name.test.ts +98 -0
  453. package/packages/pi-ai/src/providers/openai-completions.ts +57 -16
  454. package/packages/pi-ai/src/providers/simple-options.ts +17 -1
  455. package/packages/pi-ai/src/providers/think-tag-parser.test.ts +44 -0
  456. package/packages/pi-ai/src/providers/think-tag-parser.ts +94 -0
  457. package/packages/pi-ai/src/utils/oauth/github-copilot.test.ts +200 -23
  458. package/packages/pi-ai/src/utils/oauth/github-copilot.ts +12 -2
  459. package/packages/pi-ai/src/utils/oauth/google-antigravity.test.ts +84 -0
  460. package/packages/pi-ai/src/utils/oauth/google-antigravity.ts +15 -5
  461. package/packages/pi-ai/src/utils/oauth/google-gemini-cli.test.ts +84 -0
  462. package/packages/pi-ai/src/utils/oauth/google-gemini-cli.ts +16 -5
  463. package/packages/pi-ai/src/utils/oauth/oauth-providers.test.ts +363 -0
  464. package/packages/pi-ai/tsconfig.tsbuildinfo +1 -1
  465. package/packages/pi-coding-agent/dist/core/agent-session-abort-order.test.js +3 -2
  466. package/packages/pi-coding-agent/dist/core/agent-session-abort-order.test.js.map +1 -1
  467. package/packages/pi-coding-agent/dist/core/agent-session.d.ts +2 -0
  468. package/packages/pi-coding-agent/dist/core/agent-session.d.ts.map +1 -1
  469. package/packages/pi-coding-agent/dist/core/agent-session.js +32 -2
  470. package/packages/pi-coding-agent/dist/core/agent-session.js.map +1 -1
  471. package/packages/pi-coding-agent/dist/core/compaction/compaction.d.ts +25 -0
  472. package/packages/pi-coding-agent/dist/core/compaction/compaction.d.ts.map +1 -1
  473. package/packages/pi-coding-agent/dist/core/compaction/compaction.js +105 -6
  474. package/packages/pi-coding-agent/dist/core/compaction/compaction.js.map +1 -1
  475. package/packages/pi-coding-agent/dist/core/compaction/compaction.test.js +230 -28
  476. package/packages/pi-coding-agent/dist/core/compaction/compaction.test.js.map +1 -1
  477. package/packages/pi-coding-agent/dist/core/compaction/utils.d.ts +30 -2
  478. package/packages/pi-coding-agent/dist/core/compaction/utils.d.ts.map +1 -1
  479. package/packages/pi-coding-agent/dist/core/compaction/utils.js +113 -12
  480. package/packages/pi-coding-agent/dist/core/compaction/utils.js.map +1 -1
  481. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.d.ts +1 -0
  482. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.d.ts.map +1 -1
  483. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.js +29 -18
  484. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.js.map +1 -1
  485. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.test.d.ts +2 -0
  486. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.test.d.ts.map +1 -0
  487. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.test.js +130 -0
  488. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.test.js.map +1 -0
  489. package/packages/pi-coding-agent/dist/core/compaction-utils.test.js +56 -1
  490. package/packages/pi-coding-agent/dist/core/compaction-utils.test.js.map +1 -1
  491. package/packages/pi-coding-agent/dist/core/discovery-cache.test.js +8 -15
  492. package/packages/pi-coding-agent/dist/core/discovery-cache.test.js.map +1 -1
  493. package/packages/pi-coding-agent/dist/core/extensions/extension-discovery.d.ts +25 -0
  494. package/packages/pi-coding-agent/dist/core/extensions/extension-discovery.d.ts.map +1 -0
  495. package/packages/pi-coding-agent/dist/core/extensions/extension-discovery.js +109 -0
  496. package/packages/pi-coding-agent/dist/core/extensions/extension-discovery.js.map +1 -0
  497. package/packages/pi-coding-agent/dist/core/extensions/extension-registry.d.ts +67 -0
  498. package/packages/pi-coding-agent/dist/core/extensions/extension-registry.d.ts.map +1 -0
  499. package/packages/pi-coding-agent/dist/core/extensions/extension-registry.js +167 -0
  500. package/packages/pi-coding-agent/dist/core/extensions/extension-registry.js.map +1 -0
  501. package/packages/pi-coding-agent/dist/core/extensions/index.d.ts +1 -1
  502. package/packages/pi-coding-agent/dist/core/extensions/index.d.ts.map +1 -1
  503. package/packages/pi-coding-agent/dist/core/extensions/index.js.map +1 -1
  504. package/packages/pi-coding-agent/dist/core/extensions/loader.d.ts +3 -2
  505. package/packages/pi-coding-agent/dist/core/extensions/loader.d.ts.map +1 -1
  506. package/packages/pi-coding-agent/dist/core/extensions/loader.js +28 -8
  507. package/packages/pi-coding-agent/dist/core/extensions/loader.js.map +1 -1
  508. package/packages/pi-coding-agent/dist/core/extensions/runner.d.ts +35 -2
  509. package/packages/pi-coding-agent/dist/core/extensions/runner.d.ts.map +1 -1
  510. package/packages/pi-coding-agent/dist/core/extensions/runner.js +233 -0
  511. package/packages/pi-coding-agent/dist/core/extensions/runner.js.map +1 -1
  512. package/packages/pi-coding-agent/dist/core/extensions/types.d.ts +212 -2
  513. package/packages/pi-coding-agent/dist/core/extensions/types.d.ts.map +1 -1
  514. package/packages/pi-coding-agent/dist/core/extensions/types.js.map +1 -1
  515. package/packages/pi-coding-agent/dist/core/hooks-runner.d.ts +53 -0
  516. package/packages/pi-coding-agent/dist/core/hooks-runner.d.ts.map +1 -0
  517. package/packages/pi-coding-agent/dist/core/hooks-runner.js +337 -0
  518. package/packages/pi-coding-agent/dist/core/hooks-runner.js.map +1 -0
  519. package/packages/pi-coding-agent/dist/core/hooks-runner.test.d.ts +2 -0
  520. package/packages/pi-coding-agent/dist/core/hooks-runner.test.d.ts.map +1 -0
  521. package/packages/pi-coding-agent/dist/core/hooks-runner.test.js +234 -0
  522. package/packages/pi-coding-agent/dist/core/hooks-runner.test.js.map +1 -0
  523. package/packages/pi-coding-agent/dist/core/index.d.ts +1 -0
  524. package/packages/pi-coding-agent/dist/core/index.d.ts.map +1 -1
  525. package/packages/pi-coding-agent/dist/core/index.js +1 -0
  526. package/packages/pi-coding-agent/dist/core/index.js.map +1 -1
  527. package/packages/pi-coding-agent/dist/core/lsp/lsp-integration.test.js +11 -0
  528. package/packages/pi-coding-agent/dist/core/lsp/lsp-integration.test.js.map +1 -1
  529. package/packages/pi-coding-agent/dist/core/model-discovery.d.ts +3 -1
  530. package/packages/pi-coding-agent/dist/core/model-discovery.d.ts.map +1 -1
  531. package/packages/pi-coding-agent/dist/core/model-discovery.js +92 -12
  532. package/packages/pi-coding-agent/dist/core/model-discovery.js.map +1 -1
  533. package/packages/pi-coding-agent/dist/core/model-discovery.test.js +16 -1
  534. package/packages/pi-coding-agent/dist/core/model-discovery.test.js.map +1 -1
  535. package/packages/pi-coding-agent/dist/core/model-registry-auth-header.test.d.ts +2 -0
  536. package/packages/pi-coding-agent/dist/core/model-registry-auth-header.test.d.ts.map +1 -0
  537. package/packages/pi-coding-agent/dist/core/model-registry-auth-header.test.js +40 -0
  538. package/packages/pi-coding-agent/dist/core/model-registry-auth-header.test.js.map +1 -0
  539. package/packages/pi-coding-agent/dist/core/model-registry-auth-mode.test.js +2 -2
  540. package/packages/pi-coding-agent/dist/core/model-registry-auth-mode.test.js.map +1 -1
  541. package/packages/pi-coding-agent/dist/core/model-registry-custom-caps.test.d.ts +2 -0
  542. package/packages/pi-coding-agent/dist/core/model-registry-custom-caps.test.d.ts.map +1 -0
  543. package/packages/pi-coding-agent/dist/core/model-registry-custom-caps.test.js +203 -0
  544. package/packages/pi-coding-agent/dist/core/model-registry-custom-caps.test.js.map +1 -0
  545. package/packages/pi-coding-agent/dist/core/model-registry-discovery.test.js +61 -1
  546. package/packages/pi-coding-agent/dist/core/model-registry-discovery.test.js.map +1 -1
  547. package/packages/pi-coding-agent/dist/core/model-registry.d.ts +5 -0
  548. package/packages/pi-coding-agent/dist/core/model-registry.d.ts.map +1 -1
  549. package/packages/pi-coding-agent/dist/core/model-registry.js +90 -10
  550. package/packages/pi-coding-agent/dist/core/model-registry.js.map +1 -1
  551. package/packages/pi-coding-agent/dist/core/redact-secrets.d.ts +2 -0
  552. package/packages/pi-coding-agent/dist/core/redact-secrets.d.ts.map +1 -0
  553. package/packages/pi-coding-agent/dist/core/redact-secrets.js +49 -0
  554. package/packages/pi-coding-agent/dist/core/redact-secrets.js.map +1 -0
  555. package/packages/pi-coding-agent/dist/core/redact-secrets.test.d.ts +2 -0
  556. package/packages/pi-coding-agent/dist/core/redact-secrets.test.d.ts.map +1 -0
  557. package/packages/pi-coding-agent/dist/core/redact-secrets.test.js +67 -0
  558. package/packages/pi-coding-agent/dist/core/redact-secrets.test.js.map +1 -0
  559. package/packages/pi-coding-agent/dist/core/resource-loader.js +1 -1
  560. package/packages/pi-coding-agent/dist/core/resource-loader.js.map +1 -1
  561. package/packages/pi-coding-agent/dist/core/sdk.d.ts +1 -0
  562. package/packages/pi-coding-agent/dist/core/sdk.d.ts.map +1 -1
  563. package/packages/pi-coding-agent/dist/core/sdk.js +4 -1
  564. package/packages/pi-coding-agent/dist/core/sdk.js.map +1 -1
  565. package/packages/pi-coding-agent/dist/core/sdk.test.js +19 -1
  566. package/packages/pi-coding-agent/dist/core/sdk.test.js.map +1 -1
  567. package/packages/pi-coding-agent/dist/core/session-manager.d.ts.map +1 -1
  568. package/packages/pi-coding-agent/dist/core/session-manager.js +10 -6
  569. package/packages/pi-coding-agent/dist/core/session-manager.js.map +1 -1
  570. package/packages/pi-coding-agent/dist/core/session-manager.test.js +45 -1
  571. package/packages/pi-coding-agent/dist/core/session-manager.test.js.map +1 -1
  572. package/packages/pi-coding-agent/dist/core/settings-manager.d.ts +55 -0
  573. package/packages/pi-coding-agent/dist/core/settings-manager.d.ts.map +1 -1
  574. package/packages/pi-coding-agent/dist/core/settings-manager.js.map +1 -1
  575. package/packages/pi-coding-agent/dist/core/system-prompt.js +3 -3
  576. package/packages/pi-coding-agent/dist/core/system-prompt.js.map +1 -1
  577. package/packages/pi-coding-agent/dist/core/tools/path-utils.test.js +2 -1
  578. package/packages/pi-coding-agent/dist/core/tools/path-utils.test.js.map +1 -1
  579. package/packages/pi-coding-agent/dist/index.d.ts +1 -1
  580. package/packages/pi-coding-agent/dist/index.d.ts.map +1 -1
  581. package/packages/pi-coding-agent/dist/index.js.map +1 -1
  582. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/provider-display-name.test.js +15 -6
  583. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/provider-display-name.test.js.map +1 -1
  584. package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.d.ts +1 -1
  585. package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.d.ts.map +1 -1
  586. package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.js +5 -4
  587. package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.js.map +1 -1
  588. package/packages/pi-coding-agent/dist/modes/interactive/components/footer.d.ts.map +1 -1
  589. package/packages/pi-coding-agent/dist/modes/interactive/components/footer.js +14 -5
  590. package/packages/pi-coding-agent/dist/modes/interactive/components/footer.js.map +1 -1
  591. package/packages/pi-coding-agent/dist/modes/interactive/components/model-selector.d.ts +7 -1
  592. package/packages/pi-coding-agent/dist/modes/interactive/components/model-selector.d.ts.map +1 -1
  593. package/packages/pi-coding-agent/dist/modes/interactive/components/model-selector.js +31 -9
  594. package/packages/pi-coding-agent/dist/modes/interactive/components/model-selector.js.map +1 -1
  595. package/packages/pi-coding-agent/dist/modes/interactive/components/provider-manager.d.ts.map +1 -1
  596. package/packages/pi-coding-agent/dist/modes/interactive/components/provider-manager.js +13 -7
  597. package/packages/pi-coding-agent/dist/modes/interactive/components/provider-manager.js.map +1 -1
  598. package/packages/pi-coding-agent/dist/modes/interactive/components/skill-invocation-message.d.ts +7 -6
  599. package/packages/pi-coding-agent/dist/modes/interactive/components/skill-invocation-message.d.ts.map +1 -1
  600. package/packages/pi-coding-agent/dist/modes/interactive/components/skill-invocation-message.js +29 -21
  601. package/packages/pi-coding-agent/dist/modes/interactive/components/skill-invocation-message.js.map +1 -1
  602. package/packages/pi-coding-agent/dist/modes/interactive/controllers/input-controller.test.js +14 -0
  603. package/packages/pi-coding-agent/dist/modes/interactive/controllers/input-controller.test.js.map +1 -1
  604. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts.map +1 -1
  605. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js +13 -1
  606. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js.map +1 -1
  607. package/packages/pi-coding-agent/package.json +6 -1
  608. package/packages/pi-coding-agent/src/core/agent-session-abort-order.test.ts +3 -2
  609. package/packages/pi-coding-agent/src/core/agent-session.ts +38 -2
  610. package/packages/pi-coding-agent/src/core/compaction/compaction.test.ts +368 -28
  611. package/packages/pi-coding-agent/src/core/compaction/compaction.ts +122 -6
  612. package/packages/pi-coding-agent/src/core/compaction/utils.ts +111 -13
  613. package/packages/pi-coding-agent/src/core/compaction-orchestrator.test.ts +154 -0
  614. package/packages/pi-coding-agent/src/core/compaction-orchestrator.ts +32 -18
  615. package/packages/pi-coding-agent/src/core/compaction-utils.test.ts +68 -1
  616. package/packages/pi-coding-agent/src/core/discovery-cache.test.ts +9 -18
  617. package/packages/pi-coding-agent/src/core/extensions/extension-discovery.ts +119 -0
  618. package/packages/pi-coding-agent/src/core/extensions/extension-registry.ts +222 -0
  619. package/packages/pi-coding-agent/src/core/extensions/index.ts +16 -0
  620. package/packages/pi-coding-agent/src/core/extensions/loader.ts +29 -11
  621. package/packages/pi-coding-agent/src/core/extensions/runner.ts +351 -0
  622. package/packages/pi-coding-agent/src/core/extensions/types.ts +266 -0
  623. package/packages/pi-coding-agent/src/core/hooks-runner.test.ts +269 -0
  624. package/packages/pi-coding-agent/src/core/hooks-runner.ts +460 -0
  625. package/packages/pi-coding-agent/src/core/index.ts +10 -0
  626. package/packages/pi-coding-agent/src/core/lsp/lsp-integration.test.ts +13 -0
  627. package/packages/pi-coding-agent/src/core/model-discovery.test.ts +19 -0
  628. package/packages/pi-coding-agent/src/core/model-discovery.ts +99 -12
  629. package/packages/pi-coding-agent/src/core/model-registry-auth-header.test.ts +44 -0
  630. package/packages/pi-coding-agent/src/core/model-registry-auth-mode.test.ts +2 -2
  631. package/packages/pi-coding-agent/src/core/model-registry-custom-caps.test.ts +245 -0
  632. package/packages/pi-coding-agent/src/core/model-registry-discovery.test.ts +75 -0
  633. package/packages/pi-coding-agent/src/core/model-registry.ts +102 -10
  634. package/packages/pi-coding-agent/src/core/redact-secrets.test.ts +86 -0
  635. package/packages/pi-coding-agent/src/core/redact-secrets.ts +58 -0
  636. package/packages/pi-coding-agent/src/core/resource-loader.ts +1 -1
  637. package/packages/pi-coding-agent/src/core/sdk.test.ts +25 -1
  638. package/packages/pi-coding-agent/src/core/sdk.ts +10 -3
  639. package/packages/pi-coding-agent/src/core/session-manager.test.ts +65 -1
  640. package/packages/pi-coding-agent/src/core/session-manager.ts +10 -6
  641. package/packages/pi-coding-agent/src/core/settings-manager.ts +57 -0
  642. package/packages/pi-coding-agent/src/core/system-prompt.ts +3 -3
  643. package/packages/pi-coding-agent/src/core/tools/path-utils.test.ts +2 -1
  644. package/packages/pi-coding-agent/src/index.ts +16 -0
  645. package/packages/pi-coding-agent/src/modes/interactive/components/__tests__/provider-display-name.test.ts +17 -7
  646. package/packages/pi-coding-agent/src/modes/interactive/components/chat-frame.ts +6 -6
  647. package/packages/pi-coding-agent/src/modes/interactive/components/footer.ts +14 -5
  648. package/packages/pi-coding-agent/src/modes/interactive/components/model-selector.ts +45 -11
  649. package/packages/pi-coding-agent/src/modes/interactive/components/provider-manager.ts +16 -7
  650. package/packages/pi-coding-agent/src/modes/interactive/components/skill-invocation-message.ts +36 -22
  651. package/packages/pi-coding-agent/src/modes/interactive/controllers/input-controller.test.ts +14 -0
  652. package/packages/pi-coding-agent/src/modes/interactive/interactive-mode.ts +13 -1
  653. package/packages/pi-coding-agent/tsconfig.tsbuildinfo +1 -1
  654. package/packages/pi-tui/dist/__tests__/autocomplete.test.js +12 -5
  655. package/packages/pi-tui/dist/__tests__/autocomplete.test.js.map +1 -1
  656. package/packages/pi-tui/dist/__tests__/stdin-buffer.test.js +21 -0
  657. package/packages/pi-tui/dist/__tests__/stdin-buffer.test.js.map +1 -1
  658. package/packages/pi-tui/dist/stdin-buffer.d.ts +7 -0
  659. package/packages/pi-tui/dist/stdin-buffer.d.ts.map +1 -1
  660. package/packages/pi-tui/dist/stdin-buffer.js +20 -0
  661. package/packages/pi-tui/dist/stdin-buffer.js.map +1 -1
  662. package/packages/pi-tui/package.json +6 -1
  663. package/packages/pi-tui/src/__tests__/autocomplete.test.ts +20 -5
  664. package/packages/pi-tui/src/__tests__/stdin-buffer.test.ts +27 -0
  665. package/packages/pi-tui/src/stdin-buffer.ts +26 -0
  666. package/packages/pi-tui/tsconfig.tsbuildinfo +1 -1
  667. package/packages/rpc-client/package.json +6 -1
  668. package/pkg/package.json +1 -1
  669. package/scripts/install.js +512 -0
  670. package/scripts/lib/workspace-manifest.cjs +86 -0
  671. package/scripts/link-workspace-packages.cjs +5 -16
  672. package/scripts/postinstall.js +9 -178
  673. package/src/resources/agents/researcher.md +1 -1
  674. package/src/resources/extensions/claude-code-cli/readiness.ts +32 -8
  675. package/src/resources/extensions/claude-code-cli/stream-adapter.ts +158 -67
  676. package/src/resources/extensions/claude-code-cli/tests/stream-adapter.test.ts +251 -14
  677. package/src/resources/extensions/cmux/index.ts +35 -10
  678. package/src/resources/extensions/github-sync/templates.ts +151 -0
  679. package/src/resources/extensions/github-sync/tests/templates.test.ts +59 -0
  680. package/src/resources/extensions/google-search/extension-manifest.json +5 -4
  681. package/src/resources/extensions/google-search/index.ts +9 -470
  682. package/src/resources/extensions/gsd/abandon-detect.ts +62 -0
  683. package/src/resources/extensions/gsd/auto/loop-deps.ts +15 -1
  684. package/src/resources/extensions/gsd/auto/loop.ts +104 -2
  685. package/src/resources/extensions/gsd/auto/phases.ts +176 -27
  686. package/src/resources/extensions/gsd/auto/resolve.ts +29 -0
  687. package/src/resources/extensions/gsd/auto/run-unit.ts +56 -4
  688. package/src/resources/extensions/gsd/auto/session.ts +35 -2
  689. package/src/resources/extensions/gsd/auto/turn-epoch.ts +108 -0
  690. package/src/resources/extensions/gsd/auto/types.ts +1 -1
  691. package/src/resources/extensions/gsd/auto-dispatch.ts +117 -16
  692. package/src/resources/extensions/gsd/auto-loop.ts +1 -1
  693. package/src/resources/extensions/gsd/auto-model-selection.ts +71 -15
  694. package/src/resources/extensions/gsd/auto-post-unit.ts +92 -3
  695. package/src/resources/extensions/gsd/auto-prompts.ts +28 -1
  696. package/src/resources/extensions/gsd/auto-recovery.ts +40 -1
  697. package/src/resources/extensions/gsd/auto-start.ts +88 -74
  698. package/src/resources/extensions/gsd/auto-timeout-recovery.ts +12 -5
  699. package/src/resources/extensions/gsd/auto-unit-closeout.ts +14 -3
  700. package/src/resources/extensions/gsd/auto-verification.ts +33 -0
  701. package/src/resources/extensions/gsd/auto-worktree.ts +122 -68
  702. package/src/resources/extensions/gsd/auto.ts +115 -42
  703. package/src/resources/extensions/gsd/blocked-models.ts +98 -0
  704. package/src/resources/extensions/gsd/bootstrap/agent-end-recovery.ts +131 -1
  705. package/src/resources/extensions/gsd/bootstrap/db-tools.ts +40 -9
  706. package/src/resources/extensions/gsd/bootstrap/exec-tools.ts +109 -0
  707. package/src/resources/extensions/gsd/bootstrap/memory-tools.ts +5 -0
  708. package/src/resources/extensions/gsd/bootstrap/provider-error-resume.ts +6 -2
  709. package/src/resources/extensions/gsd/bootstrap/register-extension.ts +26 -0
  710. package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +54 -6
  711. package/src/resources/extensions/gsd/bootstrap/system-context.ts +102 -35
  712. package/src/resources/extensions/gsd/bootstrap/write-gate.ts +35 -2
  713. package/src/resources/extensions/gsd/clean-root-preflight.ts +111 -0
  714. package/src/resources/extensions/gsd/commands/handlers/workflow.ts +27 -8
  715. package/src/resources/extensions/gsd/commands-cmux.ts +10 -6
  716. package/src/resources/extensions/gsd/commands-extensions.ts +747 -41
  717. package/src/resources/extensions/gsd/commands-extract-learnings.ts +55 -90
  718. package/src/resources/extensions/gsd/commands-prefs-wizard.ts +898 -32
  719. package/src/resources/extensions/gsd/compaction-snapshot.ts +165 -0
  720. package/src/resources/extensions/gsd/complexity-classifier.ts +5 -3
  721. package/src/resources/extensions/gsd/db-writer.ts +88 -17
  722. package/src/resources/extensions/gsd/dispatch-guard.ts +26 -2
  723. package/src/resources/extensions/gsd/doctor-git-checks.ts +23 -27
  724. package/src/resources/extensions/gsd/doctor-providers.ts +59 -6
  725. package/src/resources/extensions/gsd/ecosystem/gsd-extension-api.ts +2 -0
  726. package/src/resources/extensions/gsd/error-classifier.ts +36 -3
  727. package/src/resources/extensions/gsd/exec-history.ts +153 -0
  728. package/src/resources/extensions/gsd/exec-sandbox.ts +326 -0
  729. package/src/resources/extensions/gsd/file-lock.ts +84 -11
  730. package/src/resources/extensions/gsd/git-service.ts +1 -0
  731. package/src/resources/extensions/gsd/gitignore.ts +2 -1
  732. package/src/resources/extensions/gsd/gsd-db.ts +186 -23
  733. package/src/resources/extensions/gsd/guided-flow-queue.ts +4 -1
  734. package/src/resources/extensions/gsd/guided-flow.ts +259 -10
  735. package/src/resources/extensions/gsd/health-widget.ts +3 -1
  736. package/src/resources/extensions/gsd/hook-emitter.ts +188 -0
  737. package/src/resources/extensions/gsd/init-wizard.ts +15 -1
  738. package/src/resources/extensions/gsd/journal.ts +29 -3
  739. package/src/resources/extensions/gsd/key-manager.ts +28 -0
  740. package/src/resources/extensions/gsd/memory-backfill.ts +140 -0
  741. package/src/resources/extensions/gsd/memory-store.ts +26 -0
  742. package/src/resources/extensions/gsd/milestone-actions.ts +18 -0
  743. package/src/resources/extensions/gsd/milestone-summary-classifier.ts +42 -0
  744. package/src/resources/extensions/gsd/model-router.ts +42 -1
  745. package/src/resources/extensions/gsd/notifications.ts +27 -15
  746. package/src/resources/extensions/gsd/pre-execution-checks.ts +46 -10
  747. package/src/resources/extensions/gsd/preferences-types.ts +46 -0
  748. package/src/resources/extensions/gsd/preferences-validation.ts +79 -0
  749. package/src/resources/extensions/gsd/preferences.ts +17 -17
  750. package/src/resources/extensions/gsd/prompt-loader.ts +30 -7
  751. package/src/resources/extensions/gsd/prompts/complete-milestone.md +1 -1
  752. package/src/resources/extensions/gsd/prompts/complete-slice.md +2 -2
  753. package/src/resources/extensions/gsd/prompts/debug-diagnose.md +2 -0
  754. package/src/resources/extensions/gsd/prompts/discuss-headless.md +29 -2
  755. package/src/resources/extensions/gsd/prompts/discuss.md +29 -2
  756. package/src/resources/extensions/gsd/prompts/doctor-heal.md +5 -4
  757. package/src/resources/extensions/gsd/prompts/execute-task.md +3 -2
  758. package/src/resources/extensions/gsd/prompts/parallel-research-slices.md +5 -2
  759. package/src/resources/extensions/gsd/prompts/plan-slice.md +1 -0
  760. package/src/resources/extensions/gsd/prompts/research-slice.md +1 -0
  761. package/src/resources/extensions/gsd/prompts/system.md +1 -0
  762. package/src/resources/extensions/gsd/reports.ts +5 -4
  763. package/src/resources/extensions/gsd/safety/evidence-collector.ts +119 -0
  764. package/src/resources/extensions/gsd/safety/file-change-validator.ts +17 -4
  765. package/src/resources/extensions/gsd/safety/safety-harness.ts +9 -0
  766. package/src/resources/extensions/gsd/state-transition-matrix.ts +152 -0
  767. package/src/resources/extensions/gsd/state.ts +80 -34
  768. package/src/resources/extensions/gsd/tests/auto-loop.test.ts +238 -4
  769. package/src/resources/extensions/gsd/tests/auto-mode-guards.test.ts +79 -0
  770. package/src/resources/extensions/gsd/tests/auto-model-selection.test.ts +95 -1
  771. package/src/resources/extensions/gsd/tests/auto-paused-session-validation.test.ts +12 -0
  772. package/src/resources/extensions/gsd/tests/auto-recovery.test.ts +122 -0
  773. package/src/resources/extensions/gsd/tests/auto-start-bootstrap-await-3420.test.ts +141 -0
  774. package/src/resources/extensions/gsd/tests/auto-start-clean-runtime-db-gated.test.ts +63 -0
  775. package/src/resources/extensions/gsd/tests/auto-start-model-capture.test.ts +33 -3
  776. package/src/resources/extensions/gsd/tests/auto-thinking-restore.test.ts +38 -0
  777. package/src/resources/extensions/gsd/tests/auto-wrapup-inflight-guard.test.ts +23 -0
  778. package/src/resources/extensions/gsd/tests/blocked-models.test.ts +98 -0
  779. package/src/resources/extensions/gsd/tests/bundled-skill-triggers.test.ts +54 -0
  780. package/src/resources/extensions/gsd/tests/clean-root-preflight.test.ts +186 -0
  781. package/src/resources/extensions/gsd/tests/cmux.test.ts +5 -9
  782. package/src/resources/extensions/gsd/tests/commands-extract-learnings.test.ts +68 -66
  783. package/src/resources/extensions/gsd/tests/compaction-snapshot.test.ts +123 -0
  784. package/src/resources/extensions/gsd/tests/complete-milestone-false-merge.test.ts +15 -0
  785. package/src/resources/extensions/gsd/tests/complete-milestone.test.ts +61 -1
  786. package/src/resources/extensions/gsd/tests/complete-slice.test.ts +2 -2
  787. package/src/resources/extensions/gsd/tests/complete-task.test.ts +2 -2
  788. package/src/resources/extensions/gsd/tests/complexity-classifier.test.ts +3 -3
  789. package/src/resources/extensions/gsd/tests/custom-engine-loop-integration.test.ts +161 -0
  790. package/src/resources/extensions/gsd/tests/db-access-guardrails.test.ts +1 -0
  791. package/src/resources/extensions/gsd/tests/derive-state-db.test.ts +42 -0
  792. package/src/resources/extensions/gsd/tests/derive-state-helpers.test.ts +8 -4
  793. package/src/resources/extensions/gsd/tests/derive-state.test.ts +1 -2
  794. package/src/resources/extensions/gsd/tests/dispatch-complete-milestone-guard.test.ts +14 -9
  795. package/src/resources/extensions/gsd/tests/dispatch-guard-summary-db-mismatch.test.ts +77 -0
  796. package/src/resources/extensions/gsd/tests/dispatch-guard.test.ts +25 -0
  797. package/src/resources/extensions/gsd/tests/dispatch-missing-task-plans.test.ts +14 -0
  798. package/src/resources/extensions/gsd/tests/doctor-providers.test.ts +148 -3
  799. package/src/resources/extensions/gsd/tests/double-merge-guard.test.ts +1 -1
  800. package/src/resources/extensions/gsd/tests/ensure-db-open.test.ts +306 -1
  801. package/src/resources/extensions/gsd/tests/escalation.test.ts +1 -1
  802. package/src/resources/extensions/gsd/tests/exec-history.test.ts +237 -0
  803. package/src/resources/extensions/gsd/tests/exec-sandbox.test.ts +210 -0
  804. package/src/resources/extensions/gsd/tests/execution-entry-missing-context-4671.test.ts +173 -0
  805. package/src/resources/extensions/gsd/tests/file-change-validator.test.ts +58 -0
  806. package/src/resources/extensions/gsd/tests/file-lock.test.ts +86 -12
  807. package/src/resources/extensions/gsd/tests/flat-rate-routing-guard.test.ts +40 -9
  808. package/src/resources/extensions/gsd/tests/freeform-decisions.test.ts +62 -0
  809. package/src/resources/extensions/gsd/tests/google-search-stub.test.ts +131 -0
  810. package/src/resources/extensions/gsd/tests/gsd-db.test.ts +447 -1
  811. package/src/resources/extensions/gsd/tests/headless-milestone-parity.test.ts +117 -0
  812. package/src/resources/extensions/gsd/tests/init-wizard.test.ts +27 -0
  813. package/src/resources/extensions/gsd/tests/integration/auto-worktree-milestone-merge.test.ts +30 -0
  814. package/src/resources/extensions/gsd/tests/integration/doctor-git-symlink-cwd.test.ts +11 -0
  815. package/src/resources/extensions/gsd/tests/integration/doctor-git.test.ts +78 -0
  816. package/src/resources/extensions/gsd/tests/integration/git-service.test.ts +4 -2
  817. package/src/resources/extensions/gsd/tests/integration/gitignore-tracked-gsd.test.ts +1 -0
  818. package/src/resources/extensions/gsd/tests/integration/idle-recovery.test.ts +30 -0
  819. package/src/resources/extensions/gsd/tests/integration/worktree-e2e.test.ts +11 -0
  820. package/src/resources/extensions/gsd/tests/interactive-routing-bypass.test.ts +1 -1
  821. package/src/resources/extensions/gsd/tests/isolation-none-branch-guard.test.ts +1 -1
  822. package/src/resources/extensions/gsd/tests/issue-4540-regressions.test.ts +288 -0
  823. package/src/resources/extensions/gsd/tests/journal-integration.test.ts +101 -0
  824. package/src/resources/extensions/gsd/tests/key-manager.test.ts +9 -0
  825. package/src/resources/extensions/gsd/tests/load-memory-block.test.ts +36 -0
  826. package/src/resources/extensions/gsd/tests/mcp-client-security.test.ts +76 -0
  827. package/src/resources/extensions/gsd/tests/md-importer.test.ts +1 -1
  828. package/src/resources/extensions/gsd/tests/memory-pressure-stuck-state.test.ts +12 -0
  829. package/src/resources/extensions/gsd/tests/memory-store.test.ts +2 -2
  830. package/src/resources/extensions/gsd/tests/milestone-status-authoritative.test.ts +3 -3
  831. package/src/resources/extensions/gsd/tests/milestone-summary-classifier.test.ts +30 -0
  832. package/src/resources/extensions/gsd/tests/milestone-transition-state-rebuild.test.ts +4 -2
  833. package/src/resources/extensions/gsd/tests/parallel-commit-scope.test.ts +5 -0
  834. package/src/resources/extensions/gsd/tests/parallel-research-dispatch.test.ts +19 -0
  835. package/src/resources/extensions/gsd/tests/parallel-skill-prompt-integration.test.ts +150 -0
  836. package/src/resources/extensions/gsd/tests/plan-gate-failed-doctor-heal-hint.test.ts +37 -0
  837. package/src/resources/extensions/gsd/tests/pre-exec-backtick-strip.test.ts +14 -0
  838. package/src/resources/extensions/gsd/tests/pre-exec-gate-loop.test.ts +272 -0
  839. package/src/resources/extensions/gsd/tests/pre-execution-checks.test.ts +356 -0
  840. package/src/resources/extensions/gsd/tests/preferences.test.ts +110 -0
  841. package/src/resources/extensions/gsd/tests/prefs-wizard-coverage.test.ts +44 -0
  842. package/src/resources/extensions/gsd/tests/prompt-loader-extension-dir.test.ts +49 -0
  843. package/src/resources/extensions/gsd/tests/provider-errors.test.ts +142 -29
  844. package/src/resources/extensions/gsd/tests/queue-auto-guard.test.ts +181 -0
  845. package/src/resources/extensions/gsd/tests/quick-auto-guard.test.ts +13 -7
  846. package/src/resources/extensions/gsd/tests/ready-phrase-no-files-4573.test.ts +388 -0
  847. package/src/resources/extensions/gsd/tests/require-slice-discussion-dispatch.test.ts +170 -0
  848. package/src/resources/extensions/gsd/tests/restore-tools-after-discuss.test.ts +9 -3
  849. package/src/resources/extensions/gsd/tests/resume-dispatch-worktree.test.ts +230 -0
  850. package/src/resources/extensions/gsd/tests/rewrite-docs-abandon-detect.test.ts +195 -0
  851. package/src/resources/extensions/gsd/tests/safety-harness-false-positives.test.ts +205 -0
  852. package/src/resources/extensions/gsd/tests/save-gate-result-render.test.ts +95 -0
  853. package/src/resources/extensions/gsd/tests/schema-v21-sequence.test.ts +413 -0
  854. package/src/resources/extensions/gsd/tests/session-start-footer.test.ts +32 -40
  855. package/src/resources/extensions/gsd/tests/stale-dirlistcache-4648.test.ts +112 -0
  856. package/src/resources/extensions/gsd/tests/stash-queued-context-files.test.ts +56 -0
  857. package/src/resources/extensions/gsd/tests/state-machine-full-walkthrough.test.ts +24 -0
  858. package/src/resources/extensions/gsd/tests/state-transition-matrix.test.ts +44 -0
  859. package/src/resources/extensions/gsd/tests/stuck-detection-coverage.test.ts +2 -2
  860. package/src/resources/extensions/gsd/tests/token-counter.test.ts +105 -1
  861. package/src/resources/extensions/gsd/tests/tool-compatibility.test.ts +107 -0
  862. package/src/resources/extensions/gsd/tests/triage-resolution.test.ts +50 -2
  863. package/src/resources/extensions/gsd/tests/turn-epoch.test.ts +162 -0
  864. package/src/resources/extensions/gsd/tests/uok-contracts.test.ts +51 -0
  865. package/src/resources/extensions/gsd/tests/uok-execution-graph.test.ts +16 -0
  866. package/src/resources/extensions/gsd/tests/uok-loop-adapter-writer.test.ts +65 -0
  867. package/src/resources/extensions/gsd/tests/uok-parity-report.test.ts +42 -0
  868. package/src/resources/extensions/gsd/tests/uok-plan-v2-wiring.test.ts +42 -2
  869. package/src/resources/extensions/gsd/tests/uok-writer.test.ts +75 -0
  870. package/src/resources/extensions/gsd/tests/validate-extension-package.test.ts +168 -0
  871. package/src/resources/extensions/gsd/tests/validate-milestone.test.ts +147 -8
  872. package/src/resources/extensions/gsd/tests/workflow-mcp.test.ts +25 -2
  873. package/src/resources/extensions/gsd/tests/workflow-tool-executors.test.ts +65 -2
  874. package/src/resources/extensions/gsd/tests/worktree-db.test.ts +35 -0
  875. package/src/resources/extensions/gsd/tests/worktree-journal-events.test.ts +6 -1
  876. package/src/resources/extensions/gsd/tests/worktree-resolver.test.ts +78 -5
  877. package/src/resources/extensions/gsd/tests/write-gate.test.ts +64 -0
  878. package/src/resources/extensions/gsd/tests/zombie-gsd-state.test.ts +3 -1
  879. package/src/resources/extensions/gsd/token-counter.ts +22 -5
  880. package/src/resources/extensions/gsd/tools/complete-milestone.ts +15 -9
  881. package/src/resources/extensions/gsd/tools/complete-slice.ts +38 -0
  882. package/src/resources/extensions/gsd/tools/complete-task.ts +49 -0
  883. package/src/resources/extensions/gsd/tools/exec-search-tool.ts +81 -0
  884. package/src/resources/extensions/gsd/tools/exec-tool.ts +183 -0
  885. package/src/resources/extensions/gsd/tools/memory-tools.ts +31 -1
  886. package/src/resources/extensions/gsd/tools/resume-tool.ts +40 -0
  887. package/src/resources/extensions/gsd/uok/audit.ts +20 -2
  888. package/src/resources/extensions/gsd/uok/contracts.ts +65 -0
  889. package/src/resources/extensions/gsd/uok/dispatch-envelope.ts +56 -0
  890. package/src/resources/extensions/gsd/uok/execution-graph.ts +22 -0
  891. package/src/resources/extensions/gsd/uok/gitops.ts +6 -1
  892. package/src/resources/extensions/gsd/uok/loop-adapter.ts +45 -10
  893. package/src/resources/extensions/gsd/uok/parity-report.ts +84 -0
  894. package/src/resources/extensions/gsd/uok/plan-v2.ts +39 -8
  895. package/src/resources/extensions/gsd/uok/writer.ts +113 -0
  896. package/src/resources/extensions/gsd/workflow-logger.ts +25 -3
  897. package/src/resources/extensions/gsd/workflow-mcp.ts +3 -0
  898. package/src/resources/extensions/gsd/workflow-templates/spike.md +6 -0
  899. package/src/resources/extensions/gsd/worktree-manager.ts +1 -0
  900. package/src/resources/extensions/gsd/worktree-resolver.ts +54 -9
  901. package/src/resources/extensions/mcp-client/auth.ts +12 -1
  902. package/src/resources/extensions/mcp-client/index.ts +129 -10
  903. package/src/resources/extensions/search-the-web/command-search-provider.ts +5 -4
  904. package/src/resources/extensions/search-the-web/native-search.ts +48 -12
  905. package/src/resources/extensions/shared/cmux-events.ts +59 -0
  906. package/src/resources/extensions/shared/rtk-session-stats.ts +1 -2
  907. package/src/resources/skills/api-design/SKILL.md +190 -0
  908. package/src/resources/skills/create-mcp-server/SKILL.md +121 -0
  909. package/src/resources/skills/create-skill/SKILL.md +2 -2
  910. package/src/resources/skills/create-skill/references/gsd-skill-ecosystem.md +4 -4
  911. package/src/resources/skills/create-skill/workflows/audit-skill.md +4 -4
  912. package/src/resources/skills/create-skill/workflows/create-new-skill.md +5 -5
  913. package/src/resources/skills/decompose-into-slices/SKILL.md +139 -0
  914. package/src/resources/skills/dependency-upgrade/SKILL.md +158 -0
  915. package/src/resources/skills/design-an-interface/SKILL.md +102 -0
  916. package/src/resources/skills/forensics/SKILL.md +153 -0
  917. package/src/resources/skills/grill-me/SKILL.md +93 -0
  918. package/src/resources/skills/handoff/SKILL.md +121 -0
  919. package/src/resources/skills/observability/SKILL.md +174 -0
  920. package/src/resources/skills/security-review/SKILL.md +181 -0
  921. package/src/resources/skills/spike-wrap-up/SKILL.md +138 -0
  922. package/src/resources/skills/tdd/SKILL.md +112 -0
  923. package/src/resources/skills/verify-before-complete/SKILL.md +98 -0
  924. package/src/resources/skills/write-docs/SKILL.md +82 -0
  925. package/src/resources/skills/write-milestone-brief/SKILL.md +135 -0
  926. package/dist/web/standalone/.next/server/chunks/7461.js +0 -1
  927. package/dist/web/standalone/.next/static/chunks/2826.e59e8578e2e28639.js +0 -9
  928. package/dist/web/standalone/.next/static/chunks/app/page-151349214571e2b6.js +0 -1
  929. package/dist/web/standalone/.next/static/chunks/main-app-d3d4c336195465f9.js +0 -1
  930. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/global-error-ab5a8926e07ec673.js +0 -1
  931. /package/dist/web/standalone/.next/static/{ssX7BLv3Dw9Fb4CtrCGeR → vidAVJkURvTJ0_V2-64ro}/_buildManifest.js +0 -0
  932. /package/dist/web/standalone/.next/static/{ssX7BLv3Dw9Fb4CtrCGeR → vidAVJkURvTJ0_V2-64ro}/_ssgManifest.js +0 -0
@@ -1,180 +1,11 @@
1
1
  #!/usr/bin/env node
2
2
 
3
- import { exec as execCb, spawnSync } from 'child_process'
4
- import { createHash, randomUUID } from 'crypto'
5
- import { chmodSync, copyFileSync, createWriteStream, existsSync, mkdirSync, readFileSync, readdirSync, rmSync } from 'fs'
6
- import { arch, homedir, platform } from 'os'
7
- import { dirname, resolve, join } from 'path'
8
- import { Readable } from 'stream'
9
- import { finished } from 'stream/promises'
10
- import extractZip from 'extract-zip'
11
- import { fileURLToPath } from 'url'
12
-
13
- const __dirname = dirname(fileURLToPath(import.meta.url))
14
- const cwd = resolve(__dirname, '..')
15
- const PLAYWRIGHT_SKIP =
16
- process.env.PLAYWRIGHT_SKIP_BROWSER_DOWNLOAD === '1' ||
17
- process.env.PLAYWRIGHT_SKIP_BROWSER_DOWNLOAD === 'true'
18
- const RTK_SKIP =
19
- process.env.GSD_SKIP_RTK_INSTALL === '1' ||
20
- process.env.GSD_SKIP_RTK_INSTALL === 'true' ||
21
- process.env.GSD_RTK_DISABLED === '1' ||
22
- process.env.GSD_RTK_DISABLED === 'true'
23
-
24
- const RTK_VERSION = '0.33.1'
25
- const RTK_REPO = 'rtk-ai/rtk'
26
- const RTK_ENV = { ...process.env, RTK_TELEMETRY_DISABLED: '1' }
27
- const managedBinDir = join(process.env.GSD_HOME || join(homedir(), '.gsd'), 'agent', 'bin')
28
- const managedBinaryPath = join(managedBinDir, platform() === 'win32' ? 'rtk.exe' : 'rtk')
29
-
30
- function run(cmd) {
31
- return new Promise((resolvePromise) => {
32
- execCb(cmd, { cwd }, (error, stdout, stderr) => {
33
- resolvePromise({ ok: !error, stdout, stderr })
34
- })
35
- })
36
- }
37
-
38
- function logWarn(message) {
39
- process.stderr.write(`[gsd] postinstall: ${message}\n`)
40
- }
41
-
42
- function resolveAssetName() {
43
- const currentPlatform = platform()
44
- const currentArch = arch()
45
- if (currentPlatform === 'darwin' && currentArch === 'arm64') return 'rtk-aarch64-apple-darwin.tar.gz'
46
- if (currentPlatform === 'darwin' && currentArch === 'x64') return 'rtk-x86_64-apple-darwin.tar.gz'
47
- if (currentPlatform === 'linux' && currentArch === 'arm64') return 'rtk-aarch64-unknown-linux-gnu.tar.gz'
48
- if (currentPlatform === 'linux' && currentArch === 'x64') return 'rtk-x86_64-unknown-linux-musl.tar.gz'
49
- if (currentPlatform === 'win32' && currentArch === 'x64') return 'rtk-x86_64-pc-windows-msvc.zip'
50
- return null
51
- }
52
-
53
- function parseChecksums(text) {
54
- const checksums = new Map()
55
- for (const rawLine of text.split(/\r?\n/)) {
56
- const line = rawLine.trim()
57
- if (!line) continue
58
- const match = line.match(/^([a-f0-9]{64})\s+(.+)$/i)
59
- if (!match) continue
60
- checksums.set(match[2], match[1].toLowerCase())
61
- }
62
- return checksums
63
- }
64
-
65
- function sha256File(path) {
66
- const hash = createHash('sha256')
67
- hash.update(readFileSync(path))
68
- return hash.digest('hex')
69
- }
70
-
71
- async function downloadToFile(url, destination) {
72
- const response = await fetch(url, { headers: { 'User-Agent': 'gsd-pi-postinstall' } })
73
- if (!response.ok) {
74
- throw new Error(`download failed (${response.status}) for ${url}`)
75
- }
76
- if (!response.body) {
77
- throw new Error(`download returned no body for ${url}`)
78
- }
79
- const output = createWriteStream(destination)
80
- await finished(Readable.fromWeb(response.body).pipe(output))
81
- }
82
-
83
- function findBinaryRecursively(rootDir, binaryName) {
84
- const stack = [rootDir]
85
- while (stack.length > 0) {
86
- const current = stack.pop()
87
- if (!current) continue
88
- const entries = readdirSync(current, { withFileTypes: true })
89
- for (const entry of entries) {
90
- const fullPath = join(current, entry.name)
91
- if (entry.isFile() && entry.name === binaryName) return fullPath
92
- if (entry.isDirectory()) stack.push(fullPath)
93
- }
94
- }
95
- return null
96
- }
97
-
98
- function validateRtkBinary(binaryPath) {
99
- const result = spawnSync(binaryPath, ['rewrite', 'git status'], {
100
- encoding: 'utf-8',
101
- env: RTK_ENV,
102
- stdio: ['ignore', 'pipe', 'ignore'],
103
- timeout: 5000,
104
- })
105
- return !result.error && result.status === 0 && (result.stdout || '').trim() === 'rtk git status'
106
- }
107
-
108
- async function ensureRtkInstalled() {
109
- if (RTK_SKIP) return
110
- const assetName = resolveAssetName()
111
- if (!assetName) return
112
- if (existsSync(managedBinaryPath) && validateRtkBinary(managedBinaryPath)) return
113
-
114
- const tempRoot = join(managedBinDir, `.rtk-postinstall-${randomUUID().slice(0, 8)}`)
115
- const archivePath = join(tempRoot, assetName)
116
- const extractDir = join(tempRoot, 'extract')
117
- const releaseBase = `https://github.com/${RTK_REPO}/releases/download/v${RTK_VERSION}`
118
-
119
- mkdirSync(tempRoot, { recursive: true })
120
- mkdirSync(managedBinDir, { recursive: true })
121
-
122
- try {
123
- const checksumsResponse = await fetch(`${releaseBase}/checksums.txt`, {
124
- headers: { 'User-Agent': 'gsd-pi-postinstall' },
125
- })
126
- if (!checksumsResponse.ok) {
127
- throw new Error(`failed to fetch RTK checksums (${checksumsResponse.status})`)
128
- }
129
-
130
- const checksums = parseChecksums(await checksumsResponse.text())
131
- const expectedSha = checksums.get(assetName)
132
- if (!expectedSha) {
133
- throw new Error(`missing checksum for ${assetName}`)
134
- }
135
-
136
- await downloadToFile(`${releaseBase}/${assetName}`, archivePath)
137
- const actualSha = sha256File(archivePath)
138
- if (actualSha !== expectedSha) {
139
- throw new Error(`checksum mismatch for ${assetName}`)
140
- }
141
-
142
- mkdirSync(extractDir, { recursive: true })
143
- if (assetName.endsWith('.zip')) {
144
- await extractZip(archivePath, { dir: extractDir })
145
- } else {
146
- const extractResult = spawnSync('tar', ['xzf', archivePath, '-C', extractDir], {
147
- encoding: 'utf-8',
148
- timeout: 30000,
149
- })
150
- if (extractResult.error || extractResult.status !== 0) {
151
- throw new Error(extractResult.error?.message || extractResult.stderr?.trim() || `failed to extract ${assetName}`)
152
- }
153
- }
154
-
155
- const extractedBinary = findBinaryRecursively(extractDir, platform() === 'win32' ? 'rtk.exe' : 'rtk')
156
- if (!extractedBinary) {
157
- throw new Error(`RTK binary not found in ${assetName}`)
158
- }
159
-
160
- copyFileSync(extractedBinary, managedBinaryPath)
161
- if (platform() !== 'win32') {
162
- chmodSync(managedBinaryPath, 0o755)
163
- }
164
-
165
- if (!validateRtkBinary(managedBinaryPath)) {
166
- rmSync(managedBinaryPath, { force: true })
167
- throw new Error('downloaded RTK binary failed validation')
168
- }
169
- } catch (error) {
170
- logWarn(`RTK install skipped: ${error instanceof Error ? error.message : String(error)}`)
171
- } finally {
172
- rmSync(tempRoot, { recursive: true, force: true })
173
- }
174
- }
175
-
176
- if (!PLAYWRIGHT_SKIP) {
177
- await run('npx playwright install chromium')
178
- }
179
-
180
- await ensureRtkInstalled()
3
+ /**
4
+ * GSD Postinstall
5
+ *
6
+ * Thin wrapper that delegates to install.js in postinstall mode
7
+ * (workspace linking + deps only, no global/local npm install).
8
+ */
9
+
10
+ process.env.npm_lifecycle_event = process.env.npm_lifecycle_event || 'postinstall'
11
+ import('./install.js')
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  name: researcher
3
3
  description: Web researcher that finds and synthesizes current information using Brave Search
4
- tools: search-the-web, bash
4
+ tools: search-the-web, bash, capture_thought, memory_query, gsd_graph
5
5
  ---
6
6
 
7
7
  You are a web researcher. You find current, accurate information using web search and synthesize it into a clear, well-structured report.
@@ -12,16 +12,40 @@
12
12
  import { execFileSync } from "node:child_process";
13
13
 
14
14
  /**
15
- * Platform-correct binary name for the Claude Code CLI.
15
+ * Candidate executable names for the Claude Code CLI.
16
16
  *
17
- * On Windows, npm-global binaries are installed as `.cmd` shims and
18
- * `execFileSync` does not auto-resolve the extension — calling bare
19
- * `claude` would fail with ENOENT even when the CLI is installed and
20
- * authenticated. Mirrors the `NPM_COMMAND` pattern in
21
- * `src/resources/extensions/gsd/pre-execution-checks.ts`.
17
+ * Keep the explicit win32 ternary selector for regression coverage (Issue #4424):
18
+ * Node's execFileSync must target `claude.cmd` directly on Windows.
22
19
  */
23
20
  const CLAUDE_COMMAND = process.platform === "win32" ? "claude.cmd" : "claude";
24
21
 
22
+ /**
23
+ * Windows installs vary: some environments expose `claude.cmd` (npm shim),
24
+ * `claude.exe` (direct binary install), or a bare `claude` shim on PATH
25
+ * (for example Git Bash wrappers). Try all three to avoid false "not
26
+ * installed" results in readiness checks.
27
+ */
28
+ const CLAUDE_COMMAND_CANDIDATES = process.platform === "win32" ? [CLAUDE_COMMAND, "claude.exe", "claude"] : [CLAUDE_COMMAND];
29
+
30
+ function execClaude(args: string[]): Buffer {
31
+ let lastError: unknown;
32
+ for (const command of CLAUDE_COMMAND_CANDIDATES) {
33
+ try {
34
+ return execFileSync(command, args, { timeout: 5_000, stdio: "pipe" });
35
+ } catch (error) {
36
+ lastError = error;
37
+ const code = (error as NodeJS.ErrnoException | undefined)?.code;
38
+ // Windows Git Bash can surface `.cmd` spawn failures as EINVAL instead
39
+ // of ENOENT. Treat both as "try next candidate".
40
+ if (code === "ENOENT" || code === "EINVAL") {
41
+ continue;
42
+ }
43
+ throw error;
44
+ }
45
+ }
46
+ throw lastError ?? new Error(`Claude CLI executable not found (tried: ${CLAUDE_COMMAND_CANDIDATES.join(", ")})`);
47
+ }
48
+
25
49
  let cachedBinaryPresent: boolean | null = null;
26
50
  let cachedAuthed: boolean | null = null;
27
51
  let lastCheckMs = 0;
@@ -38,7 +62,7 @@ function refreshCache(): void {
38
62
 
39
63
  // Check binary presence
40
64
  try {
41
- execFileSync(CLAUDE_COMMAND, ["--version"], { timeout: 5_000, stdio: "pipe" });
65
+ execClaude(["--version"]);
42
66
  cachedBinaryPresent = true;
43
67
  } catch {
44
68
  cachedBinaryPresent = false;
@@ -48,7 +72,7 @@ function refreshCache(): void {
48
72
 
49
73
  // Check auth status — exit code 0 with non-error output means authenticated
50
74
  try {
51
- const output = execFileSync(CLAUDE_COMMAND, ["auth", "status"], { timeout: 5_000, stdio: "pipe" })
75
+ const output = execClaude(["auth", "status"])
52
76
  .toString()
53
77
  .toLowerCase();
54
78
  // The CLI outputs "not logged in", "no credentials", or similar when unauthenticated
@@ -3,8 +3,9 @@
3
3
  *
4
4
  * The SDK runs the full agentic loop (multi-turn, tool execution, compaction)
5
5
  * in one call. This adapter translates the SDK's streaming output into
6
- * AssistantMessageEvents for TUI rendering, then strips tool-call blocks from
7
- * the final AssistantMessage so GSD's agent loop doesn't try to dispatch them.
6
+ * AssistantMessageEvents for TUI rendering, then preserves externally executed
7
+ * tool-call blocks on the final AssistantMessage so Agent Core can render them
8
+ * while `externalToolExecution` prevents local redispatch.
8
9
  */
9
10
 
10
11
  import type {
@@ -692,18 +693,22 @@ export function makeAbortedMessage(model: string, lastTextContent: string): Assi
692
693
  /**
693
694
  * Resolve the Claude Code permission mode for the current run.
694
695
  *
695
- * GSD subagents run underneath a host Claude Code session the user has
696
- * already consented to, and their work (edits, shell inspection, MCP calls)
697
- * spans the full workflow toolset. Defaulting the inner SDK to
698
- * `bypassPermissions` avoids per-tool approval prompts that offer no
699
- * meaningful safety beyond what the host session and the subagent prompts
700
- * already enforce. `GSD_CLAUDE_CODE_PERMISSION_MODE` lets security-conscious
701
- * users opt into a stricter mode (`acceptEdits`, `default`, `plan`).
696
+ * Defaults to `acceptEdits`, which auto-approves file reads/edits but
697
+ * surfaces a permission dialog for dangerous operations (e.g. general Bash,
698
+ * Agent, WebFetch). This prevents tools outside the allowlist from being
699
+ * silently denied the SDK emits an `extension_ui_request` event so the
700
+ * user sees a prompt instead of a silent refusal that Claude Code mistakes
701
+ * for user rejection (#4383).
702
702
  *
703
- * Tradeoff: bypass means a prompt-injection payload read from an untrusted
704
- * file could trigger tool calls without a second gate. Accepted for GSD
705
- * because the workflow is explicit user intent and the alternative
706
- * (#4099) is continuous approval fatigue that blocks real work.
703
+ * Set `GSD_CLAUDE_CODE_PERMISSION_MODE` to `bypassPermissions` to restore
704
+ * the old always-approve behaviour, or to `default` / `plan` for stricter
705
+ * modes.
706
+ *
707
+ * When `GSD_HEADLESS=1` is set (auto-mode / non-interactive runs), the
708
+ * default flips to `bypassPermissions` because there is no UI to approve
709
+ * permission dialogs — `acceptEdits` would hang verification commands like
710
+ * `npx tsc --noEmit` or `npx vitest run` indefinitely (#4657). Explicit
711
+ * overrides still win, so users can opt back into `acceptEdits` in headless.
707
712
  */
708
713
  export async function resolveClaudePermissionMode(
709
714
  env: NodeJS.ProcessEnv = process.env,
@@ -712,6 +717,12 @@ export async function resolveClaudePermissionMode(
712
717
  if (override === "bypassPermissions" || override === "acceptEdits" || override === "default" || override === "plan") {
713
718
  return override;
714
719
  }
720
+ if (env.GSD_HEADLESS === "1") {
721
+ console.warn(
722
+ "[claude-code-cli] Headless mode detected (GSD_HEADLESS=1): defaulting permissionMode to 'bypassPermissions' so verification Bash commands can run. Set GSD_CLAUDE_CODE_PERMISSION_MODE=acceptEdits to opt out.",
723
+ );
724
+ return "bypassPermissions";
725
+ }
715
726
  return "bypassPermissions";
716
727
  }
717
728
 
@@ -773,20 +784,24 @@ export function buildSdkOptions(
773
784
  const { reasoning, ...sdkExtraOptions } = extraOptions;
774
785
  const mcpServers = buildWorkflowMcpServers();
775
786
  const permissionMode = overrides?.permissionMode ?? "bypassPermissions";
776
- const disallowedTools = ["AskUserQuestion"];
777
- // Pre-authorize the safe built-ins and every registered workflow MCP
778
- // server's tools. `acceptEdits` mode (the interactive default) only
779
- // auto-approves file edits Read/Glob/Grep, basic shell inspection, and
780
- // every `mcp__gsd-workflow__*` call still surface as "This command
781
- // requires approval" and block GSD actions (#4099).
787
+ // Globally unblock all tools. Users reported that the `acceptEdits` default
788
+ // plus a narrow allowlist silently declined most Bash/Agent/WebFetch calls
789
+ // when `extensionUIContext` wasn't threaded through. Default to
790
+ // bypassPermissions and an empty disallow list so every tool — including
791
+ // `AskUserQuestion` and every `mcp__*` workflow tool is auto-approved.
792
+ // Opt back into gated mode with GSD_CLAUDE_CODE_PERMISSION_MODE=acceptEdits.
793
+ const disallowedTools: string[] = [];
782
794
  const allowedTools = [
783
795
  "Read",
784
796
  "Write",
785
797
  "Edit",
786
798
  "Glob",
787
799
  "Grep",
788
- "Bash(ls:*)",
789
- "Bash(pwd)",
800
+ "Bash",
801
+ "Agent",
802
+ "WebFetch",
803
+ "WebSearch",
804
+ "AskUserQuestion",
790
805
  ...(mcpServers ? Object.keys(mcpServers).map((serverName) => `mcp__${serverName}__*`) : []),
791
806
  ];
792
807
  const supportsAdaptive = modelSupportsAdaptiveThinking(modelId);
@@ -867,6 +882,69 @@ function normalizeToolResultContent(content: unknown): ExternalToolResultContent
867
882
  return blocks.length > 0 ? blocks : [{ type: "text", text: "" }];
868
883
  }
869
884
 
885
+ /**
886
+ * Extract a `details` payload from an MCP tool-result block.
887
+ *
888
+ * MCP's `CallToolResult` carries structured data in `structuredContent` — the
889
+ * protocol's supported channel for non-text payloads. Claude Code's synthetic
890
+ * user message may surface that field in one of two shapes depending on SDK
891
+ * version: as a sibling on the `mcp_tool_result` block itself, or as a
892
+ * dedicated content sub-block with `type: "structuredContent"`. Snake-case
893
+ * (`structured_content`) is accepted defensively in case a transport hop
894
+ * rewrites casing. All other shapes fall back to an empty object so callers
895
+ * can rely on `details` being present.
896
+ */
897
+ function extractStructuredDetailsFromBlock(block: Record<string, unknown>): Record<string, unknown> | undefined {
898
+ const sibling = block.structuredContent ?? (block as Record<string, unknown>).structured_content;
899
+ if (sibling && typeof sibling === "object" && !Array.isArray(sibling)) {
900
+ return sibling as Record<string, unknown>;
901
+ }
902
+
903
+ if (Array.isArray(block.content)) {
904
+ for (const item of block.content) {
905
+ if (!item || typeof item !== "object") continue;
906
+ const sub = item as Record<string, unknown>;
907
+ if (sub.type !== "structuredContent" && sub.type !== "structured_content") continue;
908
+ const payload = sub.structuredContent ?? sub.structured_content ?? sub.data ?? sub.value;
909
+ if (payload && typeof payload === "object" && !Array.isArray(payload)) {
910
+ return payload as Record<string, unknown>;
911
+ }
912
+ }
913
+ }
914
+
915
+ // Return undefined (not {}) when no structured payload is present, matching
916
+ // the pre-#4477 contract where `details` was nullable. An empty-object
917
+ // sentinel is truthy and breaks downstream consumers that gate on
918
+ // `if (details)`. `undefined` matches the type of the field these results
919
+ // flow into (`Record<string, unknown> | undefined`).
920
+ return undefined;
921
+ }
922
+
923
+ /**
924
+ * True for items that are MCP `structuredContent` pseudo-blocks living inside
925
+ * a tool-result `content[]` array. These blocks carry the structured payload
926
+ * (extracted separately by `extractStructuredDetailsFromBlock`) and must NOT
927
+ * leak into the visible content rendered to the user — otherwise the renderer
928
+ * stringifies the JSON pseudo-block and shows it next to the actual tool
929
+ * output. See PR #4477 review (CodeRabbit, post-fix-round).
930
+ */
931
+ function isStructuredContentPseudoBlock(item: unknown): boolean {
932
+ if (!item || typeof item !== "object") return false;
933
+ const type = (item as Record<string, unknown>).type;
934
+ return type === "structuredContent" || type === "structured_content";
935
+ }
936
+
937
+ /**
938
+ * Strip `structuredContent` pseudo-blocks from a tool-result content array
939
+ * before normalization. The structured payload is extracted via the sibling
940
+ * `structuredContent` field (or a dedicated extractor pass on the raw block);
941
+ * the visible content path must not include the pseudo-block itself.
942
+ */
943
+ function stripStructuredContentPseudoBlocks(content: unknown): unknown {
944
+ if (!Array.isArray(content)) return content;
945
+ return content.filter((item) => !isStructuredContentPseudoBlock(item));
946
+ }
947
+
870
948
  /** Extract tool result payloads from an SDK synthetic user message, keyed by tool-use ID. */
871
949
  export function extractToolResultsFromSdkUserMessage(message: SDKUserMessage): Array<{
872
950
  toolUseId: string;
@@ -890,8 +968,8 @@ export function extractToolResultsFromSdkUserMessage(message: SDKUserMessage): A
890
968
  extracted.push({
891
969
  toolUseId,
892
970
  result: {
893
- content: normalizeToolResultContent(block.content),
894
- details: {},
971
+ content: normalizeToolResultContent(stripStructuredContentPseudoBlocks(block.content)),
972
+ details: extractStructuredDetailsFromBlock(block),
895
973
  isError: block.is_error === true,
896
974
  },
897
975
  });
@@ -906,8 +984,8 @@ export function extractToolResultsFromSdkUserMessage(message: SDKUserMessage): A
906
984
  extracted.push({
907
985
  toolUseId,
908
986
  result: {
909
- content: normalizeToolResultContent(toolResult.content),
910
- details: {},
987
+ content: normalizeToolResultContent(stripStructuredContentPseudoBlocks(toolResult.content)),
988
+ details: extractStructuredDetailsFromBlock(toolResult),
911
989
  isError: toolResult.is_error === true,
912
990
  },
913
991
  });
@@ -931,6 +1009,49 @@ function attachExternalResultsToToolBlocks(
931
1009
  }
932
1010
  }
933
1011
 
1012
+ /**
1013
+ * Build the final assistant content that Agent Core consumes in
1014
+ * `externalToolExecution` mode. This preserves tool-call blocks, attaches any
1015
+ * SDK-produced external results by tool-call id, and then appends the final
1016
+ * text/thinking blocks for the completed turn.
1017
+ */
1018
+ export function buildFinalAssistantContent(params: {
1019
+ intermediateToolBlocks: AssistantMessage["content"];
1020
+ pendingContent?: AssistantMessage["content"];
1021
+ toolResultsById: ReadonlyMap<string, ExternalToolResultPayload>;
1022
+ lastThinkingContent?: string;
1023
+ lastTextContent?: string;
1024
+ fallbackResultText?: string;
1025
+ }): AssistantMessage["content"] {
1026
+ const mergedToolBlocks = [...params.intermediateToolBlocks];
1027
+ if (params.pendingContent) {
1028
+ mergePendingToolCalls(mergedToolBlocks, params.pendingContent);
1029
+ }
1030
+ attachExternalResultsToToolBlocks(mergedToolBlocks, params.toolResultsById);
1031
+
1032
+ const finalContent: AssistantMessage["content"] = [...mergedToolBlocks];
1033
+ if (params.pendingContent && params.pendingContent.length > 0) {
1034
+ for (const block of params.pendingContent) {
1035
+ if (block.type === "text" || block.type === "thinking") {
1036
+ finalContent.push(block);
1037
+ }
1038
+ }
1039
+ } else {
1040
+ if (params.lastThinkingContent) {
1041
+ finalContent.push({ type: "thinking", thinking: params.lastThinkingContent });
1042
+ }
1043
+ if (params.lastTextContent) {
1044
+ finalContent.push({ type: "text", text: params.lastTextContent });
1045
+ }
1046
+ }
1047
+
1048
+ if (finalContent.length === 0 && params.fallbackResultText) {
1049
+ finalContent.push({ type: "text", text: params.fallbackResultText });
1050
+ }
1051
+
1052
+ return finalContent;
1053
+ }
1054
+
934
1055
  /**
935
1056
  * Merge tool-call blocks from the active partial-message builder into the
936
1057
  * running list of intermediate tool calls, preserving order and de-duping
@@ -962,8 +1083,9 @@ export function mergePendingToolCalls(
962
1083
  * GSD streamSimple function that delegates to the Claude Agent SDK.
963
1084
  *
964
1085
  * Emits AssistantMessageEvent deltas for real-time TUI rendering
965
- * (thinking, text, tool calls). The final AssistantMessage has tool-call
966
- * blocks stripped so the agent loop ends the turn without local dispatch.
1086
+ * (thinking, text, tool calls). The final AssistantMessage preserves
1087
+ * SDK-executed tool-call blocks for Agent Core's `externalToolExecution`
1088
+ * path, which renders the results without dispatching the tools locally.
967
1089
  */
968
1090
  export function streamViaClaudeCode(
969
1091
  model: Model<any>,
@@ -1164,46 +1286,15 @@ async function pumpSdkMessages(
1164
1286
  // -- Result (terminal) --
1165
1287
  case "result": {
1166
1288
  const result = msg as SDKResultMessage;
1167
-
1168
- // Build final message. Include intermediate tool calls so the
1169
- // agent loop's externalToolExecution path emits tool_execution
1170
- // events for proper TUI rendering, followed by the text response.
1171
- const finalContent: AssistantMessage["content"] = [];
1172
-
1173
- // If the final turn ended without a synthetic user message
1174
- // (e.g. stop_reason: "tool_use" followed directly by result,
1175
- // or a turn with text but no tool execution), the `builder`
1176
- // still holds toolCall blocks that were never pushed into
1177
- // `intermediateToolBlocks`. Fold them in here so they aren't
1178
- // dropped from the final AssistantMessage.
1179
- if (builder) {
1180
- mergePendingToolCalls(intermediateToolBlocks, builder.message.content);
1181
- }
1182
-
1183
- // Add tool calls from intermediate turns first (renders above text)
1184
- attachExternalResultsToToolBlocks(intermediateToolBlocks, toolResultsById);
1185
- finalContent.push(...intermediateToolBlocks);
1186
-
1187
- // Add text/thinking from the last turn
1188
- if (builder && builder.message.content.length > 0) {
1189
- for (const block of builder.message.content) {
1190
- if (block.type === "text" || block.type === "thinking") {
1191
- finalContent.push(block);
1192
- }
1193
- }
1194
- } else {
1195
- if (lastThinkingContent) {
1196
- finalContent.push({ type: "thinking", thinking: lastThinkingContent });
1197
- }
1198
- if (lastTextContent) {
1199
- finalContent.push({ type: "text", text: lastTextContent });
1200
- }
1201
- }
1202
-
1203
- // Fallback: use the SDK's result text if we have no content
1204
- if (finalContent.length === 0 && result.subtype === "success" && result.result) {
1205
- finalContent.push({ type: "text", text: result.result });
1206
- }
1289
+ const finalContent = buildFinalAssistantContent({
1290
+ intermediateToolBlocks,
1291
+ pendingContent: builder?.message.content,
1292
+ toolResultsById,
1293
+ lastThinkingContent,
1294
+ lastTextContent,
1295
+ fallbackResultText:
1296
+ result.subtype === "success" && result.result ? result.result : undefined,
1297
+ });
1207
1298
 
1208
1299
  const finalMessage: AssistantMessage = {
1209
1300
  role: "assistant",