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.
- package/.turbo/turbo-typecheck.log +1 -0
- package/AGENTS.md +72 -0
- package/BUN_SHELL_MIGRATION_PLAN.md +136 -0
- package/Dockerfile +18 -0
- package/assets/saeeol.ico +0 -0
- package/bin/saeeol.cjs +0 -0
- package/database.db +0 -0
- package/drizzle.config.ts +10 -0
- package/git +0 -0
- package/migration/20260127222353_familiar_lady_ursula/migration.sql +90 -0
- package/migration/20260127222353_familiar_lady_ursula/snapshot.json +796 -0
- package/migration/20260211171708_add_project_commands/migration.sql +1 -0
- package/migration/20260211171708_add_project_commands/snapshot.json +806 -0
- package/migration/20260213144116_wakeful_the_professor/migration.sql +11 -0
- package/migration/20260213144116_wakeful_the_professor/snapshot.json +897 -0
- package/migration/20260225215848_workspace/migration.sql +7 -0
- package/migration/20260225215848_workspace/snapshot.json +959 -0
- package/migration/20260227213759_add_session_workspace_id/migration.sql +2 -0
- package/migration/20260227213759_add_session_workspace_id/snapshot.json +983 -0
- package/migration/20260228203230_blue_harpoon/migration.sql +17 -0
- package/migration/20260228203230_blue_harpoon/snapshot.json +1102 -0
- package/migration/20260303231226_add_workspace_fields/migration.sql +5 -0
- package/migration/20260303231226_add_workspace_fields/snapshot.json +1013 -0
- package/migration/20260309230000_move_org_to_state/migration.sql +3 -0
- package/migration/20260309230000_move_org_to_state/snapshot.json +1156 -0
- package/migration/20260312043431_session_message_cursor/migration.sql +4 -0
- package/migration/20260312043431_session_message_cursor/snapshot.json +1168 -0
- package/migration/20260323234822_events/migration.sql +13 -0
- package/migration/20260323234822_events/snapshot.json +1271 -0
- package/migration/20260410174513_workspace-name/migration.sql +16 -0
- package/migration/20260410174513_workspace-name/snapshot.json +1271 -0
- package/migration/20260413175956_chief_energizer/migration.sql +13 -0
- package/migration/20260413175956_chief_energizer/snapshot.json +1399 -0
- package/migration/20260423070820_add_icon_url_override/migration.sql +2 -0
- package/migration/20260423070820_add_icon_url_override/snapshot.json +1409 -0
- package/migration/20260428004200_add_session_path/migration.sql +1 -0
- package/migration/20260428004200_add_session_path/snapshot.json +1419 -0
- package/npm/bin/saeeol +42 -0
- package/npm/package.json +39 -0
- package/npm/postinstall.js +162 -0
- package/package.json +201 -207
- package/parsers-config.ts +289 -0
- package/script/build.ts +393 -0
- package/script/check-migrations.ts +16 -0
- package/script/fix-node-pty.ts +34 -0
- package/script/generate.ts +23 -0
- package/script/postinstall.mjs +189 -0
- package/script/publish.ts +200 -0
- package/script/run-workspace-server +106 -0
- package/script/schema.ts +63 -0
- package/script/test-runner.ts +420 -0
- package/script/time.ts +6 -0
- package/script/trace-imports.ts +153 -0
- package/script/upgrade-opentui.ts +64 -0
- package/scripts/diff-sdk-types.sh +52 -0
- package/specs/effect/facades.md +221 -0
- package/specs/effect/http-api.md +401 -0
- package/specs/effect/instance-context.md +309 -0
- package/specs/effect/loose-ends.md +34 -0
- package/specs/effect/migration.md +299 -0
- package/specs/effect/routes.md +64 -0
- package/specs/effect/schema.md +399 -0
- package/specs/effect/server-package.md +668 -0
- package/specs/effect/tools.md +90 -0
- package/specs/tui-plugins.md +433 -0
- package/specs/v2/api.ts +67 -0
- package/specs/v2/keymappings.md +10 -0
- package/specs/v2/message-shape.md +136 -0
- package/src/acp/agent-message.ts +1 -1
- package/src/acp/agent-utils.ts +1 -1
- package/src/boxes/ansi.ts +17 -0
- package/src/boxes/atomic-write.ts +35 -0
- package/src/boxes/b64.ts +58 -0
- package/src/boxes/bash-security.ts +129 -0
- package/src/boxes/bom.ts +18 -0
- package/src/boxes/cancel.ts +16 -0
- package/src/boxes/chop.ts +12 -0
- package/src/boxes/clamp.ts +3 -0
- package/src/boxes/compact.ts +9 -0
- package/src/boxes/cost-tracker.ts +116 -0
- package/src/boxes/dataurl.ts +29 -0
- package/src/boxes/delay.ts +27 -0
- package/src/boxes/diff-apply.ts +53 -0
- package/src/boxes/disposable.ts +13 -0
- package/src/boxes/err.ts +34 -0
- package/src/boxes/human.ts +47 -0
- package/src/boxes/iife.ts +9 -0
- package/src/boxes/latch.ts +8 -0
- package/src/boxes/memory.ts +198 -0
- package/src/boxes/net.ts +16 -0
- package/src/boxes/plural.ts +4 -0
- package/src/boxes/puny.ts +21 -0
- package/src/boxes/retry.ts +49 -0
- package/src/boxes/rwlock.ts +41 -0
- package/src/boxes/schedule.ts +71 -0
- package/src/boxes/scope.ts +21 -0
- package/src/boxes/tokens.ts +9 -0
- package/src/boxes/ttl-cache.ts +63 -0
- package/src/boxes/typed-event.ts +51 -0
- package/src/boxes/uid.ts +50 -0
- package/src/boxes/wave6.test.ts +296 -0
- package/src/boxes/wildcard.ts +58 -0
- package/src/bus/global.ts +1 -1
- package/src/cli/cmd/github-run-api.ts +2 -2
- package/src/cli/cmd/run-events.ts +2 -2
- package/src/cli/cmd/tui/component/logo.tsx +1 -1
- package/src/cli/cmd/tui/component/prompt/use-prompt-memos.ts +2 -2
- package/src/cli/cmd/tui/context/app/editor-zed.ts +1 -1
- package/src/cli/cmd/tui/context/app/editor.ts +1 -1
- package/src/cli/cmd/tui/context/app/theme.tsx +1 -1
- package/src/cli/cmd/tui/util/revert-diff.ts +1 -1
- package/src/overlay/cli/cmd/roll-call-call.ts +1 -1
- package/src/overlay/cost-tracker/format.ts +1 -1
- package/src/overlay/cost-tracker/index.ts +4 -4
- package/src/overlay/cost-tracker/state.ts +2 -2
- package/src/overlay/cost-tracker/types.ts +2 -2
- package/src/overlay/memory/age.ts +1 -1
- package/src/overlay/memory/index.ts +4 -4
- package/src/overlay/memory/paths.ts +2 -2
- package/src/overlay/memory/scan.ts +1 -1
- package/src/overlay/memory/types.ts +2 -2
- package/src/overlay/tool/bash-security.ts +3 -3
- package/src/overlay/util/url.ts +1 -1
- package/src/plugin/codex-auth.ts +1 -1
- package/src/provider/model-cache.ts +2 -2
- package/src/provider/provider-resolve.ts +3 -3
- package/src/provider/transform-message.ts +1 -1
- package/src/server/routes/game.ts +284 -0
- package/src/server/server.ts +2 -0
- package/src/session/core/compaction/compaction-helpers.ts +1 -1
- package/src/session/core/compaction/compaction.ts +1 -1
- package/src/session/core/session.ts +2 -0
- package/src/sessions/ingest-queue.ts +2 -2
- package/src/sessions/remote-ws.ts +1 -1
- package/src/tool/workflow/question.ts +1 -1
- package/src/util/abort.ts +1 -1
- package/src/util/bom.ts +2 -2
- package/src/util/color.ts +1 -1
- package/src/util/data-url.ts +1 -1
- package/src/util/defer.ts +1 -1
- package/src/util/error.ts +2 -2
- package/src/util/filesystem.ts +2 -2
- package/src/util/format.ts +1 -1
- package/src/util/iife.ts +1 -1
- package/src/util/local-context.ts +1 -1
- package/src/util/locale.ts +2 -2
- package/src/util/lock.ts +1 -1
- package/src/util/network.ts +1 -1
- package/src/util/signal.ts +1 -1
- package/src/util/token.ts +1 -1
- package/src/util/wildcard.ts +1 -1
- package/sst-env.d.ts +10 -0
- package/test/AGENTS.md +133 -0
- package/test/account/repo.test.ts +352 -0
- package/test/account/service.test.ts +456 -0
- package/test/acp/agent-interface.test.ts +51 -0
- package/test/acp/event-subscription.test.ts +725 -0
- package/test/agent/agent.test.ts +890 -0
- package/test/auth/auth.test.ts +86 -0
- package/test/bun/registry.test.ts +75 -0
- package/test/bus/bus-effect.test.ts +161 -0
- package/test/bus/bus-integration.test.ts +87 -0
- package/test/bus/bus.test.ts +219 -0
- package/test/cli/account.test.ts +26 -0
- package/test/cli/auto-mode.test.ts +75 -0
- package/test/cli/bin-saeeol.test.ts +8 -0
- package/test/cli/cmd/tui/prompt-part.test.ts +47 -0
- package/test/cli/cmd/tui/prompt-traits.test.ts +38 -0
- package/test/cli/cmd/tui/sync.test.tsx +159 -0
- package/test/cli/error.test.ts +18 -0
- package/test/cli/github-action.test.ts +198 -0
- package/test/cli/github-remote.test.ts +85 -0
- package/test/cli/import.test.ts +97 -0
- package/test/cli/install-artifact.test.ts +72 -0
- package/test/cli/plugin-auth-picker.test.ts +120 -0
- package/test/cli/pr.test.ts +59 -0
- package/test/cli/tui/editor-context-zed.test.ts +356 -0
- package/test/cli/tui/editor-context.test.tsx +228 -0
- package/test/cli/tui/keybind-plugin.test.ts +90 -0
- package/test/cli/tui/markdown.test.ts +161 -0
- package/test/cli/tui/plugin-add.test.ts +111 -0
- package/test/cli/tui/plugin-install.test.ts +87 -0
- package/test/cli/tui/plugin-lifecycle.test.ts +224 -0
- package/test/cli/tui/plugin-loader-entrypoint.test.ts +484 -0
- package/test/cli/tui/plugin-loader-pure.test.ts +71 -0
- package/test/cli/tui/plugin-loader.test.ts +816 -0
- package/test/cli/tui/plugin-toggle.test.ts +157 -0
- package/test/cli/tui/revert-diff.test.ts +35 -0
- package/test/cli/tui/slot-replace.test.tsx +47 -0
- package/test/cli/tui/theme-store.test.ts +54 -0
- package/test/cli/tui/thread.test.ts +28 -0
- package/test/cli/tui/transcript.test.ts +426 -0
- package/test/cli/tui/usage.test.ts +60 -0
- package/test/cli/tui/use-event.test.tsx +175 -0
- package/test/config/agent-color.test.ts +67 -0
- package/test/config/config.test.ts +2544 -0
- package/test/config/fixtures/empty-frontmatter.md +4 -0
- package/test/config/fixtures/frontmatter.md +28 -0
- package/test/config/fixtures/markdown-header.md +11 -0
- package/test/config/fixtures/no-frontmatter.md +1 -0
- package/test/config/fixtures/weird-model-id.md +13 -0
- package/test/config/lsp.test.ts +87 -0
- package/test/config/markdown.test.ts +228 -0
- package/test/config/plugin.test.ts +0 -0
- package/test/config/tui.test.ts +624 -0
- package/test/control-plane/adapters.test.ts +71 -0
- package/test/control-plane/workspace.test.ts +1526 -0
- package/test/effect/app-runtime-logger.test.ts +98 -0
- package/test/effect/config-service.test.ts +65 -0
- package/test/effect/instance-state.test.ts +394 -0
- package/test/effect/run-service.test.ts +89 -0
- package/test/effect/runner.test.ts +523 -0
- package/test/fake/provider.ts +82 -0
- package/test/file/fsmonitor.test.ts +68 -0
- package/test/file/ignore.test.ts +10 -0
- package/test/file/index.test.ts +954 -0
- package/test/file/path-traversal.test.ts +205 -0
- package/test/file/ripgrep.test.ts +226 -0
- package/test/file/watcher.test.ts +249 -0
- package/test/filesystem/filesystem.test.ts +319 -0
- package/test/fixture/db.ts +11 -0
- package/test/fixture/fixture.test.ts +26 -0
- package/test/fixture/fixture.ts +175 -0
- package/test/fixture/flock-worker.ts +72 -0
- package/test/fixture/log-init-worker.ts +62 -0
- package/test/fixture/lsp/fake-lsp-server.js +249 -0
- package/test/fixture/plug-worker.ts +93 -0
- package/test/fixture/plugin-meta-worker.ts +19 -0
- package/test/fixture/skills/agents-sdk/SKILL.md +152 -0
- package/test/fixture/skills/cloudflare/SKILL.md +211 -0
- package/test/fixture/skills/index.json +6 -0
- package/test/fixture/tui-plugin.ts +323 -0
- package/test/fixture/tui-runtime.ts +31 -0
- package/test/format/format.test.ts +272 -0
- package/test/git/git.test.ts +128 -0
- package/test/ide/ide.test.ts +82 -0
- package/test/installation/installation.test.ts +168 -0
- package/test/keybind.test.ts +421 -0
- package/test/lib/effect.ts +53 -0
- package/test/lib/filesystem.ts +10 -0
- package/test/lib/llm-server.ts +778 -0
- package/test/lib/websocket.ts +46 -0
- package/test/lsp/client.test.ts +482 -0
- package/test/lsp/index.test.ts +160 -0
- package/test/lsp/launch.test.ts +22 -0
- package/test/lsp/lifecycle.test.ts +184 -0
- package/test/ltm/ltm.test.ts +230 -0
- package/test/mcp/headers.test.ts +178 -0
- package/test/mcp/lifecycle.test.ts +787 -0
- package/test/mcp/oauth-auto-connect.test.ts +311 -0
- package/test/mcp/oauth-browser.test.ts +276 -0
- package/test/mcp/oauth-callback.test.ts +34 -0
- package/test/memory/abort-leak-webfetch.ts +49 -0
- package/test/memory/abort-leak.test.ts +128 -0
- package/test/patch/patch.test.ts +348 -0
- package/test/permission/arity.test.ts +33 -0
- package/test/permission/next.test.ts +1227 -0
- package/test/permission/next.toConfig.test.ts +110 -0
- package/test/permission-task.test.ts +326 -0
- package/test/plugin/auth-override.test.ts +79 -0
- package/test/plugin/cloudflare.test.ts +68 -0
- package/test/plugin/codex.test.ts +123 -0
- package/test/plugin/github-copilot-models.test.ts +261 -0
- package/test/plugin/install-concurrency.test.ts +140 -0
- package/test/plugin/install.test.ts +570 -0
- package/test/plugin/loader-shared.test.ts +1169 -0
- package/test/plugin/meta.test.ts +137 -0
- package/test/plugin/plugin-contract.test.ts +291 -0
- package/test/plugin/shared.test.ts +88 -0
- package/test/plugin/trigger.test.ts +102 -0
- package/test/plugin/workspace-adapter.test.ts +109 -0
- package/test/preload.ts +77 -0
- package/test/project/instance.test.ts +276 -0
- package/test/project/migrate-global.test.ts +152 -0
- package/test/project/project.test.ts +600 -0
- package/test/project/vcs.test.ts +286 -0
- package/test/project/worktree-remove.test.ts +126 -0
- package/test/project/worktree.test.ts +223 -0
- package/test/provider/amazon-bedrock.test.ts +462 -0
- package/test/provider/copilot/convert-to-copilot-messages.test.ts +523 -0
- package/test/provider/copilot/copilot-chat-model.test.ts +592 -0
- package/test/provider/gitlab-duo.test.ts +413 -0
- package/test/provider/local.test.ts +208 -0
- package/test/provider/models.test.ts +261 -0
- package/test/provider/provider-category.test.ts +190 -0
- package/test/provider/provider.test.ts +2758 -0
- package/test/provider/transform.test.ts +3681 -0
- package/test/pty/pty-output-isolation.test.ts +147 -0
- package/test/pty/pty-session.test.ts +102 -0
- package/test/pty/pty-shell.test.ts +104 -0
- package/test/question/question.test.ts +490 -0
- package/test/saeeol/agent-global-config-dirs.test.ts +24 -0
- package/test/saeeol/agent-manager-tool.test.ts +71 -0
- package/test/saeeol/agent-permission-overrides.test.ts +75 -0
- package/test/saeeol/agent-skill-permissions.test.ts +37 -0
- package/test/saeeol/ask-agent-permissions.test.ts +303 -0
- package/test/saeeol/bash-hierarchy.test.ts +64 -0
- package/test/saeeol/bash-permission-metadata.test.ts +66 -0
- package/test/saeeol/bash-security-extended.test.ts +243 -0
- package/test/saeeol/bedrock-claude-empty-content.test.ts +138 -0
- package/test/saeeol/boxes-integration.test.ts +415 -0
- package/test/saeeol/builtin-skills.test.ts +75 -0
- package/test/saeeol/cleanup.ts +28 -0
- package/test/saeeol/cli/dev-setup.test.ts +74 -0
- package/test/saeeol/cli/roll-call.test.ts +161 -0
- package/test/saeeol/cli-run-auto-helper.test.ts +58 -0
- package/test/saeeol/codex-auth-refresh.test.ts +124 -0
- package/test/saeeol/commit-message/generate.test.ts +188 -0
- package/test/saeeol/commit-message/git-context.test.ts +303 -0
- package/test/saeeol/commit-message-windows.test.ts +38 -0
- package/test/saeeol/compaction-payload-recovery.test.ts +406 -0
- package/test/saeeol/compaction-preservation-audit.test.ts +122 -0
- package/test/saeeol/compaction-skip-guard.test.ts +224 -0
- package/test/saeeol/compaction-smart-select.test.ts +100 -0
- package/test/saeeol/config/config.test.ts +166 -0
- package/test/saeeol/config/indexing-default-plugin.test.ts +82 -0
- package/test/saeeol/config/opentelemetry-default.test.ts +29 -0
- package/test/saeeol/config-gitignore.test.ts +70 -0
- package/test/saeeol/config-injector.test.ts +305 -0
- package/test/saeeol/config-resilience.test.ts +234 -0
- package/test/saeeol/config-validation.test.ts +183 -0
- package/test/saeeol/cost-propagation.test.ts +94 -0
- package/test/saeeol/cost-tracker-extended.test.ts +141 -0
- package/test/saeeol/cost-tracker.test.ts +64 -0
- package/test/saeeol/custom-provider-delete.test.ts +149 -0
- package/test/saeeol/diff-full.test.ts +226 -0
- package/test/saeeol/edit-permission-filediff.test.ts +223 -0
- package/test/saeeol/encoding.test.ts +364 -0
- package/test/saeeol/enhance-prompt.test.ts +61 -0
- package/test/saeeol/ensure-plan-dir.test.ts +32 -0
- package/test/saeeol/errors.test.ts +144 -0
- package/test/saeeol/external-directory-boundary.test.ts +96 -0
- package/test/saeeol/gateway-headers.test.ts +88 -0
- package/test/saeeol/help.test.ts +191 -0
- package/test/saeeol/ignore-migrator.test.ts +308 -0
- package/test/saeeol/indexing-auth.test.ts +45 -0
- package/test/saeeol/indexing-feature.test.ts +44 -0
- package/test/saeeol/indexing-label.test.ts +70 -0
- package/test/saeeol/indexing-startup.test.ts +381 -0
- package/test/saeeol/indexing-worktree.test.ts +73 -0
- package/test/saeeol/instruction.test.ts +136 -0
- package/test/saeeol/lancedb-runtime.test.ts +116 -0
- package/test/saeeol/loader-auth.test.ts +168 -0
- package/test/saeeol/local-model.test.ts +621 -0
- package/test/saeeol/logo.test.ts +31 -0
- package/test/saeeol/lsp-typescript-lightweight.test.ts +89 -0
- package/test/saeeol/mcp-branding.test.ts +33 -0
- package/test/saeeol/mcp-docker-rm.test.ts +32 -0
- package/test/saeeol/mcp-migrator.test.ts +736 -0
- package/test/saeeol/mcp-oauth-callback.test.ts +33 -0
- package/test/saeeol/memory-io.test.ts +198 -0
- package/test/saeeol/memory-paths.test.ts +87 -0
- package/test/saeeol/memory-security.test.ts +166 -0
- package/test/saeeol/model-cache-org.test.ts +164 -0
- package/test/saeeol/model-info-panel-utils.test.ts +52 -0
- package/test/saeeol/model-info-panel.types.test.ts +7 -0
- package/test/saeeol/models-401-fallback.test.ts +52 -0
- package/test/saeeol/modes-migrator.test.ts +320 -0
- package/test/saeeol/nvidia-headers.test.ts +74 -0
- package/test/saeeol/patch-jsonc.test.ts +73 -0
- package/test/saeeol/patch.test.ts +172 -0
- package/test/saeeol/paths.test.ts +265 -0
- package/test/saeeol/permission/config-paths.test.ts +174 -0
- package/test/saeeol/permission/env-read.test.ts +149 -0
- package/test/saeeol/permission/external-directory-allow.test.ts +327 -0
- package/test/saeeol/permission/next.always-rules.test.ts +882 -0
- package/test/saeeol/permission/next.reply-http.test.ts +205 -0
- package/test/saeeol/permission/next.reply-routing.test.ts +184 -0
- package/test/saeeol/plan-exit-detection.test.ts +494 -0
- package/test/saeeol/plan-followup.test.ts +1376 -0
- package/test/saeeol/project-config-update.test.ts +120 -0
- package/test/saeeol/project-id.test.ts +455 -0
- package/test/saeeol/provider-cost.test.ts +171 -0
- package/test/saeeol/provider-list-failed-state.test.ts +100 -0
- package/test/saeeol/question-dismiss-all.test.ts +174 -0
- package/test/saeeol/read-directory.test.ts +116 -0
- package/test/saeeol/rules-migrator.test.ts +257 -0
- package/test/saeeol/run-auto.test.ts +176 -0
- package/test/saeeol/run-network.test.ts +224 -0
- package/test/saeeol/semantic-search.test.ts +186 -0
- package/test/saeeol/server/permission-allow-everything.test.ts +125 -0
- package/test/saeeol/session/instruction-substitution.test.ts +72 -0
- package/test/saeeol/session/platform-attribution.test.ts +118 -0
- package/test/saeeol/session/session.test.ts +105 -0
- package/test/saeeol/session-compaction-cap.test.ts +399 -0
- package/test/saeeol/session-compaction-chunks.test.ts +501 -0
- package/test/saeeol/session-compaction-safety.test.ts +481 -0
- package/test/saeeol/session-fork-remap.test.ts +251 -0
- package/test/saeeol/session-import-service.test.ts +114 -0
- package/test/saeeol/session-list.test.ts +47 -0
- package/test/saeeol/session-message-metadata.test.ts +128 -0
- package/test/saeeol/session-overflow.test.ts +78 -0
- package/test/saeeol/session-processor-empty-tool-calls.test.ts +571 -0
- package/test/saeeol/session-processor-network-offline.test.ts +204 -0
- package/test/saeeol/session-processor-retry-limit.test.ts +238 -0
- package/test/saeeol/session-processor-review-telemetry.test.ts +82 -0
- package/test/saeeol/session-prompt-compaction-safety.test.ts +517 -0
- package/test/saeeol/session-prompt-queue.test.ts +815 -0
- package/test/saeeol/sessions/inflight-cache.test.ts +157 -0
- package/test/saeeol/sessions/ingest-queue.test.ts +402 -0
- package/test/saeeol/sessions/remote-protocol.test.ts +258 -0
- package/test/saeeol/sessions/remote-sender.test.ts +1036 -0
- package/test/saeeol/sessions/remote-ws.test.ts +367 -0
- package/test/saeeol/sessions/sessions-enable-remote.test.disable +181 -0
- package/test/saeeol/slot-prop-reactivity.test.ts +142 -0
- package/test/saeeol/snapshot-cache.test.ts +84 -0
- package/test/saeeol/snapshot-freeze-repro.test.ts +100 -0
- package/test/saeeol/snapshot-track-timeout.test.ts +519 -0
- package/test/saeeol/stats-subagent-cost.test.ts +123 -0
- package/test/saeeol/suggestion/auto-dismiss.test.ts +65 -0
- package/test/saeeol/suggestion/suggestion.test.ts +145 -0
- package/test/saeeol/suggestion/tool.test.ts +298 -0
- package/test/saeeol/summary-file-diff.test.ts +28 -0
- package/test/saeeol/system-prompt.test.ts +142 -0
- package/test/saeeol/task-nesting.test.ts +193 -0
- package/test/saeeol/telemetry/feedback.test.ts +8 -0
- package/test/saeeol/todo-view.test.ts +57 -0
- package/test/saeeol/tool-encoding.test.ts +455 -0
- package/test/saeeol/tool-registry-indexing-import-failure.test.ts +49 -0
- package/test/saeeol/tool-registry-indexing.test.ts +236 -0
- package/test/saeeol/tool-registry-semantic-import-failure.test.ts +55 -0
- package/test/saeeol/tool-task-model.test.ts +352 -0
- package/test/saeeol/transform-opus-4.7.test.ts +89 -0
- package/test/saeeol/tui-diff.test.ts +91 -0
- package/test/saeeol/tui-sync.test.ts +80 -0
- package/test/saeeol/util/url.test.ts +141 -0
- package/test/saeeol/workflows-migrator.test.ts +261 -0
- package/test/saeeol/worktree-diff-summary.test.ts +64 -0
- package/test/saeeol/worktree-diff.test.ts +223 -0
- package/test/saeeol/worktree-remove-lock.test.ts +82 -0
- package/test/server/AGENTS.md +15 -0
- package/test/server/contract.test.ts +357 -0
- package/test/server/experimental-session-list.test.ts +157 -0
- package/test/server/global-session-list.test.ts +155 -0
- package/test/server/httpapi-authorization.test.ts +103 -0
- package/test/server/httpapi-bridge.test.ts +440 -0
- package/test/server/httpapi-config.test.ts +67 -0
- package/test/server/httpapi-cors.test.ts +89 -0
- package/test/server/httpapi-event.test.ts +57 -0
- package/test/server/httpapi-experimental.test.ts +219 -0
- package/test/server/httpapi-file.test.ts +79 -0
- package/test/server/httpapi-instance-context.test.ts +237 -0
- package/test/server/httpapi-instance.legacy.test.ts +140 -0
- package/test/server/httpapi-instance.test.ts +83 -0
- package/test/server/httpapi-json-parity.test.ts +263 -0
- package/test/server/httpapi-mcp-oauth.test.ts +76 -0
- package/test/server/httpapi-mcp.test.ts +189 -0
- package/test/server/httpapi-provider.test.ts +153 -0
- package/test/server/httpapi-pty-websocket.test.ts +16 -0
- package/test/server/httpapi-pty.test.ts +175 -0
- package/test/server/httpapi-raw-route-auth.test.ts +89 -0
- package/test/server/httpapi-sdk.test.ts +681 -0
- package/test/server/httpapi-session.test.ts +464 -0
- package/test/server/httpapi-sync.test.ts +130 -0
- package/test/server/httpapi-tui.test.ts +121 -0
- package/test/server/httpapi-workspace-routing.test.ts +471 -0
- package/test/server/httpapi-workspace.test.ts +427 -0
- package/test/server/lib/conformance.ts +88 -0
- package/test/server/lib/stateful.ts +112 -0
- package/test/server/project-init-git.test.ts +113 -0
- package/test/server/proxy-util.test.ts +113 -0
- package/test/server/session-actions.test.ts +49 -0
- package/test/server/session-list.test.ts +238 -0
- package/test/server/session-messages.test.ts +167 -0
- package/test/server/session-select.test.ts +100 -0
- package/test/server/trace-attributes.test.ts +76 -0
- package/test/server/workspace-proxy.test.ts +165 -0
- package/test/server/workspace-routing.test.ts +85 -0
- package/test/session/compaction.test.ts +2420 -0
- package/test/session/instruction.test.ts +247 -0
- package/test/session/llm.test.ts +1273 -0
- package/test/session/message-v2.test.ts +1291 -0
- package/test/session/messages-pagination.test.ts +1173 -0
- package/test/session/network.test.ts +249 -0
- package/test/session/processor-effect.test.ts +847 -0
- package/test/session/prompt.test.ts +2131 -0
- package/test/session/retry.test.ts +340 -0
- package/test/session/revert-compact.test.ts +639 -0
- package/test/session/schema-decoding.test.ts +311 -0
- package/test/session/session-entry-stepper.test.ts +917 -0
- package/test/session/session-schema.test.ts +76 -0
- package/test/session/snapshot-tool-race.test.ts +257 -0
- package/test/session/structured-output-integration.test.ts +265 -0
- package/test/session/structured-output.test.ts +381 -0
- package/test/session/system.test.ts +73 -0
- package/test/share/share-next.test.ts +333 -0
- package/test/shell/shell.test.ts +99 -0
- package/test/skill/discovery.test.ts +116 -0
- package/test/skill/skill.test.ts +393 -0
- package/test/snapshot/snapshot.test.ts +1531 -0
- package/test/storage/db.test.ts +23 -0
- package/test/storage/json-migration.test.ts +832 -0
- package/test/storage/storage.test.ts +293 -0
- package/test/suggestion/suggestion.test.ts +1 -0
- package/test/sync/index.test.ts +256 -0
- package/test/tool/__snapshots__/parameters.test.ts.snap +500 -0
- package/test/tool/__snapshots__/tool.test.ts.snap +9 -0
- package/test/tool/apply_patch.test.ts +614 -0
- package/test/tool/bash.test.ts +1225 -0
- package/test/tool/diagnostics-filter.test.ts +55 -0
- package/test/tool/edit.test.ts +754 -0
- package/test/tool/external-directory.test.ts +169 -0
- package/test/tool/fixtures/large-image.png +0 -0
- package/test/tool/fixtures/models-api.json +65179 -0
- package/test/tool/glob.test.ts +107 -0
- package/test/tool/grep.test.ts +114 -0
- package/test/tool/lsp.test.ts +187 -0
- package/test/tool/parameters.test.ts +243 -0
- package/test/tool/question.test.ts +129 -0
- package/test/tool/read.test.ts +500 -0
- package/test/tool/recall.test.ts +151 -0
- package/test/tool/registry.test.ts +203 -0
- package/test/tool/skill.test.ts +135 -0
- package/test/tool/suggest.test.ts +1 -0
- package/test/tool/task.test.ts +612 -0
- package/test/tool/tool-define.test.ts +99 -0
- package/test/tool/truncation.test.ts +260 -0
- package/test/tool/webfetch.test.ts +103 -0
- package/test/tool/write.test.ts +291 -0
- package/test/util/data-url.test.ts +14 -0
- package/test/util/effect-zod.test.ts +754 -0
- package/test/util/error.test.ts +38 -0
- package/test/util/filesystem.test.ts +656 -0
- package/test/util/format.test.ts +59 -0
- package/test/util/glob.test.ts +164 -0
- package/test/util/iife.test.ts +36 -0
- package/test/util/lazy.test.ts +50 -0
- package/test/util/lock.test.ts +72 -0
- package/test/util/log.test.ts +86 -0
- package/test/util/module.test.ts +59 -0
- package/test/util/process.test.ts +128 -0
- package/test/util/timeout.test.ts +21 -0
- package/test/util/which.test.ts +100 -0
- package/test/util/wildcard.test.ts +90 -0
- package/test/workspace/workspace-restore.test.ts +296 -0
- package/src/provider/models-snapshot.d.ts +0 -2
- 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.
|