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
@@ -0,0 +1,58 @@
1
+ // pi-coding-agent — secret redaction for session log persistence
2
+ //
3
+ // Called by prepareForPersistence() in session-manager.ts on every string
4
+ // before it lands in the JSONL transcript. Replaces well-known secret shapes
5
+ // with [REDACTED:<kind>] placeholders so credentials pasted by the user or
6
+ // read from .env-style files never persist to disk.
7
+ //
8
+ // Pattern selection bias: high-specificity shapes only. Loose patterns
9
+ // (e.g. FOO_SECRET=...) produce too many false positives in docs and code
10
+ // samples and are intentionally excluded.
11
+
12
+ interface SecretPattern {
13
+ kind: string;
14
+ regex: RegExp;
15
+ }
16
+
17
+ // Order matters: more-specific patterns first (sk-ant- before generic sk-).
18
+ const PATTERNS: readonly SecretPattern[] = [
19
+ { kind: "anthropic", regex: /sk-ant-[A-Za-z0-9_-]{20,}/g },
20
+ { kind: "llamacloud", regex: /llx-[A-Za-z0-9_-]{20,}/g },
21
+ // Covers all three official OpenAI key shapes: legacy `sk-…`, project `sk-proj-…`,
22
+ // and admin `sk-admin-…`. Hyphens and underscores appear inside real project keys
23
+ // so the remainder class must allow them. `sk-ant-` is matched earlier by the
24
+ // anthropic pattern and already replaced by the time this runs.
25
+ { kind: "openai", regex: /sk-(?:proj-|admin-)?[A-Za-z0-9_-]{20,}/g },
26
+ { kind: "aws-access-key", regex: /\b(?:AKIA|ASIA|AROA)[0-9A-Z]{16}\b/g },
27
+ { kind: "github-token", regex: /\bgh[pousr]_[A-Za-z0-9]{30,}\b/g },
28
+ { kind: "slack-token", regex: /\bxox[baprs]-[A-Za-z0-9-]{10,}\b/g },
29
+ { kind: "google-api-key", regex: /\bAIza[0-9A-Za-z_-]{35}\b/g },
30
+ {
31
+ kind: "pem-private-key",
32
+ regex: /-----BEGIN [A-Z ]*PRIVATE KEY-----[\s\S]*?-----END [A-Z ]*PRIVATE KEY-----/g,
33
+ },
34
+ ];
35
+
36
+ export function redactSecrets(input: string): string {
37
+ // Short-circuit: skip regex work on strings with no plausible secret markers.
38
+ // Cheap heuristic — if none of these substrings are present, no pattern can match.
39
+ if (
40
+ !input.includes("sk-") &&
41
+ !input.includes("llx-") &&
42
+ !input.includes("AKIA") &&
43
+ !input.includes("ASIA") &&
44
+ !input.includes("AROA") &&
45
+ !input.includes("gh") &&
46
+ !input.includes("xox") &&
47
+ !input.includes("AIza") &&
48
+ !input.includes("PRIVATE KEY")
49
+ ) {
50
+ return input;
51
+ }
52
+
53
+ let out = input;
54
+ for (const { kind, regex } of PATTERNS) {
55
+ out = out.replace(regex, `[REDACTED:${kind}]`);
56
+ }
57
+ return out;
58
+ }
@@ -242,7 +242,7 @@ export class DefaultResourceLoader implements ResourceLoader {
242
242
  this.systemPromptOverride = options.systemPromptOverride;
243
243
  this.appendSystemPromptOverride = options.appendSystemPromptOverride;
244
244
 
245
- this.extensionsResult = { extensions: [], errors: [], runtime: createExtensionRuntime() };
245
+ this.extensionsResult = { extensions: [], errors: [], warnings: [], runtime: createExtensionRuntime() };
246
246
  this.skills = [];
247
247
  this.skillDiagnostics = [];
248
248
  this.prompts = [];
@@ -3,7 +3,8 @@
3
3
 
4
4
  import { describe, it } from "node:test";
5
5
  import assert from "node:assert/strict";
6
- import { CredentialCooldownError } from "./sdk.js";
6
+ import { canRestoreSessionModel, CredentialCooldownError } from "./sdk.js";
7
+ import type { Model } from "@gsd/pi-ai";
7
8
 
8
9
  // ─── CredentialCooldownError ──────────────────────────────────────────────────
9
10
 
@@ -87,3 +88,26 @@ describe("CredentialCooldownError", () => {
87
88
  assert.equal(plain.retryAfterMs, 15_000);
88
89
  });
89
90
  });
