rird 2.1.231 → 2.3.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/AGENTS.md +86 -0
- package/COMPLETED_TEST_SUITE.txt +280 -0
- package/Dockerfile +18 -0
- package/README.md +397 -6
- package/RIRD_ERROR_HANDLING_SUMMARY.md +307 -0
- package/TESTING.md +512 -0
- package/TEST_IMPLEMENTATION_REPORT.md +463 -0
- package/TEST_SUITE.md +307 -0
- package/TEST_SUMMARY.txt +380 -0
- package/bin/rird-perf.js +37 -0
- package/bin/rird.js +43 -8
- package/bunfig.toml +4 -0
- package/create-wrapper.ps1 +51 -0
- package/docs/ARCHITECTURE.md +768 -0
- package/docs/CLI_REFERENCE.md +681 -0
- package/docs/DOCUMENTATION_MANIFEST.md +392 -0
- package/docs/INDEX.md +295 -0
- package/docs/PRODUCTION_SETUP.md +633 -0
- package/docs/TROUBLESHOOTING.md +914 -0
- package/facebook_ads_library.png +0 -0
- package/nul +0 -0
- package/nul`nif +0 -0
- package/package.json +104 -15
- package/parsers-config.ts +239 -0
- package/rird-1.0.199.tgz +0 -0
- package/rird-1.0.205.tgz +0 -0
- package/script/build-windows.ts +56 -0
- package/script/build.ts +165 -0
- package/{postinstall.mjs → script/postinstall.mjs} +47 -68
- package/script/publish-registries.ts +187 -0
- package/script/publish.ts +85 -0
- package/script/schema.ts +47 -0
- package/src/acp/README.md +164 -0
- package/src/acp/agent.ts +1063 -0
- package/src/acp/session.ts +101 -0
- package/src/acp/types.ts +22 -0
- package/src/agent/agent.ts +367 -0
- package/src/agent/generate.txt +75 -0
- package/src/agent/prompt/compaction.txt +12 -0
- package/src/agent/prompt/explore.txt +18 -0
- package/src/agent/prompt/summary.txt +10 -0
- package/src/agent/prompt/title.txt +36 -0
- package/src/auth/index.ts +70 -0
- package/src/bun/index.ts +114 -0
- package/src/bus/bus-event.ts +43 -0
- package/src/bus/global.ts +10 -0
- package/src/bus/index.ts +105 -0
- package/src/cli/bootstrap.ts +17 -0
- package/src/cli/cmd/acp.ts +104 -0
- package/src/cli/cmd/activate.ts +50 -0
- package/src/cli/cmd/agent.ts +256 -0
- package/src/cli/cmd/auth.ts +412 -0
- package/src/cli/cmd/cmd.ts +7 -0
- package/src/cli/cmd/debug/config.ts +15 -0
- package/src/cli/cmd/debug/file.ts +91 -0
- package/src/cli/cmd/debug/index.ts +43 -0
- package/src/cli/cmd/debug/lsp.ts +48 -0
- package/src/cli/cmd/debug/ripgrep.ts +83 -0
- package/src/cli/cmd/debug/scrap.ts +15 -0
- package/src/cli/cmd/debug/skill.ts +15 -0
- package/src/cli/cmd/debug/snapshot.ts +48 -0
- package/src/cli/cmd/export.ts +88 -0
- package/src/cli/cmd/generate.ts +38 -0
- package/src/cli/cmd/github.ts +1400 -0
- package/src/cli/cmd/import.ts +98 -0
- package/src/cli/cmd/mcp.ts +654 -0
- package/src/cli/cmd/models.ts +68 -0
- package/src/cli/cmd/pr.ts +112 -0
- package/src/cli/cmd/run.ts +434 -0
- package/src/cli/cmd/serve.ts +31 -0
- package/src/cli/cmd/session.ts +106 -0
- package/src/cli/cmd/stats.ts +298 -0
- package/src/cli/cmd/tui/app.tsx +694 -0
- package/src/cli/cmd/tui/attach.ts +30 -0
- package/src/cli/cmd/tui/component/border.tsx +21 -0
- package/src/cli/cmd/tui/component/dialog-agent.tsx +31 -0
- package/src/cli/cmd/tui/component/dialog-command.tsx +124 -0
- package/src/cli/cmd/tui/component/dialog-mcp.tsx +86 -0
- package/src/cli/cmd/tui/component/dialog-model.tsx +236 -0
- package/src/cli/cmd/tui/component/dialog-provider.tsx +240 -0
- package/src/cli/cmd/tui/component/dialog-session-list.tsx +102 -0
- package/src/cli/cmd/tui/component/dialog-session-rename.tsx +31 -0
- package/src/cli/cmd/tui/component/dialog-stash.tsx +86 -0
- package/src/cli/cmd/tui/component/dialog-status.tsx +162 -0
- package/src/cli/cmd/tui/component/dialog-tag.tsx +44 -0
- package/src/cli/cmd/tui/component/dialog-theme-list.tsx +50 -0
- package/src/cli/cmd/tui/component/did-you-know.tsx +85 -0
- package/src/cli/cmd/tui/component/logo.tsx +48 -0
- package/src/cli/cmd/tui/component/prompt/autocomplete.tsx +574 -0
- package/src/cli/cmd/tui/component/prompt/history.tsx +108 -0
- package/src/cli/cmd/tui/component/prompt/index.tsx +1087 -0
- package/src/cli/cmd/tui/component/prompt/stash.tsx +101 -0
- package/src/cli/cmd/tui/component/tips.ts +27 -0
- package/src/cli/cmd/tui/component/todo-item.tsx +32 -0
- package/src/cli/cmd/tui/context/args.tsx +14 -0
- package/src/cli/cmd/tui/context/directory.ts +13 -0
- package/src/cli/cmd/tui/context/exit.tsx +23 -0
- package/src/cli/cmd/tui/context/helper.tsx +25 -0
- package/src/cli/cmd/tui/context/keybind.tsx +101 -0
- package/src/cli/cmd/tui/context/kv.tsx +49 -0
- package/src/cli/cmd/tui/context/local.tsx +345 -0
- package/src/cli/cmd/tui/context/prompt.tsx +18 -0
- package/src/cli/cmd/tui/context/route.tsx +46 -0
- package/src/cli/cmd/tui/context/sdk.tsx +74 -0
- package/src/cli/cmd/tui/context/sync.tsx +372 -0
- package/src/cli/cmd/tui/context/theme/aura.json +69 -0
- package/src/cli/cmd/tui/context/theme/ayu.json +80 -0
- package/src/cli/cmd/tui/context/theme/catppuccin-frappe.json +233 -0
- package/src/cli/cmd/tui/context/theme/catppuccin-macchiato.json +233 -0
- package/src/cli/cmd/tui/context/theme/catppuccin.json +112 -0
- package/src/cli/cmd/tui/context/theme/cobalt2.json +228 -0
- package/src/cli/cmd/tui/context/theme/cursor.json +249 -0
- package/src/cli/cmd/tui/context/theme/dracula.json +219 -0
- package/src/cli/cmd/tui/context/theme/everforest.json +241 -0
- package/src/cli/cmd/tui/context/theme/flexoki.json +237 -0
- package/src/cli/cmd/tui/context/theme/github.json +233 -0
- package/src/cli/cmd/tui/context/theme/gruvbox.json +95 -0
- package/src/cli/cmd/tui/context/theme/kanagawa.json +77 -0
- package/src/cli/cmd/tui/context/theme/lucent-orng.json +227 -0
- package/src/cli/cmd/tui/context/theme/material.json +235 -0
- package/src/cli/cmd/tui/context/theme/matrix.json +77 -0
- package/src/cli/cmd/tui/context/theme/mercury.json +252 -0
- package/src/cli/cmd/tui/context/theme/monokai.json +221 -0
- package/src/cli/cmd/tui/context/theme/nightowl.json +221 -0
- package/src/cli/cmd/tui/context/theme/nord.json +223 -0
- package/src/cli/cmd/tui/context/theme/one-dark.json +84 -0
- package/src/cli/cmd/tui/context/theme/orng.json +245 -0
- package/src/cli/cmd/tui/context/theme/palenight.json +222 -0
- package/src/cli/cmd/tui/context/theme/rird.json +245 -0
- package/src/cli/cmd/tui/context/theme/rosepine.json +234 -0
- package/src/cli/cmd/tui/context/theme/solarized.json +223 -0
- package/src/cli/cmd/tui/context/theme/synthwave84.json +226 -0
- package/src/cli/cmd/tui/context/theme/tokyonight.json +243 -0
- package/src/cli/cmd/tui/context/theme/vercel.json +245 -0
- package/src/cli/cmd/tui/context/theme/vesper.json +218 -0
- package/src/cli/cmd/tui/context/theme/zenburn.json +223 -0
- package/src/cli/cmd/tui/context/theme.tsx +1109 -0
- package/src/cli/cmd/tui/event.ts +40 -0
- package/src/cli/cmd/tui/hooks/use-safe-terminal-dimensions.ts +12 -0
- package/src/cli/cmd/tui/routes/home.tsx +138 -0
- package/src/cli/cmd/tui/routes/session/dialog-fork-from-timeline.tsx +64 -0
- package/src/cli/cmd/tui/routes/session/dialog-message.tsx +109 -0
- package/src/cli/cmd/tui/routes/session/dialog-subagent.tsx +26 -0
- package/src/cli/cmd/tui/routes/session/dialog-timeline.tsx +47 -0
- package/src/cli/cmd/tui/routes/session/footer.tsx +88 -0
- package/src/cli/cmd/tui/routes/session/header.tsx +125 -0
- package/src/cli/cmd/tui/routes/session/index.tsx +1876 -0
- package/src/cli/cmd/tui/routes/session/sidebar.tsx +320 -0
- package/src/cli/cmd/tui/spawn.ts +60 -0
- package/src/cli/cmd/tui/thread.ts +142 -0
- package/src/cli/cmd/tui/ui/dialog-alert.tsx +57 -0
- package/src/cli/cmd/tui/ui/dialog-confirm.tsx +83 -0
- package/src/cli/cmd/tui/ui/dialog-help.tsx +38 -0
- package/src/cli/cmd/tui/ui/dialog-prompt.tsx +77 -0
- package/src/cli/cmd/tui/ui/dialog-select.tsx +333 -0
- package/src/cli/cmd/tui/ui/dialog.tsx +171 -0
- package/src/cli/cmd/tui/ui/spinner.ts +368 -0
- package/src/cli/cmd/tui/ui/toast.tsx +100 -0
- package/src/cli/cmd/tui/util/clipboard.ts +127 -0
- package/src/cli/cmd/tui/util/editor.ts +32 -0
- package/src/cli/cmd/tui/util/terminal.ts +146 -0
- package/src/cli/cmd/tui/worker.ts +63 -0
- package/src/cli/cmd/uninstall.ts +344 -0
- package/src/cli/cmd/upgrade.ts +127 -0
- package/src/cli/cmd/web.ts +84 -0
- package/src/cli/error.ts +69 -0
- package/src/cli/ui.ts +101 -0
- package/src/cli/upgrade.ts +28 -0
- package/src/command/index.ts +80 -0
- package/src/command/template/initialize.txt +10 -0
- package/src/command/template/review.txt +97 -0
- package/src/config/config.ts +994 -0
- package/src/config/markdown.ts +41 -0
- package/src/env/index.ts +26 -0
- package/src/file/ignore.ts +83 -0
- package/src/file/index.ts +328 -0
- package/src/file/ripgrep.ts +393 -0
- package/src/file/time.ts +64 -0
- package/src/file/watcher.ts +103 -0
- package/src/flag/flag.ts +84 -0
- package/src/format/formatter.ts +315 -0
- package/src/format/index.ts +137 -0
- package/src/global/index.ts +101 -0
- package/src/id/id.ts +73 -0
- package/src/ide/index.ts +76 -0
- package/src/index.ts +297 -0
- package/src/index.ts.backup +271 -0
- package/src/installation/index.ts +258 -0
- package/src/lib/IMPLEMENTATION_NOTES.md +345 -0
- package/src/lib/error-handler.ts +225 -0
- package/src/lib/error-testing-guide.md +258 -0
- package/src/lib/errors.ts +285 -0
- package/src/lib/performance.ts +70 -0
- package/src/lib/telemetry.ts +282 -0
- package/src/lsp/client.ts +229 -0
- package/src/lsp/index.ts +485 -0
- package/src/lsp/language.ts +116 -0
- package/src/lsp/server.ts +1895 -0
- package/src/mcp/auth.ts +135 -0
- package/src/mcp/index.ts +1117 -0
- package/src/mcp/intent-analyzer.ts +376 -0
- package/src/mcp/oauth-callback.ts +200 -0
- package/src/mcp/oauth-provider.ts +154 -0
- package/src/patch/index.ts +632 -0
- package/src/permission/index.ts +199 -0
- package/src/plugin/index.ts +91 -0
- package/src/project/bootstrap.ts +33 -0
- package/src/project/instance.ts +78 -0
- package/src/project/project.ts +236 -0
- package/src/project/state.ts +65 -0
- package/src/project/vcs.ts +76 -0
- package/src/provider/auth.ts +143 -0
- package/src/provider/models-macro.ts +55 -0
- package/src/provider/models.ts +161 -0
- package/src/provider/provider.ts +1109 -0
- package/src/provider/sdk/openai-compatible/src/README.md +5 -0
- package/src/provider/sdk/openai-compatible/src/index.ts +2 -0
- package/src/provider/sdk/openai-compatible/src/openai-compatible-provider.ts +100 -0
- package/src/provider/sdk/openai-compatible/src/responses/convert-to-openai-responses-input.ts +303 -0
- package/src/provider/sdk/openai-compatible/src/responses/map-openai-responses-finish-reason.ts +22 -0
- package/src/provider/sdk/openai-compatible/src/responses/openai-config.ts +18 -0
- package/src/provider/sdk/openai-compatible/src/responses/openai-error.ts +22 -0
- package/src/provider/sdk/openai-compatible/src/responses/openai-responses-api-types.ts +207 -0
- package/src/provider/sdk/openai-compatible/src/responses/openai-responses-language-model.ts +1713 -0
- package/src/provider/sdk/openai-compatible/src/responses/openai-responses-prepare-tools.ts +177 -0
- package/src/provider/sdk/openai-compatible/src/responses/openai-responses-settings.ts +1 -0
- package/src/provider/sdk/openai-compatible/src/responses/tool/code-interpreter.ts +88 -0
- package/src/provider/sdk/openai-compatible/src/responses/tool/file-search.ts +128 -0
- package/src/provider/sdk/openai-compatible/src/responses/tool/image-generation.ts +115 -0
- package/src/provider/sdk/openai-compatible/src/responses/tool/local-shell.ts +65 -0
- package/src/provider/sdk/openai-compatible/src/responses/tool/web-search-preview.ts +104 -0
- package/src/provider/sdk/openai-compatible/src/responses/tool/web-search.ts +103 -0
- package/src/provider/transform.ts +455 -0
- package/src/pty/index.ts +231 -0
- package/src/security/guardrails.test.ts +341 -0
- package/src/security/guardrails.ts +570 -0
- package/src/security/index.ts +19 -0
- package/src/server/error.ts +36 -0
- package/src/server/project.ts +79 -0
- package/src/server/server.ts +2641 -0
- package/src/server/tui.ts +71 -0
- package/src/session/compaction.ts +228 -0
- package/src/session/index.ts +464 -0
- package/src/session/llm.ts +201 -0
- package/src/session/message-v2.ts +695 -0
- package/src/session/message.ts +189 -0
- package/src/session/processor.ts +409 -0
- package/src/session/prompt/act-switch.txt +5 -0
- package/src/session/prompt/anthropic-20250930.txt +166 -0
- package/src/session/prompt/anthropic.txt +63 -0
- package/src/session/prompt/anthropic_spoof.txt +1 -0
- package/src/session/prompt/beast.txt +76 -0
- package/src/session/prompt/codex.txt +304 -0
- package/src/session/prompt/copilot-gpt-5.txt +137 -0
- package/src/session/prompt/gemini.txt +62 -0
- package/src/session/prompt/max-steps.txt +16 -0
- package/src/session/prompt/plan-reminder-anthropic.txt +35 -0
- package/src/session/prompt/plan.txt +24 -0
- package/src/session/prompt/polaris.txt +88 -0
- package/src/session/prompt/qwen.txt +59 -0
- package/src/session/prompt.ts +1552 -0
- package/src/session/retry.ts +86 -0
- package/src/session/revert.ts +108 -0
- package/src/session/sensitive-filter.test.ts +327 -0
- package/src/session/sensitive-filter.ts +466 -0
- package/src/session/status.ts +76 -0
- package/src/session/summary.ts +209 -0
- package/src/session/system.ts +122 -0
- package/src/session/todo.ts +37 -0
- package/src/share/share-next.ts +222 -0
- package/src/share/share.ts +87 -0
- package/src/shell/shell.ts +67 -0
- package/src/skill/index.ts +1 -0
- package/src/skill/skill.ts +83 -0
- package/src/snapshot/index.ts +197 -0
- package/src/storage/storage.ts +226 -0
- package/src/tests/agent.test.ts +308 -0
- package/src/tests/build-guards.test.ts +267 -0
- package/src/tests/config.test.ts +664 -0
- package/src/tests/tool-registry.test.ts +589 -0
- package/src/tool/bash.ts +314 -0
- package/src/tool/bash.txt +158 -0
- package/src/tool/batch.ts +175 -0
- package/src/tool/batch.txt +24 -0
- package/src/tool/codesearch.ts +184 -0
- package/src/tool/codesearch.txt +12 -0
- package/src/tool/edit.ts +675 -0
- package/src/tool/edit.txt +10 -0
- package/src/tool/glob.ts +65 -0
- package/src/tool/glob.txt +6 -0
- package/src/tool/grep.ts +121 -0
- package/src/tool/grep.txt +8 -0
- package/src/tool/invalid.ts +17 -0
- package/src/tool/ls.ts +110 -0
- package/src/tool/ls.txt +1 -0
- package/src/tool/lsp-diagnostics.ts +26 -0
- package/src/tool/lsp-diagnostics.txt +1 -0
- package/src/tool/lsp-hover.ts +31 -0
- package/src/tool/lsp-hover.txt +1 -0
- package/src/tool/lsp.ts +87 -0
- package/src/tool/lsp.txt +19 -0
- package/src/tool/multiedit.ts +46 -0
- package/src/tool/multiedit.txt +41 -0
- package/src/tool/patch.ts +233 -0
- package/src/tool/patch.txt +1 -0
- package/src/tool/read.ts +219 -0
- package/src/tool/read.txt +12 -0
- package/src/tool/registry.ts +162 -0
- package/src/tool/skill.ts +100 -0
- package/src/tool/task.ts +136 -0
- package/src/tool/task.txt +51 -0
- package/src/tool/todo.ts +39 -0
- package/src/tool/todoread.txt +14 -0
- package/src/tool/todowrite.txt +167 -0
- package/src/tool/tool.ts +71 -0
- package/src/tool/webfetch.ts +198 -0
- package/src/tool/webfetch.txt +13 -0
- package/src/tool/websearch.ts +268 -0
- package/src/tool/websearch.txt +13 -0
- package/src/tool/write.ts +110 -0
- package/src/tool/write.txt +8 -0
- package/src/util/archive.ts +16 -0
- package/src/util/color.ts +19 -0
- package/src/util/context.ts +25 -0
- package/src/util/defer.ts +12 -0
- package/src/util/eventloop.ts +20 -0
- package/src/util/filesystem.ts +83 -0
- package/src/util/fn.ts +11 -0
- package/src/util/iife.ts +3 -0
- package/src/util/keybind.ts +102 -0
- package/src/util/lazy.ts +11 -0
- package/src/util/license.ts +362 -0
- package/src/util/locale.ts +81 -0
- package/src/util/lock.ts +98 -0
- package/src/util/log.ts +180 -0
- package/src/util/queue.ts +32 -0
- package/src/util/rpc.ts +42 -0
- package/src/util/scrap.ts +10 -0
- package/src/util/signal.ts +12 -0
- package/src/util/timeout.ts +14 -0
- package/src/util/token.ts +7 -0
- package/src/util/wildcard.ts +54 -0
- package/sst-env.d.ts +9 -0
- package/test/agent/agent.test.ts +146 -0
- package/test/bun.test.ts +53 -0
- package/test/cli/cmd/acp.test.ts +144 -0
- package/test/cli/cmd/run.test.ts +250 -0
- package/test/cli/github-remote.test.ts +80 -0
- package/test/config/agent-color.test.ts +66 -0
- package/test/config/config.test.ts +536 -0
- package/test/config/markdown.test.ts +89 -0
- package/test/file/ignore.test.ts +10 -0
- package/test/fixture/fixture.ts +37 -0
- package/test/fixture/lsp/fake-lsp-server.js +77 -0
- package/test/helpers.ts +172 -0
- package/test/ide/ide.test.ts +82 -0
- package/test/installation/installation.test.ts +143 -0
- package/test/keybind.test.ts +421 -0
- package/test/lsp/client.test.ts +95 -0
- package/test/mcp/headers.test.ts +153 -0
- package/test/patch/patch.test.ts +348 -0
- package/test/preload.ts +57 -0
- package/test/project/project.test.ts +74 -0
- package/test/provider/provider.test.ts +74 -0
- package/test/provider/transform.test.ts +411 -0
- package/test/session/retry.test.ts +111 -0
- package/test/session/session.test.ts +71 -0
- package/test/skill/skill.test.ts +131 -0
- package/test/snapshot/snapshot.test.ts +940 -0
- package/test/tool/__snapshots__/tool.test.ts.snap +9 -0
- package/test/tool/bash.test.ts +434 -0
- package/test/tool/grep.test.ts +108 -0
- package/test/tool/patch.test.ts +259 -0
- package/test/tool/read.test.ts +42 -0
- package/test/util/iife.test.ts +36 -0
- package/test/util/lazy.test.ts +50 -0
- package/test/util/license.test.ts +235 -0
- package/test/util/timeout.test.ts +21 -0
- package/test/util/wildcard.test.ts +55 -0
- package/tsconfig.json +16 -0
- package/update-versions.ps1 +65 -0
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import path from "path"
|
|
2
|
+
import { Global } from "../global"
|
|
3
|
+
import fs from "fs/promises"
|
|
4
|
+
import z from "zod"
|
|
5
|
+
|
|
6
|
+
export namespace Auth {
|
|
7
|
+
export const Oauth = z
|
|
8
|
+
.object({
|
|
9
|
+
type: z.literal("oauth"),
|
|
10
|
+
refresh: z.string(),
|
|
11
|
+
access: z.string(),
|
|
12
|
+
expires: z.number(),
|
|
13
|
+
enterpriseUrl: z.string().optional(),
|
|
14
|
+
})
|
|
15
|
+
.meta({ ref: "OAuth" })
|
|
16
|
+
|
|
17
|
+
export const Api = z
|
|
18
|
+
.object({
|
|
19
|
+
type: z.literal("api"),
|
|
20
|
+
key: z.string(),
|
|
21
|
+
})
|
|
22
|
+
.meta({ ref: "ApiAuth" })
|
|
23
|
+
|
|
24
|
+
export const WellKnown = z
|
|
25
|
+
.object({
|
|
26
|
+
type: z.literal("wellknown"),
|
|
27
|
+
key: z.string(),
|
|
28
|
+
token: z.string(),
|
|
29
|
+
})
|
|
30
|
+
.meta({ ref: "WellKnownAuth" })
|
|
31
|
+
|
|
32
|
+
export const Info = z.discriminatedUnion("type", [Oauth, Api, WellKnown]).meta({ ref: "Auth" })
|
|
33
|
+
export type Info = z.infer<typeof Info>
|
|
34
|
+
|
|
35
|
+
const filepath = path.join(Global.Path.data, "auth.json")
|
|
36
|
+
|
|
37
|
+
export async function get(providerID: string) {
|
|
38
|
+
const auth = await all()
|
|
39
|
+
return auth[providerID]
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
export async function all(): Promise<Record<string, Info>> {
|
|
43
|
+
const file = Bun.file(filepath)
|
|
44
|
+
const data = await file.json().catch(() => ({}) as Record<string, unknown>)
|
|
45
|
+
return Object.entries(data).reduce(
|
|
46
|
+
(acc, [key, value]) => {
|
|
47
|
+
const parsed = Info.safeParse(value)
|
|
48
|
+
if (!parsed.success) return acc
|
|
49
|
+
acc[key] = parsed.data
|
|
50
|
+
return acc
|
|
51
|
+
},
|
|
52
|
+
{} as Record<string, Info>,
|
|
53
|
+
)
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
export async function set(key: string, info: Info) {
|
|
57
|
+
const file = Bun.file(filepath)
|
|
58
|
+
const data = await all()
|
|
59
|
+
await Bun.write(file, JSON.stringify({ ...data, [key]: info }, null, 2))
|
|
60
|
+
await fs.chmod(file.name!, 0o600)
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
export async function remove(key: string) {
|
|
64
|
+
const file = Bun.file(filepath)
|
|
65
|
+
const data = await all()
|
|
66
|
+
delete data[key]
|
|
67
|
+
await Bun.write(file, JSON.stringify(data, null, 2))
|
|
68
|
+
await fs.chmod(file.name!, 0o600)
|
|
69
|
+
}
|
|
70
|
+
}
|
package/src/bun/index.ts
ADDED
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
import z from "zod"
|
|
2
|
+
import { Global } from "../global"
|
|
3
|
+
import { Log } from "../util/log"
|
|
4
|
+
import path from "path"
|
|
5
|
+
import { NamedError } from "@opencode-ai/util/error"
|
|
6
|
+
import { readableStreamToText } from "bun"
|
|
7
|
+
import { createRequire } from "module"
|
|
8
|
+
import { Lock } from "../util/lock"
|
|
9
|
+
|
|
10
|
+
export namespace BunProc {
|
|
11
|
+
const log = Log.create({ service: "bun" })
|
|
12
|
+
const req = createRequire(import.meta.url)
|
|
13
|
+
|
|
14
|
+
export async function run(cmd: string[], options?: Bun.SpawnOptions.OptionsObject<any, any, any>) {
|
|
15
|
+
log.info("running", {
|
|
16
|
+
cmd: [which(), ...cmd],
|
|
17
|
+
...options,
|
|
18
|
+
})
|
|
19
|
+
const result = Bun.spawn([which(), ...cmd], {
|
|
20
|
+
...options,
|
|
21
|
+
stdout: "pipe",
|
|
22
|
+
stderr: "pipe",
|
|
23
|
+
env: {
|
|
24
|
+
...process.env,
|
|
25
|
+
...options?.env,
|
|
26
|
+
BUN_BE_BUN: "1",
|
|
27
|
+
},
|
|
28
|
+
})
|
|
29
|
+
const code = await result.exited
|
|
30
|
+
const stdout = result.stdout
|
|
31
|
+
? typeof result.stdout === "number"
|
|
32
|
+
? result.stdout
|
|
33
|
+
: await readableStreamToText(result.stdout)
|
|
34
|
+
: undefined
|
|
35
|
+
const stderr = result.stderr
|
|
36
|
+
? typeof result.stderr === "number"
|
|
37
|
+
? result.stderr
|
|
38
|
+
: await readableStreamToText(result.stderr)
|
|
39
|
+
: undefined
|
|
40
|
+
log.info("done", {
|
|
41
|
+
code,
|
|
42
|
+
stdout,
|
|
43
|
+
stderr,
|
|
44
|
+
})
|
|
45
|
+
if (code !== 0) {
|
|
46
|
+
throw new Error(`Command failed with exit code ${result.exitCode}: ${stderr}`)
|
|
47
|
+
}
|
|
48
|
+
return result
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
export function which() {
|
|
52
|
+
return process.execPath
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
export const InstallFailedError = NamedError.create(
|
|
56
|
+
"BunInstallFailedError",
|
|
57
|
+
z.object({
|
|
58
|
+
pkg: z.string(),
|
|
59
|
+
version: z.string(),
|
|
60
|
+
}),
|
|
61
|
+
)
|
|
62
|
+
|
|
63
|
+
export async function install(pkg: string, version = "latest") {
|
|
64
|
+
// Use lock to ensure only one install at a time
|
|
65
|
+
using _ = await Lock.write("bun-install")
|
|
66
|
+
|
|
67
|
+
const mod = path.join(Global.Path.cache, "node_modules", pkg)
|
|
68
|
+
const pkgjson = Bun.file(path.join(Global.Path.cache, "package.json"))
|
|
69
|
+
const parsed = await pkgjson.json().catch(async () => {
|
|
70
|
+
const result = { dependencies: {} }
|
|
71
|
+
await Bun.write(pkgjson.name!, JSON.stringify(result, null, 2))
|
|
72
|
+
return result
|
|
73
|
+
})
|
|
74
|
+
if (parsed.dependencies[pkg] === version) return mod
|
|
75
|
+
|
|
76
|
+
// Build command arguments
|
|
77
|
+
const args = ["add", "--force", "--exact", "--cwd", Global.Path.cache, pkg + "@" + version]
|
|
78
|
+
|
|
79
|
+
// Let Bun handle registry resolution:
|
|
80
|
+
// - If .npmrc files exist, Bun will use them automatically
|
|
81
|
+
// - If no .npmrc files exist, Bun will default to https://registry.npmjs.org
|
|
82
|
+
// - No need to pass --registry flag
|
|
83
|
+
log.info("installing package using Bun's default registry resolution", {
|
|
84
|
+
pkg,
|
|
85
|
+
version,
|
|
86
|
+
})
|
|
87
|
+
|
|
88
|
+
await BunProc.run(args, {
|
|
89
|
+
cwd: Global.Path.cache,
|
|
90
|
+
}).catch((e) => {
|
|
91
|
+
throw new InstallFailedError(
|
|
92
|
+
{ pkg, version },
|
|
93
|
+
{
|
|
94
|
+
cause: e,
|
|
95
|
+
},
|
|
96
|
+
)
|
|
97
|
+
})
|
|
98
|
+
|
|
99
|
+
// Resolve actual version from installed package when using "latest"
|
|
100
|
+
// This ensures subsequent starts use the cached version until explicitly updated
|
|
101
|
+
let resolvedVersion = version
|
|
102
|
+
if (version === "latest") {
|
|
103
|
+
const installedPkgJson = Bun.file(path.join(mod, "package.json"))
|
|
104
|
+
const installedPkg = await installedPkgJson.json().catch(() => null)
|
|
105
|
+
if (installedPkg?.version) {
|
|
106
|
+
resolvedVersion = installedPkg.version
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
parsed.dependencies[pkg] = resolvedVersion
|
|
111
|
+
await Bun.write(pkgjson.name!, JSON.stringify(parsed, null, 2))
|
|
112
|
+
return mod
|
|
113
|
+
}
|
|
114
|
+
}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import z from "zod"
|
|
2
|
+
import type { ZodType } from "zod"
|
|
3
|
+
import { Log } from "../util/log"
|
|
4
|
+
|
|
5
|
+
export namespace BusEvent {
|
|
6
|
+
const log = Log.create({ service: "event" })
|
|
7
|
+
|
|
8
|
+
export type Definition = ReturnType<typeof define>
|
|
9
|
+
|
|
10
|
+
const registry = new Map<string, Definition>()
|
|
11
|
+
|
|
12
|
+
export function define<Type extends string, Properties extends ZodType>(type: Type, properties: Properties) {
|
|
13
|
+
const result = {
|
|
14
|
+
type,
|
|
15
|
+
properties,
|
|
16
|
+
}
|
|
17
|
+
registry.set(type, result)
|
|
18
|
+
return result
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
export function payloads() {
|
|
22
|
+
return z
|
|
23
|
+
.discriminatedUnion(
|
|
24
|
+
"type",
|
|
25
|
+
registry
|
|
26
|
+
.entries()
|
|
27
|
+
.map(([type, def]) => {
|
|
28
|
+
return z
|
|
29
|
+
.object({
|
|
30
|
+
type: z.literal(type),
|
|
31
|
+
properties: def.properties,
|
|
32
|
+
})
|
|
33
|
+
.meta({
|
|
34
|
+
ref: "Event" + "." + def.type,
|
|
35
|
+
})
|
|
36
|
+
})
|
|
37
|
+
.toArray() as any,
|
|
38
|
+
)
|
|
39
|
+
.meta({
|
|
40
|
+
ref: "Event",
|
|
41
|
+
})
|
|
42
|
+
}
|
|
43
|
+
}
|
package/src/bus/index.ts
ADDED
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import z from "zod"
|
|
2
|
+
import { Log } from "../util/log"
|
|
3
|
+
import { Instance } from "../project/instance"
|
|
4
|
+
import { BusEvent } from "./bus-event"
|
|
5
|
+
import { GlobalBus } from "./global"
|
|
6
|
+
|
|
7
|
+
export namespace Bus {
|
|
8
|
+
const log = Log.create({ service: "bus" })
|
|
9
|
+
type Subscription = (event: any) => void
|
|
10
|
+
|
|
11
|
+
export const InstanceDisposed = BusEvent.define(
|
|
12
|
+
"server.instance.disposed",
|
|
13
|
+
z.object({
|
|
14
|
+
directory: z.string(),
|
|
15
|
+
}),
|
|
16
|
+
)
|
|
17
|
+
|
|
18
|
+
const state = Instance.state(
|
|
19
|
+
() => {
|
|
20
|
+
const subscriptions = new Map<any, Subscription[]>()
|
|
21
|
+
|
|
22
|
+
return {
|
|
23
|
+
subscriptions,
|
|
24
|
+
}
|
|
25
|
+
},
|
|
26
|
+
async (entry) => {
|
|
27
|
+
const wildcard = entry.subscriptions.get("*")
|
|
28
|
+
if (!wildcard) return
|
|
29
|
+
const event = {
|
|
30
|
+
type: InstanceDisposed.type,
|
|
31
|
+
properties: {
|
|
32
|
+
directory: Instance.directory,
|
|
33
|
+
},
|
|
34
|
+
}
|
|
35
|
+
for (const sub of [...wildcard]) {
|
|
36
|
+
sub(event)
|
|
37
|
+
}
|
|
38
|
+
},
|
|
39
|
+
)
|
|
40
|
+
|
|
41
|
+
export async function publish<Definition extends BusEvent.Definition>(
|
|
42
|
+
def: Definition,
|
|
43
|
+
properties: z.output<Definition["properties"]>,
|
|
44
|
+
) {
|
|
45
|
+
const payload = {
|
|
46
|
+
type: def.type,
|
|
47
|
+
properties,
|
|
48
|
+
}
|
|
49
|
+
log.info("publishing", {
|
|
50
|
+
type: def.type,
|
|
51
|
+
})
|
|
52
|
+
const pending = []
|
|
53
|
+
for (const key of [def.type, "*"]) {
|
|
54
|
+
const match = state().subscriptions.get(key)
|
|
55
|
+
for (const sub of match ?? []) {
|
|
56
|
+
pending.push(sub(payload))
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
GlobalBus.emit("event", {
|
|
60
|
+
directory: Instance.directory,
|
|
61
|
+
payload,
|
|
62
|
+
})
|
|
63
|
+
return Promise.all(pending)
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
export function subscribe<Definition extends BusEvent.Definition>(
|
|
67
|
+
def: Definition,
|
|
68
|
+
callback: (event: { type: Definition["type"]; properties: z.infer<Definition["properties"]> }) => void,
|
|
69
|
+
) {
|
|
70
|
+
return raw(def.type, callback)
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
export function once<Definition extends BusEvent.Definition>(
|
|
74
|
+
def: Definition,
|
|
75
|
+
callback: (event: {
|
|
76
|
+
type: Definition["type"]
|
|
77
|
+
properties: z.infer<Definition["properties"]>
|
|
78
|
+
}) => "done" | undefined,
|
|
79
|
+
) {
|
|
80
|
+
const unsub = subscribe(def, (event) => {
|
|
81
|
+
if (callback(event)) unsub()
|
|
82
|
+
})
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
export function subscribeAll(callback: (event: any) => void) {
|
|
86
|
+
return raw("*", callback)
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
function raw(type: string, callback: (event: any) => void) {
|
|
90
|
+
log.info("subscribing", { type })
|
|
91
|
+
const subscriptions = state().subscriptions
|
|
92
|
+
let match = subscriptions.get(type) ?? []
|
|
93
|
+
match.push(callback)
|
|
94
|
+
subscriptions.set(type, match)
|
|
95
|
+
|
|
96
|
+
return () => {
|
|
97
|
+
log.info("unsubscribing", { type })
|
|
98
|
+
const match = subscriptions.get(type)
|
|
99
|
+
if (!match) return
|
|
100
|
+
const index = match.indexOf(callback)
|
|
101
|
+
if (index === -1) return
|
|
102
|
+
match.splice(index, 1)
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { InstanceBootstrap } from "../project/bootstrap"
|
|
2
|
+
import { Instance } from "../project/instance"
|
|
3
|
+
|
|
4
|
+
export async function bootstrap<T>(directory: string, cb: () => Promise<T>) {
|
|
5
|
+
return Instance.provide({
|
|
6
|
+
directory,
|
|
7
|
+
init: InstanceBootstrap,
|
|
8
|
+
fn: async () => {
|
|
9
|
+
try {
|
|
10
|
+
const result = await cb()
|
|
11
|
+
return result
|
|
12
|
+
} finally {
|
|
13
|
+
await Instance.dispose()
|
|
14
|
+
}
|
|
15
|
+
},
|
|
16
|
+
})
|
|
17
|
+
}
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
import { Log } from "@/util/log"
|
|
2
|
+
import { bootstrap } from "../bootstrap"
|
|
3
|
+
import { cmd } from "./cmd"
|
|
4
|
+
import { AgentSideConnection, ndJsonStream } from "@agentclientprotocol/sdk"
|
|
5
|
+
import { ACP } from "@/acp/agent"
|
|
6
|
+
import { Server } from "@/server/server"
|
|
7
|
+
import { createOpencodeClient } from "@opencode-ai/sdk/v2"
|
|
8
|
+
import { handleError, setupGlobalErrorHandlers, setupGracefulShutdown } from "@/lib/error-handler"
|
|
9
|
+
import { ServerError } from "@/lib/errors"
|
|
10
|
+
|
|
11
|
+
const log = Log.create({ service: "acp-command" })
|
|
12
|
+
|
|
13
|
+
setupGlobalErrorHandlers()
|
|
14
|
+
|
|
15
|
+
export const AcpCommand = cmd({
|
|
16
|
+
command: "acp",
|
|
17
|
+
describe: "start ACP (Agent Client Protocol) server for rird",
|
|
18
|
+
builder: (yargs) => {
|
|
19
|
+
return yargs
|
|
20
|
+
.option("cwd", {
|
|
21
|
+
describe: "working directory",
|
|
22
|
+
type: "string",
|
|
23
|
+
default: process.cwd(),
|
|
24
|
+
})
|
|
25
|
+
.option("port", {
|
|
26
|
+
type: "number",
|
|
27
|
+
describe: "port to listen on",
|
|
28
|
+
default: 0,
|
|
29
|
+
})
|
|
30
|
+
.option("hostname", {
|
|
31
|
+
type: "string",
|
|
32
|
+
describe: "hostname to listen on",
|
|
33
|
+
default: "127.0.0.1",
|
|
34
|
+
})
|
|
35
|
+
},
|
|
36
|
+
handler: async (args) => {
|
|
37
|
+
try {
|
|
38
|
+
let server: any = null
|
|
39
|
+
await bootstrap(process.cwd(), async () => {
|
|
40
|
+
try {
|
|
41
|
+
server = Server.listen({
|
|
42
|
+
port: args.port,
|
|
43
|
+
hostname: args.hostname,
|
|
44
|
+
})
|
|
45
|
+
|
|
46
|
+
const sdk = createOpencodeClient({
|
|
47
|
+
baseUrl: `http://${server.hostname}:${server.port}`,
|
|
48
|
+
})
|
|
49
|
+
|
|
50
|
+
const input = new WritableStream<Uint8Array>({
|
|
51
|
+
write(chunk) {
|
|
52
|
+
return new Promise<void>((resolve, reject) => {
|
|
53
|
+
process.stdout.write(chunk, (err) => {
|
|
54
|
+
if (err) {
|
|
55
|
+
reject(err)
|
|
56
|
+
} else {
|
|
57
|
+
resolve()
|
|
58
|
+
}
|
|
59
|
+
})
|
|
60
|
+
})
|
|
61
|
+
},
|
|
62
|
+
})
|
|
63
|
+
const output = new ReadableStream<Uint8Array>({
|
|
64
|
+
start(controller) {
|
|
65
|
+
process.stdin.on("data", (chunk: Buffer) => {
|
|
66
|
+
controller.enqueue(new Uint8Array(chunk))
|
|
67
|
+
})
|
|
68
|
+
process.stdin.on("end", () => controller.close())
|
|
69
|
+
process.stdin.on("error", (err) => controller.error(err))
|
|
70
|
+
},
|
|
71
|
+
})
|
|
72
|
+
|
|
73
|
+
const stream = ndJsonStream(input, output)
|
|
74
|
+
const agent = await ACP.init({ sdk })
|
|
75
|
+
|
|
76
|
+
new AgentSideConnection((conn) => {
|
|
77
|
+
return agent.create(conn, { sdk })
|
|
78
|
+
}, stream)
|
|
79
|
+
|
|
80
|
+
setupGracefulShutdown(async () => {
|
|
81
|
+
if (server) {
|
|
82
|
+
server.stop()
|
|
83
|
+
}
|
|
84
|
+
})
|
|
85
|
+
|
|
86
|
+
log.info("ACP server listening", { hostname: args.hostname, port: args.port })
|
|
87
|
+
process.stdin.resume()
|
|
88
|
+
await new Promise((resolve, reject) => {
|
|
89
|
+
process.stdin.on("end", resolve)
|
|
90
|
+
process.stdin.on("error", reject)
|
|
91
|
+
})
|
|
92
|
+
} catch (error) {
|
|
93
|
+
throw new ServerError("Failed to start ACP server", {
|
|
94
|
+
code: "ACP_STARTUP_FAILED",
|
|
95
|
+
originalError: error as Error,
|
|
96
|
+
details: { hostname: args.hostname, port: args.port },
|
|
97
|
+
})
|
|
98
|
+
}
|
|
99
|
+
})
|
|
100
|
+
} catch (error) {
|
|
101
|
+
await handleError(error, "acp-command", { exitOnError: true })
|
|
102
|
+
}
|
|
103
|
+
},
|
|
104
|
+
})
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { cmd } from "./cmd"
|
|
2
|
+
import { UI } from "../ui"
|
|
3
|
+
import { saveLicenseKey, clearLicenseCache, validateLicense } from "../../util/license"
|
|
4
|
+
import * as prompts from "@clack/prompts"
|
|
5
|
+
|
|
6
|
+
export const ActivateCommand = cmd({
|
|
7
|
+
command: "activate <key>",
|
|
8
|
+
describe: "activate RIRD with your license key",
|
|
9
|
+
builder: (yargs) =>
|
|
10
|
+
yargs.positional("key", {
|
|
11
|
+
describe: "your license key from rird.ai",
|
|
12
|
+
type: "string",
|
|
13
|
+
demandOption: true,
|
|
14
|
+
}),
|
|
15
|
+
async handler(args) {
|
|
16
|
+
UI.empty()
|
|
17
|
+
prompts.intro("Activating RIRD")
|
|
18
|
+
|
|
19
|
+
const key = args.key as string
|
|
20
|
+
if (!key || key.length < 10) {
|
|
21
|
+
prompts.log.error("Invalid license key format")
|
|
22
|
+
prompts.outro("Get your key at: https://rird.ai")
|
|
23
|
+
process.exit(1)
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
// Save the key
|
|
27
|
+
saveLicenseKey(key)
|
|
28
|
+
clearLicenseCache()
|
|
29
|
+
prompts.log.step("License key saved")
|
|
30
|
+
|
|
31
|
+
// Validate it
|
|
32
|
+
const spinner = prompts.spinner()
|
|
33
|
+
spinner.start("Validating license...")
|
|
34
|
+
|
|
35
|
+
const result = await validateLicense()
|
|
36
|
+
|
|
37
|
+
if (result.valid) {
|
|
38
|
+
spinner.stop("License activated!")
|
|
39
|
+
if (result.user?.email) {
|
|
40
|
+
prompts.log.success(`Welcome, ${result.user.email}`)
|
|
41
|
+
}
|
|
42
|
+
prompts.outro("Run 'rird' to get started")
|
|
43
|
+
} else {
|
|
44
|
+
spinner.stop("Activation failed", 1)
|
|
45
|
+
prompts.log.error(result.message)
|
|
46
|
+
prompts.outro("Check your key and try again")
|
|
47
|
+
process.exit(1)
|
|
48
|
+
}
|
|
49
|
+
},
|
|
50
|
+
})
|