saeeol 1.3.0 → 1.3.1

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 (537) hide show
  1. package/.turbo/turbo-typecheck.log +1 -0
  2. package/AGENTS.md +72 -0
  3. package/BUN_SHELL_MIGRATION_PLAN.md +136 -0
  4. package/Dockerfile +18 -0
  5. package/assets/saeeol.ico +0 -0
  6. package/bin/saeeol.cjs +0 -0
  7. package/database.db +0 -0
  8. package/drizzle.config.ts +10 -0
  9. package/git +0 -0
  10. package/migration/20260127222353_familiar_lady_ursula/migration.sql +90 -0
  11. package/migration/20260127222353_familiar_lady_ursula/snapshot.json +796 -0
  12. package/migration/20260211171708_add_project_commands/migration.sql +1 -0
  13. package/migration/20260211171708_add_project_commands/snapshot.json +806 -0
  14. package/migration/20260213144116_wakeful_the_professor/migration.sql +11 -0
  15. package/migration/20260213144116_wakeful_the_professor/snapshot.json +897 -0
  16. package/migration/20260225215848_workspace/migration.sql +7 -0
  17. package/migration/20260225215848_workspace/snapshot.json +959 -0
  18. package/migration/20260227213759_add_session_workspace_id/migration.sql +2 -0
  19. package/migration/20260227213759_add_session_workspace_id/snapshot.json +983 -0
  20. package/migration/20260228203230_blue_harpoon/migration.sql +17 -0
  21. package/migration/20260228203230_blue_harpoon/snapshot.json +1102 -0
  22. package/migration/20260303231226_add_workspace_fields/migration.sql +5 -0
  23. package/migration/20260303231226_add_workspace_fields/snapshot.json +1013 -0
  24. package/migration/20260309230000_move_org_to_state/migration.sql +3 -0
  25. package/migration/20260309230000_move_org_to_state/snapshot.json +1156 -0
  26. package/migration/20260312043431_session_message_cursor/migration.sql +4 -0
  27. package/migration/20260312043431_session_message_cursor/snapshot.json +1168 -0
  28. package/migration/20260323234822_events/migration.sql +13 -0
  29. package/migration/20260323234822_events/snapshot.json +1271 -0
  30. package/migration/20260410174513_workspace-name/migration.sql +16 -0
  31. package/migration/20260410174513_workspace-name/snapshot.json +1271 -0
  32. package/migration/20260413175956_chief_energizer/migration.sql +13 -0
  33. package/migration/20260413175956_chief_energizer/snapshot.json +1399 -0
  34. package/migration/20260423070820_add_icon_url_override/migration.sql +2 -0
  35. package/migration/20260423070820_add_icon_url_override/snapshot.json +1409 -0
  36. package/migration/20260428004200_add_session_path/migration.sql +1 -0
  37. package/migration/20260428004200_add_session_path/snapshot.json +1419 -0
  38. package/npm/bin/saeeol +42 -0
  39. package/npm/package.json +39 -0
  40. package/npm/postinstall.js +162 -0
  41. package/package.json +201 -207
  42. package/parsers-config.ts +289 -0
  43. package/script/build.ts +393 -0
  44. package/script/check-migrations.ts +16 -0
  45. package/script/fix-node-pty.ts +34 -0
  46. package/script/generate.ts +23 -0
  47. package/script/postinstall.mjs +189 -0
  48. package/script/publish.ts +200 -0
  49. package/script/run-workspace-server +106 -0
  50. package/script/schema.ts +63 -0
  51. package/script/test-runner.ts +420 -0
  52. package/script/time.ts +6 -0
  53. package/script/trace-imports.ts +153 -0
  54. package/script/upgrade-opentui.ts +64 -0
  55. package/scripts/diff-sdk-types.sh +52 -0
  56. package/specs/effect/facades.md +221 -0
  57. package/specs/effect/http-api.md +401 -0
  58. package/specs/effect/instance-context.md +309 -0
  59. package/specs/effect/loose-ends.md +34 -0
  60. package/specs/effect/migration.md +299 -0
  61. package/specs/effect/routes.md +64 -0
  62. package/specs/effect/schema.md +399 -0
  63. package/specs/effect/server-package.md +668 -0
  64. package/specs/effect/tools.md +90 -0
  65. package/specs/tui-plugins.md +433 -0
  66. package/specs/v2/api.ts +67 -0
  67. package/specs/v2/keymappings.md +10 -0
  68. package/specs/v2/message-shape.md +136 -0
  69. package/src/acp/agent-message.ts +1 -1
  70. package/src/acp/agent-utils.ts +1 -1
  71. package/src/boxes/ansi.ts +17 -0
  72. package/src/boxes/atomic-write.ts +35 -0
  73. package/src/boxes/b64.ts +58 -0
  74. package/src/boxes/bash-security.ts +129 -0
  75. package/src/boxes/bom.ts +18 -0
  76. package/src/boxes/cancel.ts +16 -0
  77. package/src/boxes/chop.ts +12 -0
  78. package/src/boxes/clamp.ts +3 -0
  79. package/src/boxes/compact.ts +9 -0
  80. package/src/boxes/cost-tracker.ts +116 -0
  81. package/src/boxes/dataurl.ts +29 -0
  82. package/src/boxes/delay.ts +27 -0
  83. package/src/boxes/diff-apply.ts +53 -0
  84. package/src/boxes/disposable.ts +13 -0
  85. package/src/boxes/err.ts +34 -0
  86. package/src/boxes/human.ts +47 -0
  87. package/src/boxes/iife.ts +9 -0
  88. package/src/boxes/latch.ts +8 -0
  89. package/src/boxes/memory.ts +198 -0
  90. package/src/boxes/net.ts +16 -0
  91. package/src/boxes/plural.ts +4 -0
  92. package/src/boxes/puny.ts +21 -0
  93. package/src/boxes/retry.ts +49 -0
  94. package/src/boxes/rwlock.ts +41 -0
  95. package/src/boxes/schedule.ts +71 -0
  96. package/src/boxes/scope.ts +21 -0
  97. package/src/boxes/tokens.ts +9 -0
  98. package/src/boxes/ttl-cache.ts +63 -0
  99. package/src/boxes/typed-event.ts +51 -0
  100. package/src/boxes/uid.ts +50 -0
  101. package/src/boxes/wave6.test.ts +296 -0
  102. package/src/boxes/wildcard.ts +58 -0
  103. package/src/bus/global.ts +1 -1
  104. package/src/cli/cmd/github-run-api.ts +2 -2
  105. package/src/cli/cmd/run-events.ts +2 -2
  106. package/src/cli/cmd/tui/component/logo.tsx +1 -1
  107. package/src/cli/cmd/tui/component/prompt/use-prompt-memos.ts +2 -2
  108. package/src/cli/cmd/tui/context/app/editor-zed.ts +1 -1
  109. package/src/cli/cmd/tui/context/app/editor.ts +1 -1
  110. package/src/cli/cmd/tui/context/app/theme.tsx +1 -1
  111. package/src/cli/cmd/tui/util/revert-diff.ts +1 -1
  112. package/src/overlay/cli/cmd/roll-call-call.ts +1 -1
  113. package/src/overlay/cost-tracker/format.ts +1 -1
  114. package/src/overlay/cost-tracker/index.ts +4 -4
  115. package/src/overlay/cost-tracker/state.ts +2 -2
  116. package/src/overlay/cost-tracker/types.ts +2 -2
  117. package/src/overlay/memory/age.ts +1 -1
  118. package/src/overlay/memory/index.ts +4 -4
  119. package/src/overlay/memory/paths.ts +2 -2
  120. package/src/overlay/memory/scan.ts +1 -1
  121. package/src/overlay/memory/types.ts +2 -2
  122. package/src/overlay/tool/bash-security.ts +3 -3
  123. package/src/overlay/util/url.ts +1 -1
  124. package/src/plugin/codex-auth.ts +1 -1
  125. package/src/provider/model-cache.ts +2 -2
  126. package/src/provider/provider-resolve.ts +3 -3
  127. package/src/provider/transform-message.ts +1 -1
  128. package/src/server/routes/game.ts +284 -0
  129. package/src/server/server.ts +2 -0
  130. package/src/session/core/compaction/compaction-helpers.ts +1 -1
  131. package/src/session/core/compaction/compaction.ts +1 -1
  132. package/src/session/core/session.ts +2 -0
  133. package/src/sessions/ingest-queue.ts +2 -2
  134. package/src/sessions/remote-ws.ts +1 -1
  135. package/src/tool/workflow/question.ts +1 -1
  136. package/src/util/abort.ts +1 -1
  137. package/src/util/bom.ts +2 -2
  138. package/src/util/color.ts +1 -1
  139. package/src/util/data-url.ts +1 -1
  140. package/src/util/defer.ts +1 -1
  141. package/src/util/error.ts +2 -2
  142. package/src/util/filesystem.ts +2 -2
  143. package/src/util/format.ts +1 -1
  144. package/src/util/iife.ts +1 -1
  145. package/src/util/local-context.ts +1 -1
  146. package/src/util/locale.ts +2 -2
  147. package/src/util/lock.ts +1 -1
  148. package/src/util/network.ts +1 -1
  149. package/src/util/signal.ts +1 -1
  150. package/src/util/token.ts +1 -1
  151. package/src/util/wildcard.ts +1 -1
  152. package/sst-env.d.ts +10 -0
  153. package/test/AGENTS.md +133 -0
  154. package/test/account/repo.test.ts +352 -0
  155. package/test/account/service.test.ts +456 -0
  156. package/test/acp/agent-interface.test.ts +51 -0
  157. package/test/acp/event-subscription.test.ts +725 -0
  158. package/test/agent/agent.test.ts +890 -0
  159. package/test/auth/auth.test.ts +86 -0
  160. package/test/bun/registry.test.ts +75 -0
  161. package/test/bus/bus-effect.test.ts +161 -0
  162. package/test/bus/bus-integration.test.ts +87 -0
  163. package/test/bus/bus.test.ts +219 -0
  164. package/test/cli/account.test.ts +26 -0
  165. package/test/cli/auto-mode.test.ts +75 -0
  166. package/test/cli/bin-saeeol.test.ts +8 -0
  167. package/test/cli/cmd/tui/prompt-part.test.ts +47 -0
  168. package/test/cli/cmd/tui/prompt-traits.test.ts +38 -0
  169. package/test/cli/cmd/tui/sync.test.tsx +159 -0
  170. package/test/cli/error.test.ts +18 -0
  171. package/test/cli/github-action.test.ts +198 -0
  172. package/test/cli/github-remote.test.ts +85 -0
  173. package/test/cli/import.test.ts +97 -0
  174. package/test/cli/install-artifact.test.ts +72 -0
  175. package/test/cli/plugin-auth-picker.test.ts +120 -0
  176. package/test/cli/pr.test.ts +59 -0
  177. package/test/cli/tui/editor-context-zed.test.ts +356 -0
  178. package/test/cli/tui/editor-context.test.tsx +228 -0
  179. package/test/cli/tui/keybind-plugin.test.ts +90 -0
  180. package/test/cli/tui/markdown.test.ts +161 -0
  181. package/test/cli/tui/plugin-add.test.ts +111 -0
  182. package/test/cli/tui/plugin-install.test.ts +87 -0
  183. package/test/cli/tui/plugin-lifecycle.test.ts +224 -0
  184. package/test/cli/tui/plugin-loader-entrypoint.test.ts +484 -0
  185. package/test/cli/tui/plugin-loader-pure.test.ts +71 -0
  186. package/test/cli/tui/plugin-loader.test.ts +816 -0
  187. package/test/cli/tui/plugin-toggle.test.ts +157 -0
  188. package/test/cli/tui/revert-diff.test.ts +35 -0
  189. package/test/cli/tui/slot-replace.test.tsx +47 -0
  190. package/test/cli/tui/theme-store.test.ts +54 -0
  191. package/test/cli/tui/thread.test.ts +28 -0
  192. package/test/cli/tui/transcript.test.ts +426 -0
  193. package/test/cli/tui/usage.test.ts +60 -0
  194. package/test/cli/tui/use-event.test.tsx +175 -0
  195. package/test/config/agent-color.test.ts +67 -0
  196. package/test/config/config.test.ts +2544 -0
  197. package/test/config/fixtures/empty-frontmatter.md +4 -0
  198. package/test/config/fixtures/frontmatter.md +28 -0
  199. package/test/config/fixtures/markdown-header.md +11 -0
  200. package/test/config/fixtures/no-frontmatter.md +1 -0
  201. package/test/config/fixtures/weird-model-id.md +13 -0
  202. package/test/config/lsp.test.ts +87 -0
  203. package/test/config/markdown.test.ts +228 -0
  204. package/test/config/plugin.test.ts +0 -0
  205. package/test/config/tui.test.ts +624 -0
  206. package/test/control-plane/adapters.test.ts +71 -0
  207. package/test/control-plane/workspace.test.ts +1526 -0
  208. package/test/effect/app-runtime-logger.test.ts +98 -0
  209. package/test/effect/config-service.test.ts +65 -0
  210. package/test/effect/instance-state.test.ts +394 -0
  211. package/test/effect/run-service.test.ts +89 -0
  212. package/test/effect/runner.test.ts +523 -0
  213. package/test/fake/provider.ts +82 -0
  214. package/test/file/fsmonitor.test.ts +68 -0
  215. package/test/file/ignore.test.ts +10 -0
  216. package/test/file/index.test.ts +954 -0
  217. package/test/file/path-traversal.test.ts +205 -0
  218. package/test/file/ripgrep.test.ts +226 -0
  219. package/test/file/watcher.test.ts +249 -0
  220. package/test/filesystem/filesystem.test.ts +319 -0
  221. package/test/fixture/db.ts +11 -0
  222. package/test/fixture/fixture.test.ts +26 -0
  223. package/test/fixture/fixture.ts +175 -0
  224. package/test/fixture/flock-worker.ts +72 -0
  225. package/test/fixture/log-init-worker.ts +62 -0
  226. package/test/fixture/lsp/fake-lsp-server.js +249 -0
  227. package/test/fixture/plug-worker.ts +93 -0
  228. package/test/fixture/plugin-meta-worker.ts +19 -0
  229. package/test/fixture/skills/agents-sdk/SKILL.md +152 -0
  230. package/test/fixture/skills/cloudflare/SKILL.md +211 -0
  231. package/test/fixture/skills/index.json +6 -0
  232. package/test/fixture/tui-plugin.ts +323 -0
  233. package/test/fixture/tui-runtime.ts +31 -0
  234. package/test/format/format.test.ts +272 -0
  235. package/test/git/git.test.ts +128 -0
  236. package/test/ide/ide.test.ts +82 -0
  237. package/test/installation/installation.test.ts +168 -0
  238. package/test/keybind.test.ts +421 -0
  239. package/test/lib/effect.ts +53 -0
  240. package/test/lib/filesystem.ts +10 -0
  241. package/test/lib/llm-server.ts +778 -0
  242. package/test/lib/websocket.ts +46 -0
  243. package/test/lsp/client.test.ts +482 -0
  244. package/test/lsp/index.test.ts +160 -0
  245. package/test/lsp/launch.test.ts +22 -0
  246. package/test/lsp/lifecycle.test.ts +184 -0
  247. package/test/ltm/ltm.test.ts +230 -0
  248. package/test/mcp/headers.test.ts +178 -0
  249. package/test/mcp/lifecycle.test.ts +787 -0
  250. package/test/mcp/oauth-auto-connect.test.ts +311 -0
  251. package/test/mcp/oauth-browser.test.ts +276 -0
  252. package/test/mcp/oauth-callback.test.ts +34 -0
  253. package/test/memory/abort-leak-webfetch.ts +49 -0
  254. package/test/memory/abort-leak.test.ts +128 -0
  255. package/test/patch/patch.test.ts +348 -0
  256. package/test/permission/arity.test.ts +33 -0
  257. package/test/permission/next.test.ts +1227 -0
  258. package/test/permission/next.toConfig.test.ts +110 -0
  259. package/test/permission-task.test.ts +326 -0
  260. package/test/plugin/auth-override.test.ts +79 -0
  261. package/test/plugin/cloudflare.test.ts +68 -0
  262. package/test/plugin/codex.test.ts +123 -0
  263. package/test/plugin/github-copilot-models.test.ts +261 -0
  264. package/test/plugin/install-concurrency.test.ts +140 -0
  265. package/test/plugin/install.test.ts +570 -0
  266. package/test/plugin/loader-shared.test.ts +1169 -0
  267. package/test/plugin/meta.test.ts +137 -0
  268. package/test/plugin/plugin-contract.test.ts +291 -0
  269. package/test/plugin/shared.test.ts +88 -0
  270. package/test/plugin/trigger.test.ts +102 -0
  271. package/test/plugin/workspace-adapter.test.ts +109 -0
  272. package/test/preload.ts +77 -0
  273. package/test/project/instance.test.ts +276 -0
  274. package/test/project/migrate-global.test.ts +152 -0
  275. package/test/project/project.test.ts +600 -0
  276. package/test/project/vcs.test.ts +286 -0
  277. package/test/project/worktree-remove.test.ts +126 -0
  278. package/test/project/worktree.test.ts +223 -0
  279. package/test/provider/amazon-bedrock.test.ts +462 -0
  280. package/test/provider/copilot/convert-to-copilot-messages.test.ts +523 -0
  281. package/test/provider/copilot/copilot-chat-model.test.ts +592 -0
  282. package/test/provider/gitlab-duo.test.ts +413 -0
  283. package/test/provider/local.test.ts +208 -0
  284. package/test/provider/models.test.ts +261 -0
  285. package/test/provider/provider-category.test.ts +190 -0
  286. package/test/provider/provider.test.ts +2758 -0
  287. package/test/provider/transform.test.ts +3681 -0
  288. package/test/pty/pty-output-isolation.test.ts +147 -0
  289. package/test/pty/pty-session.test.ts +102 -0
  290. package/test/pty/pty-shell.test.ts +104 -0
  291. package/test/question/question.test.ts +490 -0
  292. package/test/saeeol/agent-global-config-dirs.test.ts +24 -0
  293. package/test/saeeol/agent-manager-tool.test.ts +71 -0
  294. package/test/saeeol/agent-permission-overrides.test.ts +75 -0
  295. package/test/saeeol/agent-skill-permissions.test.ts +37 -0
  296. package/test/saeeol/ask-agent-permissions.test.ts +303 -0
  297. package/test/saeeol/bash-hierarchy.test.ts +64 -0
  298. package/test/saeeol/bash-permission-metadata.test.ts +66 -0
  299. package/test/saeeol/bash-security-extended.test.ts +243 -0
  300. package/test/saeeol/bedrock-claude-empty-content.test.ts +138 -0
  301. package/test/saeeol/boxes-integration.test.ts +415 -0
  302. package/test/saeeol/builtin-skills.test.ts +75 -0
  303. package/test/saeeol/cleanup.ts +28 -0
  304. package/test/saeeol/cli/dev-setup.test.ts +74 -0
  305. package/test/saeeol/cli/roll-call.test.ts +161 -0
  306. package/test/saeeol/cli-run-auto-helper.test.ts +58 -0
  307. package/test/saeeol/codex-auth-refresh.test.ts +124 -0
  308. package/test/saeeol/commit-message/generate.test.ts +188 -0
  309. package/test/saeeol/commit-message/git-context.test.ts +303 -0
  310. package/test/saeeol/commit-message-windows.test.ts +38 -0
  311. package/test/saeeol/compaction-payload-recovery.test.ts +406 -0
  312. package/test/saeeol/compaction-preservation-audit.test.ts +122 -0
  313. package/test/saeeol/compaction-skip-guard.test.ts +224 -0
  314. package/test/saeeol/compaction-smart-select.test.ts +100 -0
  315. package/test/saeeol/config/config.test.ts +166 -0
  316. package/test/saeeol/config/indexing-default-plugin.test.ts +82 -0
  317. package/test/saeeol/config/opentelemetry-default.test.ts +29 -0
  318. package/test/saeeol/config-gitignore.test.ts +70 -0
  319. package/test/saeeol/config-injector.test.ts +305 -0
  320. package/test/saeeol/config-resilience.test.ts +234 -0
  321. package/test/saeeol/config-validation.test.ts +183 -0
  322. package/test/saeeol/cost-propagation.test.ts +94 -0
  323. package/test/saeeol/cost-tracker-extended.test.ts +141 -0
  324. package/test/saeeol/cost-tracker.test.ts +64 -0
  325. package/test/saeeol/custom-provider-delete.test.ts +149 -0
  326. package/test/saeeol/diff-full.test.ts +226 -0
  327. package/test/saeeol/edit-permission-filediff.test.ts +223 -0
  328. package/test/saeeol/encoding.test.ts +364 -0
  329. package/test/saeeol/enhance-prompt.test.ts +61 -0
  330. package/test/saeeol/ensure-plan-dir.test.ts +32 -0
  331. package/test/saeeol/errors.test.ts +144 -0
  332. package/test/saeeol/external-directory-boundary.test.ts +96 -0
  333. package/test/saeeol/gateway-headers.test.ts +88 -0
  334. package/test/saeeol/help.test.ts +191 -0
  335. package/test/saeeol/ignore-migrator.test.ts +308 -0
  336. package/test/saeeol/indexing-auth.test.ts +45 -0
  337. package/test/saeeol/indexing-feature.test.ts +44 -0
  338. package/test/saeeol/indexing-label.test.ts +70 -0
  339. package/test/saeeol/indexing-startup.test.ts +381 -0
  340. package/test/saeeol/indexing-worktree.test.ts +73 -0
  341. package/test/saeeol/instruction.test.ts +136 -0
  342. package/test/saeeol/lancedb-runtime.test.ts +116 -0
  343. package/test/saeeol/loader-auth.test.ts +168 -0
  344. package/test/saeeol/local-model.test.ts +621 -0
  345. package/test/saeeol/logo.test.ts +31 -0
  346. package/test/saeeol/lsp-typescript-lightweight.test.ts +89 -0
  347. package/test/saeeol/mcp-branding.test.ts +33 -0
  348. package/test/saeeol/mcp-docker-rm.test.ts +32 -0
  349. package/test/saeeol/mcp-migrator.test.ts +736 -0
  350. package/test/saeeol/mcp-oauth-callback.test.ts +33 -0
  351. package/test/saeeol/memory-io.test.ts +198 -0
  352. package/test/saeeol/memory-paths.test.ts +87 -0
  353. package/test/saeeol/memory-security.test.ts +166 -0
  354. package/test/saeeol/model-cache-org.test.ts +164 -0
  355. package/test/saeeol/model-info-panel-utils.test.ts +52 -0
  356. package/test/saeeol/model-info-panel.types.test.ts +7 -0
  357. package/test/saeeol/models-401-fallback.test.ts +52 -0
  358. package/test/saeeol/modes-migrator.test.ts +320 -0
  359. package/test/saeeol/nvidia-headers.test.ts +74 -0
  360. package/test/saeeol/patch-jsonc.test.ts +73 -0
  361. package/test/saeeol/patch.test.ts +172 -0
  362. package/test/saeeol/paths.test.ts +265 -0
  363. package/test/saeeol/permission/config-paths.test.ts +174 -0
  364. package/test/saeeol/permission/env-read.test.ts +149 -0
  365. package/test/saeeol/permission/external-directory-allow.test.ts +327 -0
  366. package/test/saeeol/permission/next.always-rules.test.ts +882 -0
  367. package/test/saeeol/permission/next.reply-http.test.ts +205 -0
  368. package/test/saeeol/permission/next.reply-routing.test.ts +184 -0
  369. package/test/saeeol/plan-exit-detection.test.ts +494 -0
  370. package/test/saeeol/plan-followup.test.ts +1376 -0
  371. package/test/saeeol/project-config-update.test.ts +120 -0
  372. package/test/saeeol/project-id.test.ts +455 -0
  373. package/test/saeeol/provider-cost.test.ts +171 -0
  374. package/test/saeeol/provider-list-failed-state.test.ts +100 -0
  375. package/test/saeeol/question-dismiss-all.test.ts +174 -0
  376. package/test/saeeol/read-directory.test.ts +116 -0
  377. package/test/saeeol/rules-migrator.test.ts +257 -0
  378. package/test/saeeol/run-auto.test.ts +176 -0
  379. package/test/saeeol/run-network.test.ts +224 -0
  380. package/test/saeeol/semantic-search.test.ts +186 -0
  381. package/test/saeeol/server/permission-allow-everything.test.ts +125 -0
  382. package/test/saeeol/session/instruction-substitution.test.ts +72 -0
  383. package/test/saeeol/session/platform-attribution.test.ts +118 -0
  384. package/test/saeeol/session/session.test.ts +105 -0
  385. package/test/saeeol/session-compaction-cap.test.ts +399 -0
  386. package/test/saeeol/session-compaction-chunks.test.ts +501 -0
  387. package/test/saeeol/session-compaction-safety.test.ts +481 -0
  388. package/test/saeeol/session-fork-remap.test.ts +251 -0
  389. package/test/saeeol/session-import-service.test.ts +114 -0
  390. package/test/saeeol/session-list.test.ts +47 -0
  391. package/test/saeeol/session-message-metadata.test.ts +128 -0
  392. package/test/saeeol/session-overflow.test.ts +78 -0
  393. package/test/saeeol/session-processor-empty-tool-calls.test.ts +571 -0
  394. package/test/saeeol/session-processor-network-offline.test.ts +204 -0
  395. package/test/saeeol/session-processor-retry-limit.test.ts +238 -0
  396. package/test/saeeol/session-processor-review-telemetry.test.ts +82 -0
  397. package/test/saeeol/session-prompt-compaction-safety.test.ts +517 -0
  398. package/test/saeeol/session-prompt-queue.test.ts +815 -0
  399. package/test/saeeol/sessions/inflight-cache.test.ts +157 -0
  400. package/test/saeeol/sessions/ingest-queue.test.ts +402 -0
  401. package/test/saeeol/sessions/remote-protocol.test.ts +258 -0
  402. package/test/saeeol/sessions/remote-sender.test.ts +1036 -0
  403. package/test/saeeol/sessions/remote-ws.test.ts +367 -0
  404. package/test/saeeol/sessions/sessions-enable-remote.test.disable +181 -0
  405. package/test/saeeol/slot-prop-reactivity.test.ts +142 -0
  406. package/test/saeeol/snapshot-cache.test.ts +84 -0
  407. package/test/saeeol/snapshot-freeze-repro.test.ts +100 -0
  408. package/test/saeeol/snapshot-track-timeout.test.ts +519 -0
  409. package/test/saeeol/stats-subagent-cost.test.ts +123 -0
  410. package/test/saeeol/suggestion/auto-dismiss.test.ts +65 -0
  411. package/test/saeeol/suggestion/suggestion.test.ts +145 -0
  412. package/test/saeeol/suggestion/tool.test.ts +298 -0
  413. package/test/saeeol/summary-file-diff.test.ts +28 -0
  414. package/test/saeeol/system-prompt.test.ts +142 -0
  415. package/test/saeeol/task-nesting.test.ts +193 -0
  416. package/test/saeeol/telemetry/feedback.test.ts +8 -0
  417. package/test/saeeol/todo-view.test.ts +57 -0
  418. package/test/saeeol/tool-encoding.test.ts +455 -0
  419. package/test/saeeol/tool-registry-indexing-import-failure.test.ts +49 -0
  420. package/test/saeeol/tool-registry-indexing.test.ts +236 -0
  421. package/test/saeeol/tool-registry-semantic-import-failure.test.ts +55 -0
  422. package/test/saeeol/tool-task-model.test.ts +352 -0
  423. package/test/saeeol/transform-opus-4.7.test.ts +89 -0
  424. package/test/saeeol/tui-diff.test.ts +91 -0
  425. package/test/saeeol/tui-sync.test.ts +80 -0
  426. package/test/saeeol/util/url.test.ts +141 -0
  427. package/test/saeeol/workflows-migrator.test.ts +261 -0
  428. package/test/saeeol/worktree-diff-summary.test.ts +64 -0
  429. package/test/saeeol/worktree-diff.test.ts +223 -0
  430. package/test/saeeol/worktree-remove-lock.test.ts +82 -0
  431. package/test/server/AGENTS.md +15 -0
  432. package/test/server/contract.test.ts +357 -0
  433. package/test/server/experimental-session-list.test.ts +157 -0
  434. package/test/server/global-session-list.test.ts +155 -0
  435. package/test/server/httpapi-authorization.test.ts +103 -0
  436. package/test/server/httpapi-bridge.test.ts +440 -0
  437. package/test/server/httpapi-config.test.ts +67 -0
  438. package/test/server/httpapi-cors.test.ts +89 -0
  439. package/test/server/httpapi-event.test.ts +57 -0
  440. package/test/server/httpapi-experimental.test.ts +219 -0
  441. package/test/server/httpapi-file.test.ts +79 -0
  442. package/test/server/httpapi-instance-context.test.ts +237 -0
  443. package/test/server/httpapi-instance.legacy.test.ts +140 -0
  444. package/test/server/httpapi-instance.test.ts +83 -0
  445. package/test/server/httpapi-json-parity.test.ts +263 -0
  446. package/test/server/httpapi-mcp-oauth.test.ts +76 -0
  447. package/test/server/httpapi-mcp.test.ts +189 -0
  448. package/test/server/httpapi-provider.test.ts +153 -0
  449. package/test/server/httpapi-pty-websocket.test.ts +16 -0
  450. package/test/server/httpapi-pty.test.ts +175 -0
  451. package/test/server/httpapi-raw-route-auth.test.ts +89 -0
  452. package/test/server/httpapi-sdk.test.ts +681 -0
  453. package/test/server/httpapi-session.test.ts +464 -0
  454. package/test/server/httpapi-sync.test.ts +130 -0
  455. package/test/server/httpapi-tui.test.ts +121 -0
  456. package/test/server/httpapi-workspace-routing.test.ts +471 -0
  457. package/test/server/httpapi-workspace.test.ts +427 -0
  458. package/test/server/lib/conformance.ts +88 -0
  459. package/test/server/lib/stateful.ts +112 -0
  460. package/test/server/project-init-git.test.ts +113 -0
  461. package/test/server/proxy-util.test.ts +113 -0
  462. package/test/server/session-actions.test.ts +49 -0
  463. package/test/server/session-list.test.ts +238 -0
  464. package/test/server/session-messages.test.ts +167 -0
  465. package/test/server/session-select.test.ts +100 -0
  466. package/test/server/trace-attributes.test.ts +76 -0
  467. package/test/server/workspace-proxy.test.ts +165 -0
  468. package/test/server/workspace-routing.test.ts +85 -0
  469. package/test/session/compaction.test.ts +2420 -0
  470. package/test/session/instruction.test.ts +247 -0
  471. package/test/session/llm.test.ts +1273 -0
  472. package/test/session/message-v2.test.ts +1291 -0
  473. package/test/session/messages-pagination.test.ts +1173 -0
  474. package/test/session/network.test.ts +249 -0
  475. package/test/session/processor-effect.test.ts +847 -0
  476. package/test/session/prompt.test.ts +2131 -0
  477. package/test/session/retry.test.ts +340 -0
  478. package/test/session/revert-compact.test.ts +639 -0
  479. package/test/session/schema-decoding.test.ts +311 -0
  480. package/test/session/session-entry-stepper.test.ts +917 -0
  481. package/test/session/session-schema.test.ts +76 -0
  482. package/test/session/snapshot-tool-race.test.ts +257 -0
  483. package/test/session/structured-output-integration.test.ts +265 -0
  484. package/test/session/structured-output.test.ts +381 -0
  485. package/test/session/system.test.ts +73 -0
  486. package/test/share/share-next.test.ts +333 -0
  487. package/test/shell/shell.test.ts +99 -0
  488. package/test/skill/discovery.test.ts +116 -0
  489. package/test/skill/skill.test.ts +393 -0
  490. package/test/snapshot/snapshot.test.ts +1531 -0
  491. package/test/storage/db.test.ts +23 -0
  492. package/test/storage/json-migration.test.ts +832 -0
  493. package/test/storage/storage.test.ts +293 -0
  494. package/test/suggestion/suggestion.test.ts +1 -0
  495. package/test/sync/index.test.ts +256 -0
  496. package/test/tool/__snapshots__/parameters.test.ts.snap +500 -0
  497. package/test/tool/__snapshots__/tool.test.ts.snap +9 -0
  498. package/test/tool/apply_patch.test.ts +614 -0
  499. package/test/tool/bash.test.ts +1225 -0
  500. package/test/tool/diagnostics-filter.test.ts +55 -0
  501. package/test/tool/edit.test.ts +754 -0
  502. package/test/tool/external-directory.test.ts +169 -0
  503. package/test/tool/fixtures/large-image.png +0 -0
  504. package/test/tool/fixtures/models-api.json +65179 -0
  505. package/test/tool/glob.test.ts +107 -0
  506. package/test/tool/grep.test.ts +114 -0
  507. package/test/tool/lsp.test.ts +187 -0
  508. package/test/tool/parameters.test.ts +243 -0
  509. package/test/tool/question.test.ts +129 -0
  510. package/test/tool/read.test.ts +500 -0
  511. package/test/tool/recall.test.ts +151 -0
  512. package/test/tool/registry.test.ts +203 -0
  513. package/test/tool/skill.test.ts +135 -0
  514. package/test/tool/suggest.test.ts +1 -0
  515. package/test/tool/task.test.ts +612 -0
  516. package/test/tool/tool-define.test.ts +99 -0
  517. package/test/tool/truncation.test.ts +260 -0
  518. package/test/tool/webfetch.test.ts +103 -0
  519. package/test/tool/write.test.ts +291 -0
  520. package/test/util/data-url.test.ts +14 -0
  521. package/test/util/effect-zod.test.ts +754 -0
  522. package/test/util/error.test.ts +38 -0
  523. package/test/util/filesystem.test.ts +656 -0
  524. package/test/util/format.test.ts +59 -0
  525. package/test/util/glob.test.ts +164 -0
  526. package/test/util/iife.test.ts +36 -0
  527. package/test/util/lazy.test.ts +50 -0
  528. package/test/util/lock.test.ts +72 -0
  529. package/test/util/log.test.ts +86 -0
  530. package/test/util/module.test.ts +59 -0
  531. package/test/util/process.test.ts +128 -0
  532. package/test/util/timeout.test.ts +21 -0
  533. package/test/util/which.test.ts +100 -0
  534. package/test/util/wildcard.test.ts +90 -0
  535. package/test/workspace/workspace-restore.test.ts +296 -0
  536. package/src/provider/models-snapshot.d.ts +0 -2
  537. package/src/provider/models-snapshot.js +0 -3