91
+
92
+ describe("canRestoreSessionModel", () => {
93
+ const model = {
94
+ provider: "claude-code",
95
+ id: "claude-sonnet",
96
+ } as Model<any>;
97
+
98
+ it("allows keyless external providers when the provider is request-ready", () => {
99
+ const registry = {
100
+ isProviderRequestReady: (provider: string) => provider === "claude-code",
101
+ };
102
+
103
+ assert.equal(canRestoreSessionModel(registry, model), true);
104
+ });
105
+
106
+ it("blocks restore when the provider is not request-ready", () => {
107
+ const registry = {
108
+ isProviderRequestReady: () => false,
109
+ };
110
+
111
+ assert.equal(canRestoreSessionModel(registry, model), false);
112
+ });
113
+ });
@@ -31,6 +31,13 @@ export class CredentialCooldownError extends Error {
31
31
  this.retryAfterMs = retryAfterMs;
32
32
  }
33
33
  }
34
+
35
+ export function canRestoreSessionModel(
36
+ modelRegistry: Pick<ModelRegistry, "isProviderRequestReady">,
37
+ model: Model<any>,
38
+ ): boolean {
39
+ return modelRegistry.isProviderRequestReady(model.provider);
40
+ }
34
41
  import { Agent, type AgentMessage, type ThinkingLevel } from "@gsd/pi-agent-core";
35
42
  import type { Message, Model } from "@gsd/pi-ai";
36
43
  import { getAgentDir, getDocsPath } from "../config.js";
@@ -262,9 +269,9 @@ export async function createAgentSession(options: CreateAgentSessionOptions = {}
262
269
  // If session has data, try to restore model from it
263
270
  if (!model && hasExistingSession && existingSession.model) {
264
271
  const restoredModel = modelRegistry.find(existingSession.model.provider, existingSession.model.modelId);
265
- if (restoredModel && (await modelRegistry.getApiKey(restoredModel))) {
266
- model = restoredModel;
267
- }
272
+ if (restoredModel && canRestoreSessionModel(modelRegistry, restoredModel)) {
273
+ model = restoredModel;
274
+ }
268
275
  if (!model) {
269
276
  modelFallbackMessage = `Could not restore model ${existingSession.model.provider}/${existingSession.model.modelId}`;
270
277
  }
@@ -1,6 +1,6 @@
1
1
  import assert from "node:assert/strict";
2
2
  import { describe, it, afterEach } from "node:test";
3
- import { mkdtempSync, rmSync } from "node:fs";
3
+ import { mkdtempSync, readFileSync, rmSync, writeFileSync } from "node:fs";
4
4
  import { join } from "node:path";
5
5
  import { tmpdir } from "node:os";
6
6
 
@@ -63,3 +63,67 @@ describe("SessionManager usage totals", () => {
63
63
  });
64
64
  });
65
65
  });
