rimuru-ai 1.19.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.rimuru/AGENTS.md +30 -0
- package/.rimuru/agents/backend.md +27 -0
- package/.rimuru/agents/database.md +31 -0
- package/.rimuru/agents/devops.md +30 -0
- package/.rimuru/agents/document-prep.md +49 -0
- package/.rimuru/agents/erp-architect.md +41 -0
- package/.rimuru/agents/ethical-hacking.md +49 -0
- package/.rimuru/agents/frontend.md +31 -0
- package/.rimuru/agents/fullstack.md +24 -0
- package/.rimuru/agents/system-engineer.md +31 -0
- package/.rimuru/agents/veldora-agent-tool-dev.md +30 -0
- package/.rimuru/agents/veldora-backend-dev.md +32 -0
- package/.rimuru/agents/veldora-cicd.md +32 -0
- package/.rimuru/agents/veldora-database.md +32 -0
- package/.rimuru/agents/veldora-doc.md +87 -0
- package/.rimuru/agents/veldora-frontend-dev.md +32 -0
- package/.rimuru/agents/veldora-great-sage.md +33 -0
- package/.rimuru/agents/veldora-mcp-creator.md +30 -0
- package/.rimuru/agents/veldora-pro.md +224 -0
- package/.rimuru/agents/veldora-prompt-enhancer.md +27 -0
- package/.rimuru/agents/veldora-skill-creator.md +28 -0
- package/.rimuru/agents/veldora.md +225 -0
- package/.rimuru/agents/veldorapro-agent-tool-dev.md +29 -0
- package/.rimuru/agents/veldorapro-backend-dev.md +29 -0
- package/.rimuru/agents/veldorapro-cicd.md +29 -0
- package/.rimuru/agents/veldorapro-database.md +29 -0
- package/.rimuru/agents/veldorapro-frontend-dev.md +29 -0
- package/.rimuru/agents/veldorapro-great-sage.md +33 -0
- package/.rimuru/agents/veldorapro-mcp-creator.md +27 -0
- package/.rimuru/agents/veldorapro-prompt-enhancer.md +25 -0
- package/.rimuru/agents/veldorapro-skill-creator.md +27 -0
- package/.rimuru/command/ai-deps.md +24 -0
- package/.rimuru/command/changelog.md +49 -0
- package/.rimuru/command/commit.md +37 -0
- package/.rimuru/command/issues.md +23 -0
- package/.rimuru/command/learn.md +42 -0
- package/.rimuru/command/rmslop.md +15 -0
- package/.rimuru/command/spellcheck.md +5 -0
- package/.rimuru/command/translate.md +14 -0
- package/.rimuru/glossary/README.md +63 -0
- package/.rimuru/glossary/ar.md +28 -0
- package/.rimuru/glossary/br.md +34 -0
- package/.rimuru/glossary/bs.md +33 -0
- package/.rimuru/glossary/da.md +27 -0
- package/.rimuru/glossary/de.md +27 -0
- package/.rimuru/glossary/es.md +27 -0
- package/.rimuru/glossary/fr.md +27 -0
- package/.rimuru/glossary/ja.md +33 -0
- package/.rimuru/glossary/ko.md +27 -0
- package/.rimuru/glossary/no.md +38 -0
- package/.rimuru/glossary/pl.md +27 -0
- package/.rimuru/glossary/ru.md +27 -0
- package/.rimuru/glossary/th.md +34 -0
- package/.rimuru/glossary/tr.md +38 -0
- package/.rimuru/glossary/zh-cn.md +42 -0
- package/.rimuru/glossary/zh-tw.md +42 -0
- package/.rimuru/improver/changelog.md +250 -0
- package/.rimuru/improver/knowledge.md +172 -0
- package/.rimuru/improver/plugins.md +21 -0
- package/.rimuru/improver/skills.md +60 -0
- package/.rimuru/improver/token-audit.md +21 -0
- package/.rimuru/opencode.jsonc +140 -0
- package/.rimuru/plugins/smoke-theme.json +223 -0
- package/.rimuru/plugins/tui-smoke.tsx +1019 -0
- package/.rimuru/skills/effect/SKILL.md +38 -0
- package/.rimuru/themes/mytheme.json +223 -0
- package/.rimuru/tool/github-pr-search.ts +64 -0
- package/.rimuru/tool/github-triage.ts +60 -0
- package/README.md +31 -0
- package/package.json +167 -0
- package/src/account/account.ts +463 -0
- package/src/account/repo.ts +173 -0
- package/src/account/schema.ts +99 -0
- package/src/account/url.ts +8 -0
- package/src/acp/agent.ts +95 -0
- package/src/acp/config-option.ts +203 -0
- package/src/acp/content.ts +250 -0
- package/src/acp/directory.ts +210 -0
- package/src/acp/error.ts +90 -0
- package/src/acp/event.ts +342 -0
- package/src/acp/permission.ts +124 -0
- package/src/acp/profile.ts +42 -0
- package/src/acp/service.ts +1048 -0
- package/src/acp/session.ts +231 -0
- package/src/acp/tool.ts +367 -0
- package/src/acp/usage.ts +232 -0
- package/src/agent/agent.ts +459 -0
- package/src/agent/generate.txt +75 -0
- package/src/agent/prompt/compaction.txt +9 -0
- package/src/agent/prompt/explore.txt +18 -0
- package/src/agent/prompt/summary.txt +11 -0
- package/src/agent/prompt/title.txt +44 -0
- package/src/agent/subagent-permissions.ts +27 -0
- package/src/audio.d.ts +14 -0
- package/src/auth/index.ts +99 -0
- package/src/background/job.ts +39 -0
- package/src/bus/global.ts +22 -0
- package/src/cli/bootstrap.ts +11 -0
- package/src/cli/cmd/account.ts +264 -0
- package/src/cli/cmd/acp.ts +73 -0
- package/src/cli/cmd/agent.ts +259 -0
- package/src/cli/cmd/attach.ts +97 -0
- package/src/cli/cmd/cmd.ts +7 -0
- package/src/cli/cmd/db.ts +62 -0
- package/src/cli/cmd/debug/agent.handler.ts +193 -0
- package/src/cli/cmd/debug/agent.ts +27 -0
- package/src/cli/cmd/debug/config.ts +14 -0
- package/src/cli/cmd/debug/file.ts +73 -0
- package/src/cli/cmd/debug/index.ts +87 -0
- package/src/cli/cmd/debug/lsp.ts +50 -0
- package/src/cli/cmd/debug/ripgrep.ts +79 -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 +50 -0
- package/src/cli/cmd/debug/startup.ts +11 -0
- package/src/cli/cmd/debug/v2.ts +49 -0
- package/src/cli/cmd/export.ts +292 -0
- package/src/cli/cmd/generate.ts +54 -0
- package/src/cli/cmd/github.handler.ts +1593 -0
- package/src/cli/cmd/github.shared.ts +30 -0
- package/src/cli/cmd/github.ts +42 -0
- package/src/cli/cmd/import.ts +224 -0
- package/src/cli/cmd/mcp.ts +850 -0
- package/src/cli/cmd/models.ts +66 -0
- package/src/cli/cmd/plug.ts +230 -0
- package/src/cli/cmd/pr.ts +115 -0
- package/src/cli/cmd/prompt-display.ts +1 -0
- package/src/cli/cmd/providers.ts +534 -0
- package/src/cli/cmd/run/demo.ts +1274 -0
- package/src/cli/cmd/run/entry.body.ts +205 -0
- package/src/cli/cmd/run/footer.command.tsx +1064 -0
- package/src/cli/cmd/run/footer.menu.tsx +351 -0
- package/src/cli/cmd/run/footer.permission.tsx +472 -0
- package/src/cli/cmd/run/footer.prompt.tsx +1306 -0
- package/src/cli/cmd/run/footer.question.tsx +573 -0
- package/src/cli/cmd/run/footer.subagent.tsx +173 -0
- package/src/cli/cmd/run/footer.ts +1129 -0
- package/src/cli/cmd/run/footer.view.tsx +943 -0
- package/src/cli/cmd/run/footer.width.ts +27 -0
- package/src/cli/cmd/run/permission.shared.ts +256 -0
- package/src/cli/cmd/run/prompt.editor.ts +157 -0
- package/src/cli/cmd/run/prompt.shared.ts +153 -0
- package/src/cli/cmd/run/question.shared.ts +340 -0
- package/src/cli/cmd/run/runtime.boot.ts +202 -0
- package/src/cli/cmd/run/runtime.lifecycle.ts +406 -0
- package/src/cli/cmd/run/runtime.queue.ts +349 -0
- package/src/cli/cmd/run/runtime.shared.ts +17 -0
- package/src/cli/cmd/run/runtime.stdin.ts +37 -0
- package/src/cli/cmd/run/runtime.ts +814 -0
- package/src/cli/cmd/run/scrollback.shared.ts +92 -0
- package/src/cli/cmd/run/scrollback.surface.ts +431 -0
- package/src/cli/cmd/run/scrollback.writer.tsx +352 -0
- package/src/cli/cmd/run/session-data.ts +1113 -0
- package/src/cli/cmd/run/session-replay.ts +374 -0
- package/src/cli/cmd/run/session.shared.ts +196 -0
- package/src/cli/cmd/run/splash.ts +280 -0
- package/src/cli/cmd/run/stream.transport.ts +1462 -0
- package/src/cli/cmd/run/stream.ts +175 -0
- package/src/cli/cmd/run/subagent-data.ts +876 -0
- package/src/cli/cmd/run/theme.ts +690 -0
- package/src/cli/cmd/run/tool.ts +1489 -0
- package/src/cli/cmd/run/trace.ts +94 -0
- package/src/cli/cmd/run/turn-summary.ts +47 -0
- package/src/cli/cmd/run/types.ts +350 -0
- package/src/cli/cmd/run/variant.shared.ts +215 -0
- package/src/cli/cmd/run.ts +894 -0
- package/src/cli/cmd/serve.ts +24 -0
- package/src/cli/cmd/session.ts +147 -0
- package/src/cli/cmd/stats.ts +393 -0
- package/src/cli/cmd/tui.ts +224 -0
- package/src/cli/cmd/uninstall.ts +353 -0
- package/src/cli/cmd/upgrade.ts +74 -0
- package/src/cli/cmd/web.ts +84 -0
- package/src/cli/effect/prompt.ts +37 -0
- package/src/cli/effect-cmd.ts +96 -0
- package/src/cli/error.ts +130 -0
- package/src/cli/heap.ts +45 -0
- package/src/cli/logo.ts +1 -0
- package/src/cli/network.ts +64 -0
- package/src/cli/tui/layer.ts +7 -0
- package/src/cli/tui/validate-session.ts +29 -0
- package/src/cli/tui/worker.ts +71 -0
- package/src/cli/ui.ts +98 -0
- package/src/cli/upgrade.ts +53 -0
- package/src/command/index.ts +184 -0
- package/src/command/template/initialize.txt +66 -0
- package/src/command/template/review.txt +101 -0
- package/src/config/agent.ts +59 -0
- package/src/config/command.ts +39 -0
- package/src/config/config.ts +686 -0
- package/src/config/entry-name.ts +19 -0
- package/src/config/managed.ts +69 -0
- package/src/config/markdown.ts +36 -0
- package/src/config/parse.ts +79 -0
- package/src/config/paths.ts +45 -0
- package/src/config/plugin.ts +79 -0
- package/src/config/tui-cwd.ts +5 -0
- package/src/config/tui-host-attention.ts +21 -0
- package/src/config/tui-migrate.ts +132 -0
- package/src/config/tui.ts +274 -0
- package/src/config/variable.ts +91 -0
- package/src/control-plane/adapters/index.ts +41 -0
- package/src/control-plane/adapters/worktree.ts +96 -0
- package/src/control-plane/dev/README.md +19 -0
- package/src/control-plane/dev/debug-workspace-plugin.ts +73 -0
- package/src/control-plane/types.ts +59 -0
- package/src/control-plane/util.ts +39 -0
- package/src/control-plane/workspace-adapter-runtime.ts +51 -0
- package/src/control-plane/workspace-context.ts +26 -0
- package/src/control-plane/workspace.ts +989 -0
- package/src/effect/app-runtime.ts +132 -0
- package/src/effect/bootstrap-runtime.ts +23 -0
- package/src/effect/bridge.ts +84 -0
- package/src/effect/config-service.ts +67 -0
- package/src/effect/instance-ref.ts +11 -0
- package/src/effect/instance-registry.ts +12 -0
- package/src/effect/instance-state.ts +69 -0
- package/src/effect/promise.ts +17 -0
- package/src/effect/run-service.ts +47 -0
- package/src/effect/runner.ts +217 -0
- package/src/effect/runtime-flags.ts +79 -0
- package/src/env/index.ts +43 -0
- package/src/event-v2-bridge.ts +79 -0
- package/src/format/formatter.ts +404 -0
- package/src/format/index.ts +205 -0
- package/src/git/index.ts +350 -0
- package/src/id/id.ts +80 -0
- package/src/ide/index.ts +61 -0
- package/src/image/image.ts +174 -0
- package/src/index.ts +142 -0
- package/src/installation/index.ts +350 -0
- package/src/lsp/client.ts +650 -0
- package/src/lsp/diagnostic.ts +29 -0
- package/src/lsp/language.ts +121 -0
- package/src/lsp/launch.ts +21 -0
- package/src/lsp/lsp.ts +511 -0
- package/src/lsp/server.ts +1983 -0
- package/src/markdown.d.ts +4 -0
- package/src/mcp/auth.ts +174 -0
- package/src/mcp/catalog.ts +153 -0
- package/src/mcp/index.ts +946 -0
- package/src/mcp/oauth-callback.ts +233 -0
- package/src/mcp/oauth-provider.ts +206 -0
- package/src/node.ts +4 -0
- package/src/patch/index.ts +686 -0
- package/src/permission/arity.ts +163 -0
- package/src/permission/evaluate.ts +1 -0
- package/src/permission/index.ts +230 -0
- package/src/plugin/azure.ts +26 -0
- package/src/plugin/cloudflare.ts +76 -0
- package/src/plugin/digitalocean.ts +383 -0
- package/src/plugin/github-copilot/copilot.ts +413 -0
- package/src/plugin/github-copilot/models.ts +246 -0
- package/src/plugin/index.ts +316 -0
- package/src/plugin/install.ts +439 -0
- package/src/plugin/loader.ts +237 -0
- package/src/plugin/meta.ts +188 -0
- package/src/plugin/openai/README.md +31 -0
- package/src/plugin/openai/codex.ts +641 -0
- package/src/plugin/openai/ws-pool.ts +270 -0
- package/src/plugin/openai/ws.ts +381 -0
- package/src/plugin/pty-environment.ts +24 -0
- package/src/plugin/shared.ts +323 -0
- package/src/plugin/snowflake-cortex.ts +529 -0
- package/src/plugin/tui/internal.ts +10 -0
- package/src/plugin/tui/runtime.ts +1130 -0
- package/src/plugin/xai.ts +716 -0
- package/src/project/bootstrap-service.ts +9 -0
- package/src/project/bootstrap.ts +76 -0
- package/src/project/instance-context.ts +24 -0
- package/src/project/instance-layer.ts +11 -0
- package/src/project/instance-runtime.ts +16 -0
- package/src/project/instance-store.ts +209 -0
- package/src/project/project.ts +519 -0
- package/src/project/vcs.ts +431 -0
- package/src/provider/auth.ts +233 -0
- package/src/provider/error.ts +188 -0
- package/src/provider/model-status.ts +8 -0
- package/src/provider/provider.ts +1979 -0
- package/src/provider/transform.ts +1426 -0
- package/src/question/index.ts +229 -0
- package/src/question/schema.ts +10 -0
- package/src/server/auth.ts +48 -0
- package/src/server/event.ts +13 -0
- package/src/server/global-lifecycle.ts +28 -0
- package/src/server/init-projectors.ts +3 -0
- package/src/server/mdns.ts +47 -0
- package/src/server/projectors.ts +1 -0
- package/src/server/proxy-util.ts +48 -0
- package/src/server/routes/instance/httpapi/AGENTS.md +39 -0
- package/src/server/routes/instance/httpapi/api.ts +78 -0
- package/src/server/routes/instance/httpapi/errors.ts +193 -0
- package/src/server/routes/instance/httpapi/groups/config.ts +65 -0
- package/src/server/routes/instance/httpapi/groups/control-plane.ts +35 -0
- package/src/server/routes/instance/httpapi/groups/control.ts +76 -0
- package/src/server/routes/instance/httpapi/groups/event.ts +29 -0
- package/src/server/routes/instance/httpapi/groups/experimental.ts +260 -0
- package/src/server/routes/instance/httpapi/groups/file.ts +185 -0
- package/src/server/routes/instance/httpapi/groups/global.ts +138 -0
- package/src/server/routes/instance/httpapi/groups/instance.ts +206 -0
- package/src/server/routes/instance/httpapi/groups/mcp.ts +156 -0
- package/src/server/routes/instance/httpapi/groups/metadata.ts +18 -0
- package/src/server/routes/instance/httpapi/groups/permission.ts +61 -0
- package/src/server/routes/instance/httpapi/groups/project-copy.ts +32 -0
- package/src/server/routes/instance/httpapi/groups/project.ts +93 -0
- package/src/server/routes/instance/httpapi/groups/provider.ts +101 -0
- package/src/server/routes/instance/httpapi/groups/pty.ts +172 -0
- package/src/server/routes/instance/httpapi/groups/query.ts +12 -0
- package/src/server/routes/instance/httpapi/groups/question.ts +74 -0
- package/src/server/routes/instance/httpapi/groups/session.ts +462 -0
- package/src/server/routes/instance/httpapi/groups/sync.ts +113 -0
- package/src/server/routes/instance/httpapi/groups/tui.ts +208 -0
- package/src/server/routes/instance/httpapi/groups/workspace.ts +141 -0
- package/src/server/routes/instance/httpapi/handlers/config.ts +34 -0
- package/src/server/routes/instance/httpapi/handlers/control-plane.ts +37 -0
- package/src/server/routes/instance/httpapi/handlers/control.ts +43 -0
- package/src/server/routes/instance/httpapi/handlers/event.ts +99 -0
- package/src/server/routes/instance/httpapi/handlers/experimental.ts +187 -0
- package/src/server/routes/instance/httpapi/handlers/file.ts +139 -0
- package/src/server/routes/instance/httpapi/handlers/global.ts +156 -0
- package/src/server/routes/instance/httpapi/handlers/instance.ts +110 -0
- package/src/server/routes/instance/httpapi/handlers/mcp.ts +111 -0
- package/src/server/routes/instance/httpapi/handlers/permission.ts +41 -0
- package/src/server/routes/instance/httpapi/handlers/project-copy.ts +83 -0
- package/src/server/routes/instance/httpapi/handlers/project.ts +63 -0
- package/src/server/routes/instance/httpapi/handlers/provider.ts +113 -0
- package/src/server/routes/instance/httpapi/handlers/pty.ts +273 -0
- package/src/server/routes/instance/httpapi/handlers/question.ts +54 -0
- package/src/server/routes/instance/httpapi/handlers/session-errors.ts +21 -0
- package/src/server/routes/instance/httpapi/handlers/session.ts +440 -0
- package/src/server/routes/instance/httpapi/handlers/sync.ts +89 -0
- package/src/server/routes/instance/httpapi/handlers/tui.ts +131 -0
- package/src/server/routes/instance/httpapi/handlers/workspace.ts +102 -0
- package/src/server/routes/instance/httpapi/lifecycle.ts +54 -0
- package/src/server/routes/instance/httpapi/middleware/authorization.ts +150 -0
- package/src/server/routes/instance/httpapi/middleware/compression.ts +64 -0
- package/src/server/routes/instance/httpapi/middleware/cors-vary.ts +29 -0
- package/src/server/routes/instance/httpapi/middleware/error.ts +43 -0
- package/src/server/routes/instance/httpapi/middleware/fence.ts +25 -0
- package/src/server/routes/instance/httpapi/middleware/instance-context.ts +43 -0
- package/src/server/routes/instance/httpapi/middleware/proxy.ts +108 -0
- package/src/server/routes/instance/httpapi/middleware/schema-error.ts +41 -0
- package/src/server/routes/instance/httpapi/middleware/workspace-routing.ts +250 -0
- package/src/server/routes/instance/httpapi/public.ts +535 -0
- package/src/server/routes/instance/httpapi/server.ts +298 -0
- package/src/server/routes/instance/httpapi/websocket-tracker.ts +57 -0
- package/src/server/server.ts +225 -0
- package/src/server/shared/fence.ts +60 -0
- package/src/server/shared/pty-ticket.ts +15 -0
- package/src/server/shared/public-ui.ts +12 -0
- package/src/server/shared/tui-control.ts +28 -0
- package/src/server/shared/ui.ts +122 -0
- package/src/server/shared/workspace-routing.ts +38 -0
- package/src/server/tui-event.ts +53 -0
- package/src/session/compaction.ts +620 -0
- package/src/session/instruction.ts +241 -0
- package/src/session/llm/AGENTS.md +90 -0
- package/src/session/llm/ai-sdk.ts +288 -0
- package/src/session/llm/native-request.ts +196 -0
- package/src/session/llm/native-runtime.ts +196 -0
- package/src/session/llm/request.ts +218 -0
- package/src/session/llm.ts +415 -0
- package/src/session/message-error.ts +14 -0
- package/src/session/message-v2.ts +744 -0
- package/src/session/message.ts +148 -0
- package/src/session/overflow.ts +34 -0
- package/src/session/processor.ts +1084 -0
- package/src/session/prompt/anthropic.txt +105 -0
- package/src/session/prompt/beast.txt +147 -0
- package/src/session/prompt/build-switch.txt +5 -0
- package/src/session/prompt/codex.txt +79 -0
- package/src/session/prompt/copilot-gpt-5.txt +143 -0
- package/src/session/prompt/default.txt +95 -0
- package/src/session/prompt/gemini.txt +155 -0
- package/src/session/prompt/gpt.txt +107 -0
- package/src/session/prompt/kimi.txt +95 -0
- package/src/session/prompt/max-steps.txt +16 -0
- package/src/session/prompt/plan-mode.txt +70 -0
- package/src/session/prompt/plan-reminder-anthropic.txt +67 -0
- package/src/session/prompt/plan.txt +26 -0
- package/src/session/prompt/trinity.txt +97 -0
- package/src/session/prompt.ts +1722 -0
- package/src/session/reminders.ts +92 -0
- package/src/session/retry.ts +201 -0
- package/src/session/revert.ts +160 -0
- package/src/session/run-state.ts +156 -0
- package/src/session/schema.ts +26 -0
- package/src/session/session.ts +1119 -0
- package/src/session/status.ts +97 -0
- package/src/session/summary.ts +165 -0
- package/src/session/system.ts +117 -0
- package/src/session/todo.ts +90 -0
- package/src/session/tools.ts +207 -0
- package/src/share/session.ts +61 -0
- package/src/share/share-next.ts +385 -0
- package/src/skill/discovery.ts +109 -0
- package/src/skill/index.ts +366 -0
- package/src/snapshot/index.ts +808 -0
- package/src/sql.d.ts +4 -0
- package/src/storage/schema.ts +5 -0
- package/src/storage/storage.ts +329 -0
- package/src/sync/README.md +179 -0
- package/src/sync/schema.ts +11 -0
- package/src/temporary.ts +31 -0
- package/src/tool/apply_patch.ts +313 -0
- package/src/tool/apply_patch.txt +33 -0
- package/src/tool/edit.ts +737 -0
- package/src/tool/edit.txt +10 -0
- package/src/tool/external-directory.ts +49 -0
- package/src/tool/glob.ts +76 -0
- package/src/tool/glob.txt +6 -0
- package/src/tool/grep.ts +112 -0
- package/src/tool/grep.txt +8 -0
- package/src/tool/invalid.ts +21 -0
- package/src/tool/json-schema.ts +164 -0
- package/src/tool/lsp.ts +113 -0
- package/src/tool/lsp.txt +24 -0
- package/src/tool/mcp-websearch.ts +96 -0
- package/src/tool/plan-enter.txt +14 -0
- package/src/tool/plan-exit.txt +13 -0
- package/src/tool/plan.ts +79 -0
- package/src/tool/question.ts +44 -0
- package/src/tool/question.txt +10 -0
- package/src/tool/read.ts +386 -0
- package/src/tool/read.txt +14 -0
- package/src/tool/registry.ts +440 -0
- package/src/tool/schema.ts +14 -0
- package/src/tool/shell/id.ts +19 -0
- package/src/tool/shell/prompt.ts +307 -0
- package/src/tool/shell/shell.txt +21 -0
- package/src/tool/shell.ts +657 -0
- package/src/tool/skill.ts +71 -0
- package/src/tool/skill.txt +5 -0
- package/src/tool/task.ts +346 -0
- package/src/tool/task.txt +19 -0
- package/src/tool/todo.ts +57 -0
- package/src/tool/todowrite.txt +44 -0
- package/src/tool/tool.ts +183 -0
- package/src/tool/truncate.ts +158 -0
- package/src/tool/truncation-dir.ts +4 -0
- package/src/tool/webfetch.ts +192 -0
- package/src/tool/webfetch.txt +13 -0
- package/src/tool/websearch.ts +143 -0
- package/src/tool/websearch.txt +14 -0
- package/src/tool/write.ts +104 -0
- package/src/tool/write.txt +8 -0
- package/src/util/archive.ts +17 -0
- package/src/util/bom.ts +27 -0
- package/src/util/data-url.ts +9 -0
- package/src/util/defer.ts +10 -0
- package/src/util/effect-http-client.ts +11 -0
- package/src/util/error.ts +1 -0
- package/src/util/filesystem.ts +251 -0
- package/src/util/html.ts +8 -0
- package/src/util/iife.ts +3 -0
- package/src/util/lazy.ts +20 -0
- package/src/util/local-context.ts +25 -0
- package/src/util/locale.ts +2 -0
- package/src/util/media.ts +26 -0
- package/src/util/process.ts +177 -0
- package/src/util/proxy-env.ts +72 -0
- package/src/util/queue.ts +32 -0
- package/src/util/record.ts +1 -0
- package/src/util/repository.ts +232 -0
- package/src/util/rpc.ts +66 -0
- package/src/util/signal.ts +12 -0
- package/src/util/timeout.ts +13 -0
- package/src/util/token.ts +1 -0
- package/src/util/wildcard.ts +59 -0
- package/src/worktree/index.ts +654 -0
|
@@ -0,0 +1,529 @@
|
|
|
1
|
+
import type { Hooks, PluginInput } from "@rimurucode-ai/plugin"
|
|
2
|
+
import { OAUTH_DUMMY_KEY } from "../auth"
|
|
3
|
+
import { InstallationVersion } from "@rimurucode-ai/core/installation/version"
|
|
4
|
+
import { createServer } from "http"
|
|
5
|
+
import open from "open"
|
|
6
|
+
|
|
7
|
+
const OAUTH_CLIENT_ID = "LOCAL_APPLICATION"
|
|
8
|
+
const OAUTH_CALLBACK_HOST = "127.0.0.1"
|
|
9
|
+
const OAUTH_CALLBACK_PATH = "/"
|
|
10
|
+
const OAUTH_TIMEOUT_MS = 5 * 60 * 1000
|
|
11
|
+
const ACCESS_TOKEN_REFRESH_SKEW_MS = 120_000
|
|
12
|
+
|
|
13
|
+
interface PkceCodes {
|
|
14
|
+
verifier: string
|
|
15
|
+
challenge: string
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
interface TokenResponse {
|
|
19
|
+
access_token: string
|
|
20
|
+
refresh_token?: string
|
|
21
|
+
expires_in?: number
|
|
22
|
+
token_type?: string
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
interface PendingOAuth {
|
|
26
|
+
account: string
|
|
27
|
+
state: string
|
|
28
|
+
pkce: PkceCodes
|
|
29
|
+
resolve: (tokens: TokenResponse) => void
|
|
30
|
+
reject: (error: Error) => void
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
let oauthServer: ReturnType<typeof createServer> | undefined
|
|
34
|
+
let pendingOAuth: PendingOAuth | undefined
|
|
35
|
+
let oauthServerPort: number | undefined
|
|
36
|
+
|
|
37
|
+
function normalizeAccount(input: string) {
|
|
38
|
+
return input
|
|
39
|
+
.trim()
|
|
40
|
+
.replace(/^https?:\/\//, "")
|
|
41
|
+
.replace(/\.snowflakecomputing\.com\/?$/, "")
|
|
42
|
+
.replace(/\/+$/, "")
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
function generateRandomString(length: number) {
|
|
46
|
+
const chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-._~"
|
|
47
|
+
return Array.from(crypto.getRandomValues(new Uint8Array(length)))
|
|
48
|
+
.map((b) => chars[b % chars.length])
|
|
49
|
+
.join("")
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
function base64UrlEncode(buffer: ArrayBuffer) {
|
|
53
|
+
const binary = String.fromCharCode(...new Uint8Array(buffer))
|
|
54
|
+
return btoa(binary).replace(/\+/g, "-").replace(/\//g, "_").replace(/=+$/, "")
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
async function generatePKCE(): Promise<PkceCodes> {
|
|
58
|
+
const verifier = generateRandomString(64)
|
|
59
|
+
const hash = await crypto.subtle.digest("SHA-256", new TextEncoder().encode(verifier))
|
|
60
|
+
return {
|
|
61
|
+
verifier,
|
|
62
|
+
challenge: base64UrlEncode(hash),
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
function callbackUrl() {
|
|
67
|
+
if (!oauthServerPort) throw new Error("Snowflake OAuth callback server is not running")
|
|
68
|
+
return `http://${OAUTH_CALLBACK_HOST}:${oauthServerPort}${OAUTH_CALLBACK_PATH}`
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
export function oauthScope(role: string | undefined) {
|
|
72
|
+
if (!role) return "refresh_token"
|
|
73
|
+
return /^[-_A-Za-z0-9]+$/.test(role)
|
|
74
|
+
? `refresh_token session:role:${role}`
|
|
75
|
+
: `refresh_token session:role-encoded:${encodeURIComponent(role)}`
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
function authHeaders() {
|
|
79
|
+
return {
|
|
80
|
+
"Content-Type": "application/x-www-form-urlencoded",
|
|
81
|
+
Accept: "application/json",
|
|
82
|
+
"User-Agent": `rimuru-ai/${InstallationVersion}`,
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
function authBasicHeader() {
|
|
87
|
+
return `Basic ${Buffer.from(`${OAUTH_CLIENT_ID}:${OAUTH_CLIENT_ID}`).toString("base64")}`
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
function buildAuthorizeUrl(account: string, role: string | undefined, state: string, pkce: PkceCodes) {
|
|
91
|
+
const scope = oauthScope(role)
|
|
92
|
+
const params = new URLSearchParams({
|
|
93
|
+
client_id: OAUTH_CLIENT_ID,
|
|
94
|
+
response_type: "code",
|
|
95
|
+
redirect_uri: callbackUrl(),
|
|
96
|
+
scope,
|
|
97
|
+
state,
|
|
98
|
+
code_challenge: pkce.challenge,
|
|
99
|
+
code_challenge_method: "S256",
|
|
100
|
+
})
|
|
101
|
+
return `https://${account}.snowflakecomputing.com/oauth/authorize?${params.toString()}`
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
async function exchangeCodeForToken(account: string, code: string, pkce: PkceCodes) {
|
|
105
|
+
const response = await fetch(`https://${account}.snowflakecomputing.com/oauth/token-request`, {
|
|
106
|
+
method: "POST",
|
|
107
|
+
headers: {
|
|
108
|
+
...authHeaders(),
|
|
109
|
+
Authorization: authBasicHeader(),
|
|
110
|
+
},
|
|
111
|
+
body: new URLSearchParams({
|
|
112
|
+
grant_type: "authorization_code",
|
|
113
|
+
code,
|
|
114
|
+
redirect_uri: callbackUrl(),
|
|
115
|
+
client_id: OAUTH_CLIENT_ID,
|
|
116
|
+
code_verifier: pkce.verifier,
|
|
117
|
+
}).toString(),
|
|
118
|
+
})
|
|
119
|
+
|
|
120
|
+
if (!response.ok) {
|
|
121
|
+
const detail = await response.text().catch(() => "")
|
|
122
|
+
throw new Error(`Snowflake token exchange failed (${response.status})${detail ? `: ${detail}` : ""}`)
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
const token = (await response.json()) as TokenResponse
|
|
126
|
+
if (!token.access_token) throw new Error("Snowflake token response did not include access_token")
|
|
127
|
+
if (!token.refresh_token) {
|
|
128
|
+
throw new Error(
|
|
129
|
+
"Snowflake token response did not include refresh_token. Ensure integration issues refresh tokens and scope includes refresh_token.",
|
|
130
|
+
)
|
|
131
|
+
}
|
|
132
|
+
return token
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
async function refreshAccessToken(account: string, refreshToken: string) {
|
|
136
|
+
const response = await fetch(`https://${account}.snowflakecomputing.com/oauth/token-request`, {
|
|
137
|
+
method: "POST",
|
|
138
|
+
headers: {
|
|
139
|
+
...authHeaders(),
|
|
140
|
+
Authorization: authBasicHeader(),
|
|
141
|
+
},
|
|
142
|
+
body: new URLSearchParams({
|
|
143
|
+
grant_type: "refresh_token",
|
|
144
|
+
refresh_token: refreshToken,
|
|
145
|
+
client_id: OAUTH_CLIENT_ID,
|
|
146
|
+
}).toString(),
|
|
147
|
+
})
|
|
148
|
+
|
|
149
|
+
if (!response.ok) {
|
|
150
|
+
const detail = await response.text().catch(() => "")
|
|
151
|
+
throw new Error(`Snowflake token refresh failed (${response.status})${detail ? `: ${detail}` : ""}`)
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
const token = (await response.json()) as TokenResponse
|
|
155
|
+
if (!token.access_token) throw new Error("Snowflake refresh response did not include access_token")
|
|
156
|
+
return token
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
const HTML_SUCCESS = `<!doctype html>
|
|
160
|
+
<html>
|
|
161
|
+
<head><title>Rimuru - Snowflake Authorization Successful</title></head>
|
|
162
|
+
<body style="font-family: system-ui; display:flex; align-items:center; justify-content:center; height:100vh; margin:0; background:#111; color:#eee;">
|
|
163
|
+
<div style="text-align:center; max-width:36rem; padding:2rem;">
|
|
164
|
+
<h1 style="color:#7ee787;">Authorization Successful</h1>
|
|
165
|
+
<p>You can close this window and return to Rimuru.</p>
|
|
166
|
+
</div>
|
|
167
|
+
<script>setTimeout(() => window.close(), 1500)</script>
|
|
168
|
+
</body>
|
|
169
|
+
</html>`
|
|
170
|
+
|
|
171
|
+
const htmlError = (message: string) => `<!doctype html>
|
|
172
|
+
<html>
|
|
173
|
+
<head><title>Rimuru - Snowflake Authorization Failed</title></head>
|
|
174
|
+
<body style="font-family: system-ui; display:flex; align-items:center; justify-content:center; height:100vh; margin:0; background:#111; color:#eee;">
|
|
175
|
+
<div style="text-align:center; max-width:48rem; padding:2rem;">
|
|
176
|
+
<h1 style="color:#ff7b72;">Authorization Failed</h1>
|
|
177
|
+
<pre style="white-space:pre-wrap; color:#ffb3ad; background:#2a1210; padding:1rem; border-radius:.5rem;">${message}</pre>
|
|
178
|
+
</div>
|
|
179
|
+
</body>
|
|
180
|
+
</html>`
|
|
181
|
+
|
|
182
|
+
async function startOAuthServer() {
|
|
183
|
+
if (oauthServer) return
|
|
184
|
+
|
|
185
|
+
oauthServer = createServer((req, res) => {
|
|
186
|
+
const host = req.headers.host || `${OAUTH_CALLBACK_HOST}:${oauthServerPort ?? 0}`
|
|
187
|
+
const url = new URL(req.url || "/", `http://${host}`)
|
|
188
|
+
|
|
189
|
+
if (url.pathname !== OAUTH_CALLBACK_PATH) {
|
|
190
|
+
res.writeHead(404)
|
|
191
|
+
res.end("Not found")
|
|
192
|
+
return
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
const state = url.searchParams.get("state")
|
|
196
|
+
const code = url.searchParams.get("code")
|
|
197
|
+
const error = url.searchParams.get("error")
|
|
198
|
+
const errorDescription = url.searchParams.get("error_description")
|
|
199
|
+
|
|
200
|
+
// CSRF guard: validate state before processing any callback
|
|
201
|
+
if (!pendingOAuth || state !== pendingOAuth.state) {
|
|
202
|
+
const message = "Invalid state - potential CSRF attack"
|
|
203
|
+
pendingOAuth?.reject(new Error(message))
|
|
204
|
+
pendingOAuth = undefined
|
|
205
|
+
res.writeHead(400, { "Content-Type": "text/html" })
|
|
206
|
+
res.end(htmlError(message))
|
|
207
|
+
return
|
|
208
|
+
}
|
|
209
|
+
|
|
210
|
+
const current = pendingOAuth
|
|
211
|
+
pendingOAuth = undefined
|
|
212
|
+
|
|
213
|
+
if (error) {
|
|
214
|
+
const message = errorDescription || error
|
|
215
|
+
current.reject(new Error(message))
|
|
216
|
+
res.writeHead(200, { "Content-Type": "text/html" })
|
|
217
|
+
res.end(htmlError(message))
|
|
218
|
+
return
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
if (!code) {
|
|
222
|
+
const message = "Missing authorization code"
|
|
223
|
+
current.reject(new Error(message))
|
|
224
|
+
res.writeHead(400, { "Content-Type": "text/html" })
|
|
225
|
+
res.end(htmlError(message))
|
|
226
|
+
return
|
|
227
|
+
}
|
|
228
|
+
|
|
229
|
+
exchangeCodeForToken(current.account, code, current.pkce)
|
|
230
|
+
.then((tokens) => current.resolve(tokens))
|
|
231
|
+
.catch((err) => current.reject(err instanceof Error ? err : new Error(String(err))))
|
|
232
|
+
|
|
233
|
+
res.writeHead(200, { "Content-Type": "text/html" })
|
|
234
|
+
res.end(HTML_SUCCESS)
|
|
235
|
+
})
|
|
236
|
+
|
|
237
|
+
await new Promise<void>((resolve, reject) => {
|
|
238
|
+
oauthServer!.listen(0, OAUTH_CALLBACK_HOST, () => {
|
|
239
|
+
const address = oauthServer!.address()
|
|
240
|
+
if (!address || typeof address === "string") {
|
|
241
|
+
reject(new Error("Unable to resolve Snowflake OAuth callback port"))
|
|
242
|
+
return
|
|
243
|
+
}
|
|
244
|
+
oauthServerPort = address.port
|
|
245
|
+
resolve()
|
|
246
|
+
})
|
|
247
|
+
oauthServer!.on("error", reject)
|
|
248
|
+
})
|
|
249
|
+
}
|
|
250
|
+
|
|
251
|
+
function stopOAuthServer() {
|
|
252
|
+
if (!oauthServer) return
|
|
253
|
+
oauthServer.close()
|
|
254
|
+
oauthServer = undefined
|
|
255
|
+
oauthServerPort = undefined
|
|
256
|
+
}
|
|
257
|
+
|
|
258
|
+
function waitForOAuthCallback(account: string, pkce: PkceCodes, state: string): Promise<TokenResponse> {
|
|
259
|
+
if (pendingOAuth) {
|
|
260
|
+
pendingOAuth.reject(new Error("Superseded by a newer Snowflake authorize request"))
|
|
261
|
+
pendingOAuth = undefined
|
|
262
|
+
}
|
|
263
|
+
|
|
264
|
+
return new Promise((resolve, reject) => {
|
|
265
|
+
const timeout = setTimeout(() => {
|
|
266
|
+
if (!pendingOAuth) return
|
|
267
|
+
pendingOAuth = undefined
|
|
268
|
+
stopOAuthServer()
|
|
269
|
+
reject(new Error("Snowflake OAuth callback timeout - authorization took too long"))
|
|
270
|
+
}, OAUTH_TIMEOUT_MS)
|
|
271
|
+
|
|
272
|
+
pendingOAuth = {
|
|
273
|
+
account,
|
|
274
|
+
state,
|
|
275
|
+
pkce,
|
|
276
|
+
resolve: (tokens) => {
|
|
277
|
+
clearTimeout(timeout)
|
|
278
|
+
resolve(tokens)
|
|
279
|
+
},
|
|
280
|
+
reject: (error) => {
|
|
281
|
+
clearTimeout(timeout)
|
|
282
|
+
reject(error)
|
|
283
|
+
},
|
|
284
|
+
}
|
|
285
|
+
})
|
|
286
|
+
}
|
|
287
|
+
|
|
288
|
+
export async function SnowflakeCortexAuthPlugin(_input: PluginInput): Promise<Hooks> {
|
|
289
|
+
const prompts = [
|
|
290
|
+
{
|
|
291
|
+
type: "text" as const,
|
|
292
|
+
key: "account",
|
|
293
|
+
message: "Snowflake Account Identifier",
|
|
294
|
+
placeholder: "myorg-myaccount",
|
|
295
|
+
validate: (value: string) => (value && value.trim().length > 0 ? undefined : "Required"),
|
|
296
|
+
},
|
|
297
|
+
{
|
|
298
|
+
type: "text" as const,
|
|
299
|
+
key: "role",
|
|
300
|
+
message: "Snowflake Role (optional)",
|
|
301
|
+
placeholder: "PUBLIC",
|
|
302
|
+
},
|
|
303
|
+
]
|
|
304
|
+
|
|
305
|
+
return {
|
|
306
|
+
auth: {
|
|
307
|
+
provider: "snowflake-cortex",
|
|
308
|
+
async loader(getAuth, _provider) {
|
|
309
|
+
let auth = await getAuth()
|
|
310
|
+
if (auth.type !== "oauth") return {}
|
|
311
|
+
|
|
312
|
+
let refreshPromise:
|
|
313
|
+
| Promise<{
|
|
314
|
+
access: string
|
|
315
|
+
refresh: string
|
|
316
|
+
expires: number
|
|
317
|
+
}>
|
|
318
|
+
| undefined
|
|
319
|
+
|
|
320
|
+
const oauth = auth as typeof auth & { refresh: string; access: string; expires: number; accountId?: string }
|
|
321
|
+
|
|
322
|
+
if (oauth.accountId && oauth.refresh && oauth.expires && oauth.expires <= Date.now()) {
|
|
323
|
+
try {
|
|
324
|
+
const tokens = await refreshAccessToken(oauth.accountId, oauth.refresh)
|
|
325
|
+
const refreshedRefresh = tokens.refresh_token || oauth.refresh
|
|
326
|
+
const refreshedExpires = Date.now() + (tokens.expires_in ?? 600) * 1000
|
|
327
|
+
await _input.client.auth
|
|
328
|
+
.set({
|
|
329
|
+
path: { id: "snowflake-cortex" },
|
|
330
|
+
body: {
|
|
331
|
+
type: "oauth",
|
|
332
|
+
access: tokens.access_token,
|
|
333
|
+
refresh: refreshedRefresh,
|
|
334
|
+
expires: refreshedExpires,
|
|
335
|
+
...(oauth.accountId && { accountId: oauth.accountId }),
|
|
336
|
+
},
|
|
337
|
+
})
|
|
338
|
+
.catch(() => {})
|
|
339
|
+
} catch {}
|
|
340
|
+
}
|
|
341
|
+
|
|
342
|
+
return {
|
|
343
|
+
apiKey: OAUTH_DUMMY_KEY,
|
|
344
|
+
async fetch(requestInput: RequestInfo | URL, init?: RequestInit) {
|
|
345
|
+
let currentAuth = await getAuth()
|
|
346
|
+
if (currentAuth.type !== "oauth") return fetch(requestInput, init)
|
|
347
|
+
let currentOauth = currentAuth as typeof currentAuth & {
|
|
348
|
+
refresh: string
|
|
349
|
+
access: string
|
|
350
|
+
expires: number
|
|
351
|
+
accountId?: string
|
|
352
|
+
}
|
|
353
|
+
|
|
354
|
+
if (!currentOauth.accountId) throw new Error("Snowflake OAuth auth is missing accountId")
|
|
355
|
+
const accountId = currentOauth.accountId
|
|
356
|
+
|
|
357
|
+
const refresh = async () => {
|
|
358
|
+
if (!refreshPromise) {
|
|
359
|
+
const refreshToken = currentOauth.refresh
|
|
360
|
+
refreshPromise = refreshAccessToken(accountId, refreshToken)
|
|
361
|
+
.then(async (tokens) => {
|
|
362
|
+
const refreshedRefresh = tokens.refresh_token || refreshToken
|
|
363
|
+
const refreshedExpires = Date.now() + (tokens.expires_in ?? 600) * 1000
|
|
364
|
+
await _input.client.auth
|
|
365
|
+
.set({
|
|
366
|
+
path: { id: "snowflake-cortex" },
|
|
367
|
+
body: {
|
|
368
|
+
type: "oauth",
|
|
369
|
+
access: tokens.access_token,
|
|
370
|
+
refresh: refreshedRefresh,
|
|
371
|
+
expires: refreshedExpires,
|
|
372
|
+
...(accountId && { accountId }),
|
|
373
|
+
},
|
|
374
|
+
})
|
|
375
|
+
.catch(() => {})
|
|
376
|
+
return {
|
|
377
|
+
access: tokens.access_token,
|
|
378
|
+
refresh: refreshedRefresh,
|
|
379
|
+
expires: refreshedExpires,
|
|
380
|
+
}
|
|
381
|
+
})
|
|
382
|
+
.finally(() => {
|
|
383
|
+
refreshPromise = undefined
|
|
384
|
+
})
|
|
385
|
+
}
|
|
386
|
+
|
|
387
|
+
const refreshed = await refreshPromise
|
|
388
|
+
currentOauth = { ...currentOauth, ...refreshed }
|
|
389
|
+
}
|
|
390
|
+
|
|
391
|
+
const prepareRequest = () => {
|
|
392
|
+
const headers = new Headers(requestInput instanceof Request ? requestInput.headers : undefined)
|
|
393
|
+
if (init?.headers) {
|
|
394
|
+
const entries =
|
|
395
|
+
init.headers instanceof Headers
|
|
396
|
+
? init.headers.entries()
|
|
397
|
+
: Array.isArray(init.headers)
|
|
398
|
+
? init.headers
|
|
399
|
+
: Object.entries(init.headers as Record<string, string | undefined>)
|
|
400
|
+
for (const [key, value] of entries) {
|
|
401
|
+
if (value !== undefined) headers.set(key, String(value))
|
|
402
|
+
}
|
|
403
|
+
}
|
|
404
|
+
headers.set("authorization", `Bearer ${currentOauth.access}`)
|
|
405
|
+
headers.set("User-Agent", `rimuru-ai/${InstallationVersion}`)
|
|
406
|
+
|
|
407
|
+
let body = init?.body
|
|
408
|
+
if (body && typeof body === "string") {
|
|
409
|
+
try {
|
|
410
|
+
const parsed = JSON.parse(body)
|
|
411
|
+
if ("max_tokens" in parsed) {
|
|
412
|
+
parsed.max_completion_tokens = parsed.max_tokens
|
|
413
|
+
delete parsed.max_tokens
|
|
414
|
+
body = JSON.stringify(parsed)
|
|
415
|
+
}
|
|
416
|
+
} catch {}
|
|
417
|
+
}
|
|
418
|
+
|
|
419
|
+
return { ...init, headers, body }
|
|
420
|
+
}
|
|
421
|
+
|
|
422
|
+
const transformResponse = async (response: Response) => {
|
|
423
|
+
if (!response.ok && response.status === 400) {
|
|
424
|
+
try {
|
|
425
|
+
const errorData = await response.clone().json()
|
|
426
|
+
const errorMessage = String(errorData.message || errorData.error || "")
|
|
427
|
+
if (errorMessage.toLowerCase().includes("conversation complete")) {
|
|
428
|
+
return new Response(
|
|
429
|
+
JSON.stringify({
|
|
430
|
+
choices: [{ finish_reason: "stop", message: { content: "", role: "assistant" } }],
|
|
431
|
+
}),
|
|
432
|
+
{ status: 200, headers: new Headers({ "content-type": "application/json" }) },
|
|
433
|
+
)
|
|
434
|
+
}
|
|
435
|
+
} catch {}
|
|
436
|
+
}
|
|
437
|
+
|
|
438
|
+
if (response.body && response.headers.get("content-type")?.includes("text/event-stream")) {
|
|
439
|
+
const reader = response.body.getReader()
|
|
440
|
+
const encoder = new TextEncoder()
|
|
441
|
+
const decoder = new TextDecoder()
|
|
442
|
+
const stream = new ReadableStream({
|
|
443
|
+
async pull(ctrl) {
|
|
444
|
+
const { done, value } = await reader.read()
|
|
445
|
+
if (done) {
|
|
446
|
+
ctrl.close()
|
|
447
|
+
return
|
|
448
|
+
}
|
|
449
|
+
const text = decoder.decode(value, { stream: true })
|
|
450
|
+
ctrl.enqueue(encoder.encode(text.replace(/"role"\s*:\s*""/g, '"role":"assistant"')))
|
|
451
|
+
},
|
|
452
|
+
cancel() {
|
|
453
|
+
reader.cancel()
|
|
454
|
+
},
|
|
455
|
+
})
|
|
456
|
+
return new Response(stream, { headers: response.headers, status: response.status })
|
|
457
|
+
}
|
|
458
|
+
|
|
459
|
+
return response
|
|
460
|
+
}
|
|
461
|
+
|
|
462
|
+
const expiresSoon =
|
|
463
|
+
!currentOauth.expires ||
|
|
464
|
+
!currentOauth.access ||
|
|
465
|
+
currentOauth.expires - Date.now() <= ACCESS_TOKEN_REFRESH_SKEW_MS
|
|
466
|
+
|
|
467
|
+
if (expiresSoon) await refresh()
|
|
468
|
+
|
|
469
|
+
const response = await fetch(requestInput, prepareRequest())
|
|
470
|
+
|
|
471
|
+
if (response.status === 401) {
|
|
472
|
+
await refresh()
|
|
473
|
+
return transformResponse(await fetch(requestInput, prepareRequest()))
|
|
474
|
+
}
|
|
475
|
+
|
|
476
|
+
return transformResponse(response)
|
|
477
|
+
},
|
|
478
|
+
}
|
|
479
|
+
},
|
|
480
|
+
methods: [
|
|
481
|
+
{
|
|
482
|
+
type: "oauth",
|
|
483
|
+
label: "Login with Snowflake (External Browser)",
|
|
484
|
+
prompts,
|
|
485
|
+
async authorize(inputs = {}) {
|
|
486
|
+
const account = normalizeAccount(inputs.account || "")
|
|
487
|
+
if (!account) throw new Error("Snowflake account is required")
|
|
488
|
+
|
|
489
|
+
await startOAuthServer()
|
|
490
|
+
const pkce = await generatePKCE()
|
|
491
|
+
const state = generateRandomString(64)
|
|
492
|
+
const role = (inputs.role || "").trim() || undefined
|
|
493
|
+
const url = buildAuthorizeUrl(account, role, state, pkce)
|
|
494
|
+
const callbackPromise = waitForOAuthCallback(account, pkce, state)
|
|
495
|
+
await open(url).catch(() => undefined)
|
|
496
|
+
|
|
497
|
+
return {
|
|
498
|
+
url,
|
|
499
|
+
instructions:
|
|
500
|
+
"Complete Snowflake sign-in in your browser. Rimuru will capture the OAuth callback and store the bearer token automatically.",
|
|
501
|
+
method: "auto" as const,
|
|
502
|
+
async callback() {
|
|
503
|
+
try {
|
|
504
|
+
const tokens = await callbackPromise
|
|
505
|
+
return {
|
|
506
|
+
type: "success" as const,
|
|
507
|
+
refresh: tokens.refresh_token!,
|
|
508
|
+
access: tokens.access_token,
|
|
509
|
+
expires: Date.now() + (tokens.expires_in ?? 600) * 1000,
|
|
510
|
+
accountId: account,
|
|
511
|
+
}
|
|
512
|
+
} catch {
|
|
513
|
+
return { type: "failed" as const }
|
|
514
|
+
} finally {
|
|
515
|
+
stopOAuthServer()
|
|
516
|
+
}
|
|
517
|
+
},
|
|
518
|
+
}
|
|
519
|
+
},
|
|
520
|
+
},
|
|
521
|
+
{
|
|
522
|
+
type: "api",
|
|
523
|
+
label: "Paste PAT or bearer token manually",
|
|
524
|
+
prompts: prompts.filter((item) => item.key === "account"),
|
|
525
|
+
},
|
|
526
|
+
],
|
|
527
|
+
},
|
|
528
|
+
}
|
|
529
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { createBuiltinPlugins, type BuiltinTuiPlugin } from "@rimurucode-ai/tui/builtins"
|
|
2
|
+
import type { RuntimeFlags } from "@/effect/runtime-flags"
|
|
3
|
+
|
|
4
|
+
export type InternalTuiPlugin = BuiltinTuiPlugin
|
|
5
|
+
|
|
6
|
+
export function internalTuiPlugins(flags: Pick<RuntimeFlags.Info, "experimentalEventSystem">): InternalTuiPlugin[] {
|
|
7
|
+
return createBuiltinPlugins({
|
|
8
|
+
experimentalEventSystem: flags.experimentalEventSystem,
|
|
9
|
+
})
|
|
10
|
+
}
|