@@ -0,0 +1,64 @@
1
+ # Route handler effectification
2
+
3
+ Practical reference for converting server route handlers in `packages/saeeol` to a single `AppRuntime.runPromise(Effect.gen(...))` body.
4
+
5
+ ## Goal
6
+
7
+ Route handlers should wrap their entire body in a single `AppRuntime.runPromise(Effect.gen(...))` call, yielding services from context rather than calling facades one-by-one.
8
+
9
+ This eliminates multiple `runPromise` round-trips and lets handlers compose naturally.
10
+
11
+ ```ts
12
+ // Before - one facade call per service
13
+ ;async (c) => {
14
+ await SessionRunState.assertNotBusy(id)
15
+ await Session.removeMessage({ sessionID: id, messageID })
16
+ return c.json(true)
17
+ }
18
+
19
+ // After - one Effect.gen, yield services from context
20
+ ;async (c) => {
21
+ await AppRuntime.runPromise(
22
+ Effect.gen(function* () {
23
+ const state = yield* SessionRunState.Service
24
+ const session = yield* Session.Service
25
+ yield* state.assertNotBusy(id)
26
+ yield* session.removeMessage({ sessionID: id, messageID })
27
+ }),
28
+ )
29
+ return c.json(true)
30
+ }
31
+ ```
32
+
33
+ ## Rules
34
+
35
+ - Wrap the whole handler body in one `AppRuntime.runPromise(Effect.gen(...))` call when the handler is service-heavy.
36
+ - Yield services from context instead of calling async facades repeatedly.
37
+ - When independent service calls can run in parallel, use `Effect.all(..., { concurrency: "unbounded" })`.
38
+ - Prefer one composed Effect body over multiple separate `runPromise(...)` calls in the same handler.
39
+
40
+ ## Current route files
41
+
42
+ Current instance route files live under `src/server/routes/instance`.
43
+
44
+ Files that are already mostly on the intended service-yielding shape:
45
+
46
+ - [x] `server/routes/instance/question.ts` — handlers yield `Question.Service`
47
+ - [x] `server/routes/instance/provider.ts` — handlers yield `Provider.Service`, `ProviderAuth.Service`, and `Config.Service`
48
+ - [x] `server/routes/instance/permission.ts` — handlers yield `Permission.Service`
49
+ - [x] `server/routes/instance/mcp.ts` — handlers mostly yield `MCP.Service`
50
+ - [x] `server/routes/instance/pty.ts` — handlers yield `Pty.Service`
51
+
52
+ Files still worth tracking here:
53
+
54
+ - [ ] `server/routes/instance/session.ts` — still the heaviest mixed file; many handlers are composed, but the file still mixes patterns and has direct `Bus.publish(...)` / `Session.list(...)` usage
55
+ - [ ] `server/routes/instance/index.ts` — mostly converted, but still has direct `Instance.dispose()` / `Instance.*` reads for `/instance/dispose` and `/path`
56
+ - [ ] `server/routes/instance/file.ts` — most handlers yield services, but `/find` still passes `Instance.directory` directly into ripgrep and `/find/symbol` is still stubbed
57
+ - [ ] `server/routes/instance/experimental.ts` — mixed state; many handlers are composed, but some still rely on `runRequest(...)` or direct `Instance.project` reads
58
+ - [ ] `server/routes/instance/middleware.ts` — still enters the instance via `Instance.provide(...)`
59
+ - [ ] `server/routes/global.ts` — still uses `Instance.disposeAll()` and remains partly outside the fully-composed style
60
+
61
+ ## Notes
62
+
63
+ - Route conversion is now less about facade removal and more about removing the remaining direct `Instance.*` reads, `Instance.provide(...)` boundaries, and small Promise-style bridges inside route files.
64
+ - `jsonRequest(...)` / `runRequest(...)` already provide a good intermediate shape for many handlers. The remaining cleanup is mostly consistency work in the heavier files.
@@ -0,0 +1,399 @@
1
+ # Schema migration
2
+
3
+ Practical reference for migrating data types in `packages/saeeol` from
4
+ Zod-first definitions to Effect Schema with Zod compatibility shims.
5
+
6
+ ## Goal
7
+
8
+ Use Effect Schema as the source of truth for domain models, IDs, inputs,
9
+ outputs, and typed errors. Keep Zod available at existing HTTP, tool, and
10
+ compatibility boundaries by exposing a `.zod` static derived from the Effect
11
+ schema via `@/util/effect-zod`.
12
+
13
+ The long-term driver is `specs/effect/http-api.md` — once the HTTP server
14
+ moves to `@effect/platform`, every Schema-first DTO can flow through
15
+ `HttpApi` / `HttpRouter` without a zod translation layer, and the entire
16
+ `effect-zod` walker plus every `.zod` static can be deleted.
17
+
18
+ ## Preferred shapes
19
+
20
+ ### Data objects
21
+
22
+ Use `Schema.Class` for structured data.
23
+
24
+ ```ts
25
+ export class Info extends Schema.Class<Info>("Foo.Info")({
26
+ id: FooID,
27
+ name: Schema.String,
28
+ enabled: Schema.Boolean,
29
+ }) {
30
+ static readonly zod = zod(Info)
31
+ }
32
+ ```
33
+
34
+ If the class cannot reference itself cleanly during initialization, use the
35
+ two-step `withStatics` pattern:
36
+
37
+ ```ts
38
+ export const Info = Schema.Struct({
39
+ id: FooID,
40
+ name: Schema.String,
41
+ }).pipe(withStatics((s) => ({ zod: zod(s) })))
42
+ ```
43
+
44
+ ### Errors
45
+
46
+ Use `Schema.TaggedErrorClass` for domain errors.
47
+
48
+ ```ts
49
+ export class NotFoundError extends Schema.TaggedErrorClass<NotFoundError>()("FooNotFoundError", {
50
+ id: FooID,
51
+ }) {}
52
+ ```
53
+
54
+ ### IDs and branded leaf types
55
+
56
+ Keep branded/schema-backed IDs as Effect schemas and expose
57
+ `static readonly zod` for compatibility when callers still expect Zod.
58
+
59
+ ### Refinements
60
+
61
+ Reuse named refinements instead of re-spelling `z.number().int().positive()`
62
+ in every schema. The `effect-zod` walker translates the Effect versions into
63
+ the corresponding zod methods, so JSON Schema output (`type: integer`,
64
+ `exclusiveMinimum`, `pattern`, `format: uuid`, …) is preserved.
65
+
66
+ ```ts
67
+ const PositiveInt = Schema.Number.check(Schema.isInt()).check(Schema.isGreaterThan(0))
68
+ const NonNegativeInt = Schema.Number.check(Schema.isInt()).check(Schema.isGreaterThanOrEqualTo(0))
69
+ const HexColor = Schema.String.check(Schema.isPattern(/^#[0-9a-fA-F]{6}$/))
70
+ ```
71
+
72
+ See `test/util/effect-zod.test.ts` for the full set of translated checks.
73
+
74
+ ## Compatibility rule
75
+
76
+ During migration, route validators, tool parameters, and any existing
77
+ Zod-based boundary should consume the derived `.zod` schema instead of
78
+ maintaining a second hand-written Zod schema.
79
+
80
+ The default should be:
81
+
82
+ - Effect Schema owns the type
83
+ - `.zod` exists only as a compatibility surface
84
+ - new domain models should not start Zod-first unless there is a concrete
85
+ boundary-specific need
86
+
87
+ ## When Zod can stay
88
+
89
+ It is fine to keep a Zod-native schema temporarily when:
90
+
91
+ - the type is only used at an HTTP or tool boundary and is not reused elsewhere
92
+ - the validator depends on Zod-only transforms or behavior not yet covered by `zod()`
93
+ - the migration would force unrelated churn across a large call graph
94
+
95
+ When this happens, prefer leaving a short note or TODO rather than silently
96
+ creating a parallel schema source of truth.
97
+
98
+ ## Escape hatches
99
+
100
+ The walker in `@/util/effect-zod` exposes two explicit escape hatches for
101
+ cases the pure-Schema path cannot express. Each one stays in the codebase
102
+ only as long as its upstream or local dependency requires it — inline
103
+ comments document when each can be deleted.
104
+
105
+ ### `ZodOverride` annotation
106
+
107
+ Replaces the entire derivation with a hand-crafted zod schema. Used when:
108
+
109
+ - the target carries external `$ref` metadata (e.g.
110
+ `config/model-id.ts` points at `https://models.dev/...`)
111
+ - the target is a zod-only schema that cannot yet be expressed as Schema
112
+ (e.g. `ConfigAgent.Info`, `Log.Level`)
113
+
114
+ ### Local `DeepMutable<T>` in `config/config.ts`
115
+
116
+ `Schema.Struct` produces `readonly` types. Some consumer code (notably the
117
+ `Config` service) mutates `Info` objects directly, so a readonly-stripping
118
+ utility is needed when casting the derived zod schema's output type.
119
+
120
+ `Types.DeepMutable` from effect-smol would be a drop-in, but it widens
121
+ `unknown` to `{}` in the fallback branch — a bug that affects any schema
122
+ using `Schema.Record(String, Schema.Unknown)`.
123
+
124
+ Tracked upstream as `effect:core/x228my`: "Types.DeepMutable widens unknown
125
+ to `{}`." Once that lands, the local `DeepMutable` copy can be deleted and
126
+ `Types.DeepMutable` used directly.
127
+
128
+ ## Ordering
129
+
130
+ Migrate in this order:
131
+
132
+ 1. Shared leaf models and `schema.ts` files
133
+ 2. Exported `Info`, `Input`, `Output`, and DTO types
134
+ 3. Tagged domain errors
135
+ 4. Service-local internal models
136
+ 5. Route and tool boundary validators that can switch to `.zod`
137
+
138
+ This keeps shared types canonical first and makes boundary updates mostly
139
+ mechanical.
140
+
141
+ ## Progress tracker
142
+
143
+ ### `src/config/` ✅ complete
144
+
145
+ All of `packages/saeeol/src/config/` has been migrated. Files that still
146
+ import `z` do so only for local `ZodOverride` bridges or for `z.ZodType`
147
+ type annotations — the `export const <Info|Spec>` values are all Effect
148
+ Schema at source.
149
+
150
+ A file is considered "done" when:
151
+
152
+ - its exported schema values (`Info`, `Input`, `Event`, `Definition`, etc.)
153
+ are authored as Effect Schema
154
+ - any remaining zod is either a derived compat bridge (via `zod()` /
155
+ `zodObject()`), a `z.ZodType` type annotation, or a documented
156
+ `ZodOverride` escape hatch — never a hand-written parallel source of truth
157
+
158
+ Files that meet this bar but still carry a compat bridge are checked off
159
+ with an inline note describing the bridge and what unblocks its removal.
160
+
161
+ - [x] skills, formatter, console-state, mcp, lsp, permission (leaves), model-id, command, plugin, provider
162
+ - [x] server, layout
163
+ - [x] keybinds
164
+ - [x] permission#Info
165
+ - [x] agent
166
+ - [x] config.ts root
167
+
168
+ ### `src/*/schema.ts` leaf modules
169
+
170
+ These are the highest-priority next targets. Each is a small, self-contained
171
+ schema module with a clear domain.
172
+
173
+ - [x] `src/account/schema.ts`
174
+ - [x] `src/control-plane/schema.ts`
175
+ - [x] `src/permission/schema.ts`
176
+ - [x] `src/project/schema.ts`
177
+ - [x] `src/provider/schema.ts`
178
+ - [x] `src/pty/schema.ts`
179
+ - [x] `src/question/schema.ts`
180
+ - [x] `src/session/schema.ts`
181
+ - [x] `src/storage/schema.ts`
182
+ - [x] `src/sync/schema.ts`
183
+ - [x] `src/tool/schema.ts`
184
+ - [x] `src/util/schema.ts`
185
+
186
+ ### Session domain
187
+
188
+ Major cluster. Message + event types flow through the SSE API and every SDK
189
+ output, so byte-identical SDK surface is critical.
190
+
191
+ Suggested order for this cluster, starting from the leaves that `session.ts`
192
+ and the SSE/event surface depend on:
193
+
194
+ 1. `src/session/schema.ts` ✅ already migrated
195
+ 2. `src/provider/schema.ts` if `message-v2.ts` still relies on zod-first IDs
196
+ 3. `src/lsp/*` schema leaves needed by `LSP.Range`
197
+ 4. `src/snapshot/*` leaves used by `Snapshot.FileDiff`
198
+ 5. `src/session/message-v2.ts`
199
+ 6. `src/session/message.ts`
200
+ 7. `src/session/prompt.ts`
201
+ 8. `src/session/revert.ts`
202
+ 9. `src/session/summary.ts`
203
+ 10. `src/session/status.ts`
204
+ 11. `src/session/todo.ts`
205
+ 12. `src/session/session.ts`
206
+ 13. `src/session/compaction.ts`
207
+
208
+ Dependency sketch:
209
+
210
+ ```text
211
+ session.ts
212
+ |- project/schema.ts
213
+ |- control-plane/schema.ts
214
+ |- permission/schema.ts
215
+ |- snapshot/*
216
+ |- message-v2.ts
217
+ | |- provider/schema.ts
218
+ | |- lsp/*
219
+ | |- snapshot/*
220
+ | |- sync/index.ts
221
+ | `- bus/bus-event.ts
222
+ |- sync/index.ts
223
+ |- bus/bus-event.ts
224
+ `- util/update-schema.ts
225
+ ```
226
+
227
+ Working rule for this cluster:
228
+
229
+ - migrate reusable leaf schemas and nested payload objects first
230
+ - migrate aggregate DTOs like `Session.Info` after their nested pieces exist as
231
+ named Schema values
232
+ - leave zod-only event/update helpers in place temporarily when converting
233
+ them would force unrelated churn across sync/bus boundaries
234
+
235
+ `message-v2.ts` first-pass outline:
236
+
237
+ 1. Schema-backed imports already available
238
+ - `SessionID`, `MessageID`, `PartID`
239
+ - `ProviderID`, `ModelID`
240
+ 2. Local leaf objects to extract and migrate first
241
+ - output format payloads
242
+ - common part bases like `PartBase`
243
+ - timestamp/range helper objects like `time.start/end`
244
+ - file/source helper objects
245
+ - token/cost/model helper objects
246
+ 3. Part variants built from those leaves
247
+ - `SnapshotPart`, `PatchPart`, `TextPart`, `ReasoningPart`
248
+ - `FilePart`, `AgentPart`, `CompactionPart`, `SubtaskPart`
249
+ - retry/step/tool related parts
250
+ 4. Higher-level unions and DTOs
251
+ - `FilePartSource`
252
+ - part unions
253
+ - message unions and assistant/user payloads
254
+ 5. Errors and event payloads last
255
+ - `NamedError.create(...)` shapes can stay temporarily if converting them to
256
+ `Schema.TaggedErrorClass` would force unrelated churn
257
+ - `SyncEvent.define(...)` and `BusEvent.define(...)` payloads can use
258
+ derived `.zod` at remaining zod-based HTTP/OpenAPI boundaries
259
+
260
+ Possible later tightening after the Schema-first migration is stable:
261
+
262
+ - promote repeated opaque strings and timestamp numbers into branded/newtype
263
+ leaf schemas where that adds domain value without changing the wire format
264
+
265
+ - [x] `src/session/compaction.ts`
266
+ - [x] `src/session/message-v2.ts`
267
+ - [x] `src/session/message.ts`
268
+ - [x] `src/session/prompt.ts`
269
+ - [x] `src/session/revert.ts`
270
+ - [x] `src/session/session.ts`
271
+ - [x] `src/session/status.ts`
272
+ - [x] `src/session/summary.ts`
273
+ - [x] `src/session/todo.ts`
274
+
275
+ ### Provider domain
276
+
277
+ - [x] `src/provider/auth.ts`
278
+ - [x] `src/provider/models.ts`
279
+ - [x] `src/provider/provider.ts`
280
+
281
+ ### Tool schemas
282
+
283
+ Each tool declares its parameters via a zod schema. Tools are consumed by
284
+ both the in-process runtime and the AI SDK's tool-calling layer, so the
285
+ emitted JSON Schema must stay byte-identical.
286
+
287
+ - [x] `src/tool/apply_patch.ts`
288
+ - [x] `src/tool/bash.ts`
289
+ - [x] `src/tool/edit.ts`
290
+ - [x] `src/tool/glob.ts`
291
+ - [x] `src/tool/grep.ts`
292
+ - [x] `src/tool/invalid.ts`
293
+ - [x] `src/tool/lsp.ts`
294
+ - [x] `src/tool/plan.ts`
295
+ - [x] `src/tool/question.ts`
296
+ - [x] `src/tool/read.ts`
297
+ - [x] `src/tool/registry.ts`
298
+ - [x] `src/tool/skill.ts`
299
+ - [x] `src/tool/task.ts`
300
+ - [x] `src/tool/todo.ts`
301
+ - [x] `src/tool/tool.ts`
302
+ - [x] `src/tool/webfetch.ts`
303
+ - [x] `src/tool/websearch.ts`
304
+ - [x] `src/tool/write.ts`
305
+
306
+ ### HTTP route boundaries
307
+
308
+ Every file in `src/server/routes/` uses hono-openapi with zod validators for
309
+ route inputs/outputs. Migrating these individually is the last step; most
310
+ will switch to `.zod` derived from the Schema-migrated domain types above,
311
+ which means touching them is largely mechanical once the domain side is
312
+ done.
313
+
314
+ - [ ] `src/server/error.ts`
315
+ - [x] `src/server/event.ts`
316
+ - [x] `src/server/projectors.ts`
317
+ - [ ] `src/server/routes/control/index.ts`
318
+ - [ ] `src/server/routes/control/workspace.ts`
319
+ - [ ] `src/server/routes/global.ts`
320
+ - [ ] `src/server/routes/instance/index.ts`
321
+ - [ ] `src/server/routes/instance/config.ts`
322
+ - [ ] `src/server/routes/instance/event.ts`
323
+ - [ ] `src/server/routes/instance/experimental.ts`
324
+ - [ ] `src/server/routes/instance/file.ts`
325
+ - [ ] `src/server/routes/instance/mcp.ts`
326
+ - [ ] `src/server/routes/instance/permission.ts`
327
+ - [ ] `src/server/routes/instance/project.ts`
328
+ - [ ] `src/server/routes/instance/provider.ts`
329
+ - [ ] `src/server/routes/instance/pty.ts`
330
+ - [ ] `src/server/routes/instance/question.ts`
331
+ - [ ] `src/server/routes/instance/session.ts`
332
+ - [ ] `src/server/routes/instance/sync.ts`
333
+ - [ ] `src/server/routes/instance/tui.ts`
334
+
335
+ The bigger prize for this group is the `@effect/platform` HTTP migration
336
+ described in `specs/effect/http-api.md`. Once that lands, every one of
337
+ these files changes shape entirely (`HttpApi.endpoint(...)` and friends),
338
+ so the Schema-first domain types become a prerequisite rather than a
339
+ sibling task.
340
+
341
+ ### Everything else
342
+
343
+ Small / shared / control-plane / CLI. Mostly independent; can be done
344
+ piecewise.
345
+
346
+ - [ ] `src/acp/agent.ts`
347
+ - [ ] `src/agent/agent.ts`
348
+ - [x] `src/bus/bus-event.ts`
349
+ - [ ] `src/bus/index.ts`
350
+ - [ ] `src/cli/cmd/tui/config/tui-migrate.ts`
351
+ - [ ] `src/cli/cmd/tui/config/tui-schema.ts`
352
+ - [ ] `src/cli/cmd/tui/config/tui.ts`
353
+ - [ ] `src/cli/cmd/tui/event.ts`
354
+ - [ ] `src/cli/ui.ts`
355
+ - [ ] `src/command/index.ts`
356
+ - [x] `src/control-plane/adapters/worktree.ts`
357
+ - [x] `src/control-plane/types.ts`
358
+ - [x] `src/control-plane/workspace.ts`
359
+ - [ ] `src/file/index.ts`
360
+ - [ ] `src/file/ripgrep.ts`
361
+ - [ ] `src/file/watcher.ts`
362
+ - [ ] `src/format/index.ts`
363
+ - [ ] `src/id/id.ts`
364
+ - [ ] `src/ide/index.ts`
365
+ - [ ] `src/installation/index.ts`
366
+ - [ ] `src/lsp/client.ts`
367
+ - [ ] `src/lsp/lsp.ts`
368
+ - [ ] `src/mcp/auth.ts`
369
+ - [ ] `src/patch/index.ts`
370
+ - [ ] `src/plugin/github-copilot/models.ts`
371
+ - [ ] `src/project/project.ts`
372
+ - [ ] `src/project/vcs.ts`
373
+ - [ ] `src/pty/index.ts`
374
+ - [ ] `src/skill/index.ts`
375
+ - [ ] `src/snapshot/index.ts`
376
+ - [ ] `src/storage/db.ts`
377
+ - [ ] `src/storage/storage.ts`
378
+ - [x] `src/sync/index.ts` — public API (`SyncEvent.define`) is Schema-first; `payloads()` still derives zod for the remaining HTTP/OpenAPI boundary
379
+ - [ ] `src/util/fn.ts`
380
+ - [ ] `src/util/log.ts`
381
+ - [ ] `src/util/update-schema.ts`
382
+ - [ ] `src/worktree/index.ts`
383
+
384
+ ### Do-not-migrate
385
+
386
+ - `src/util/effect-zod.ts` — the walker itself. Stays zod-importing forever
387
+ (it's what emits zod from Schema). Goes away only when the `.zod`
388
+ compatibility layer is no longer needed anywhere.
389
+
390
+ ## Notes
391
+
392
+ - Use `@/util/effect-zod` for all Schema → Zod conversion.
393
+ - Prefer one canonical schema definition. Avoid maintaining parallel Zod and
394
+ Effect definitions for the same domain type.
395
+ - Keep the migration incremental. Converting the domain model first is more
396
+ valuable than converting every boundary in the same change.
397
+ - Every migrated file should leave the generated SDK output (`packages/sdk/
398
+ openapi.json` and `packages/sdk/js/src/v2/gen/types.gen.ts`) byte-identical
399
+ unless the change is deliberately user-visible.