66
+
67
+ describe("SessionManager secret redaction on persistence", () => {
68
+ let dir: string;
69
+
70
+ afterEach(() => {
71
+ if (dir) {
72
+ rmSync(dir, { recursive: true, force: true });
73
+ }
74
+ });
75
+
76
+ it("scrubs known secret shapes from JSONL on disk", () => {
77
+ dir = mkdtempSync(join(tmpdir(), "gsd-session-redact-test-"));
78
+ const manager = SessionManager.create(dir, dir);
79
+
80
+ const leakedKey = "llx-abcDEF1234567890abcDEF1234567890";
81
+ manager.appendMessage({
82
+ role: "user",
83
+ content: [{ type: "text", text: `here is my key: ${leakedKey}` }],
84
+ } as any);
85
+ // Persistence is gated on an assistant message being present.
86
+ manager.appendMessage(makeAssistantMessage(1, 1, 0, 0, 0));
87
+
88
+ const sessionFile = manager.getSessionFile();
89
+ assert.ok(sessionFile, "session file should be set");
90
+ const contents = readFileSync(sessionFile!, "utf8");
91
+ assert.ok(
92
+ !contents.includes(leakedKey),
93
+ "raw secret must not appear in persisted JSONL",
94
+ );
95
+ assert.ok(
96
+ contents.includes("[REDACTED:llamacloud]"),
97
+ "redaction placeholder must appear in persisted JSONL",
98
+ );
99
+ });
100
+
101
+ it("scrubs secrets from JSONL rewritten by _rewriteFile() during migration", () => {
102
+ // Write a v1 session file (no id/parentId on entries) containing a secret.
103
+ // setSessionFile() will detect version < 3, run migration, and call _rewriteFile()
104
+ // which previously serialised entries without passing them through redaction.
105
+ dir = mkdtempSync(join(tmpdir(), "gsd-session-rewrite-redact-test-"));
106
+ const leakedKey = "sk-ant-api03-abcDEF1234567890abcDEF1234567890xYz";
107
+ const v1Header = JSON.stringify({ type: "session", version: 1, id: "test-session-id", timestamp: new Date().toISOString(), cwd: dir });
108
+ const v1UserMsg = JSON.stringify({ type: "message", message: { role: "user", content: [{ type: "text", text: `secret: ${leakedKey}` }] } });
109
+ const v1AssistantMsg = JSON.stringify({ type: "message", message: { role: "assistant", content: [{ type: "text", text: "ok" }], usage: { input: 1, output: 1, cacheRead: 0, cacheWrite: 0, total: 2, cost: { total: 0 } } } });
110
+ const sessionFile = join(dir, "test-session.jsonl");
111
+ writeFileSync(sessionFile, [v1Header, v1UserMsg, v1AssistantMsg].join("\n") + "\n", "utf8");
112
+
113
+ // Loading this file triggers migrateToCurrentVersion() which returns true (v1 → v3),
114
+ // causing _rewriteFile() to rewrite the file. The bug: _rewriteFile() called
115
+ // JSON.stringify(e) without redaction, so the secret would survive on disk.
116
+ const manager = SessionManager.create(dir, dir);
117
+ manager.setSessionFile(sessionFile);
118
+
119
+ const contents = readFileSync(sessionFile, "utf8");
120
+ assert.ok(
121
+ !contents.includes(leakedKey),
122
+ "raw secret must not appear in JSONL rewritten by _rewriteFile()",
123
+ );
124
+ assert.ok(
125
+ contents.includes("[REDACTED:anthropic]"),
126
+ "redaction placeholder must appear in JSONL rewritten by _rewriteFile()",
127
+ );
128
+ });
129
+ });
@@ -26,6 +26,7 @@ import {
26
26
  createCustomMessage,
27
27
  } from "./messages.js";
28
28
  import { BlobStore, externalizeImageData, isBlobRef, resolveImageData } from "./blob-store.js";
29
+ import { redactSecrets } from "./redact-secrets.js";
29
30
 
30
31
  /** Inline concurrency limiter to cap parallel async operations. */
