onlycode 1.18.0 → 1.19.0
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/package.json +11 -146
- package/src/account/account.ts +0 -463
- package/src/account/repo.ts +0 -173
- package/src/account/schema.ts +0 -99
- package/src/account/url.ts +0 -8
- package/src/acp/agent.ts +0 -95
- package/src/acp/config-option.ts +0 -203
- package/src/acp/content.ts +0 -250
- package/src/acp/directory.ts +0 -210
- package/src/acp/error.ts +0 -90
- package/src/acp/event.ts +0 -342
- package/src/acp/permission.ts +0 -124
- package/src/acp/profile.ts +0 -42
- package/src/acp/service.ts +0 -1048
- package/src/acp/session.ts +0 -231
- package/src/acp/tool.ts +0 -367
- package/src/acp/usage.ts +0 -232
- package/src/agent/agent.ts +0 -459
- package/src/agent/generate.txt +0 -75
- package/src/agent/prompt/compaction.txt +0 -9
- package/src/agent/prompt/explore.txt +0 -18
- package/src/agent/prompt/summary.txt +0 -11
- package/src/agent/prompt/title.txt +0 -44
- package/src/agent/subagent-permissions.ts +0 -27
- package/src/audio.d.ts +0 -14
- package/src/auth/index.ts +0 -99
- package/src/background/job.ts +0 -39
- package/src/bus/global.ts +0 -22
- package/src/cli/bootstrap.ts +0 -11
- package/src/cli/cmd/account.ts +0 -264
- package/src/cli/cmd/acp.ts +0 -73
- package/src/cli/cmd/agent.ts +0 -259
- package/src/cli/cmd/attach.ts +0 -97
- package/src/cli/cmd/cmd.ts +0 -7
- package/src/cli/cmd/db.ts +0 -62
- package/src/cli/cmd/debug/agent.handler.ts +0 -193
- package/src/cli/cmd/debug/agent.ts +0 -27
- package/src/cli/cmd/debug/config.ts +0 -14
- package/src/cli/cmd/debug/file.ts +0 -73
- package/src/cli/cmd/debug/index.ts +0 -87
- package/src/cli/cmd/debug/lsp.ts +0 -50
- package/src/cli/cmd/debug/ripgrep.ts +0 -79
- package/src/cli/cmd/debug/scrap.ts +0 -15
- package/src/cli/cmd/debug/skill.ts +0 -15
- package/src/cli/cmd/debug/snapshot.ts +0 -50
- package/src/cli/cmd/debug/startup.ts +0 -11
- package/src/cli/cmd/debug/v2.ts +0 -44
- package/src/cli/cmd/export.ts +0 -292
- package/src/cli/cmd/generate.ts +0 -54
- package/src/cli/cmd/github.handler.ts +0 -1593
- package/src/cli/cmd/github.shared.ts +0 -30
- package/src/cli/cmd/github.ts +0 -42
- package/src/cli/cmd/import.ts +0 -224
- package/src/cli/cmd/mcp.ts +0 -849
- package/src/cli/cmd/models.ts +0 -66
- package/src/cli/cmd/plug.ts +0 -230
- package/src/cli/cmd/pr.ts +0 -115
- package/src/cli/cmd/prompt-display.ts +0 -1
- package/src/cli/cmd/providers.ts +0 -534
- package/src/cli/cmd/run/demo.ts +0 -1274
- package/src/cli/cmd/run/entry.body.ts +0 -205
- package/src/cli/cmd/run/footer.command.tsx +0 -1064
- package/src/cli/cmd/run/footer.menu.tsx +0 -351
- package/src/cli/cmd/run/footer.permission.tsx +0 -472
- package/src/cli/cmd/run/footer.prompt.tsx +0 -1306
- package/src/cli/cmd/run/footer.question.tsx +0 -573
- package/src/cli/cmd/run/footer.subagent.tsx +0 -173
- package/src/cli/cmd/run/footer.ts +0 -1129
- package/src/cli/cmd/run/footer.view.tsx +0 -943
- package/src/cli/cmd/run/footer.width.ts +0 -27
- package/src/cli/cmd/run/permission.shared.ts +0 -256
- package/src/cli/cmd/run/prompt.editor.ts +0 -157
- package/src/cli/cmd/run/prompt.shared.ts +0 -153
- package/src/cli/cmd/run/question.shared.ts +0 -340
- package/src/cli/cmd/run/runtime.boot.ts +0 -202
- package/src/cli/cmd/run/runtime.lifecycle.ts +0 -406
- package/src/cli/cmd/run/runtime.queue.ts +0 -349
- package/src/cli/cmd/run/runtime.shared.ts +0 -17
- package/src/cli/cmd/run/runtime.stdin.ts +0 -37
- package/src/cli/cmd/run/runtime.ts +0 -814
- package/src/cli/cmd/run/scrollback.shared.ts +0 -92
- package/src/cli/cmd/run/scrollback.surface.ts +0 -431
- package/src/cli/cmd/run/scrollback.writer.tsx +0 -352
- package/src/cli/cmd/run/session-data.ts +0 -1113
- package/src/cli/cmd/run/session-replay.ts +0 -374
- package/src/cli/cmd/run/session.shared.ts +0 -196
- package/src/cli/cmd/run/splash.ts +0 -275
- package/src/cli/cmd/run/stream.transport.ts +0 -1462
- package/src/cli/cmd/run/stream.ts +0 -175
- package/src/cli/cmd/run/subagent-data.ts +0 -876
- package/src/cli/cmd/run/theme.ts +0 -690
- package/src/cli/cmd/run/tool.ts +0 -1489
- package/src/cli/cmd/run/trace.ts +0 -94
- package/src/cli/cmd/run/turn-summary.ts +0 -47
- package/src/cli/cmd/run/types.ts +0 -350
- package/src/cli/cmd/run/variant.shared.ts +0 -215
- package/src/cli/cmd/run.ts +0 -894
- package/src/cli/cmd/serve.ts +0 -24
- package/src/cli/cmd/session.ts +0 -147
- package/src/cli/cmd/stats.ts +0 -393
- package/src/cli/cmd/tui.ts +0 -224
- package/src/cli/cmd/uninstall.ts +0 -353
- package/src/cli/cmd/upgrade.ts +0 -74
- package/src/cli/cmd/web.ts +0 -84
- package/src/cli/effect/prompt.ts +0 -37
- package/src/cli/effect-cmd.ts +0 -96
- package/src/cli/error.ts +0 -130
- package/src/cli/heap.ts +0 -45
- package/src/cli/logo-pixel.ts +0 -35
- package/src/cli/logo.ts +0 -1
- package/src/cli/network.ts +0 -64
- package/src/cli/tui/layer.ts +0 -7
- package/src/cli/tui/validate-session.ts +0 -29
- package/src/cli/tui/worker.ts +0 -71
- package/src/cli/ui.ts +0 -148
- package/src/cli/upgrade.ts +0 -53
- package/src/command/index.ts +0 -184
- package/src/command/template/initialize.txt +0 -66
- package/src/command/template/review.txt +0 -101
- package/src/config/agent.ts +0 -59
- package/src/config/command.ts +0 -39
- package/src/config/config.ts +0 -686
- package/src/config/entry-name.ts +0 -19
- package/src/config/managed.ts +0 -69
- package/src/config/markdown.ts +0 -36
- package/src/config/parse.ts +0 -79
- package/src/config/paths.ts +0 -45
- package/src/config/plugin.ts +0 -79
- package/src/config/tui-cwd.ts +0 -5
- package/src/config/tui-host-attention.ts +0 -21
- package/src/config/tui-migrate.ts +0 -132
- package/src/config/tui.ts +0 -274
- package/src/config/variable.ts +0 -91
- package/src/control-plane/adapters/index.ts +0 -41
- package/src/control-plane/adapters/worktree.ts +0 -96
- package/src/control-plane/dev/README.md +0 -19
- package/src/control-plane/dev/debug-workspace-plugin.ts +0 -73
- package/src/control-plane/types.ts +0 -59
- package/src/control-plane/util.ts +0 -39
- package/src/control-plane/workspace-adapter-runtime.ts +0 -51
- package/src/control-plane/workspace-context.ts +0 -26
- package/src/control-plane/workspace.ts +0 -989
- package/src/effect/app-runtime.ts +0 -132
- package/src/effect/bootstrap-runtime.ts +0 -23
- package/src/effect/bridge.ts +0 -84
- package/src/effect/config-service.ts +0 -67
- package/src/effect/instance-ref.ts +0 -11
- package/src/effect/instance-registry.ts +0 -12
- package/src/effect/instance-state.ts +0 -69
- package/src/effect/promise.ts +0 -17
- package/src/effect/run-service.ts +0 -47
- package/src/effect/runner.ts +0 -217
- package/src/effect/runtime-flags.ts +0 -79
- package/src/env/index.ts +0 -43
- package/src/event-v2-bridge.ts +0 -79
- package/src/format/formatter.ts +0 -404
- package/src/format/index.ts +0 -205
- package/src/git/index.ts +0 -350
- package/src/id/id.ts +0 -80
- package/src/ide/index.ts +0 -61
- package/src/image/image.ts +0 -174
- package/src/index.ts +0 -142
- package/src/installation/index.ts +0 -350
- package/src/lsp/client.ts +0 -650
- package/src/lsp/diagnostic.ts +0 -29
- package/src/lsp/language.ts +0 -121
- package/src/lsp/launch.ts +0 -21
- package/src/lsp/lsp.ts +0 -511
- package/src/lsp/server.ts +0 -1983
- package/src/markdown.d.ts +0 -4
- package/src/mcp/auth.ts +0 -174
- package/src/mcp/catalog.ts +0 -153
- package/src/mcp/index.ts +0 -953
- package/src/mcp/oauth-callback.ts +0 -233
- package/src/mcp/oauth-provider.ts +0 -206
- package/src/node.ts +0 -4
- package/src/patch/index.ts +0 -686
- package/src/permission/arity.ts +0 -163
- package/src/permission/evaluate.ts +0 -1
- package/src/permission/index.ts +0 -230
- package/src/plugin/azure.ts +0 -26
- package/src/plugin/cloudflare.ts +0 -76
- package/src/plugin/digitalocean.ts +0 -383
- package/src/plugin/github-copilot/copilot.ts +0 -414
- package/src/plugin/github-copilot/models.ts +0 -246
- package/src/plugin/index.ts +0 -316
- package/src/plugin/install.ts +0 -439
- package/src/plugin/loader.ts +0 -237
- package/src/plugin/meta.ts +0 -188
- package/src/plugin/openai/README.md +0 -31
- package/src/plugin/openai/codex.ts +0 -641
- package/src/plugin/openai/ws-pool.ts +0 -270
- package/src/plugin/openai/ws.ts +0 -381
- package/src/plugin/pty-environment.ts +0 -24
- package/src/plugin/shared.ts +0 -323
- package/src/plugin/snowflake-cortex.ts +0 -529
- package/src/plugin/tui/internal.ts +0 -10
- package/src/plugin/tui/runtime.ts +0 -1130
- package/src/plugin/xai.ts +0 -716
- package/src/project/bootstrap-service.ts +0 -9
- package/src/project/bootstrap.ts +0 -76
- package/src/project/instance-context.ts +0 -24
- package/src/project/instance-layer.ts +0 -11
- package/src/project/instance-runtime.ts +0 -16
- package/src/project/instance-store.ts +0 -209
- package/src/project/project.ts +0 -519
- package/src/project/vcs.ts +0 -431
- package/src/provider/auth.ts +0 -233
- package/src/provider/error.ts +0 -188
- package/src/provider/model-status.ts +0 -8
- package/src/provider/provider.ts +0 -1975
- package/src/provider/transform.ts +0 -1543
- package/src/question/index.ts +0 -229
- package/src/question/schema.ts +0 -10
- package/src/server/auth.ts +0 -48
- package/src/server/event.ts +0 -13
- package/src/server/global-lifecycle.ts +0 -28
- package/src/server/init-projectors.ts +0 -3
- package/src/server/mdns.ts +0 -47
- package/src/server/projectors.ts +0 -1
- package/src/server/proxy-util.ts +0 -48
- package/src/server/routes/instance/httpapi/AGENTS.md +0 -39
- package/src/server/routes/instance/httpapi/api.ts +0 -78
- package/src/server/routes/instance/httpapi/errors.ts +0 -193
- package/src/server/routes/instance/httpapi/groups/config.ts +0 -65
- package/src/server/routes/instance/httpapi/groups/control-plane.ts +0 -35
- package/src/server/routes/instance/httpapi/groups/control.ts +0 -76
- package/src/server/routes/instance/httpapi/groups/event.ts +0 -29
- package/src/server/routes/instance/httpapi/groups/experimental.ts +0 -275
- package/src/server/routes/instance/httpapi/groups/file.ts +0 -185
- package/src/server/routes/instance/httpapi/groups/global.ts +0 -138
- package/src/server/routes/instance/httpapi/groups/instance.ts +0 -206
- package/src/server/routes/instance/httpapi/groups/mcp.ts +0 -156
- package/src/server/routes/instance/httpapi/groups/metadata.ts +0 -18
- package/src/server/routes/instance/httpapi/groups/permission.ts +0 -61
- package/src/server/routes/instance/httpapi/groups/project-copy.ts +0 -32
- package/src/server/routes/instance/httpapi/groups/project.ts +0 -93
- package/src/server/routes/instance/httpapi/groups/provider.ts +0 -101
- package/src/server/routes/instance/httpapi/groups/pty.ts +0 -172
- package/src/server/routes/instance/httpapi/groups/query.ts +0 -12
- package/src/server/routes/instance/httpapi/groups/question.ts +0 -74
- package/src/server/routes/instance/httpapi/groups/session.ts +0 -462
- package/src/server/routes/instance/httpapi/groups/sync.ts +0 -113
- package/src/server/routes/instance/httpapi/groups/tui.ts +0 -208
- package/src/server/routes/instance/httpapi/groups/workspace.ts +0 -141
- package/src/server/routes/instance/httpapi/handlers/config.ts +0 -34
- package/src/server/routes/instance/httpapi/handlers/control-plane.ts +0 -37
- package/src/server/routes/instance/httpapi/handlers/control.ts +0 -43
- package/src/server/routes/instance/httpapi/handlers/event.ts +0 -99
- package/src/server/routes/instance/httpapi/handlers/experimental.ts +0 -192
- package/src/server/routes/instance/httpapi/handlers/file.ts +0 -139
- package/src/server/routes/instance/httpapi/handlers/global.ts +0 -156
- package/src/server/routes/instance/httpapi/handlers/instance.ts +0 -110
- package/src/server/routes/instance/httpapi/handlers/mcp.ts +0 -111
- package/src/server/routes/instance/httpapi/handlers/permission.ts +0 -41
- package/src/server/routes/instance/httpapi/handlers/project-copy.ts +0 -83
- package/src/server/routes/instance/httpapi/handlers/project.ts +0 -63
- package/src/server/routes/instance/httpapi/handlers/provider.ts +0 -113
- package/src/server/routes/instance/httpapi/handlers/pty.ts +0 -273
- package/src/server/routes/instance/httpapi/handlers/question.ts +0 -54
- package/src/server/routes/instance/httpapi/handlers/session-errors.ts +0 -21
- package/src/server/routes/instance/httpapi/handlers/session.ts +0 -440
- package/src/server/routes/instance/httpapi/handlers/sync.ts +0 -89
- package/src/server/routes/instance/httpapi/handlers/tui.ts +0 -131
- package/src/server/routes/instance/httpapi/handlers/workspace.ts +0 -102
- package/src/server/routes/instance/httpapi/lifecycle.ts +0 -54
- package/src/server/routes/instance/httpapi/middleware/authorization.ts +0 -150
- package/src/server/routes/instance/httpapi/middleware/compression.ts +0 -64
- package/src/server/routes/instance/httpapi/middleware/cors-vary.ts +0 -29
- package/src/server/routes/instance/httpapi/middleware/error.ts +0 -43
- package/src/server/routes/instance/httpapi/middleware/fence.ts +0 -25
- package/src/server/routes/instance/httpapi/middleware/instance-context.ts +0 -43
- package/src/server/routes/instance/httpapi/middleware/proxy.ts +0 -108
- package/src/server/routes/instance/httpapi/middleware/schema-error.ts +0 -41
- package/src/server/routes/instance/httpapi/middleware/workspace-routing.ts +0 -250
- package/src/server/routes/instance/httpapi/public.ts +0 -535
- package/src/server/routes/instance/httpapi/server.ts +0 -298
- package/src/server/routes/instance/httpapi/websocket-tracker.ts +0 -57
- package/src/server/server.ts +0 -225
- package/src/server/shared/fence.ts +0 -60
- package/src/server/shared/pty-ticket.ts +0 -15
- package/src/server/shared/public-ui.ts +0 -12
- package/src/server/shared/tui-control.ts +0 -28
- package/src/server/shared/ui.ts +0 -108
- package/src/server/shared/workspace-routing.ts +0 -38
- package/src/server/tui-event.ts +0 -53
- package/src/session/compaction.ts +0 -620
- package/src/session/instruction.ts +0 -241
- package/src/session/llm/AGENTS.md +0 -90
- package/src/session/llm/ai-sdk.ts +0 -288
- package/src/session/llm/native-request.ts +0 -196
- package/src/session/llm/native-runtime.ts +0 -195
- package/src/session/llm/request.ts +0 -216
- package/src/session/llm.ts +0 -415
- package/src/session/message-error.ts +0 -14
- package/src/session/message-v2.ts +0 -747
- package/src/session/message.ts +0 -148
- package/src/session/overflow.ts +0 -34
- package/src/session/processor.ts +0 -1084
- package/src/session/prompt/anthropic.txt +0 -109
- package/src/session/prompt/beast.txt +0 -151
- package/src/session/prompt/build-switch.txt +0 -9
- package/src/session/prompt/codex.txt +0 -83
- package/src/session/prompt/copilot-gpt-5.txt +0 -147
- package/src/session/prompt/default.txt +0 -99
- package/src/session/prompt/gemini.txt +0 -159
- package/src/session/prompt/gpt.txt +0 -111
- package/src/session/prompt/kimi.txt +0 -99
- package/src/session/prompt/plan-mode.txt +0 -74
- package/src/session/prompt/plan-reminder-anthropic.txt +0 -71
- package/src/session/prompt/plan.txt +0 -30
- package/src/session/prompt/trinity.txt +0 -101
- package/src/session/prompt.ts +0 -1707
- package/src/session/reminders.ts +0 -92
- package/src/session/retry.ts +0 -201
- package/src/session/revert.ts +0 -160
- package/src/session/run-state.ts +0 -156
- package/src/session/schema.ts +0 -26
- package/src/session/session.ts +0 -1119
- package/src/session/status.ts +0 -97
- package/src/session/summary.ts +0 -165
- package/src/session/system.ts +0 -117
- package/src/session/todo.ts +0 -90
- package/src/session/tools.ts +0 -207
- package/src/share/session.ts +0 -61
- package/src/share/share-next.ts +0 -385
- package/src/skill/discovery.ts +0 -109
- package/src/skill/index.ts +0 -366
- package/src/snapshot/index.ts +0 -808
- package/src/sql.d.ts +0 -4
- package/src/storage/schema.ts +0 -5
- package/src/storage/storage.ts +0 -329
- package/src/sync/README.md +0 -179
- package/src/sync/schema.ts +0 -11
- package/src/temporary.ts +0 -31
- package/src/tool/apply_patch.ts +0 -315
- package/src/tool/apply_patch.txt +0 -33
- package/src/tool/apply_patch.zh.txt +0 -33
- package/src/tool/description.ts +0 -100
- package/src/tool/edit.ts +0 -739
- package/src/tool/edit.txt +0 -10
- package/src/tool/edit.zh.txt +0 -10
- package/src/tool/external-directory.ts +0 -49
- package/src/tool/glob.ts +0 -78
- package/src/tool/glob.txt +0 -6
- package/src/tool/glob.zh.txt +0 -6
- package/src/tool/grep.ts +0 -114
- package/src/tool/grep.txt +0 -8
- package/src/tool/grep.zh.txt +0 -8
- package/src/tool/invalid.ts +0 -21
- package/src/tool/json-schema.ts +0 -164
- package/src/tool/lsp.ts +0 -115
- package/src/tool/lsp.txt +0 -24
- package/src/tool/lsp.zh.txt +0 -24
- package/src/tool/mcp-websearch.ts +0 -96
- package/src/tool/plan-enter.txt +0 -14
- package/src/tool/plan-enter.zh.txt +0 -14
- package/src/tool/plan-exit.txt +0 -13
- package/src/tool/plan-exit.zh.txt +0 -13
- package/src/tool/plan.ts +0 -81
- package/src/tool/question.ts +0 -46
- package/src/tool/question.txt +0 -10
- package/src/tool/question.zh.txt +0 -10
- package/src/tool/read.ts +0 -388
- package/src/tool/read.txt +0 -14
- package/src/tool/read.zh.txt +0 -14
- package/src/tool/registry.ts +0 -440
- package/src/tool/schema.ts +0 -14
- package/src/tool/shell/id.ts +0 -19
- package/src/tool/shell/prompt.ts +0 -307
- package/src/tool/shell/shell.txt +0 -21
- package/src/tool/shell.ts +0 -657
- package/src/tool/skill.ts +0 -73
- package/src/tool/skill.txt +0 -5
- package/src/tool/skill.zh.txt +0 -5
- package/src/tool/task.ts +0 -348
- package/src/tool/task.txt +0 -19
- package/src/tool/task.zh.txt +0 -19
- package/src/tool/todo.ts +0 -59
- package/src/tool/todowrite.txt +0 -44
- package/src/tool/todowrite.zh.txt +0 -44
- package/src/tool/tool.ts +0 -183
- package/src/tool/truncate.ts +0 -158
- package/src/tool/truncation-dir.ts +0 -4
- package/src/tool/webfetch.ts +0 -194
- package/src/tool/webfetch.txt +0 -13
- package/src/tool/webfetch.zh.txt +0 -13
- package/src/tool/websearch.ts +0 -145
- package/src/tool/websearch.txt +0 -14
- package/src/tool/websearch.zh.txt +0 -14
- package/src/tool/write.ts +0 -106
- package/src/tool/write.txt +0 -8
- package/src/tool/write.zh.txt +0 -8
- package/src/util/archive.ts +0 -17
- package/src/util/bom.ts +0 -27
- package/src/util/data-url.ts +0 -9
- package/src/util/defer.ts +0 -10
- package/src/util/effect-http-client.ts +0 -11
- package/src/util/error.ts +0 -1
- package/src/util/filesystem.ts +0 -251
- package/src/util/html.ts +0 -8
- package/src/util/iife.ts +0 -3
- package/src/util/lazy.ts +0 -20
- package/src/util/local-context.ts +0 -25
- package/src/util/locale.ts +0 -2
- package/src/util/media.ts +0 -26
- package/src/util/process.ts +0 -177
- package/src/util/proxy-env.ts +0 -72
- package/src/util/queue.ts +0 -32
- package/src/util/record.ts +0 -1
- package/src/util/repository.ts +0 -232
- package/src/util/rpc.ts +0 -66
- package/src/util/signal.ts +0 -12
- package/src/util/timeout.ts +0 -13
- package/src/util/token.ts +0 -1
- package/src/util/wildcard.ts +0 -59
- package/src/worktree/index.ts +0 -654
package/src/question/index.ts
DELETED
|
@@ -1,229 +0,0 @@
|
|
|
1
|
-
import { LayerNode } from "@opencode-ai/core/effect/layer-node"
|
|
2
|
-
import { Deferred, Effect, Layer, Schema, Context } from "effect"
|
|
3
|
-
import { InstanceState } from "@/effect/instance-state"
|
|
4
|
-
import { SessionID, MessageID } from "@/session/schema"
|
|
5
|
-
import { QuestionID } from "./schema"
|
|
6
|
-
import { EventV2Bridge } from "@/event-v2-bridge"
|
|
7
|
-
import { EventV2 } from "@opencode-ai/core/event"
|
|
8
|
-
|
|
9
|
-
// Schemas — these are pure data; nothing checks class identity (see PR
|
|
10
|
-
// description) so they're plain `Schema.Struct` + type alias. That lets
|
|
11
|
-
// `Question.ask` and other internal sites trust the type contract without a
|
|
12
|
-
// re-decode to coerce nested class instances.
|
|
13
|
-
|
|
14
|
-
export const Option = Schema.Struct({
|
|
15
|
-
label: Schema.String.annotate({
|
|
16
|
-
description: "Display text (1-5 words, concise)",
|
|
17
|
-
}),
|
|
18
|
-
description: Schema.String.annotate({
|
|
19
|
-
description: "Explanation of choice",
|
|
20
|
-
}),
|
|
21
|
-
}).annotate({ identifier: "QuestionOption" })
|
|
22
|
-
export type Option = Schema.Schema.Type<typeof Option>
|
|
23
|
-
|
|
24
|
-
const base = {
|
|
25
|
-
question: Schema.String.annotate({
|
|
26
|
-
description: "Complete question",
|
|
27
|
-
}),
|
|
28
|
-
header: Schema.String.annotate({
|
|
29
|
-
description: "Very short label (max 30 chars)",
|
|
30
|
-
}),
|
|
31
|
-
options: Schema.Array(Option).annotate({
|
|
32
|
-
description: "Available choices",
|
|
33
|
-
}),
|
|
34
|
-
multiple: Schema.optional(Schema.Boolean).annotate({
|
|
35
|
-
description: "Allow selecting multiple choices",
|
|
36
|
-
}),
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
export const Info = Schema.Struct({
|
|
40
|
-
...base,
|
|
41
|
-
custom: Schema.optional(Schema.Boolean).annotate({
|
|
42
|
-
description: "Allow typing a custom answer (default: true)",
|
|
43
|
-
}),
|
|
44
|
-
}).annotate({ identifier: "QuestionInfo" })
|
|
45
|
-
export type Info = Schema.Schema.Type<typeof Info>
|
|
46
|
-
|
|
47
|
-
export const Prompt = Schema.Struct(base).annotate({ identifier: "QuestionPrompt" })
|
|
48
|
-
export type Prompt = Schema.Schema.Type<typeof Prompt>
|
|
49
|
-
|
|
50
|
-
export const Tool = Schema.Struct({
|
|
51
|
-
messageID: MessageID,
|
|
52
|
-
callID: Schema.String,
|
|
53
|
-
}).annotate({ identifier: "QuestionTool" })
|
|
54
|
-
export type Tool = Schema.Schema.Type<typeof Tool>
|
|
55
|
-
|
|
56
|
-
export const Request = Schema.Struct({
|
|
57
|
-
id: QuestionID,
|
|
58
|
-
sessionID: SessionID,
|
|
59
|
-
questions: Schema.Array(Info).annotate({
|
|
60
|
-
description: "Questions to ask",
|
|
61
|
-
}),
|
|
62
|
-
tool: Schema.optional(Tool),
|
|
63
|
-
}).annotate({ identifier: "QuestionRequest" })
|
|
64
|
-
export type Request = Schema.Schema.Type<typeof Request>
|
|
65
|
-
|
|
66
|
-
export const Answer = Schema.Array(Schema.String).annotate({ identifier: "QuestionAnswer" })
|
|
67
|
-
export type Answer = Schema.Schema.Type<typeof Answer>
|
|
68
|
-
|
|
69
|
-
export const Reply = Schema.Struct({
|
|
70
|
-
answers: Schema.Array(Answer).annotate({
|
|
71
|
-
description: "User answers in order of questions (each answer is an array of selected labels)",
|
|
72
|
-
}),
|
|
73
|
-
}).annotate({ identifier: "QuestionReply" })
|
|
74
|
-
export type Reply = Schema.Schema.Type<typeof Reply>
|
|
75
|
-
|
|
76
|
-
export const Replied = Schema.Struct({
|
|
77
|
-
sessionID: SessionID,
|
|
78
|
-
requestID: QuestionID,
|
|
79
|
-
answers: Schema.Array(Answer),
|
|
80
|
-
}).annotate({ identifier: "QuestionReplied" })
|
|
81
|
-
|
|
82
|
-
export const Rejected = Schema.Struct({
|
|
83
|
-
sessionID: SessionID,
|
|
84
|
-
requestID: QuestionID,
|
|
85
|
-
}).annotate({ identifier: "QuestionRejected" })
|
|
86
|
-
|
|
87
|
-
export const Event = {
|
|
88
|
-
Asked: EventV2.define({ type: "question.asked", schema: Request.fields }),
|
|
89
|
-
Replied: EventV2.define({ type: "question.replied", schema: Replied.fields }),
|
|
90
|
-
Rejected: EventV2.define({ type: "question.rejected", schema: Rejected.fields }),
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
export class RejectedError extends Schema.TaggedErrorClass<RejectedError>()("QuestionRejectedError", {}) {
|
|
94
|
-
override get message() {
|
|
95
|
-
return "The user dismissed this question"
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
export class NotFoundError extends Schema.TaggedErrorClass<NotFoundError>()("Question.NotFoundError", {
|
|
100
|
-
requestID: QuestionID,
|
|
101
|
-
}) {}
|
|
102
|
-
|
|
103
|
-
interface PendingEntry {
|
|
104
|
-
info: Request
|
|
105
|
-
deferred: Deferred.Deferred<ReadonlyArray<Answer>, RejectedError>
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
interface State {
|
|
109
|
-
pending: Map<QuestionID, PendingEntry>
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
// Service
|
|
113
|
-
|
|
114
|
-
export interface Interface {
|
|
115
|
-
readonly ask: (input: {
|
|
116
|
-
sessionID: SessionID
|
|
117
|
-
questions: ReadonlyArray<Info>
|
|
118
|
-
tool?: Tool
|
|
119
|
-
}) => Effect.Effect<ReadonlyArray<Answer>, RejectedError>
|
|
120
|
-
readonly reply: (input: {
|
|
121
|
-
requestID: QuestionID
|
|
122
|
-
answers: ReadonlyArray<Answer>
|
|
123
|
-
}) => Effect.Effect<void, NotFoundError>
|
|
124
|
-
readonly reject: (requestID: QuestionID) => Effect.Effect<void, NotFoundError>
|
|
125
|
-
readonly list: () => Effect.Effect<ReadonlyArray<Request>>
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
export class Service extends Context.Service<Service, Interface>()("@opencode/Question") {}
|
|
129
|
-
|
|
130
|
-
export const layer = Layer.effect(
|
|
131
|
-
Service,
|
|
132
|
-
Effect.gen(function* () {
|
|
133
|
-
const events = yield* EventV2Bridge.Service
|
|
134
|
-
const state = yield* InstanceState.make<State>(
|
|
135
|
-
Effect.fn("Question.state")(function* () {
|
|
136
|
-
const state = {
|
|
137
|
-
pending: new Map<QuestionID, PendingEntry>(),
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
yield* Effect.addFinalizer(() =>
|
|
141
|
-
Effect.gen(function* () {
|
|
142
|
-
for (const item of state.pending.values()) {
|
|
143
|
-
yield* Deferred.fail(item.deferred, new RejectedError())
|
|
144
|
-
}
|
|
145
|
-
state.pending.clear()
|
|
146
|
-
}),
|
|
147
|
-
)
|
|
148
|
-
|
|
149
|
-
return state
|
|
150
|
-
}),
|
|
151
|
-
)
|
|
152
|
-
|
|
153
|
-
const ask = Effect.fn("Question.ask")(function* (input: {
|
|
154
|
-
sessionID: SessionID
|
|
155
|
-
questions: ReadonlyArray<Info>
|
|
156
|
-
tool?: Tool
|
|
157
|
-
}) {
|
|
158
|
-
const pending = (yield* InstanceState.get(state)).pending
|
|
159
|
-
const id = QuestionID.ascending()
|
|
160
|
-
yield* Effect.logInfo("asking", { id, questions: input.questions.length })
|
|
161
|
-
|
|
162
|
-
const deferred = yield* Deferred.make<ReadonlyArray<Answer>, RejectedError>()
|
|
163
|
-
const info: Request = {
|
|
164
|
-
id,
|
|
165
|
-
sessionID: input.sessionID,
|
|
166
|
-
questions: input.questions,
|
|
167
|
-
tool: input.tool,
|
|
168
|
-
}
|
|
169
|
-
pending.set(id, { info, deferred })
|
|
170
|
-
yield* events.publish(Event.Asked, info)
|
|
171
|
-
|
|
172
|
-
return yield* Effect.ensuring(
|
|
173
|
-
Deferred.await(deferred),
|
|
174
|
-
Effect.sync(() => {
|
|
175
|
-
pending.delete(id)
|
|
176
|
-
}),
|
|
177
|
-
)
|
|
178
|
-
})
|
|
179
|
-
|
|
180
|
-
const reply = Effect.fn("Question.reply")(function* (input: {
|
|
181
|
-
requestID: QuestionID
|
|
182
|
-
answers: ReadonlyArray<Answer>
|
|
183
|
-
}) {
|
|
184
|
-
const pending = (yield* InstanceState.get(state)).pending
|
|
185
|
-
const existing = pending.get(input.requestID)
|
|
186
|
-
if (!existing) {
|
|
187
|
-
yield* Effect.logWarning("reply for unknown request", { requestID: input.requestID })
|
|
188
|
-
return yield* new NotFoundError({ requestID: input.requestID })
|
|
189
|
-
}
|
|
190
|
-
pending.delete(input.requestID)
|
|
191
|
-
yield* Effect.logInfo("replied", { requestID: input.requestID, answers: input.answers })
|
|
192
|
-
yield* events.publish(Event.Replied, {
|
|
193
|
-
sessionID: existing.info.sessionID,
|
|
194
|
-
requestID: existing.info.id,
|
|
195
|
-
answers: input.answers.map((a) => [...a]),
|
|
196
|
-
})
|
|
197
|
-
yield* Deferred.succeed(existing.deferred, input.answers)
|
|
198
|
-
})
|
|
199
|
-
|
|
200
|
-
const reject = Effect.fn("Question.reject")(function* (requestID: QuestionID) {
|
|
201
|
-
const pending = (yield* InstanceState.get(state)).pending
|
|
202
|
-
const existing = pending.get(requestID)
|
|
203
|
-
if (!existing) {
|
|
204
|
-
yield* Effect.logWarning("reject for unknown request", { requestID })
|
|
205
|
-
return yield* new NotFoundError({ requestID })
|
|
206
|
-
}
|
|
207
|
-
pending.delete(requestID)
|
|
208
|
-
yield* Effect.logInfo("rejected", { requestID })
|
|
209
|
-
yield* events.publish(Event.Rejected, {
|
|
210
|
-
sessionID: existing.info.sessionID,
|
|
211
|
-
requestID: existing.info.id,
|
|
212
|
-
})
|
|
213
|
-
yield* Deferred.fail(existing.deferred, new RejectedError())
|
|
214
|
-
})
|
|
215
|
-
|
|
216
|
-
const list = Effect.fn("Question.list")(function* () {
|
|
217
|
-
const pending = (yield* InstanceState.get(state)).pending
|
|
218
|
-
return Array.from(pending.values(), (x) => x.info)
|
|
219
|
-
})
|
|
220
|
-
|
|
221
|
-
return Service.of({ ask, reply, reject, list })
|
|
222
|
-
}),
|
|
223
|
-
)
|
|
224
|
-
|
|
225
|
-
export const defaultLayer = layer.pipe(Layer.provide(EventV2Bridge.defaultLayer))
|
|
226
|
-
|
|
227
|
-
export const node = LayerNode.make(layer, [EventV2Bridge.node])
|
|
228
|
-
|
|
229
|
-
export * as Question from "."
|
package/src/question/schema.ts
DELETED
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { Schema } from "effect"
|
|
2
|
-
|
|
3
|
-
import { Identifier } from "@/id/id"
|
|
4
|
-
import { Newtype } from "@opencode-ai/core/schema"
|
|
5
|
-
|
|
6
|
-
export class QuestionID extends Newtype<QuestionID>()("QuestionID", Schema.String.check(Schema.isStartsWith("que"))) {
|
|
7
|
-
static ascending(id?: string): QuestionID {
|
|
8
|
-
return this.make(Identifier.ascending("question", id))
|
|
9
|
-
}
|
|
10
|
-
}
|
package/src/server/auth.ts
DELETED
|
@@ -1,48 +0,0 @@
|
|
|
1
|
-
export * as ServerAuth from "./auth"
|
|
2
|
-
|
|
3
|
-
import { ConfigService } from "@/effect/config-service"
|
|
4
|
-
import { Flag } from "@opencode-ai/core/flag/flag"
|
|
5
|
-
import { Config as EffectConfig, Context, Option, Redacted } from "effect"
|
|
6
|
-
|
|
7
|
-
export type Credentials = {
|
|
8
|
-
password?: string
|
|
9
|
-
username?: string
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
export type DecodedCredentials = {
|
|
13
|
-
readonly username: string
|
|
14
|
-
readonly password: Redacted.Redacted
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
export class Config extends ConfigService.Service<Config>()("@opencode/ServerAuthConfig", {
|
|
18
|
-
password: EffectConfig.string("OPENCODE_SERVER_PASSWORD").pipe(EffectConfig.option),
|
|
19
|
-
username: EffectConfig.string("OPENCODE_SERVER_USERNAME").pipe(EffectConfig.withDefault("opencode")),
|
|
20
|
-
}) {}
|
|
21
|
-
|
|
22
|
-
export type Info = Context.Service.Shape<typeof Config>
|
|
23
|
-
|
|
24
|
-
export function required(config: Info) {
|
|
25
|
-
return Option.isSome(config.password) && config.password.value !== ""
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
export function authorized(credentials: DecodedCredentials, config: Info) {
|
|
29
|
-
return (
|
|
30
|
-
Option.isSome(config.password) &&
|
|
31
|
-
credentials.username === config.username &&
|
|
32
|
-
Redacted.value(credentials.password) === config.password.value
|
|
33
|
-
)
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
export function header(credentials?: Credentials) {
|
|
37
|
-
const password = credentials?.password ?? Flag.OPENCODE_SERVER_PASSWORD
|
|
38
|
-
if (!password) return undefined
|
|
39
|
-
|
|
40
|
-
const username = credentials?.username ?? Flag.OPENCODE_SERVER_USERNAME ?? "opencode"
|
|
41
|
-
return `Basic ${Buffer.from(`${username}:${password}`).toString("base64")}`
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
export function headers(credentials?: Credentials) {
|
|
45
|
-
const authorization = header(credentials)
|
|
46
|
-
if (!authorization) return undefined
|
|
47
|
-
return { Authorization: authorization }
|
|
48
|
-
}
|
package/src/server/event.ts
DELETED
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { EventV2 } from "@opencode-ai/core/event"
|
|
2
|
-
import { Schema } from "effect"
|
|
3
|
-
|
|
4
|
-
export const Event = {
|
|
5
|
-
Connected: EventV2.define({ type: "server.connected", schema: {} }),
|
|
6
|
-
Disposed: EventV2.define({ type: "global.disposed", schema: {} }),
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
export const InstanceDisposed = Schema.Struct({
|
|
10
|
-
id: Schema.String,
|
|
11
|
-
type: Schema.Literal("server.instance.disposed"),
|
|
12
|
-
properties: Schema.Struct({ directory: Schema.String }),
|
|
13
|
-
}).annotate({ identifier: "Event.server.instance.disposed" })
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
import { GlobalBus } from "@/bus/global"
|
|
2
|
-
import { InstanceStore } from "@/project/instance-store"
|
|
3
|
-
import { Effect } from "effect"
|
|
4
|
-
import { Event } from "./event"
|
|
5
|
-
|
|
6
|
-
export const emitGlobalDisposed = Effect.sync(() =>
|
|
7
|
-
GlobalBus.emit("event", {
|
|
8
|
-
directory: "global",
|
|
9
|
-
payload: {
|
|
10
|
-
type: Event.Disposed.type,
|
|
11
|
-
properties: {},
|
|
12
|
-
},
|
|
13
|
-
}),
|
|
14
|
-
)
|
|
15
|
-
|
|
16
|
-
export const disposeAllInstancesAndEmitGlobalDisposed = Effect.fn("Server.disposeAllInstancesAndEmitGlobalDisposed")(
|
|
17
|
-
function* (options?: { swallowErrors?: boolean }) {
|
|
18
|
-
const store = yield* InstanceStore.Service
|
|
19
|
-
yield* Effect.gen(function* () {
|
|
20
|
-
yield* options?.swallowErrors
|
|
21
|
-
? store.disposeAll().pipe(Effect.catchCause((cause) => Effect.logWarning("global disposal failed", { cause })))
|
|
22
|
-
: store.disposeAll()
|
|
23
|
-
yield* emitGlobalDisposed
|
|
24
|
-
}).pipe(Effect.uninterruptible)
|
|
25
|
-
},
|
|
26
|
-
)
|
|
27
|
-
|
|
28
|
-
export * as GlobalLifecycle from "./global-lifecycle"
|
package/src/server/mdns.ts
DELETED
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
import { Bonjour } from "bonjour-service"
|
|
2
|
-
|
|
3
|
-
let bonjour: Bonjour | undefined
|
|
4
|
-
let currentPort: number | undefined
|
|
5
|
-
|
|
6
|
-
export function publish(port: number, domain?: string) {
|
|
7
|
-
if (currentPort === port) return
|
|
8
|
-
if (bonjour) unpublish()
|
|
9
|
-
|
|
10
|
-
try {
|
|
11
|
-
const host = domain ?? "opencode.local"
|
|
12
|
-
const name = `opencode-${port}`
|
|
13
|
-
bonjour = new Bonjour()
|
|
14
|
-
const service = bonjour.publish({
|
|
15
|
-
name,
|
|
16
|
-
type: "http",
|
|
17
|
-
host,
|
|
18
|
-
port,
|
|
19
|
-
txt: { path: "/" },
|
|
20
|
-
})
|
|
21
|
-
|
|
22
|
-
service.on("error", () => {})
|
|
23
|
-
|
|
24
|
-
currentPort = port
|
|
25
|
-
} catch {
|
|
26
|
-
if (bonjour) {
|
|
27
|
-
try {
|
|
28
|
-
bonjour.destroy()
|
|
29
|
-
} catch {}
|
|
30
|
-
}
|
|
31
|
-
bonjour = undefined
|
|
32
|
-
currentPort = undefined
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
export function unpublish() {
|
|
37
|
-
if (bonjour) {
|
|
38
|
-
try {
|
|
39
|
-
bonjour.unpublishAll()
|
|
40
|
-
bonjour.destroy()
|
|
41
|
-
} catch {}
|
|
42
|
-
bonjour = undefined
|
|
43
|
-
currentPort = undefined
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
export * as MDNS from "./mdns"
|
package/src/server/projectors.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export function initProjectors() {}
|
package/src/server/proxy-util.ts
DELETED
|
@@ -1,48 +0,0 @@
|
|
|
1
|
-
const hop = new Set([
|
|
2
|
-
"connection",
|
|
3
|
-
"keep-alive",
|
|
4
|
-
"proxy-authenticate",
|
|
5
|
-
"proxy-authorization",
|
|
6
|
-
"proxy-connection",
|
|
7
|
-
"te",
|
|
8
|
-
"trailer",
|
|
9
|
-
"transfer-encoding",
|
|
10
|
-
"upgrade",
|
|
11
|
-
"host",
|
|
12
|
-
])
|
|
13
|
-
|
|
14
|
-
function sanitize(out: Headers) {
|
|
15
|
-
for (const key of hop) out.delete(key)
|
|
16
|
-
out.delete("accept-encoding")
|
|
17
|
-
out.delete("x-opencode-directory")
|
|
18
|
-
out.delete("x-opencode-workspace")
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
export function headers(input: Request | HeadersInit | Record<string, string>, extra?: HeadersInit) {
|
|
22
|
-
const raw = input instanceof Request ? input.headers : input
|
|
23
|
-
const out = new Headers(raw instanceof Headers ? raw : Object.entries(raw as Record<string, string>))
|
|
24
|
-
sanitize(out)
|
|
25
|
-
if (!extra) return out
|
|
26
|
-
for (const [key, value] of new Headers(extra).entries()) {
|
|
27
|
-
out.set(key, value)
|
|
28
|
-
}
|
|
29
|
-
return out
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
export function websocketProtocols(input: Request | Record<string, string | undefined>) {
|
|
33
|
-
const value = input instanceof Request ? input.headers.get("sec-websocket-protocol") : input["sec-websocket-protocol"]
|
|
34
|
-
if (!value) return []
|
|
35
|
-
return value
|
|
36
|
-
.split(",")
|
|
37
|
-
.map((item) => item.trim())
|
|
38
|
-
.filter(Boolean)
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
export function websocketTargetURL(url: string | URL) {
|
|
42
|
-
const next = new URL(url)
|
|
43
|
-
if (next.protocol === "http:") next.protocol = "ws:"
|
|
44
|
-
if (next.protocol === "https:") next.protocol = "wss:"
|
|
45
|
-
return next.toString()
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
export * as ProxyUtil from "./proxy-util"
|
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
# HttpApi Route Patterns
|
|
2
|
-
|
|
3
|
-
Use `HttpApiBuilder.group(...)` for normal HTTP endpoints, including streaming HTTP responses such as server-sent events. Handlers should yield stable services once while building the handler layer, then close over those services in endpoint implementations.
|
|
4
|
-
|
|
5
|
-
```ts
|
|
6
|
-
export const sessionHandlers = HttpApiBuilder.group(InstanceHttpApi, "session", (handlers) =>
|
|
7
|
-
Effect.gen(function* () {
|
|
8
|
-
const session = yield* Session.Service
|
|
9
|
-
|
|
10
|
-
return handlers.handle("list", () => session.list())
|
|
11
|
-
}),
|
|
12
|
-
)
|
|
13
|
-
```
|
|
14
|
-
|
|
15
|
-
For SSE endpoints, stay in `HttpApiBuilder.group(...)` and return `HttpServerResponse.stream(...)` from the handler. Annotate the endpoint success schema with `HttpApiSchema.asText({ contentType: "text/event-stream" })` so OpenAPI documents the stream content type.
|
|
16
|
-
|
|
17
|
-
Use `HttpApiBuilder.group(...)` with `handleRaw(...)` for declared endpoints that need the raw request or response, including WebSocket upgrade routes. This keeps endpoint middleware, routing context, and OpenAPI metadata on one typed route tree.
|
|
18
|
-
|
|
19
|
-
```ts
|
|
20
|
-
export const ptyConnectHandlers = HttpApiBuilder.group(PtyConnectApi, "pty-connect", (handlers) =>
|
|
21
|
-
Effect.gen(function* () {
|
|
22
|
-
const pty = yield* Pty.Service
|
|
23
|
-
|
|
24
|
-
return handlers.handleRaw("connect", (ctx) => connectPty(ctx.request, pty))
|
|
25
|
-
}),
|
|
26
|
-
)
|
|
27
|
-
```
|
|
28
|
-
|
|
29
|
-
Use raw `HttpRouter.use(...)` only for routes outside the declared API surface, such as a catch-all UI fallback.
|
|
30
|
-
|
|
31
|
-
Avoid `Effect.provide(SomeLayer)` inside request handlers or raw route callbacks. Stable layers should be provided once at the application/layer boundary, not rebuilt or scoped per request.
|
|
32
|
-
|
|
33
|
-
Avoid `HttpRouter.provideRequest(...)` unless the dependency is intentionally request-level. Prefer `HttpRouter.use(...)` for stable app services.
|
|
34
|
-
|
|
35
|
-
Use `Effect.provideService(...)` in middleware only for request-derived context, such as `WorkspaceRouteContext`, `InstanceRef`, or `WorkspaceRef`. Do not use it to smuggle stable services through request effects when they can be yielded at layer construction.
|
|
36
|
-
|
|
37
|
-
Public JSON errors should be explicit `Schema.ErrorClass` contracts declared on each endpoint. Use built-in `HttpApiError.*` classes only when their empty/tagged body is the intended wire shape; for SDK-visible errors with messages, define an API error schema such as `ApiNotFoundError` and fail with that exact declared error. Keep domain and storage services free of HttpApi types, and translate expected domain errors at the handler boundary.
|
|
38
|
-
|
|
39
|
-
When adding middleware, declare endpoint-contract middleware on the owning `HttpApiGroup` and provide its implementation layer at the assembly boundary in `server.ts`. Keep router middleware for truly raw fallback routes or global transport policy.
|
|
@@ -1,78 +0,0 @@
|
|
|
1
|
-
import { Schema } from "effect"
|
|
2
|
-
import { HttpApi } from "effect/unstable/httpapi"
|
|
3
|
-
import { EventV2 } from "@opencode-ai/core/event"
|
|
4
|
-
import { InstanceDisposed } from "@/server/event"
|
|
5
|
-
import { Question } from "@/question"
|
|
6
|
-
import { ConfigApi } from "./groups/config"
|
|
7
|
-
import { ControlApi } from "./groups/control"
|
|
8
|
-
import { ControlPlaneApi } from "./groups/control-plane"
|
|
9
|
-
import { EventApi } from "./groups/event"
|
|
10
|
-
import { ExperimentalApi } from "./groups/experimental"
|
|
11
|
-
import { FileApi } from "./groups/file"
|
|
12
|
-
import { InstanceApi } from "./groups/instance"
|
|
13
|
-
import { McpApi } from "./groups/mcp"
|
|
14
|
-
import { PermissionApi } from "./groups/permission"
|
|
15
|
-
import { ProjectApi } from "./groups/project"
|
|
16
|
-
import { ProjectCopyApi } from "./groups/project-copy"
|
|
17
|
-
import { ProviderApi } from "./groups/provider"
|
|
18
|
-
import { PtyApi, PtyConnectApi } from "./groups/pty"
|
|
19
|
-
import { QuestionApi } from "./groups/question"
|
|
20
|
-
import { SessionApi } from "./groups/session"
|
|
21
|
-
import { SyncApi } from "./groups/sync"
|
|
22
|
-
import { TuiApi } from "./groups/tui"
|
|
23
|
-
import { WorkspaceApi } from "./groups/workspace"
|
|
24
|
-
import { Api } from "@opencode-ai/server/api"
|
|
25
|
-
// GlobalEventSchema snapshots the registry after event-producing groups register their variants.
|
|
26
|
-
import { GlobalApi } from "./groups/global"
|
|
27
|
-
import { Authorization } from "./middleware/authorization"
|
|
28
|
-
import { SchemaErrorMiddleware } from "./middleware/schema-error"
|
|
29
|
-
|
|
30
|
-
const EventSchema = Schema.Union([
|
|
31
|
-
...EventV2.registry
|
|
32
|
-
.values()
|
|
33
|
-
.map((definition) =>
|
|
34
|
-
Schema.Struct({
|
|
35
|
-
id: EventV2.ID,
|
|
36
|
-
type: Schema.Literal(definition.type),
|
|
37
|
-
properties: definition.data,
|
|
38
|
-
}).annotate({ identifier: `Event.${definition.type}` }),
|
|
39
|
-
)
|
|
40
|
-
.toArray(),
|
|
41
|
-
InstanceDisposed,
|
|
42
|
-
]).annotate({ identifier: "Event" })
|
|
43
|
-
|
|
44
|
-
export const RootHttpApi = HttpApi.make("opencode-root")
|
|
45
|
-
.addHttpApi(ControlApi)
|
|
46
|
-
.addHttpApi(ControlPlaneApi)
|
|
47
|
-
.addHttpApi(GlobalApi)
|
|
48
|
-
.middleware(SchemaErrorMiddleware)
|
|
49
|
-
.middleware(Authorization)
|
|
50
|
-
|
|
51
|
-
export const InstanceHttpApi = HttpApi.make("opencode-instance")
|
|
52
|
-
.addHttpApi(ConfigApi)
|
|
53
|
-
.addHttpApi(ExperimentalApi)
|
|
54
|
-
.addHttpApi(FileApi)
|
|
55
|
-
.addHttpApi(InstanceApi)
|
|
56
|
-
.addHttpApi(McpApi)
|
|
57
|
-
.addHttpApi(ProjectApi)
|
|
58
|
-
.addHttpApi(ProjectCopyApi)
|
|
59
|
-
.addHttpApi(PtyApi)
|
|
60
|
-
.addHttpApi(QuestionApi)
|
|
61
|
-
.addHttpApi(PermissionApi)
|
|
62
|
-
.addHttpApi(ProviderApi)
|
|
63
|
-
.addHttpApi(SessionApi)
|
|
64
|
-
.addHttpApi(SyncApi)
|
|
65
|
-
.addHttpApi(TuiApi)
|
|
66
|
-
.addHttpApi(WorkspaceApi)
|
|
67
|
-
.middleware(SchemaErrorMiddleware)
|
|
68
|
-
|
|
69
|
-
export const OnlyCodeHttpApi = HttpApi.make("opencode")
|
|
70
|
-
.addHttpApi(RootHttpApi)
|
|
71
|
-
.addHttpApi(EventApi)
|
|
72
|
-
.addHttpApi(InstanceHttpApi)
|
|
73
|
-
.addHttpApi(Api)
|
|
74
|
-
.addHttpApi(PtyConnectApi)
|
|
75
|
-
.annotate(HttpApi.AdditionalSchemas, [EventSchema, Question.Replied, Question.Rejected])
|
|
76
|
-
|
|
77
|
-
export type RootHttpApiType = typeof RootHttpApi
|
|
78
|
-
export type InstanceHttpApiType = typeof InstanceHttpApi
|