@miaws/miaw 1.18.5 → 1.18.7
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/bin/miaw +1 -1
- package/package.json +1 -154
- package/AGENTS.md +0 -131
- package/Dockerfile +0 -18
- package/README.md +0 -15
- package/bunfig.toml +0 -7
- package/git +0 -0
- package/migration/20260511173437_session-metadata/migration.sql +0 -1
- package/migration/20260511173437_session-metadata/snapshot.json +0 -1500
- package/parsers-config.ts +0 -1
- package/script/bench-search.ts +0 -94
- package/script/bench-test-suite.ts +0 -52
- package/script/build.ts +0 -243
- package/script/generate.ts +0 -14
- package/script/httpapi-exercise.ts +0 -1
- package/script/postinstall.mjs +0 -189
- package/script/profile-test-files.ts +0 -42
- package/script/publish.ts +0 -213
- package/script/run-workspace-server +0 -106
- package/script/schema.ts +0 -77
- package/script/time.ts +0 -6
- package/script/trace-imports.ts +0 -153
- package/specs/effect/error-boundaries-plan.md +0 -235
- package/specs/effect/errors.md +0 -207
- package/specs/effect/facades.md +0 -218
- package/specs/effect/guide.md +0 -247
- package/specs/effect/instance-context.md +0 -13
- package/specs/effect/loose-ends.md +0 -30
- package/specs/effect/migration.md +0 -62
- package/specs/effect/routes.md +0 -61
- package/specs/effect/schema.md +0 -88
- package/specs/effect/server-package.md +0 -58
- package/specs/effect/todo.md +0 -241
- package/specs/effect/tools.md +0 -88
- package/specs/openapi-translation-cleanup.md +0 -204
- package/specs/tui-plugins.md +0 -544
- package/specs/v2/api.ts +0 -67
- package/specs/v2/message-shape.md +0 -136
- package/specs/v2/notifications.md +0 -13
- package/specs/v2/tui-command-shim.md +0 -67
- 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 -336
- 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 -321
- package/src/acp/usage.ts +0 -232
- package/src/agent/agent.ts +0 -467
- 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 -253
- 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 -49
- 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 -280
- 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.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 -132
- 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-preset.ts +0 -175
- package/src/config/agent.ts +0 -59
- package/src/config/command.ts +0 -39
- package/src/config/config.ts +0 -703
- 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 -144
- package/src/mcp/index.ts +0 -953
- package/src/mcp/oauth-callback.ts +0 -221
- 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 -413
- package/src/plugin/github-copilot/models.ts +0 -246
- package/src/plugin/index.ts +0 -315
- 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 -640
- 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 -734
- 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 -1426
- 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 -260
- 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 -187
- 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 -217
- 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 -250
- 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 -744
- 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 -105
- package/src/session/prompt/beast.txt +0 -147
- package/src/session/prompt/build-switch.txt +0 -5
- package/src/session/prompt/codex.txt +0 -79
- package/src/session/prompt/copilot-gpt-5.txt +0 -143
- package/src/session/prompt/default.txt +0 -95
- package/src/session/prompt/gemini.txt +0 -155
- package/src/session/prompt/gpt.txt +0 -107
- package/src/session/prompt/kimi.txt +0 -95
- package/src/session/prompt/max-steps.txt +0 -16
- package/src/session/prompt/plan-mode.txt +0 -70
- package/src/session/prompt/plan-reminder-anthropic.txt +0 -67
- package/src/session/prompt/plan.txt +0 -26
- package/src/session/prompt/trinity.txt +0 -97
- package/src/session/prompt/ultrawork.txt +0 -289
- package/src/session/prompt.ts +0 -1725
- 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/session/ultrawork.ts +0 -26
- 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 -313
- package/src/tool/apply_patch.txt +0 -33
- package/src/tool/edit.ts +0 -737
- package/src/tool/edit.txt +0 -10
- package/src/tool/external-directory.ts +0 -49
- package/src/tool/glob.ts +0 -76
- package/src/tool/glob.txt +0 -6
- package/src/tool/grep.ts +0 -112
- package/src/tool/grep.txt +0 -8
- package/src/tool/invalid.ts +0 -21
- package/src/tool/json-schema.ts +0 -164
- package/src/tool/lsp.ts +0 -113
- package/src/tool/lsp.txt +0 -24
- package/src/tool/mcp-websearch.ts +0 -96
- package/src/tool/plan-enter.txt +0 -14
- package/src/tool/plan-exit.txt +0 -13
- package/src/tool/plan.ts +0 -79
- package/src/tool/question.ts +0 -44
- package/src/tool/question.txt +0 -10
- package/src/tool/read.ts +0 -386
- package/src/tool/read.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 -71
- package/src/tool/skill.txt +0 -5
- package/src/tool/task.ts +0 -346
- package/src/tool/task.txt +0 -19
- package/src/tool/todo.ts +0 -57
- package/src/tool/todowrite.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 -192
- package/src/tool/webfetch.txt +0 -13
- package/src/tool/websearch.ts +0 -143
- package/src/tool/websearch.txt +0 -14
- package/src/tool/write.ts +0 -104
- package/src/tool/write.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/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/sst-env.d.ts +0 -10
- package/test/AGENTS.md +0 -204
- package/test/EFFECT_TEST_MIGRATION.md +0 -169
- package/test/account/repo.test.ts +0 -353
- package/test/account/service.test.ts +0 -453
- package/test/acp/config-option.test.ts +0 -229
- package/test/acp/content.test.ts +0 -201
- package/test/acp/directory.test.ts +0 -186
- package/test/acp/error.test.ts +0 -67
- package/test/acp/event.test.ts +0 -743
- package/test/acp/permission.test.ts +0 -273
- package/test/acp/service-session.test.ts +0 -1174
- package/test/acp/session.test.ts +0 -200
- package/test/acp/tool.test.ts +0 -210
- package/test/acp/usage.test.ts +0 -315
- package/test/agent/agent.test.ts +0 -760
- package/test/agent/plan-mode-subagent-bypass.test.ts +0 -159
- package/test/agent/plugin-agent-regression.test.ts +0 -64
- package/test/auth/auth.test.ts +0 -77
- package/test/background/job.test.ts +0 -243
- package/test/cli/account.test.ts +0 -30
- package/test/cli/acp/acp-test-client.ts +0 -97
- package/test/cli/acp/config-options.test.ts +0 -103
- package/test/cli/acp/helpers.ts +0 -96
- package/test/cli/acp/initialize-auth.test.ts +0 -61
- package/test/cli/acp/lifecycle.test.ts +0 -118
- package/test/cli/acp/prompt-content.test.ts +0 -97
- package/test/cli/acp/skills.test.ts +0 -38
- package/test/cli/cmd/tui/attention.test.ts +0 -484
- package/test/cli/effect-cmd-instance-als.test.ts +0 -39
- package/test/cli/error.test.ts +0 -95
- package/test/cli/github-action.test.ts +0 -199
- package/test/cli/github-remote.test.ts +0 -90
- package/test/cli/help/__snapshots__/help-snapshots.test.ts.snap +0 -631
- package/test/cli/help/help-snapshots.test.ts +0 -137
- package/test/cli/import.test.ts +0 -54
- package/test/cli/mcp-add.test.ts +0 -74
- package/test/cli/plugin-auth-picker.test.ts +0 -120
- package/test/cli/run/entry.body.test.ts +0 -536
- package/test/cli/run/footer.menu.test.ts +0 -43
- package/test/cli/run/footer.view.test.tsx +0 -1375
- package/test/cli/run/footer.width.test.ts +0 -35
- package/test/cli/run/permission.shared.test.ts +0 -144
- package/test/cli/run/prompt.editor.test.ts +0 -101
- package/test/cli/run/prompt.shared.test.ts +0 -101
- package/test/cli/run/question.shared.test.ts +0 -115
- package/test/cli/run/run-process.test.ts +0 -84
- package/test/cli/run/runtime.boot.test.ts +0 -283
- package/test/cli/run/runtime.queue.test.ts +0 -481
- package/test/cli/run/runtime.stdin.test.ts +0 -71
- package/test/cli/run/runtime.test.ts +0 -238
- package/test/cli/run/scrollback.surface.test.ts +0 -1065
- package/test/cli/run/session-data.test.ts +0 -595
- package/test/cli/run/session-replay.test.ts +0 -692
- package/test/cli/run/session.shared.test.ts +0 -247
- package/test/cli/run/stream.test.ts +0 -56
- package/test/cli/run/stream.transport.test.ts +0 -2363
- package/test/cli/run/subagent-data.test.ts +0 -547
- package/test/cli/run/theme.test.ts +0 -177
- package/test/cli/run/variant.shared.test.ts +0 -217
- package/test/cli/serve/serve-process.test.ts +0 -61
- package/test/cli/smokes/read-only.test.ts +0 -115
- package/test/cli/tui/attach.test.ts +0 -11
- package/test/cli/tui/editor-context-zed.test.ts +0 -379
- package/test/cli/tui/editor-context.test.tsx +0 -297
- package/test/cli/tui/plugin-add.test.ts +0 -110
- package/test/cli/tui/plugin-install.test.ts +0 -87
- package/test/cli/tui/plugin-lifecycle.test.ts +0 -224
- package/test/cli/tui/plugin-loader-entrypoint.test.ts +0 -485
- package/test/cli/tui/plugin-loader-pure.test.ts +0 -72
- package/test/cli/tui/plugin-loader.test.ts +0 -1332
- package/test/cli/tui/plugin-toggle.test.ts +0 -264
- package/test/cli/tui/thread.test.ts +0 -36
- package/test/config/agent-color.test.ts +0 -47
- package/test/config/config.test.ts +0 -2041
- package/test/config/entry-name.test.ts +0 -57
- package/test/config/fixtures/empty-frontmatter.md +0 -4
- package/test/config/fixtures/frontmatter.md +0 -28
- package/test/config/fixtures/markdown-header.md +0 -11
- package/test/config/fixtures/no-frontmatter.md +0 -1
- package/test/config/fixtures/weird-model-id.md +0 -13
- package/test/config/lsp.test.ts +0 -69
- package/test/config/markdown.test.ts +0 -228
- package/test/config/plugin.test.ts +0 -0
- package/test/config/tui.test.ts +0 -886
- package/test/control-plane/adapters.test.ts +0 -71
- package/test/control-plane/workspace.test.ts +0 -1703
- package/test/effect/app-graph-types.test.ts +0 -108
- package/test/effect/app-graph.test.ts +0 -204
- package/test/effect/app-runtime-logger.test.ts +0 -99
- package/test/effect/config-service.test.ts +0 -65
- package/test/effect/instance-state.test.ts +0 -391
- package/test/effect/run-service.test.ts +0 -89
- package/test/effect/runner.test.ts +0 -514
- package/test/effect/runtime-flags.test.ts +0 -373
- package/test/fake/account.ts +0 -9
- package/test/fake/auth.ts +0 -8
- package/test/fake/npm.ts +0 -8
- package/test/fake/provider.ts +0 -82
- package/test/fake/skill.ts +0 -8
- package/test/filesystem/filesystem.test.ts +0 -319
- package/test/fixture/agent-plugin.constants.ts +0 -6
- package/test/fixture/agent-plugin.ts +0 -12
- package/test/fixture/config.ts +0 -23
- package/test/fixture/db.ts +0 -11
- package/test/fixture/fixture.test.ts +0 -26
- package/test/fixture/fixture.ts +0 -224
- package/test/fixture/flag.ts +0 -20
- package/test/fixture/flock-worker.ts +0 -72
- package/test/fixture/lsp/fake-lsp-server.js +0 -249
- package/test/fixture/mcp-session-recovery.ts +0 -50
- package/test/fixture/plug-worker.ts +0 -93
- package/test/fixture/plugin-meta-worker.ts +0 -19
- package/test/fixture/plugin.ts +0 -10
- package/test/fixture/skills/agents-sdk/SKILL.md +0 -152
- package/test/fixture/skills/agents-sdk/references/callable.md +0 -92
- package/test/fixture/skills/cloudflare/SKILL.md +0 -211
- package/test/fixture/skills/index.json +0 -6
- package/test/fixture/tui-environment.tsx +0 -32
- package/test/fixture/tui-plugin.ts +0 -355
- package/test/fixture/tui-runtime.ts +0 -56
- package/test/fixture/tui-sdk.ts +0 -82
- package/test/fixture/workspace.ts +0 -30
- package/test/fixtures/recordings/session/native-anthropic-tool-loop.json +0 -49
- package/test/fixtures/recordings/session/native-openai-oauth-tool-loop.json +0 -45
- package/test/fixtures/recordings/session/native-zen-tool-loop.json +0 -49
- package/test/format/format.test.ts +0 -228
- package/test/git/git.test.ts +0 -178
- package/test/ide/ide.test.ts +0 -82
- package/test/image/fixtures/picture-5mb-base64.png +0 -0
- package/test/image/image.test.ts +0 -123
- package/test/installation/installation.test.ts +0 -230
- package/test/lib/cli-process.ts +0 -459
- package/test/lib/effect.ts +0 -177
- package/test/lib/filesystem.ts +0 -10
- package/test/lib/llm-server.ts +0 -779
- package/test/lib/snapshot.ts +0 -73
- package/test/lib/test-provider.ts +0 -37
- package/test/lib/websocket.ts +0 -46
- package/test/lsp/client.test.ts +0 -488
- package/test/lsp/index.test.ts +0 -232
- package/test/lsp/jdtls-root.test.ts +0 -459
- package/test/lsp/launch.test.ts +0 -22
- package/test/lsp/lifecycle.test.ts +0 -160
- package/test/mcp/auth.test.ts +0 -78
- package/test/mcp/headers.test.ts +0 -126
- package/test/mcp/lifecycle.test.ts +0 -1213
- package/test/mcp/oauth-auto-connect.test.ts +0 -276
- package/test/mcp/oauth-browser.test.ts +0 -239
- package/test/mcp/oauth-callback.test.ts +0 -34
- package/test/mcp/oauth-provider.test.ts +0 -61
- package/test/mcp/session-recovery.test.ts +0 -27
- package/test/patch/patch.test.ts +0 -383
- package/test/permission/arity.test.ts +0 -33
- package/test/permission/next.test.ts +0 -1176
- package/test/permission-task.test.ts +0 -318
- package/test/plugin/auth-override.test.ts +0 -105
- package/test/plugin/cloudflare.test.ts +0 -68
- package/test/plugin/codex.test.ts +0 -247
- package/test/plugin/github-copilot-models.test.ts +0 -332
- package/test/plugin/install-concurrency.test.ts +0 -140
- package/test/plugin/install.test.ts +0 -570
- package/test/plugin/loader-shared.test.ts +0 -1303
- package/test/plugin/meta.test.ts +0 -137
- package/test/plugin/openai-rollout.test.ts +0 -17
- package/test/plugin/openai-ws.test.ts +0 -877
- package/test/plugin/shared.test.ts +0 -88
- package/test/plugin/snowflake-cortex.test.ts +0 -278
- package/test/plugin/trigger.test.ts +0 -120
- package/test/plugin/workspace-adapter.test.ts +0 -140
- package/test/plugin/xai.test.ts +0 -634
- package/test/preload.ts +0 -92
- package/test/project/instance-bootstrap.test.ts +0 -110
- package/test/project/instance.test.ts +0 -245
- package/test/project/migrate-global.test.ts +0 -167
- package/test/project/project-directory.test.ts +0 -201
- package/test/project/project.test.ts +0 -815
- package/test/project/vcs.test.ts +0 -336
- package/test/project/worktree-remove.test.ts +0 -126
- package/test/project/worktree.test.ts +0 -320
- package/test/provider/amazon-bedrock.test.ts +0 -360
- package/test/provider/cf-ai-gateway-e2e.test.ts +0 -132
- package/test/provider/digitalocean.test.ts +0 -123
- package/test/provider/gitlab-duo.test.ts +0 -412
- package/test/provider/header-timeout.test.ts +0 -233
- package/test/provider/model-status.test.ts +0 -61
- package/test/provider/provider.test.ts +0 -1793
- package/test/provider/transform.test.ts +0 -4207
- package/test/question/question.test.ts +0 -465
- package/test/server/AGENTS.md +0 -15
- package/test/server/auth.test.ts +0 -59
- package/test/server/global-bus.ts +0 -31
- package/test/server/global-session-list.test.ts +0 -104
- package/test/server/httpapi-authorization.test.ts +0 -174
- package/test/server/httpapi-compression.test.ts +0 -151
- package/test/server/httpapi-config.test.ts +0 -110
- package/test/server/httpapi-control-plane.test.ts +0 -63
- package/test/server/httpapi-cors-vary.test.ts +0 -63
- package/test/server/httpapi-cors.test.ts +0 -122
- package/test/server/httpapi-error-middleware.test.ts +0 -101
- package/test/server/httpapi-event.test.ts +0 -94
- package/test/server/httpapi-exercise/assertions.ts +0 -64
- package/test/server/httpapi-exercise/backend.ts +0 -144
- package/test/server/httpapi-exercise/dsl.ts +0 -210
- package/test/server/httpapi-exercise/environment.ts +0 -40
- package/test/server/httpapi-exercise/index.ts +0 -1685
- package/test/server/httpapi-exercise/report.ts +0 -66
- package/test/server/httpapi-exercise/routing.ts +0 -96
- package/test/server/httpapi-exercise/runner.ts +0 -267
- package/test/server/httpapi-exercise/runtime.ts +0 -52
- package/test/server/httpapi-exercise/types.ts +0 -123
- package/test/server/httpapi-experimental.test.ts +0 -297
- package/test/server/httpapi-file.test.ts +0 -73
- package/test/server/httpapi-global.test.ts +0 -66
- package/test/server/httpapi-instance-context.test.ts +0 -348
- package/test/server/httpapi-instance-route-auth.test.ts +0 -81
- package/test/server/httpapi-instance.test.ts +0 -265
- package/test/server/httpapi-layer.ts +0 -33
- package/test/server/httpapi-listen.test.ts +0 -412
- package/test/server/httpapi-mcp-oauth.test.ts +0 -73
- package/test/server/httpapi-mcp.test.ts +0 -223
- package/test/server/httpapi-mdns.test.ts +0 -79
- package/test/server/httpapi-promptasync-context.test.ts +0 -223
- package/test/server/httpapi-provider.test.ts +0 -400
- package/test/server/httpapi-pty.test.ts +0 -299
- package/test/server/httpapi-public-openapi.test.ts +0 -319
- package/test/server/httpapi-query-schema-drift.test.ts +0 -330
- package/test/server/httpapi-reference.test.ts +0 -62
- package/test/server/httpapi-schema-error-body.test.ts +0 -165
- package/test/server/httpapi-sdk.test.ts +0 -909
- package/test/server/httpapi-session.test.ts +0 -1011
- package/test/server/httpapi-sync.test.ts +0 -148
- package/test/server/httpapi-ui.test.ts +0 -453
- package/test/server/httpapi-v2-location.test.ts +0 -82
- package/test/server/httpapi-v2-pty.test.ts +0 -250
- package/test/server/httpapi-workspace-routing.test.ts +0 -555
- package/test/server/httpapi-workspace.test.ts +0 -513
- package/test/server/negative-tokens-regression.test.ts +0 -83
- package/test/server/project-copy.test.ts +0 -121
- package/test/server/project-init-git.test.ts +0 -114
- package/test/server/proxy-util.test.ts +0 -113
- package/test/server/sdk-error-shape.test.ts +0 -81
- package/test/server/sdk-v1-smoke.test.ts +0 -57
- package/test/server/session-actions.test.ts +0 -109
- package/test/server/session-diff-missing-patch.test.ts +0 -96
- package/test/server/session-list.test.ts +0 -312
- package/test/server/session-messages.test.ts +0 -179
- package/test/server/session-select.test.ts +0 -66
- package/test/server/workspace-proxy.test.ts +0 -181
- package/test/server/workspace-routing.test.ts +0 -94
- package/test/server/worktree-endpoint-repro.test.ts +0 -307
- package/test/session/compaction.test.ts +0 -1834
- package/test/session/instruction.test.ts +0 -256
- package/test/session/llm-native-recorded.test.ts +0 -433
- package/test/session/llm-native.test.ts +0 -760
- package/test/session/llm.test.ts +0 -1932
- package/test/session/message-v2.test.ts +0 -1661
- package/test/session/messages-pagination.test.ts +0 -1056
- package/test/session/processor-effect.test.ts +0 -1076
- package/test/session/prompt.test.ts +0 -2326
- package/test/session/retry.test.ts +0 -439
- package/test/session/revert-compact.test.ts +0 -639
- package/test/session/schema-decoding.test.ts +0 -313
- package/test/session/session-schema.test.ts +0 -78
- package/test/session/session.test.ts +0 -248
- package/test/session/snapshot-tool-race.test.ts +0 -190
- package/test/session/structured-output-integration.test.ts +0 -235
- package/test/session/structured-output.test.ts +0 -387
- package/test/session/system.test.ts +0 -86
- package/test/session/ultrawork.test.ts +0 -25
- package/test/share/share-next.test.ts +0 -326
- package/test/skill/discovery.test.ts +0 -139
- package/test/skill/skill.test.ts +0 -571
- package/test/snapshot/snapshot.test.ts +0 -1121
- package/test/storage/storage.test.ts +0 -296
- package/test/tool/__snapshots__/parameters.test.ts.snap +0 -484
- package/test/tool/__snapshots__/tool.test.ts.snap +0 -9
- package/test/tool/apply_patch.test.ts +0 -533
- package/test/tool/edit.test.ts +0 -578
- package/test/tool/external-directory.test.ts +0 -155
- package/test/tool/fixtures/large-image.png +0 -0
- package/test/tool/fixtures/models-api.json +0 -117299
- package/test/tool/glob.test.ts +0 -136
- package/test/tool/grep.test.ts +0 -225
- package/test/tool/lsp.test.ts +0 -181
- package/test/tool/parameters.test.ts +0 -293
- package/test/tool/question.test.ts +0 -138
- package/test/tool/read.test.ts +0 -605
- package/test/tool/registry.test.ts +0 -497
- package/test/tool/shell.test.ts +0 -1238
- package/test/tool/skill.test.ts +0 -136
- package/test/tool/task.test.ts +0 -898
- package/test/tool/tool-define.test.ts +0 -153
- package/test/tool/truncation.test.ts +0 -266
- package/test/tool/webfetch.test.ts +0 -113
- package/test/tool/websearch.test.ts +0 -99
- package/test/tool/write.test.ts +0 -276
- package/test/util/data-url.test.ts +0 -14
- package/test/util/error.test.ts +0 -16
- package/test/util/filesystem.test.ts +0 -656
- package/test/util/glob.test.ts +0 -164
- package/test/util/iife.test.ts +0 -36
- package/test/util/lazy.test.ts +0 -50
- package/test/util/module.test.ts +0 -59
- package/test/util/process.test.ts +0 -128
- package/test/util/repository.test.ts +0 -93
- package/test/util/timeout.test.ts +0 -21
- package/test/util/wildcard.test.ts +0 -90
- package/test/v2/session-message-updater.test.ts +0 -269
- package/tsconfig.json +0 -16
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
import { NodeHttpServer, NodeServices } from "@effect/platform-node"
|
|
2
|
-
import { Config, Layer } from "effect"
|
|
3
|
-
import { HttpClient, HttpClientRequest, HttpRouter, HttpServer } from "effect/unstable/http"
|
|
4
|
-
import { layerWebSocketConstructorGlobal } from "effect/unstable/socket/Socket"
|
|
5
|
-
import { HttpApiApp } from "../../src/server/routes/instance/httpapi/server"
|
|
6
|
-
|
|
7
|
-
const servedRoutes: Layer.Layer<never, Config.ConfigError, HttpServer.HttpServer> = HttpRouter.serve(
|
|
8
|
-
HttpApiApp.routes,
|
|
9
|
-
{
|
|
10
|
-
disableListenLog: true,
|
|
11
|
-
disableLogger: true,
|
|
12
|
-
},
|
|
13
|
-
)
|
|
14
|
-
|
|
15
|
-
export const httpApiLayer = servedRoutes.pipe(
|
|
16
|
-
Layer.provide(layerWebSocketConstructorGlobal),
|
|
17
|
-
Layer.provideMerge(NodeHttpServer.layerTest),
|
|
18
|
-
Layer.provideMerge(NodeServices.layer),
|
|
19
|
-
)
|
|
20
|
-
|
|
21
|
-
export function request(path: string, init?: RequestInit) {
|
|
22
|
-
const url = new URL(path, "http://localhost")
|
|
23
|
-
return HttpClientRequest.fromWeb(new Request(url, init)).pipe(
|
|
24
|
-
HttpClientRequest.setUrl(url.pathname),
|
|
25
|
-
HttpClient.execute,
|
|
26
|
-
)
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
export function requestInDirectory(path: string, directory: string, init: RequestInit = {}) {
|
|
30
|
-
const headers = new Headers(init.headers)
|
|
31
|
-
headers.set("x-miaw-directory", directory)
|
|
32
|
-
return request(path, { ...init, headers })
|
|
33
|
-
}
|
|
@@ -1,412 +0,0 @@
|
|
|
1
|
-
import { afterEach, describe, expect, test } from "bun:test"
|
|
2
|
-
import net from "node:net"
|
|
3
|
-
import { Flag } from "@miaw/core/flag/flag"
|
|
4
|
-
import { Server } from "../../src/server/server"
|
|
5
|
-
import { PtyPaths } from "../../src/server/routes/instance/httpapi/groups/pty"
|
|
6
|
-
import { withTimeout } from "../../src/util/timeout"
|
|
7
|
-
import { resetDatabase } from "../fixture/db"
|
|
8
|
-
import { disposeAllInstances, tmpdir } from "../fixture/fixture"
|
|
9
|
-
|
|
10
|
-
const original = {
|
|
11
|
-
MIAW_SERVER_PASSWORD: Flag.MIAW_SERVER_PASSWORD,
|
|
12
|
-
MIAW_SERVER_USERNAME: Flag.MIAW_SERVER_USERNAME,
|
|
13
|
-
envPassword: process.env.MIAW_SERVER_PASSWORD,
|
|
14
|
-
envUsername: process.env.MIAW_SERVER_USERNAME,
|
|
15
|
-
}
|
|
16
|
-
const auth = { username: "miaw", password: "listen-secret" }
|
|
17
|
-
const testPty = process.platform === "win32" ? test.skip : test
|
|
18
|
-
|
|
19
|
-
afterEach(async () => {
|
|
20
|
-
Flag.MIAW_SERVER_PASSWORD = original.MIAW_SERVER_PASSWORD
|
|
21
|
-
Flag.MIAW_SERVER_USERNAME = original.MIAW_SERVER_USERNAME
|
|
22
|
-
if (original.envPassword === undefined) delete process.env.MIAW_SERVER_PASSWORD
|
|
23
|
-
else process.env.MIAW_SERVER_PASSWORD = original.envPassword
|
|
24
|
-
if (original.envUsername === undefined) delete process.env.MIAW_SERVER_USERNAME
|
|
25
|
-
else process.env.MIAW_SERVER_USERNAME = original.envUsername
|
|
26
|
-
await disposeAllInstances()
|
|
27
|
-
await resetDatabase()
|
|
28
|
-
})
|
|
29
|
-
|
|
30
|
-
async function startListener() {
|
|
31
|
-
Flag.MIAW_SERVER_PASSWORD = auth.password
|
|
32
|
-
Flag.MIAW_SERVER_USERNAME = auth.username
|
|
33
|
-
process.env.MIAW_SERVER_PASSWORD = auth.password
|
|
34
|
-
process.env.MIAW_SERVER_USERNAME = auth.username
|
|
35
|
-
return Server.listen({ hostname: "127.0.0.1", port: 0 })
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
async function startNoAuthListener() {
|
|
39
|
-
Flag.MIAW_SERVER_PASSWORD = undefined
|
|
40
|
-
Flag.MIAW_SERVER_USERNAME = auth.username
|
|
41
|
-
delete process.env.MIAW_SERVER_PASSWORD
|
|
42
|
-
process.env.MIAW_SERVER_USERNAME = auth.username
|
|
43
|
-
return Server.listen({ hostname: "127.0.0.1", port: 0 })
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
function authorization() {
|
|
47
|
-
return `Basic ${btoa(`${auth.username}:${auth.password}`)}`
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
function socketURL(listener: Awaited<ReturnType<typeof startListener>>, id: string, dir: string, ticket?: string) {
|
|
51
|
-
const url = new URL(PtyPaths.connect.replace(":ptyID", id), listener.url)
|
|
52
|
-
url.protocol = "ws:"
|
|
53
|
-
url.searchParams.set("directory", dir)
|
|
54
|
-
url.searchParams.set("cursor", "-1")
|
|
55
|
-
if (ticket) url.searchParams.set("ticket", ticket)
|
|
56
|
-
return url
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
async function requestTicket(
|
|
60
|
-
listener: Awaited<ReturnType<typeof startListener>>,
|
|
61
|
-
id: string,
|
|
62
|
-
dir: string,
|
|
63
|
-
options?: { ticketHeader?: boolean; origin?: string },
|
|
64
|
-
) {
|
|
65
|
-
const response = await fetch(new URL(PtyPaths.connectToken.replace(":ptyID", id), listener.url), {
|
|
66
|
-
method: "POST",
|
|
67
|
-
headers: {
|
|
68
|
-
authorization: authorization(),
|
|
69
|
-
"x-miaw-directory": dir,
|
|
70
|
-
...(options?.ticketHeader === false ? {} : { "x-miaw-ticket": "1" }),
|
|
71
|
-
...(options?.origin ? { origin: options.origin } : {}),
|
|
72
|
-
},
|
|
73
|
-
})
|
|
74
|
-
|
|
75
|
-
return response
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
async function connectTicket(listener: Awaited<ReturnType<typeof startListener>>, id: string, dir: string) {
|
|
79
|
-
const response = await requestTicket(listener, id, dir)
|
|
80
|
-
expect(response.status).toBe(200)
|
|
81
|
-
return (await response.json()) as { ticket: string; expires_in: number }
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
async function createCat(listener: Awaited<ReturnType<typeof startListener>>, dir: string) {
|
|
85
|
-
const response = await fetch(new URL(PtyPaths.create, listener.url), {
|
|
86
|
-
method: "POST",
|
|
87
|
-
headers: {
|
|
88
|
-
authorization: authorization(),
|
|
89
|
-
"x-miaw-directory": dir,
|
|
90
|
-
"content-type": "application/json",
|
|
91
|
-
},
|
|
92
|
-
body: JSON.stringify({ command: "/bin/cat", title: "listen-smoke" }),
|
|
93
|
-
})
|
|
94
|
-
expect(response.status).toBe(200)
|
|
95
|
-
return (await response.json()) as { id: string }
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
async function openSocket(url: URL) {
|
|
99
|
-
const ws = new WebSocket(url)
|
|
100
|
-
ws.binaryType = "arraybuffer"
|
|
101
|
-
await withTimeout(
|
|
102
|
-
new Promise<void>((resolve, reject) => {
|
|
103
|
-
ws.addEventListener("open", () => resolve(), { once: true })
|
|
104
|
-
ws.addEventListener("error", () => reject(new Error("websocket failed before open")), { once: true })
|
|
105
|
-
}),
|
|
106
|
-
5_000,
|
|
107
|
-
"timed out waiting for websocket open",
|
|
108
|
-
)
|
|
109
|
-
return ws
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
async function expectSocketRejected(url: URL, init?: { headers?: Record<string, string> }) {
|
|
113
|
-
// Bun's WebSocket accepts an init object with headers; standard DOM types don't reflect that.
|
|
114
|
-
const Ctor = WebSocket as unknown as new (url: URL, init?: { headers?: Record<string, string> }) => WebSocket
|
|
115
|
-
const ws = new Ctor(url, init)
|
|
116
|
-
await withTimeout(
|
|
117
|
-
new Promise<void>((resolve, reject) => {
|
|
118
|
-
ws.addEventListener(
|
|
119
|
-
"open",
|
|
120
|
-
() => {
|
|
121
|
-
ws.close(1000)
|
|
122
|
-
reject(new Error("websocket opened"))
|
|
123
|
-
},
|
|
124
|
-
{ once: true },
|
|
125
|
-
)
|
|
126
|
-
ws.addEventListener("error", () => resolve(), { once: true })
|
|
127
|
-
ws.addEventListener("close", () => resolve(), { once: true })
|
|
128
|
-
}),
|
|
129
|
-
5_000,
|
|
130
|
-
"timed out waiting for websocket rejection",
|
|
131
|
-
)
|
|
132
|
-
}
|
|
133
|
-
|
|
134
|
-
function stop(listener: Awaited<ReturnType<typeof startListener>>, label: string) {
|
|
135
|
-
return withTimeout(listener.stop(true), 10_000, label)
|
|
136
|
-
}
|
|
137
|
-
|
|
138
|
-
function waitForMessage(ws: WebSocket, predicate: (message: string) => boolean) {
|
|
139
|
-
const decoder = new TextDecoder()
|
|
140
|
-
let onMessage: ((event: MessageEvent) => void) | undefined
|
|
141
|
-
return withTimeout(
|
|
142
|
-
new Promise<string>((resolve) => {
|
|
143
|
-
onMessage = (event: MessageEvent) => {
|
|
144
|
-
const message = typeof event.data === "string" ? event.data : decoder.decode(event.data as ArrayBuffer)
|
|
145
|
-
if (!predicate(message)) return
|
|
146
|
-
resolve(message)
|
|
147
|
-
}
|
|
148
|
-
ws.addEventListener("message", onMessage)
|
|
149
|
-
}),
|
|
150
|
-
5_000,
|
|
151
|
-
"timed out waiting for websocket message",
|
|
152
|
-
).finally(() => {
|
|
153
|
-
if (onMessage) ws.removeEventListener("message", onMessage)
|
|
154
|
-
})
|
|
155
|
-
}
|
|
156
|
-
|
|
157
|
-
async function openPtySocket(listener: Awaited<ReturnType<typeof startListener>>, dir: string) {
|
|
158
|
-
const info = await createCat(listener, dir)
|
|
159
|
-
const ticket = await connectTicket(listener, info.id, dir)
|
|
160
|
-
const ws = await openSocket(socketURL(listener, info.id, dir, ticket.ticket))
|
|
161
|
-
return {
|
|
162
|
-
ws,
|
|
163
|
-
closed: new Promise<void>((resolve) => ws.addEventListener("close", () => resolve(), { once: true })),
|
|
164
|
-
}
|
|
165
|
-
}
|
|
166
|
-
|
|
167
|
-
describe("HttpApi Server.listen", () => {
|
|
168
|
-
testPty("serves HTTP routes and upgrades PTY websocket through Server.listen", async () => {
|
|
169
|
-
await using tmp = await tmpdir({ config: { formatter: false, lsp: false } })
|
|
170
|
-
const listener = await startListener()
|
|
171
|
-
let stopped = false
|
|
172
|
-
try {
|
|
173
|
-
const response = await fetch(new URL(PtyPaths.shells, listener.url), {
|
|
174
|
-
headers: { authorization: authorization(), "x-miaw-directory": tmp.path },
|
|
175
|
-
})
|
|
176
|
-
expect(response.status).toBe(200)
|
|
177
|
-
expect(await response.json()).toEqual(
|
|
178
|
-
expect.arrayContaining([
|
|
179
|
-
expect.objectContaining({
|
|
180
|
-
path: expect.any(String),
|
|
181
|
-
name: expect.any(String),
|
|
182
|
-
acceptable: expect.any(Boolean),
|
|
183
|
-
}),
|
|
184
|
-
]),
|
|
185
|
-
)
|
|
186
|
-
|
|
187
|
-
const info = await createCat(listener, tmp.path)
|
|
188
|
-
const ticket = await connectTicket(listener, info.id, tmp.path)
|
|
189
|
-
expect(ticket.expires_in).toBeGreaterThan(0)
|
|
190
|
-
const ws = await openSocket(socketURL(listener, info.id, tmp.path, ticket.ticket))
|
|
191
|
-
const closed = new Promise<void>((resolve) => ws.addEventListener("close", () => resolve(), { once: true }))
|
|
192
|
-
|
|
193
|
-
const message = waitForMessage(ws, (message) => message.includes("ping-listen"))
|
|
194
|
-
ws.send("ping-listen\n")
|
|
195
|
-
expect(await message).toContain("ping-listen")
|
|
196
|
-
|
|
197
|
-
await stop(listener, "timed out waiting for listener.stop(true)")
|
|
198
|
-
stopped = true
|
|
199
|
-
await withTimeout(closed, 5_000, "timed out waiting for websocket close")
|
|
200
|
-
expect(ws.readyState).toBe(WebSocket.CLOSED)
|
|
201
|
-
|
|
202
|
-
const restarted = await startListener()
|
|
203
|
-
try {
|
|
204
|
-
const nextInfo = await createCat(restarted, tmp.path)
|
|
205
|
-
const nextTicket = await connectTicket(restarted, nextInfo.id, tmp.path)
|
|
206
|
-
const nextWs = await openSocket(socketURL(restarted, nextInfo.id, tmp.path, nextTicket.ticket))
|
|
207
|
-
const nextMessage = waitForMessage(nextWs, (message) => message.includes("ping-restarted"))
|
|
208
|
-
nextWs.send("ping-restarted\n")
|
|
209
|
-
expect(await nextMessage).toContain("ping-restarted")
|
|
210
|
-
nextWs.close(1000)
|
|
211
|
-
} finally {
|
|
212
|
-
await stop(restarted, "timed out waiting for restarted listener.stop(true)")
|
|
213
|
-
}
|
|
214
|
-
} finally {
|
|
215
|
-
if (!stopped) await stop(listener, "timed out cleaning up listener").catch(() => undefined)
|
|
216
|
-
}
|
|
217
|
-
})
|
|
218
|
-
|
|
219
|
-
testPty("stop(true) is safe when called concurrently and repeatedly", async () => {
|
|
220
|
-
await using tmp = await tmpdir({ git: true, config: { formatter: false, lsp: false } })
|
|
221
|
-
const listener = await startListener()
|
|
222
|
-
let stopped = false
|
|
223
|
-
try {
|
|
224
|
-
const socket = await openPtySocket(listener, tmp.path)
|
|
225
|
-
|
|
226
|
-
await withTimeout(
|
|
227
|
-
Promise.all([listener.stop(true), listener.stop(true)]).then(() => undefined),
|
|
228
|
-
10_000,
|
|
229
|
-
"timed out waiting for concurrent listener.stop(true)",
|
|
230
|
-
)
|
|
231
|
-
await withTimeout(socket.closed, 5_000, "timed out waiting for websocket close after concurrent stop")
|
|
232
|
-
await withTimeout(listener.stop(true), 5_000, "timed out waiting for repeated listener.stop(true)")
|
|
233
|
-
stopped = true
|
|
234
|
-
} finally {
|
|
235
|
-
if (!stopped) await stop(listener, "timed out cleaning up concurrent stop listener").catch(() => undefined)
|
|
236
|
-
}
|
|
237
|
-
})
|
|
238
|
-
|
|
239
|
-
testPty("stop(true) can force a graceful stop already in progress", async () => {
|
|
240
|
-
await using tmp = await tmpdir({ git: true, config: { formatter: false, lsp: false } })
|
|
241
|
-
const listener = await startListener()
|
|
242
|
-
let stopped = false
|
|
243
|
-
try {
|
|
244
|
-
const socket = await openPtySocket(listener, tmp.path)
|
|
245
|
-
|
|
246
|
-
const graceful = listener.stop()
|
|
247
|
-
const forced = listener.stop(true)
|
|
248
|
-
await withTimeout(
|
|
249
|
-
Promise.all([graceful, forced]).then(() => undefined),
|
|
250
|
-
10_000,
|
|
251
|
-
"timed out waiting for forced listener stop",
|
|
252
|
-
)
|
|
253
|
-
await withTimeout(socket.closed, 5_000, "timed out waiting for websocket close after forced stop")
|
|
254
|
-
stopped = true
|
|
255
|
-
} finally {
|
|
256
|
-
if (!stopped) await stop(listener, "timed out cleaning up forced stop listener").catch(() => undefined)
|
|
257
|
-
}
|
|
258
|
-
})
|
|
259
|
-
|
|
260
|
-
testPty("graceful stop waits for an overlapping forced stop", async () => {
|
|
261
|
-
await using tmp = await tmpdir({ git: true, config: { formatter: false, lsp: false } })
|
|
262
|
-
const listener = await startListener()
|
|
263
|
-
let stopped = false
|
|
264
|
-
try {
|
|
265
|
-
const socket = await openPtySocket(listener, tmp.path)
|
|
266
|
-
const forced = listener.stop(true)
|
|
267
|
-
await withTimeout(listener.stop(), 10_000, "timed out waiting for graceful stop after forced stop")
|
|
268
|
-
stopped = true
|
|
269
|
-
await withTimeout(forced, 5_000, "timed out waiting for overlapping forced stop")
|
|
270
|
-
await withTimeout(socket.closed, 5_000, "timed out waiting for websocket close before graceful stop resolved")
|
|
271
|
-
} finally {
|
|
272
|
-
if (!stopped) await stop(listener, "timed out cleaning up overlapping stop listener").catch(() => undefined)
|
|
273
|
-
}
|
|
274
|
-
})
|
|
275
|
-
|
|
276
|
-
test("stop() gracefully closes an idle listener and is repeat-safe", async () => {
|
|
277
|
-
const listener = await startListener()
|
|
278
|
-
await withTimeout(listener.stop(), 10_000, "timed out waiting for graceful listener.stop()")
|
|
279
|
-
await withTimeout(listener.stop(), 5_000, "timed out waiting for repeated graceful listener.stop()")
|
|
280
|
-
await expect(
|
|
281
|
-
fetch(new URL(PtyPaths.shells, listener.url), { headers: { authorization: authorization() } }),
|
|
282
|
-
).rejects.toThrow()
|
|
283
|
-
})
|
|
284
|
-
|
|
285
|
-
test("default in-process handler does not emit Effect HTTP response logs", async () => {
|
|
286
|
-
let output = ""
|
|
287
|
-
// oxlint-disable-next-line typescript-eslint/unbound-method -- restored in finally after temporarily capturing stderr.
|
|
288
|
-
const original = process.stderr.write
|
|
289
|
-
process.stderr.write = ((chunk) => {
|
|
290
|
-
output += String(chunk)
|
|
291
|
-
return true
|
|
292
|
-
}) as typeof process.stderr.write
|
|
293
|
-
try {
|
|
294
|
-
const response = await Server.Default().app.request("/status")
|
|
295
|
-
expect(response.status).toBe(200)
|
|
296
|
-
} finally {
|
|
297
|
-
process.stderr.write = original
|
|
298
|
-
}
|
|
299
|
-
|
|
300
|
-
expect(output).not.toContain("Sent HTTP response")
|
|
301
|
-
})
|
|
302
|
-
|
|
303
|
-
test("port 0 prefers 4096 when free", async () => {
|
|
304
|
-
if (!(await isPortFree(4096))) return
|
|
305
|
-
const listener = await startListener()
|
|
306
|
-
try {
|
|
307
|
-
expect(listener.port).toBe(4096)
|
|
308
|
-
} finally {
|
|
309
|
-
await stop(listener, "timed out cleaning up port-0 prefers-4096 listener")
|
|
310
|
-
}
|
|
311
|
-
})
|
|
312
|
-
|
|
313
|
-
test("port 0 falls back when 4096 is taken", async () => {
|
|
314
|
-
const blocker = await occupyPort(4096)
|
|
315
|
-
if (!blocker) return
|
|
316
|
-
try {
|
|
317
|
-
const listener = await startListener()
|
|
318
|
-
try {
|
|
319
|
-
expect(listener.port).not.toBe(4096)
|
|
320
|
-
expect(listener.port).toBeGreaterThan(0)
|
|
321
|
-
} finally {
|
|
322
|
-
await stop(listener, "timed out cleaning up port-0 fallback listener")
|
|
323
|
-
}
|
|
324
|
-
} finally {
|
|
325
|
-
await new Promise<void>((resolve) => blocker.close(() => resolve()))
|
|
326
|
-
}
|
|
327
|
-
})
|
|
328
|
-
|
|
329
|
-
testPty("rejects unsafe PTY ticket mint and connect requests", async () => {
|
|
330
|
-
await using tmp = await tmpdir({ config: { formatter: false, lsp: false } })
|
|
331
|
-
const listener = await startListener()
|
|
332
|
-
try {
|
|
333
|
-
const info = await createCat(listener, tmp.path)
|
|
334
|
-
|
|
335
|
-
expect((await requestTicket(listener, info.id, tmp.path, { ticketHeader: false })).status).toBe(403)
|
|
336
|
-
expect((await requestTicket(listener, info.id, tmp.path, { origin: "https://evil.example" })).status).toBe(403)
|
|
337
|
-
|
|
338
|
-
// Regression for #25698: minting without a directory uses the server cwd
|
|
339
|
-
// and cannot find a PTY registered in a project directory.
|
|
340
|
-
const ambiguous = await fetch(new URL(PtyPaths.connectToken.replace(":ptyID", info.id), listener.url), {
|
|
341
|
-
method: "POST",
|
|
342
|
-
headers: { authorization: authorization(), "x-miaw-ticket": "1" },
|
|
343
|
-
})
|
|
344
|
-
expect(ambiguous.status).toBe(404)
|
|
345
|
-
|
|
346
|
-
const directoryScoped = await fetch(
|
|
347
|
-
new URL(
|
|
348
|
-
`${PtyPaths.connectToken.replace(":ptyID", info.id)}?directory=${encodeURIComponent(tmp.path)}`,
|
|
349
|
-
listener.url,
|
|
350
|
-
),
|
|
351
|
-
{
|
|
352
|
-
method: "POST",
|
|
353
|
-
headers: { authorization: authorization(), "x-miaw-ticket": "1" },
|
|
354
|
-
},
|
|
355
|
-
)
|
|
356
|
-
expect(directoryScoped.status).toBe(200)
|
|
357
|
-
const mint = (await directoryScoped.json()) as { ticket: string }
|
|
358
|
-
const scopedWs = await openSocket(socketURL(listener, info.id, tmp.path, mint.ticket))
|
|
359
|
-
scopedWs.close(1000)
|
|
360
|
-
|
|
361
|
-
await expectSocketRejected(socketURL(listener, info.id, tmp.path, "not-a-ticket"))
|
|
362
|
-
|
|
363
|
-
const reusable = await connectTicket(listener, info.id, tmp.path)
|
|
364
|
-
const ws = await openSocket(socketURL(listener, info.id, tmp.path, reusable.ticket))
|
|
365
|
-
await expectSocketRejected(socketURL(listener, info.id, tmp.path, reusable.ticket))
|
|
366
|
-
ws.close(1000)
|
|
367
|
-
|
|
368
|
-
const other = await createCat(listener, tmp.path)
|
|
369
|
-
const scoped = await connectTicket(listener, info.id, tmp.path)
|
|
370
|
-
await expectSocketRejected(socketURL(listener, other.id, tmp.path, scoped.ticket))
|
|
371
|
-
|
|
372
|
-
const crossOrigin = await connectTicket(listener, info.id, tmp.path)
|
|
373
|
-
await expectSocketRejected(socketURL(listener, info.id, tmp.path, crossOrigin.ticket), {
|
|
374
|
-
headers: { origin: "https://evil.example" },
|
|
375
|
-
})
|
|
376
|
-
} finally {
|
|
377
|
-
await stop(listener, "timed out cleaning up rejected ticket listener").catch(() => undefined)
|
|
378
|
-
}
|
|
379
|
-
})
|
|
380
|
-
|
|
381
|
-
testPty("keeps PTY websocket tickets optional when server auth is disabled", async () => {
|
|
382
|
-
await using tmp = await tmpdir({ config: { formatter: false, lsp: false } })
|
|
383
|
-
const listener = await startNoAuthListener()
|
|
384
|
-
try {
|
|
385
|
-
const info = await createCat(listener, tmp.path)
|
|
386
|
-
const ws = await openSocket(socketURL(listener, info.id, tmp.path))
|
|
387
|
-
const message = waitForMessage(ws, (message) => message.includes("ping-no-auth"))
|
|
388
|
-
ws.send("ping-no-auth\n")
|
|
389
|
-
expect(await message).toContain("ping-no-auth")
|
|
390
|
-
ws.close(1000)
|
|
391
|
-
} finally {
|
|
392
|
-
await stop(listener, "timed out cleaning up no-auth listener").catch(() => undefined)
|
|
393
|
-
}
|
|
394
|
-
})
|
|
395
|
-
})
|
|
396
|
-
|
|
397
|
-
function isPortFree(port: number) {
|
|
398
|
-
return new Promise<boolean>((resolve) => {
|
|
399
|
-
const probe = net.createServer()
|
|
400
|
-
probe.once("error", () => resolve(false))
|
|
401
|
-
probe.once("listening", () => probe.close(() => resolve(true)))
|
|
402
|
-
probe.listen(port, "127.0.0.1")
|
|
403
|
-
})
|
|
404
|
-
}
|
|
405
|
-
|
|
406
|
-
function occupyPort(port: number) {
|
|
407
|
-
return new Promise<net.Server | undefined>((resolve) => {
|
|
408
|
-
const server = net.createServer()
|
|
409
|
-
server.once("error", () => resolve(undefined))
|
|
410
|
-
server.listen(port, "127.0.0.1", () => resolve(server))
|
|
411
|
-
})
|
|
412
|
-
}
|
|
@@ -1,73 +0,0 @@
|
|
|
1
|
-
import { NodeHttpServer } from "@effect/platform-node"
|
|
2
|
-
import { Session } from "@/session/session"
|
|
3
|
-
import { describe, expect } from "bun:test"
|
|
4
|
-
import { Effect, Layer } from "effect"
|
|
5
|
-
import { HttpClient, HttpClientRequest, HttpRouter } from "effect/unstable/http"
|
|
6
|
-
import { HttpApi, HttpApiBuilder } from "effect/unstable/httpapi"
|
|
7
|
-
import { McpApi, McpPaths } from "../../src/server/routes/instance/httpapi/groups/mcp"
|
|
8
|
-
import { Authorization } from "../../src/server/routes/instance/httpapi/middleware/authorization"
|
|
9
|
-
import { InstanceContextMiddleware } from "../../src/server/routes/instance/httpapi/middleware/instance-context"
|
|
10
|
-
import {
|
|
11
|
-
WorkspaceRouteContext,
|
|
12
|
-
WorkspaceRoutingMiddleware,
|
|
13
|
-
} from "../../src/server/routes/instance/httpapi/middleware/workspace-routing"
|
|
14
|
-
import { testEffect } from "../lib/effect"
|
|
15
|
-
|
|
16
|
-
const TestHttpApi = HttpApi.make("miaw-instance").addHttpApi(McpApi)
|
|
17
|
-
const fakeSession = Layer.mock(Session.Service)({})
|
|
18
|
-
const testMcpHandlers = HttpApiBuilder.group(TestHttpApi, "mcp", (handlers) =>
|
|
19
|
-
Effect.succeed(
|
|
20
|
-
handlers
|
|
21
|
-
.handle("status", () => Effect.die("unexpected MCP status"))
|
|
22
|
-
.handle("add", () => Effect.die("unexpected MCP add"))
|
|
23
|
-
.handle("authStart", () =>
|
|
24
|
-
Effect.succeed({ authorizationUrl: "https://auth.example/start", oauthState: "state-123" }),
|
|
25
|
-
)
|
|
26
|
-
.handle("authCallback", () => Effect.die("unexpected MCP authCallback"))
|
|
27
|
-
.handle("authAuthenticate", () => Effect.die("unexpected MCP authAuthenticate"))
|
|
28
|
-
.handle("authRemove", () => Effect.die("unexpected MCP authRemove"))
|
|
29
|
-
.handle("connect", () => Effect.die("unexpected MCP connect"))
|
|
30
|
-
.handle("disconnect", () => Effect.die("unexpected MCP disconnect")),
|
|
31
|
-
),
|
|
32
|
-
)
|
|
33
|
-
|
|
34
|
-
const passthroughAuthorization = Layer.succeed(
|
|
35
|
-
Authorization,
|
|
36
|
-
Authorization.of((effect) => effect),
|
|
37
|
-
)
|
|
38
|
-
|
|
39
|
-
const passthroughInstanceContext = Layer.succeed(
|
|
40
|
-
InstanceContextMiddleware,
|
|
41
|
-
InstanceContextMiddleware.of((effect) => effect),
|
|
42
|
-
)
|
|
43
|
-
|
|
44
|
-
const testWorkspaceRouting = Layer.succeed(
|
|
45
|
-
WorkspaceRoutingMiddleware,
|
|
46
|
-
WorkspaceRoutingMiddleware.of((effect) =>
|
|
47
|
-
effect.pipe(Effect.provideService(WorkspaceRouteContext, WorkspaceRouteContext.of({ directory: process.cwd() }))),
|
|
48
|
-
),
|
|
49
|
-
)
|
|
50
|
-
|
|
51
|
-
const it = testEffect(
|
|
52
|
-
HttpRouter.serve(
|
|
53
|
-
HttpApiBuilder.layer(TestHttpApi).pipe(
|
|
54
|
-
Layer.provide(testMcpHandlers),
|
|
55
|
-
Layer.provide([passthroughAuthorization, passthroughInstanceContext, testWorkspaceRouting, fakeSession]),
|
|
56
|
-
),
|
|
57
|
-
{ disableListenLog: true, disableLogger: true },
|
|
58
|
-
).pipe(Layer.provideMerge(NodeHttpServer.layerTest)),
|
|
59
|
-
)
|
|
60
|
-
|
|
61
|
-
describe("mcp HttpApi OAuth", () => {
|
|
62
|
-
it.live("preserves oauth state when starting OAuth", () =>
|
|
63
|
-
Effect.gen(function* () {
|
|
64
|
-
const response = yield* HttpClientRequest.post(McpPaths.auth.replace(":name", "demo")).pipe(HttpClient.execute)
|
|
65
|
-
|
|
66
|
-
expect(response.status).toBe(200)
|
|
67
|
-
expect(yield* response.json).toEqual({
|
|
68
|
-
authorizationUrl: "https://auth.example/start",
|
|
69
|
-
oauthState: "state-123",
|
|
70
|
-
})
|
|
71
|
-
}),
|
|
72
|
-
)
|
|
73
|
-
})
|