31
32
  function pLimit(concurrency: number) {
@@ -499,15 +500,18 @@ function prepareForPersistence(obj: unknown, blobStore: BlobStore, key?: string)
499
500
  if (obj === null || obj === undefined) return obj;
500
501
 
501
502
  if (typeof obj === "string") {
502
- if (obj.length > MAX_PERSIST_CHARS) {
503
- // Cryptographic signatures must be preserved exactly or cleared entirely
504
- if (key === "thinkingSignature" || key === "thoughtSignature" || key === "textSignature") {
503
+ // Cryptographic signatures must be preserved byte-exact — never redact or truncate
504
+ // their contents, only the oversize-clear path below handles them.
505
+ const isSignature = key === "thinkingSignature" || key === "thoughtSignature" || key === "textSignature";
506
+ const redacted = isSignature ? obj : redactSecrets(obj);
507
+ if (redacted.length > MAX_PERSIST_CHARS) {
508
+ if (isSignature) {
505
509
  return "";
506
510
  }
507
511
  const limit = Math.max(0, MAX_PERSIST_CHARS - TRUNCATION_NOTICE.length);
508
- return `${truncateString(obj, limit)}${TRUNCATION_NOTICE}`;
512
+ return `${truncateString(redacted, limit)}${TRUNCATION_NOTICE}`;
509
513
  }
510
- return obj;
514
+ return redacted;
511
515
  }
512
516
 
513
517
  if (Array.isArray(obj)) {
@@ -955,7 +959,7 @@ export class SessionManager {
955
959
 
956
960
  private _rewriteFile(): void {
957
961
  if (!this.persist || !this.sessionFile) return;
958
- const content = `${this.fileEntries.map((e) => JSON.stringify(e)).join("\n")}\n`;
962
+ const content = `${this.fileEntries.map((e) => JSON.stringify(prepareForPersistence(e, this.blobStore))).join("\n")}\n`;
959
963
  let release: (() => void) | undefined;
960
964
  try {
961
965
  release = tryAcquireLockSync(this.sessionFile);
@@ -92,6 +92,62 @@ export interface ModelDiscoverySettings {
92
92
  autoRefreshOnModelSelect?: boolean; // default: false - refresh discovery when opening model selector
93
93
  }
94
94
 
95
+ /**
96
+ * A shell command bound to a Layer 0 hook event.
97
+ *
98
+ * Payload is passed to the command on stdin as JSON. The command may write a
99
+ * JSON object to stdout to mutate the pending action — shape varies per hook
100
+ * (e.g. `{"block":true,"reason":"..."}` for PreToolUse). Non-zero exit with
101
+ * `blocking: true` vetoes the action.
102
+ */
103
+ export interface HookEntry {
104
+ /** Optional filter on the event payload (currently supports tool name / bash command prefix). */
105
+ match?: {
106
+ tool?: string | string[];
107
+ command?: string;
108
+ };
109
+ /** The shell command to execute. */
110
+ command: string;
111
+ /** Timeout in milliseconds. Default: 30000. */
112
+ timeout?: number;
113
+ /** When true (default), a non-zero exit vetoes the pending action. */
114
+ blocking?: boolean;
115
+ /** Extra environment variables for the child process. */
116
+ env?: Record<string, string>;
117
+ }
118
+
119
+ /**
120
+ * Layer 0 shell hooks. Each key is the name of a hook event; each value is a
121
+ * list of `HookEntry` — all matching entries run in order.
122
+ *
123
+ * Hook names mirror Claude Code's for portability.
124
+ */
125
+ export interface HooksSettings {
126
+ PreToolUse?: HookEntry[];
127
+ PostToolUse?: HookEntry[];
128
+ UserPromptSubmit?: HookEntry[];
129
+ SessionStart?: HookEntry[];
130
+ SessionEnd?: HookEntry[];
131
+ Stop?: HookEntry[];
132
+ Notification?: HookEntry[];
133
+ PreCompact?: HookEntry[];
134
+ PostCompact?: HookEntry[];
135
+ PreCommit?: HookEntry[];
136
+ PostCommit?: HookEntry[];
137
+ PrePush?: HookEntry[];
138
+ PostPush?: HookEntry[];
139
+ PrePr?: HookEntry[];
140
+ PostPr?: HookEntry[];
141
+ PreMilestone?: HookEntry[];
142
+ PostMilestone?: HookEntry[];
143
+ PreUnit?: HookEntry[];
144
+ PostUnit?: HookEntry[];
145
+ PreVerify?: HookEntry[];
146
+ PostVerify?: HookEntry[];
147
+ BudgetThreshold?: HookEntry[];
148
+ Blocked?: HookEntry[];
149
+ }
150
+
95
151
  export type TransportSetting = Transport;
96
152
 
97
153
  /**
@@ -154,6 +210,7 @@ export interface Settings {
154
210
  timestampFormat?: "date-time-iso" | "date-time-us"; // Timestamp display format for messages. Default: "date-time-iso"
155
211
  allowedCommandPrefixes?: string[]; // Override built-in SAFE_COMMAND_PREFIXES for !command resolution (global-only — ignored in project settings)
156
212
  fetchAllowedUrls?: string[]; // Hostnames exempted from SSRF blocklist in fetch_page (global-only — ignored in project settings)
213
+ hooks?: HooksSettings; // Layer 0 shell-command hooks. Project-scoped hooks require explicit trust (.pi/hooks.trusted).
157
214
  }
158
215
 
159
216
  /** Settings keys that are only respected from global config — project settings cannot override these. */
@@ -109,9 +109,9 @@ export function buildSystemPrompt(options: BuildSystemPromptOptions = {}): strin
109
109
  }
110
110
 
111
111
  // Get absolute paths to documentation and examples
112
- const readmePath = getReadmePath();
113
- const docsPath = getDocsPath();
114
- const examplesPath = getExamplesPath();
112
+ const readmePath = toPosixPath(getReadmePath());
113
+ const docsPath = toPosixPath(getDocsPath());
114
+ const examplesPath = toPosixPath(getExamplesPath());
115
115
 
116
116
  // Build tools list based on selected tools.
117
117
  // Built-ins use toolDescriptions. Custom tools can provide one-line snippets.
@@ -1,11 +1,12 @@
1
1
  import { describe, it, mock, afterEach } from "node:test";
2
2
  import assert from "node:assert/strict";
3
+ import { resolve as resolvePath } from "node:path";
3
4
  import { resolveToCwd, expandPath } from "./path-utils.js";
4
5
 
5
6
  describe("resolveToCwd", () => {
6
7
  it("resolves relative paths against cwd", () => {
7
8
  const result = resolveToCwd("foo/bar.txt", "/home/user/project");
8
- assert.equal(result, "/home/user/project/foo/bar.txt");
9
+ assert.equal(result, resolvePath("/home/user/project", "foo/bar.txt"));
9
10
  });
10
11
 
11
12
  it("returns absolute paths unchanged", () => {
@@ -58,8 +58,24 @@ export type {
58
58
  AppAction,
59
59
  BashToolCallEvent,
60
60
  BeforeAgentStartEvent,
61
+ BeforeCommitEvent,
62
+ BeforeCommitEventResult,
63
+ BeforePrEvent,
64
+ BeforePrEventResult,
65
+ BeforePushEvent,
66
+ BeforePushEventResult,
67
+ BeforeVerifyEvent,
68
+ BeforeVerifyEventResult,
69
+ BudgetThresholdEvent,
70
+ BudgetThresholdEventResult,
61
71
  BeforeProviderRequestEvent,
62
72
  BeforeProviderRequestEventResult,
73
+ CommitEvent,
74
+ NotificationEvent,
75
+ PrOpenedEvent,
76
+ PushEvent,
77
+ VerifyFailure,
78
+ VerifyResultEvent,
63
79
  CompactOptions,
64
80
  ContextEvent,
65
81
  ContextUsage,
@@ -1,14 +1,11 @@
1
- // GSD-2 — Provider display name mapping tests
1
+ // GSD-2 — Provider display name + auth badge tests
2
2
  import { test, describe } from "node:test";
3
3
  import assert from "node:assert/strict";
4
- import { providerDisplayName } from "../model-selector.js";
4
+ import { providerAuthBadge, providerDisplayName } from "../model-selector.js";
5
5
 
6
6
  describe("providerDisplayName", () => {
7
- test("renames 'anthropic' to 'anthropic-api'", () => {
8
- assert.equal(providerDisplayName("anthropic"), "anthropic-api");
9
- });
10
-
11
- test("passes through unmapped providers unchanged", () => {
7
+ test("passes providers through unchanged", () => {
8
+ assert.equal(providerDisplayName("anthropic"), "anthropic");
12
9
  assert.equal(providerDisplayName("claude-code"), "claude-code");
13
10
  assert.equal(providerDisplayName("openai"), "openai");
14
11
  assert.equal(providerDisplayName("bedrock"), "bedrock");
@@ -16,3 +13,16 @@ describe("providerDisplayName", () => {
16
13
  assert.equal(providerDisplayName("openrouter"), "openrouter");
17
14
  });
18
15
  });
16
+
17
+ describe("providerAuthBadge", () => {
18
+ test("returns human-readable labels for each auth mode", () => {
19
+ assert.equal(providerAuthBadge("apiKey"), "API key");
20
+ assert.equal(providerAuthBadge("oauth"), "OAuth");
21
+ assert.equal(providerAuthBadge("externalCli"), "CLI");
22
+ });
23
+
24
+ test("returns empty string for 'none' and undefined", () => {
25
+ assert.equal(providerAuthBadge("none"), "");
26
+ assert.equal(providerAuthBadge(undefined), "");
27
+ });
28
+ });
@@ -2,7 +2,7 @@ import { truncateToWidth, visibleWidth } from "@gsd/pi-tui";
2
2
  import { theme } from "../theme/theme.js";
3
3
  import { formatTimestamp, type TimestampFormat } from "./timestamp.js";
4
4
 
5
- type FrameTone = "assistant" | "user" | "compaction";
5
+ type FrameTone = "assistant" | "user" | "compaction" | "skill";
6
6
 
7
7
  function trimOuterBlankLines(lines: string[]): string[] {
8
8
  let start = 0;
@@ -25,14 +25,14 @@ export function renderChatFrame(
25
25
  ): string[] {
26
26
  const outerWidth = Math.max(20, width);
27
27
  const contentWidth = Math.max(1, outerWidth - 2); // "│ " + content
28
+ const isPurple = opts.tone === "compaction" || opts.tone === "skill";
28
29
  const borderColor =
29
30
  opts.tone === "user"
30
31
  ? "border"
31
- : opts.tone === "compaction"
32
+ : isPurple
32
33
  ? "customMessageLabel"
33
34
  : "borderAccent";
34
- const borderMuted =
35
- opts.tone === "compaction" ? "customMessageLabel" : "borderMuted";
35
+ const borderMuted = isPurple ? "customMessageLabel" : "borderMuted";
36
36
  const border = (s: string) => theme.fg(borderColor, s);
37
37
  const leftRaw = `• ${opts.label}`;
38
38
  const rightRaw =
@@ -47,7 +47,7 @@ export function renderChatFrame(
47
47
  const labelColor =
48
48
  opts.tone === "user"
49
49
  ? "border"
50
- : opts.tone === "compaction"
50
+ : isPurple
51
51
  ? "customMessageLabel"
52
52
  : "borderAccent";
53
53
  const dashIdx = left.indexOf(" - ");
@@ -71,7 +71,7 @@ export function renderChatFrame(
71
71
  const bodyColor =
72
72
  opts.tone === "user"
73
73
  ? "userMessageText"
74
- : opts.tone === "compaction"
74
+ : isPurple
75
75
  ? "customMessageText"
76
76
  : "assistantMessageText";
77
77
  const bodyLines = (sourceLines.length > 0 ? sourceLines : [""]).map((line) => {
@@ -2,7 +2,7 @@ import { type Component, truncateToWidth, visibleWidth } from "@gsd/pi-tui";
2
2
  import type { AgentSession } from "../../../core/agent-session.js";
3
3
  import type { ReadonlyFooterDataProvider } from "../../../core/footer-data-provider.js";
4
4
  import { theme } from "../theme/theme.js";
5
- import { providerDisplayName } from "./model-selector.js";
5
+ import { providerAuthBadge, providerDisplayName } from "./model-selector.js";
6
6
 
7
7
  /**
8
8
  * Sanitize text for display in a single-line status.
@@ -199,13 +199,22 @@ export class FooterComponent implements Component {
199
199
  thinkingLevel === "off" ? `${modelName} • thinking off` : `${modelName} • ${thinkingLevel}`;
200
200
  }
201
201
 
202
- // Prepend the provider in parentheses if there are multiple providers and there's enough room
202
+ // Prepend the provider in parentheses if there are multiple providers and there's enough room.
203
+ // Include the auth mode so users can tell at a glance whether the active model is
204
+ // API-key-backed, OAuth-backed, or delegated to a third-party CLI.
203
205
  let rightSide = rightSideWithoutProvider;
204
206
  if (this.footerData.getAvailableProviderCount() > 1 && displayModel) {
205
- rightSide = `(${providerDisplayName(displayModel.provider)}) ${rightSideWithoutProvider}`;
207
+ const authMode = this.session.modelRegistry.getProviderAuthMode(displayModel.provider);
208
+ const authLabel = providerAuthBadge(authMode);
209
+ const providerLabel = providerDisplayName(displayModel.provider);
210
+ const parenthetical = authLabel ? `${providerLabel} · ${authLabel}` : providerLabel;
211
+ rightSide = `(${parenthetical}) ${rightSideWithoutProvider}`;
206
212
  if (statsLeftWidth + minPadding + visibleWidth(rightSide) > width) {
207
- // Too wide, fall back
208
- rightSide = rightSideWithoutProvider;
213
+ // Too wide: drop the auth suffix first, then fall back to no parenthetical.
214
+ rightSide = `(${providerLabel}) ${rightSideWithoutProvider}`;
215
+ if (statsLeftWidth + minPadding + visibleWidth(rightSide) > width) {
216
+ rightSide = rightSideWithoutProvider;
217
+ }
209
218
  }
210
219
  }
211
220
 
@@ -9,19 +9,32 @@ import {
9
9
  Text,
10
10
  type TUI,
11
11
  } from "@gsd/pi-tui";
12
- import type { ModelRegistry } from "../../../core/model-registry.js";
12
+ import type { ModelRegistry, ProviderAuthMode } from "../../../core/model-registry.js";
13
13
  import type { SettingsManager } from "../../../core/settings-manager.js";
14
14
  import { theme } from "../theme/theme.js";
15
15
  import { DynamicBorder } from "./dynamic-border.js";
16
16
  import { keyHint } from "./keybinding-hints.js";
17
17
 
18
- /** Display names for providers in the model selector UI. */
19
- const PROVIDER_DISPLAY_NAMES: Record<string, string> = {
20
- anthropic: "anthropic-api",
21
- };
22
-
23
18
  export function providerDisplayName(provider: string): string {
24
- return PROVIDER_DISPLAY_NAMES[provider] ?? provider;
19
+ return provider;
20
+ }
21
+
22
+ /**
23
+ * Short, user-facing label for a provider's auth mode. Returned strings are
24
+ * suitable for use as a suffix/badge alongside the provider name.
25
+ * Returns an empty string for modes that don't need a badge (e.g. "none").
26
+ */
27
+ export function providerAuthBadge(authMode?: ProviderAuthMode): string {
28
+ switch (authMode) {
29
+ case "apiKey":
30
+ return "API key";
31
+ case "oauth":
32
+ return "OAuth";
33
+ case "externalCli":
34
+ return "CLI";
35
+ default:
36
+ return "";
37
+ }
25
38
  }
26
39
 
27
40
  function formatTokenCount(count: number): string {
@@ -140,7 +153,8 @@ export class ModelSelectorComponent extends Container implements Focusable {
140
153
  this.scopeHintText = new Text(this.getScopeHintText(), 0, 0);
141
154
  this.addChild(this.scopeHintText);
142
155
  } else {
143
- const hintText = "Only showing models with configured API keys (see README for details)";
156
+ const hintText =
157
+ "Only showing models with configured credentials (API key, OAuth, or CLI). See README for details.";
144
158
  this.addChild(new Text(theme.fg("warning", hintText), 0, 0));
145
159
  }
146
160
  this.addChild(new Spacer(1));
@@ -409,7 +423,12 @@ export class ModelSelectorComponent extends Container implements Focusable {
409
423
 
410
424
  const ctx = formatTokenCount(item.model.contextWindow);
411
425
  const ctxBadge = theme.fg("muted", `${ctx}`);
412
- const providerBadge = theme.fg("muted", `[${providerDisplayName(item.provider)}]`);
426
+ const authMode = this.modelRegistry.getProviderAuthMode(item.provider);
427
+ const authLabel = providerAuthBadge(authMode);
428
+ const providerBadgeText = authLabel
429
+ ? `[${providerDisplayName(item.provider)} · ${authLabel}]`
430
+ : `[${providerDisplayName(item.provider)}]`;
431
+ const providerBadge = theme.fg("muted", providerBadgeText);
413
432
  const checkmark = isCurrent ? theme.fg("success", " ✓") : "";
414
433
 
415
434
  let line: string;
@@ -445,7 +464,19 @@ export class ModelSelectorComponent extends Container implements Focusable {
445
464
  const maxVisible = 12;
446
465
 
447
466
  if (this.groupedRows.length === 0) {
448
- this.listContainer.addChild(new Text(theme.fg("muted", " No models available"), 0, 0));
467
+ this.listContainer.addChild(
468
+ new Text(theme.fg("muted", " No providers configured."), 0, 0),
469
+ );
470
+ this.listContainer.addChild(
471
+ new Text(
472
+ theme.fg(
473
+ "muted",
474
+ " Run /login (OAuth), set an API key, or install a CLI provider. See README.",
475
+ ),
476
+ 0,
477
+ 0,
478
+ ),
479
+ );
449
480
  return;
450
481
  }
451
482
 
@@ -467,11 +498,14 @@ export class ModelSelectorComponent extends Container implements Focusable {
467
498
  // Provider group header — always unselectable
468
499
  const providerLabel = theme.fg("borderAccent", providerDisplayName(row.provider));
469
500
  const count = theme.fg("muted", ` (${row.count})`);
501
+ const authMode = this.modelRegistry.getProviderAuthMode(row.provider);
502
+ const authLabel = providerAuthBadge(authMode);
503
+ const authText = authLabel ? theme.fg("muted", ` · via ${authLabel}`) : "";
470
504
  // Add blank line before header if not the very first visible row
471
505
  if (i > startIndex) {
472
506
  this.listContainer.addChild(new Text("", 0, 0));
473
507
  }
474
- this.listContainer.addChild(new Text(` ${providerLabel}${count}`, 0, 0));
508
+ this.listContainer.addChild(new Text(` ${providerLabel}${count}${authText}`, 0, 0));
475
509
  } else {
476
510
  // Model row
477
511
  const isSelected = i === this.selectedGroupIndex;
@@ -12,7 +12,7 @@ import {
12
12
  type TUI,
13
13
  } from "@gsd/pi-tui";
14
14
  import type { AuthStorage } from "../../../core/auth-storage.js";
15
- import { getDiscoverableProviders } from "../../../core/model-discovery.js";
15
+ import { getDiscoverableProviders, getDiscoveryAdapter } from "../../../core/model-discovery.js";
16
16
  import { providerDisplayName } from "./model-selector.js";
17
17
  import type { ModelRegistry } from "../../../core/model-registry.js";
18
18
  import { ModelsJsonWriter } from "../../../core/models-json-writer.js";
@@ -102,12 +102,21 @@ export class ProviderManagerComponent extends Container implements Focusable {
102
102
 
103
103
  this.providers = Array.from(providerNames)
104
104
  .sort()
105
- .map((name) => ({
106
- name,
107
- hasAuth: this.authStorage.hasAuth(name),
108
- supportsDiscovery: discoverableSet.has(name),
109
- modelCount: providerModelCounts.get(name) ?? 0,
110
- }));
105
+ .map((name) => {
106
+ const providerApis = new Set(
107
+ allModels
108
+ .filter((m) => m.provider === name)
109
+ .map((m) => m.api)
110
+ .filter((api): api is string => typeof api === "string" && api.length > 0),
111
+ );
112
+ return {
113
+ name,
114
+ hasAuth: this.authStorage.hasAuth(name),
115
+ supportsDiscovery:
116
+ discoverableSet.has(name) || getDiscoveryAdapter(name, providerApis).supportsDiscovery,
117
+ modelCount: providerModelCounts.get(name) ?? 0,
118
+ };
119
+ });
111
120
  this.clampSelectedIndex();
112
121
  }
113
122