@staticn0va/wigolo 0.1.0 → 0.1.2
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/LICENSE +1 -1
- package/README.md +146 -227
- package/SKILL.md +382 -0
- package/assets/blocks/claude-code/CLAUDE.md.block +20 -0
- package/assets/blocks/claude-code/wigolo-command.md +40 -0
- package/assets/blocks/cursor/wigolo.mdc +46 -0
- package/assets/blocks/gemini-cli/GEMINI.md.block +18 -0
- package/assets/blocks/vscode/copilot-instructions.md.block +18 -0
- package/assets/skills/wigolo/SKILL.md +50 -0
- package/assets/skills/wigolo/rules/cache-first.md +30 -0
- package/assets/skills/wigolo/rules/synthesis.md +43 -0
- package/assets/skills/wigolo-agent/SKILL.md +73 -0
- package/assets/skills/wigolo-crawl/SKILL.md +60 -0
- package/assets/skills/wigolo-extract/SKILL.md +59 -0
- package/assets/skills/wigolo-fetch/SKILL.md +65 -0
- package/assets/skills/wigolo-find-similar/SKILL.md +72 -0
- package/assets/skills/wigolo-research/SKILL.md +77 -0
- package/assets/skills/wigolo-search/SKILL.md +78 -0
- package/dist/agent/executor.d.ts +33 -0
- package/dist/agent/executor.d.ts.map +1 -0
- package/dist/agent/executor.js +233 -0
- package/dist/agent/executor.js.map +1 -0
- package/dist/agent/pipeline.d.ts +5 -0
- package/dist/agent/pipeline.d.ts.map +1 -0
- package/dist/agent/pipeline.js +238 -0
- package/dist/agent/pipeline.js.map +1 -0
- package/dist/agent/planner.d.ts +13 -0
- package/dist/agent/planner.d.ts.map +1 -0
- package/dist/agent/planner.js +271 -0
- package/dist/agent/planner.js.map +1 -0
- package/dist/agent/relevance.d.ts +15 -0
- package/dist/agent/relevance.d.ts.map +1 -0
- package/dist/agent/relevance.js +60 -0
- package/dist/agent/relevance.js.map +1 -0
- package/dist/cache/backfill-embeddings.d.ts +23 -0
- package/dist/cache/backfill-embeddings.d.ts.map +1 -0
- package/dist/cache/backfill-embeddings.js +105 -0
- package/dist/cache/backfill-embeddings.js.map +1 -0
- package/dist/cache/change-detector.d.ts +7 -0
- package/dist/cache/change-detector.d.ts.map +1 -0
- package/dist/cache/change-detector.js +43 -0
- package/dist/cache/change-detector.js.map +1 -0
- package/dist/cache/db.d.ts +1 -0
- package/dist/cache/db.d.ts.map +1 -1
- package/dist/cache/db.js +94 -22
- package/dist/cache/db.js.map +1 -1
- package/dist/cache/diff-summary.d.ts +2 -0
- package/dist/cache/diff-summary.d.ts.map +1 -0
- package/dist/cache/diff-summary.js +82 -0
- package/dist/cache/diff-summary.js.map +1 -0
- package/dist/cache/migrations/runner.d.ts +29 -0
- package/dist/cache/migrations/runner.d.ts.map +1 -0
- package/dist/cache/migrations/runner.js +147 -0
- package/dist/cache/migrations/runner.js.map +1 -0
- package/dist/cache/sqlite-vec-store.d.ts +42 -0
- package/dist/cache/sqlite-vec-store.d.ts.map +1 -0
- package/dist/cache/sqlite-vec-store.js +176 -0
- package/dist/cache/sqlite-vec-store.js.map +1 -0
- package/dist/cache/store.d.ts +47 -1
- package/dist/cache/store.d.ts.map +1 -1
- package/dist/cache/store.js +364 -168
- package/dist/cache/store.js.map +1 -1
- package/dist/cli/agents/antigravity.d.ts +20 -0
- package/dist/cli/agents/antigravity.d.ts.map +1 -0
- package/dist/cli/agents/antigravity.js +49 -0
- package/dist/cli/agents/antigravity.js.map +1 -0
- package/dist/cli/agents/claude-code.d.ts +25 -0
- package/dist/cli/agents/claude-code.d.ts.map +1 -0
- package/dist/cli/agents/claude-code.js +111 -0
- package/dist/cli/agents/claude-code.js.map +1 -0
- package/dist/cli/agents/cursor.d.ts +21 -0
- package/dist/cli/agents/cursor.d.ts.map +1 -0
- package/dist/cli/agents/cursor.js +58 -0
- package/dist/cli/agents/cursor.js.map +1 -0
- package/dist/cli/agents/gemini-cli.d.ts +21 -0
- package/dist/cli/agents/gemini-cli.d.ts.map +1 -0
- package/dist/cli/agents/gemini-cli.js +55 -0
- package/dist/cli/agents/gemini-cli.js.map +1 -0
- package/dist/cli/agents/registry.d.ts +21 -0
- package/dist/cli/agents/registry.d.ts.map +1 -0
- package/dist/cli/agents/registry.js +27 -0
- package/dist/cli/agents/registry.js.map +1 -0
- package/dist/cli/agents/utils.d.ts +26 -0
- package/dist/cli/agents/utils.d.ts.map +1 -0
- package/dist/cli/agents/utils.js +136 -0
- package/dist/cli/agents/utils.js.map +1 -0
- package/dist/cli/agents/vscode.d.ts +21 -0
- package/dist/cli/agents/vscode.d.ts.map +1 -0
- package/dist/cli/agents/vscode.js +62 -0
- package/dist/cli/agents/vscode.js.map +1 -0
- package/dist/cli/auth.d.ts +2 -0
- package/dist/cli/auth.d.ts.map +1 -0
- package/dist/cli/auth.js +94 -0
- package/dist/cli/auth.js.map +1 -0
- package/dist/cli/backfill.d.ts +2 -0
- package/dist/cli/backfill.d.ts.map +1 -0
- package/dist/cli/backfill.js +58 -0
- package/dist/cli/backfill.js.map +1 -0
- package/dist/cli/daemon.d.ts +6 -1
- package/dist/cli/daemon.d.ts.map +1 -1
- package/dist/cli/daemon.js +61 -3
- package/dist/cli/daemon.js.map +1 -1
- package/dist/cli/doctor.d.ts +8 -0
- package/dist/cli/doctor.d.ts.map +1 -0
- package/dist/cli/doctor.js +344 -0
- package/dist/cli/doctor.js.map +1 -0
- package/dist/cli/health.d.ts +1 -1
- package/dist/cli/health.d.ts.map +1 -1
- package/dist/cli/health.js +42 -3
- package/dist/cli/health.js.map +1 -1
- package/dist/cli/help.d.ts +6 -0
- package/dist/cli/help.d.ts.map +1 -0
- package/dist/cli/help.js +63 -0
- package/dist/cli/help.js.map +1 -0
- package/dist/cli/index.d.ts +1 -1
- package/dist/cli/index.d.ts.map +1 -1
- package/dist/cli/index.js +35 -7
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/init.d.ts +2 -0
- package/dist/cli/init.d.ts.map +1 -0
- package/dist/cli/init.js +201 -0
- package/dist/cli/init.js.map +1 -0
- package/dist/cli/plugin.d.ts +5 -0
- package/dist/cli/plugin.d.ts.map +1 -0
- package/dist/cli/plugin.js +185 -0
- package/dist/cli/plugin.js.map +1 -0
- package/dist/cli/setup-mcp.d.ts +2 -0
- package/dist/cli/setup-mcp.d.ts.map +1 -0
- package/dist/cli/setup-mcp.js +114 -0
- package/dist/cli/setup-mcp.js.map +1 -0
- package/dist/cli/shell.d.ts +2 -0
- package/dist/cli/shell.d.ts.map +1 -0
- package/dist/cli/shell.js +86 -0
- package/dist/cli/shell.js.map +1 -0
- package/dist/cli/shutdown.d.ts +2 -0
- package/dist/cli/shutdown.d.ts.map +1 -0
- package/dist/cli/shutdown.js +26 -0
- package/dist/cli/shutdown.js.map +1 -0
- package/dist/cli/status.d.ts +2 -0
- package/dist/cli/status.d.ts.map +1 -0
- package/dist/cli/status.js +31 -0
- package/dist/cli/status.js.map +1 -0
- package/dist/cli/telemetry.d.ts +10 -0
- package/dist/cli/telemetry.d.ts.map +1 -0
- package/dist/cli/telemetry.js +56 -0
- package/dist/cli/telemetry.js.map +1 -0
- package/dist/cli/tui/agents-types.d.ts +28 -0
- package/dist/cli/tui/agents-types.d.ts.map +1 -0
- package/dist/cli/tui/agents-types.js +1 -0
- package/dist/cli/tui/agents-types.js.map +1 -0
- package/dist/cli/tui/agents.d.ts +11 -0
- package/dist/cli/tui/agents.d.ts.map +1 -0
- package/dist/cli/tui/agents.js +93 -0
- package/dist/cli/tui/agents.js.map +1 -0
- package/dist/cli/tui/banner.d.ts +3 -0
- package/dist/cli/tui/banner.d.ts.map +1 -0
- package/dist/cli/tui/banner.js +30 -0
- package/dist/cli/tui/banner.js.map +1 -0
- package/dist/cli/tui/components/AgentSelect.d.ts +13 -0
- package/dist/cli/tui/components/AgentSelect.d.ts.map +1 -0
- package/dist/cli/tui/components/AgentSelect.js +116 -0
- package/dist/cli/tui/components/AgentSelect.js.map +1 -0
- package/dist/cli/tui/components/Banner.d.ts +6 -0
- package/dist/cli/tui/components/Banner.d.ts.map +1 -0
- package/dist/cli/tui/components/Banner.js +25 -0
- package/dist/cli/tui/components/Banner.js.map +1 -0
- package/dist/cli/tui/components/BrowserSelect.d.ts +7 -0
- package/dist/cli/tui/components/BrowserSelect.d.ts.map +1 -0
- package/dist/cli/tui/components/BrowserSelect.js +19 -0
- package/dist/cli/tui/components/BrowserSelect.js.map +1 -0
- package/dist/cli/tui/components/InstallProgress.d.ts +9 -0
- package/dist/cli/tui/components/InstallProgress.d.ts.map +1 -0
- package/dist/cli/tui/components/InstallProgress.js +67 -0
- package/dist/cli/tui/components/InstallProgress.js.map +1 -0
- package/dist/cli/tui/components/SkillInstall.d.ts +14 -0
- package/dist/cli/tui/components/SkillInstall.d.ts.map +1 -0
- package/dist/cli/tui/components/SkillInstall.js +94 -0
- package/dist/cli/tui/components/SkillInstall.js.map +1 -0
- package/dist/cli/tui/components/Summary.d.ts +22 -0
- package/dist/cli/tui/components/Summary.d.ts.map +1 -0
- package/dist/cli/tui/components/Summary.js +135 -0
- package/dist/cli/tui/components/Summary.js.map +1 -0
- package/dist/cli/tui/components/SystemCheck.d.ts +8 -0
- package/dist/cli/tui/components/SystemCheck.d.ts.map +1 -0
- package/dist/cli/tui/components/SystemCheck.js +71 -0
- package/dist/cli/tui/components/SystemCheck.js.map +1 -0
- package/dist/cli/tui/components/Verification.d.ts +8 -0
- package/dist/cli/tui/components/Verification.d.ts.map +1 -0
- package/dist/cli/tui/components/Verification.js +63 -0
- package/dist/cli/tui/components/Verification.js.map +1 -0
- package/dist/cli/tui/config-writer-cli.d.ts +12 -0
- package/dist/cli/tui/config-writer-cli.d.ts.map +1 -0
- package/dist/cli/tui/config-writer-cli.js +39 -0
- package/dist/cli/tui/config-writer-cli.js.map +1 -0
- package/dist/cli/tui/config-writer-json.d.ts +16 -0
- package/dist/cli/tui/config-writer-json.d.ts.map +1 -0
- package/dist/cli/tui/config-writer-json.js +86 -0
- package/dist/cli/tui/config-writer-json.js.map +1 -0
- package/dist/cli/tui/config-writer-toml.d.ts +16 -0
- package/dist/cli/tui/config-writer-toml.d.ts.map +1 -0
- package/dist/cli/tui/config-writer-toml.js +83 -0
- package/dist/cli/tui/config-writer-toml.js.map +1 -0
- package/dist/cli/tui/config-writer.d.ts +25 -0
- package/dist/cli/tui/config-writer.d.ts.map +1 -0
- package/dist/cli/tui/config-writer.js +101 -0
- package/dist/cli/tui/config-writer.js.map +1 -0
- package/dist/cli/tui/detect-helpers.d.ts +6 -0
- package/dist/cli/tui/detect-helpers.d.ts.map +1 -0
- package/dist/cli/tui/detect-helpers.js +45 -0
- package/dist/cli/tui/detect-helpers.js.map +1 -0
- package/dist/cli/tui/extras-prompt.d.ts +7 -0
- package/dist/cli/tui/extras-prompt.d.ts.map +1 -0
- package/dist/cli/tui/extras-prompt.js +42 -0
- package/dist/cli/tui/extras-prompt.js.map +1 -0
- package/dist/cli/tui/flags-types.d.ts +19 -0
- package/dist/cli/tui/flags-types.d.ts.map +1 -0
- package/dist/cli/tui/flags-types.js +23 -0
- package/dist/cli/tui/flags-types.js.map +1 -0
- package/dist/cli/tui/flags.d.ts +5 -0
- package/dist/cli/tui/flags.d.ts.map +1 -0
- package/dist/cli/tui/flags.js +132 -0
- package/dist/cli/tui/flags.js.map +1 -0
- package/dist/cli/tui/format.d.ts +14 -0
- package/dist/cli/tui/format.d.ts.map +1 -0
- package/dist/cli/tui/format.js +37 -0
- package/dist/cli/tui/format.js.map +1 -0
- package/dist/cli/tui/hooks/useAgentDetect.d.ts +6 -0
- package/dist/cli/tui/hooks/useAgentDetect.d.ts.map +1 -0
- package/dist/cli/tui/hooks/useAgentDetect.js +19 -0
- package/dist/cli/tui/hooks/useAgentDetect.js.map +1 -0
- package/dist/cli/tui/hooks/useInstall.d.ts +14 -0
- package/dist/cli/tui/hooks/useInstall.d.ts.map +1 -0
- package/dist/cli/tui/hooks/useInstall.js +90 -0
- package/dist/cli/tui/hooks/useInstall.js.map +1 -0
- package/dist/cli/tui/hooks/useSystemCheck.d.ts +13 -0
- package/dist/cli/tui/hooks/useSystemCheck.d.ts.map +1 -0
- package/dist/cli/tui/hooks/useSystemCheck.js +95 -0
- package/dist/cli/tui/hooks/useSystemCheck.js.map +1 -0
- package/dist/cli/tui/hooks/useVerify.d.ts +14 -0
- package/dist/cli/tui/hooks/useVerify.d.ts.map +1 -0
- package/dist/cli/tui/hooks/useVerify.js +71 -0
- package/dist/cli/tui/hooks/useVerify.js.map +1 -0
- package/dist/cli/tui/ink-init.d.ts +2 -0
- package/dist/cli/tui/ink-init.d.ts.map +1 -0
- package/dist/cli/tui/ink-init.js +198 -0
- package/dist/cli/tui/ink-init.js.map +1 -0
- package/dist/cli/tui/reporter-auto.d.ts +7 -0
- package/dist/cli/tui/reporter-auto.d.ts.map +1 -0
- package/dist/cli/tui/reporter-auto.js +15 -0
- package/dist/cli/tui/reporter-auto.js.map +1 -0
- package/dist/cli/tui/reporter.d.ts +26 -0
- package/dist/cli/tui/reporter.d.ts.map +1 -0
- package/dist/cli/tui/reporter.js +32 -0
- package/dist/cli/tui/reporter.js.map +1 -0
- package/dist/cli/tui/run-command.d.ts +14 -0
- package/dist/cli/tui/run-command.d.ts.map +1 -0
- package/dist/cli/tui/run-command.js +72 -0
- package/dist/cli/tui/run-command.js.map +1 -0
- package/dist/cli/tui/select-agents.d.ts +6 -0
- package/dist/cli/tui/select-agents.d.ts.map +1 -0
- package/dist/cli/tui/select-agents.js +32 -0
- package/dist/cli/tui/select-agents.js.map +1 -0
- package/dist/cli/tui/status-agents.d.ts +11 -0
- package/dist/cli/tui/status-agents.d.ts.map +1 -0
- package/dist/cli/tui/status-agents.js +53 -0
- package/dist/cli/tui/status-agents.js.map +1 -0
- package/dist/cli/tui/status-cache.d.ts +6 -0
- package/dist/cli/tui/status-cache.d.ts.map +1 -0
- package/dist/cli/tui/status-cache.js +39 -0
- package/dist/cli/tui/status-cache.js.map +1 -0
- package/dist/cli/tui/status-format.d.ts +14 -0
- package/dist/cli/tui/status-format.d.ts.map +1 -0
- package/dist/cli/tui/status-format.js +41 -0
- package/dist/cli/tui/status-format.js.map +1 -0
- package/dist/cli/tui/status-python.d.ts +6 -0
- package/dist/cli/tui/status-python.d.ts.map +1 -0
- package/dist/cli/tui/status-python.js +30 -0
- package/dist/cli/tui/status-python.js.map +1 -0
- package/dist/cli/tui/system-check.d.ts +24 -0
- package/dist/cli/tui/system-check.d.ts.map +1 -0
- package/dist/cli/tui/system-check.js +103 -0
- package/dist/cli/tui/system-check.js.map +1 -0
- package/dist/cli/tui/tui-reporter.d.ts +19 -0
- package/dist/cli/tui/tui-reporter.d.ts.map +1 -0
- package/dist/cli/tui/tui-reporter.js +95 -0
- package/dist/cli/tui/tui-reporter.js.map +1 -0
- package/dist/cli/tui/utils/config-writer.d.ts +3 -0
- package/dist/cli/tui/utils/config-writer.d.ts.map +1 -0
- package/dist/cli/tui/utils/config-writer.js +22 -0
- package/dist/cli/tui/utils/config-writer.js.map +1 -0
- package/dist/cli/tui/utils/suppress-logs.d.ts +3 -0
- package/dist/cli/tui/utils/suppress-logs.d.ts.map +1 -0
- package/dist/cli/tui/utils/suppress-logs.js +11 -0
- package/dist/cli/tui/utils/suppress-logs.js.map +1 -0
- package/dist/cli/tui/verify-suggestions.d.ts +5 -0
- package/dist/cli/tui/verify-suggestions.d.ts.map +1 -0
- package/dist/cli/tui/verify-suggestions.js +20 -0
- package/dist/cli/tui/verify-suggestions.js.map +1 -0
- package/dist/cli/tui/verify.d.ts +14 -0
- package/dist/cli/tui/verify.d.ts.map +1 -0
- package/dist/cli/tui/verify.js +101 -0
- package/dist/cli/tui/verify.js.map +1 -0
- package/dist/cli/tui/version.d.ts +2 -0
- package/dist/cli/tui/version.d.ts.map +1 -0
- package/dist/cli/tui/version.js +14 -0
- package/dist/cli/tui/version.js.map +1 -0
- package/dist/cli/uninstall.d.ts +2 -0
- package/dist/cli/uninstall.d.ts.map +1 -0
- package/dist/cli/uninstall.js +57 -0
- package/dist/cli/uninstall.js.map +1 -0
- package/dist/cli/warmup.d.ts +10 -2
- package/dist/cli/warmup.d.ts.map +1 -1
- package/dist/cli/warmup.js +226 -93
- package/dist/cli/warmup.js.map +1 -1
- package/dist/config.d.ts +28 -2
- package/dist/config.d.ts.map +1 -1
- package/dist/config.js +106 -56
- package/dist/config.js.map +1 -1
- package/dist/crawl/crawler.d.ts +6 -0
- package/dist/crawl/crawler.d.ts.map +1 -1
- package/dist/crawl/crawler.js +210 -209
- package/dist/crawl/crawler.js.map +1 -1
- package/dist/crawl/dedup.d.ts +1 -0
- package/dist/crawl/dedup.d.ts.map +1 -1
- package/dist/crawl/dedup.js +124 -81
- package/dist/crawl/dedup.js.map +1 -1
- package/dist/crawl/etag-incremental.d.ts +43 -0
- package/dist/crawl/etag-incremental.d.ts.map +1 -0
- package/dist/crawl/etag-incremental.js +94 -0
- package/dist/crawl/etag-incremental.js.map +1 -0
- package/dist/crawl/index-to-vec.d.ts +10 -0
- package/dist/crawl/index-to-vec.d.ts.map +1 -0
- package/dist/crawl/index-to-vec.js +44 -0
- package/dist/crawl/index-to-vec.js.map +1 -0
- package/dist/crawl/mapper.js +136 -164
- package/dist/crawl/mapper.js.map +1 -1
- package/dist/crawl/rate-limiter.js +63 -66
- package/dist/crawl/rate-limiter.js.map +1 -1
- package/dist/crawl/robots.js +58 -57
- package/dist/crawl/robots.js.map +1 -1
- package/dist/crawl/sitemap-first.d.ts +12 -0
- package/dist/crawl/sitemap-first.d.ts.map +1 -0
- package/dist/crawl/sitemap-first.js +47 -0
- package/dist/crawl/sitemap-first.js.map +1 -0
- package/dist/crawl/sitemap.js +33 -32
- package/dist/crawl/sitemap.js.map +1 -1
- package/dist/crawl/url-utils.d.ts +1 -0
- package/dist/crawl/url-utils.d.ts.map +1 -1
- package/dist/crawl/url-utils.js +49 -37
- package/dist/crawl/url-utils.js.map +1 -1
- package/dist/daemon/health-check.d.ts +16 -0
- package/dist/daemon/health-check.d.ts.map +1 -0
- package/dist/daemon/health-check.js +33 -0
- package/dist/daemon/health-check.js.map +1 -0
- package/dist/daemon/http-server.d.ts +26 -0
- package/dist/daemon/http-server.d.ts.map +1 -0
- package/dist/daemon/http-server.js +275 -0
- package/dist/daemon/http-server.js.map +1 -0
- package/dist/daemon/proxy.d.ts +10 -0
- package/dist/daemon/proxy.d.ts.map +1 -0
- package/dist/daemon/proxy.js +93 -0
- package/dist/daemon/proxy.js.map +1 -0
- package/dist/embedding/embed.d.ts +59 -0
- package/dist/embedding/embed.d.ts.map +1 -0
- package/dist/embedding/embed.js +233 -0
- package/dist/embedding/embed.js.map +1 -0
- package/dist/embedding/fastembed-provider.d.ts +19 -0
- package/dist/embedding/fastembed-provider.d.ts.map +1 -0
- package/dist/embedding/fastembed-provider.js +51 -0
- package/dist/embedding/fastembed-provider.js.map +1 -0
- package/dist/embedding/key-terms.d.ts +12 -0
- package/dist/embedding/key-terms.d.ts.map +1 -0
- package/dist/embedding/key-terms.js +234 -0
- package/dist/embedding/key-terms.js.map +1 -0
- package/dist/extraction/boilerplate.d.ts +15 -0
- package/dist/extraction/boilerplate.d.ts.map +1 -0
- package/dist/extraction/boilerplate.js +52 -0
- package/dist/extraction/boilerplate.js.map +1 -0
- package/dist/extraction/defuddle.d.ts.map +1 -1
- package/dist/extraction/defuddle.js +27 -23
- package/dist/extraction/defuddle.js.map +1 -1
- package/dist/extraction/extract.d.ts.map +1 -1
- package/dist/extraction/extract.js +76 -76
- package/dist/extraction/extract.js.map +1 -1
- package/dist/extraction/jsonld.js +50 -54
- package/dist/extraction/jsonld.js.map +1 -1
- package/dist/extraction/lang-hints.d.ts +2 -0
- package/dist/extraction/lang-hints.d.ts.map +1 -0
- package/dist/extraction/lang-hints.js +30 -0
- package/dist/extraction/lang-hints.js.map +1 -0
- package/dist/extraction/llm-fallback.d.ts +17 -0
- package/dist/extraction/llm-fallback.d.ts.map +1 -0
- package/dist/extraction/llm-fallback.js +130 -0
- package/dist/extraction/llm-fallback.js.map +1 -0
- package/dist/extraction/markdown-sanitize.d.ts +2 -0
- package/dist/extraction/markdown-sanitize.d.ts.map +1 -0
- package/dist/extraction/markdown-sanitize.js +151 -0
- package/dist/extraction/markdown-sanitize.js.map +1 -0
- package/dist/extraction/markdown.d.ts +11 -0
- package/dist/extraction/markdown.d.ts.map +1 -1
- package/dist/extraction/markdown.js +195 -91
- package/dist/extraction/markdown.js.map +1 -1
- package/dist/extraction/pipeline.d.ts +8 -0
- package/dist/extraction/pipeline.d.ts.map +1 -1
- package/dist/extraction/pipeline.js +57 -91
- package/dist/extraction/pipeline.js.map +1 -1
- package/dist/extraction/readability.d.ts +1 -1
- package/dist/extraction/readability.d.ts.map +1 -1
- package/dist/extraction/readability.js +28 -29
- package/dist/extraction/readability.js.map +1 -1
- package/dist/extraction/schema.d.ts +12 -0
- package/dist/extraction/schema.d.ts.map +1 -1
- package/dist/extraction/schema.js +135 -72
- package/dist/extraction/schema.js.map +1 -1
- package/dist/extraction/site-extractors/docs-generic.d.ts.map +1 -1
- package/dist/extraction/site-extractors/docs-generic.js +81 -91
- package/dist/extraction/site-extractors/docs-generic.js.map +1 -1
- package/dist/extraction/site-extractors/github.d.ts.map +1 -1
- package/dist/extraction/site-extractors/github.js +87 -95
- package/dist/extraction/site-extractors/github.js.map +1 -1
- package/dist/extraction/site-extractors/mdn.d.ts.map +1 -1
- package/dist/extraction/site-extractors/mdn.js +46 -54
- package/dist/extraction/site-extractors/mdn.js.map +1 -1
- package/dist/extraction/site-extractors/stackoverflow.d.ts.map +1 -1
- package/dist/extraction/site-extractors/stackoverflow.js +71 -80
- package/dist/extraction/site-extractors/stackoverflow.js.map +1 -1
- package/dist/extraction/structured-data.d.ts +4 -0
- package/dist/extraction/structured-data.d.ts.map +1 -0
- package/dist/extraction/structured-data.js +173 -0
- package/dist/extraction/structured-data.js.map +1 -0
- package/dist/extraction/structured.d.ts +4 -0
- package/dist/extraction/structured.d.ts.map +1 -0
- package/dist/extraction/structured.js +163 -0
- package/dist/extraction/structured.js.map +1 -0
- package/dist/extraction/v1/classifier.d.ts +3 -0
- package/dist/extraction/v1/classifier.d.ts.map +1 -0
- package/dist/extraction/v1/classifier.js +110 -0
- package/dist/extraction/v1/classifier.js.map +1 -0
- package/dist/extraction/v1/extract-provider.d.ts +16 -0
- package/dist/extraction/v1/extract-provider.d.ts.map +1 -0
- package/dist/extraction/v1/extract-provider.js +43 -0
- package/dist/extraction/v1/extract-provider.js.map +1 -0
- package/dist/extraction/v1/local-llm.d.ts +8 -0
- package/dist/extraction/v1/local-llm.d.ts.map +1 -0
- package/dist/extraction/v1/local-llm.js +34 -0
- package/dist/extraction/v1/local-llm.js.map +1 -0
- package/dist/extraction/v1/news.d.ts +3 -0
- package/dist/extraction/v1/news.d.ts.map +1 -0
- package/dist/extraction/v1/news.js +61 -0
- package/dist/extraction/v1/news.js.map +1 -0
- package/dist/extraction/v1/product.d.ts +3 -0
- package/dist/extraction/v1/product.d.ts.map +1 -0
- package/dist/extraction/v1/product.js +166 -0
- package/dist/extraction/v1/product.js.map +1 -0
- package/dist/extraction/v1/recipe.d.ts +3 -0
- package/dist/extraction/v1/recipe.d.ts.map +1 -0
- package/dist/extraction/v1/recipe.js +136 -0
- package/dist/extraction/v1/recipe.js.map +1 -0
- package/dist/extraction/v1/routed.d.ts +17 -0
- package/dist/extraction/v1/routed.d.ts.map +1 -0
- package/dist/extraction/v1/routed.js +68 -0
- package/dist/extraction/v1/routed.js.map +1 -0
- package/dist/extraction/v1/schemas/Article.d.ts +11 -0
- package/dist/extraction/v1/schemas/Article.d.ts.map +1 -0
- package/dist/extraction/v1/schemas/Article.js +23 -0
- package/dist/extraction/v1/schemas/Article.js.map +1 -0
- package/dist/extraction/v1/schemas/CodeSnippet.d.ts +9 -0
- package/dist/extraction/v1/schemas/CodeSnippet.d.ts.map +1 -0
- package/dist/extraction/v1/schemas/CodeSnippet.js +90 -0
- package/dist/extraction/v1/schemas/CodeSnippet.js.map +1 -0
- package/dist/extraction/v1/schemas/EventListing.d.ts +10 -0
- package/dist/extraction/v1/schemas/EventListing.d.ts.map +1 -0
- package/dist/extraction/v1/schemas/EventListing.js +122 -0
- package/dist/extraction/v1/schemas/EventListing.js.map +1 -0
- package/dist/extraction/v1/schemas/Paper.d.ts +10 -0
- package/dist/extraction/v1/schemas/Paper.d.ts.map +1 -0
- package/dist/extraction/v1/schemas/Paper.js +156 -0
- package/dist/extraction/v1/schemas/Paper.js.map +1 -0
- package/dist/extraction/v1/schemas/Product.d.ts +17 -0
- package/dist/extraction/v1/schemas/Product.d.ts.map +1 -0
- package/dist/extraction/v1/schemas/Product.js +149 -0
- package/dist/extraction/v1/schemas/Product.js.map +1 -0
- package/dist/extraction/v1/schemas/Recipe.d.ts +14 -0
- package/dist/extraction/v1/schemas/Recipe.d.ts.map +1 -0
- package/dist/extraction/v1/schemas/Recipe.js +160 -0
- package/dist/extraction/v1/schemas/Recipe.js.map +1 -0
- package/dist/extraction/v1/schemas/index.d.ts +13 -0
- package/dist/extraction/v1/schemas/index.d.ts.map +1 -0
- package/dist/extraction/v1/schemas/index.js +44 -0
- package/dist/extraction/v1/schemas/index.js.map +1 -0
- package/dist/extraction/v1/site-extractors.d.ts +5 -0
- package/dist/extraction/v1/site-extractors.d.ts.map +1 -0
- package/dist/extraction/v1/site-extractors.js +31 -0
- package/dist/extraction/v1/site-extractors.js.map +1 -0
- package/dist/fetch/action-executor.d.ts +28 -0
- package/dist/fetch/action-executor.d.ts.map +1 -0
- package/dist/fetch/action-executor.js +88 -0
- package/dist/fetch/action-executor.js.map +1 -0
- package/dist/fetch/auth.d.ts +2 -1
- package/dist/fetch/auth.d.ts.map +1 -1
- package/dist/fetch/auth.js +56 -26
- package/dist/fetch/auth.js.map +1 -1
- package/dist/fetch/browser-pool.d.ts +30 -11
- package/dist/fetch/browser-pool.d.ts.map +1 -1
- package/dist/fetch/browser-pool.js +303 -127
- package/dist/fetch/browser-pool.js.map +1 -1
- package/dist/fetch/browser-selector.d.ts +17 -0
- package/dist/fetch/browser-selector.d.ts.map +1 -0
- package/dist/fetch/browser-selector.js +72 -0
- package/dist/fetch/browser-selector.js.map +1 -0
- package/dist/fetch/browser-types.d.ts +3 -0
- package/dist/fetch/browser-types.d.ts.map +1 -0
- package/dist/fetch/browser-types.js +45 -0
- package/dist/fetch/browser-types.js.map +1 -0
- package/dist/fetch/cdp-client.d.ts +9 -0
- package/dist/fetch/cdp-client.d.ts.map +1 -0
- package/dist/fetch/cdp-client.js +89 -0
- package/dist/fetch/cdp-client.js.map +1 -0
- package/dist/fetch/content-check.js +39 -46
- package/dist/fetch/content-check.js.map +1 -1
- package/dist/fetch/error-describe.d.ts +7 -0
- package/dist/fetch/error-describe.d.ts.map +1 -0
- package/dist/fetch/error-describe.js +37 -0
- package/dist/fetch/error-describe.js.map +1 -0
- package/dist/fetch/http-client.d.ts +4 -0
- package/dist/fetch/http-client.d.ts.map +1 -1
- package/dist/fetch/http-client.js +147 -128
- package/dist/fetch/http-client.js.map +1 -1
- package/dist/fetch/lightpanda.d.ts +28 -0
- package/dist/fetch/lightpanda.d.ts.map +1 -0
- package/dist/fetch/lightpanda.js +174 -0
- package/dist/fetch/lightpanda.js.map +1 -0
- package/dist/fetch/playwright-tier.d.ts +19 -0
- package/dist/fetch/playwright-tier.d.ts.map +1 -0
- package/dist/fetch/playwright-tier.js +76 -0
- package/dist/fetch/playwright-tier.js.map +1 -0
- package/dist/fetch/router.d.ts +49 -3
- package/dist/fetch/router.d.ts.map +1 -1
- package/dist/fetch/router.js +187 -81
- package/dist/fetch/router.js.map +1 -1
- package/dist/index.js +102 -17
- package/dist/index.js.map +1 -1
- package/dist/instructions.d.ts +31 -0
- package/dist/instructions.d.ts.map +1 -0
- package/dist/instructions.js +245 -0
- package/dist/instructions.js.map +1 -0
- package/dist/integrations/cloud/llm/anthropic.d.ts +3 -0
- package/dist/integrations/cloud/llm/anthropic.d.ts.map +1 -0
- package/dist/integrations/cloud/llm/anthropic.js +41 -0
- package/dist/integrations/cloud/llm/anthropic.js.map +1 -0
- package/dist/integrations/cloud/llm/cache.d.ts +5 -0
- package/dist/integrations/cloud/llm/cache.d.ts.map +1 -0
- package/dist/integrations/cloud/llm/cache.js +49 -0
- package/dist/integrations/cloud/llm/cache.js.map +1 -0
- package/dist/integrations/cloud/llm/gemini.d.ts +3 -0
- package/dist/integrations/cloud/llm/gemini.d.ts.map +1 -0
- package/dist/integrations/cloud/llm/gemini.js +37 -0
- package/dist/integrations/cloud/llm/gemini.js.map +1 -0
- package/dist/integrations/cloud/llm/groq.d.ts +3 -0
- package/dist/integrations/cloud/llm/groq.d.ts.map +1 -0
- package/dist/integrations/cloud/llm/groq.js +74 -0
- package/dist/integrations/cloud/llm/groq.js.map +1 -0
- package/dist/integrations/cloud/llm/hash.d.ts +3 -0
- package/dist/integrations/cloud/llm/hash.d.ts.map +1 -0
- package/dist/integrations/cloud/llm/hash.js +26 -0
- package/dist/integrations/cloud/llm/hash.js.map +1 -0
- package/dist/integrations/cloud/llm/model-select.d.ts +5 -0
- package/dist/integrations/cloud/llm/model-select.d.ts.map +1 -0
- package/dist/integrations/cloud/llm/model-select.js +32 -0
- package/dist/integrations/cloud/llm/model-select.js.map +1 -0
- package/dist/integrations/cloud/llm/openai.d.ts +3 -0
- package/dist/integrations/cloud/llm/openai.d.ts.map +1 -0
- package/dist/integrations/cloud/llm/openai.js +43 -0
- package/dist/integrations/cloud/llm/openai.js.map +1 -0
- package/dist/integrations/cloud/llm/run.d.ts +27 -0
- package/dist/integrations/cloud/llm/run.d.ts.map +1 -0
- package/dist/integrations/cloud/llm/run.js +99 -0
- package/dist/integrations/cloud/llm/run.js.map +1 -0
- package/dist/integrations/cloud/llm/select.d.ts +5 -0
- package/dist/integrations/cloud/llm/select.d.ts.map +1 -0
- package/dist/integrations/cloud/llm/select.js +30 -0
- package/dist/integrations/cloud/llm/select.js.map +1 -0
- package/dist/integrations/cloud/llm/text-adapters.d.ts +19 -0
- package/dist/integrations/cloud/llm/text-adapters.d.ts.map +1 -0
- package/dist/integrations/cloud/llm/text-adapters.js +103 -0
- package/dist/integrations/cloud/llm/text-adapters.js.map +1 -0
- package/dist/integrations/cloud/llm/types.d.ts +24 -0
- package/dist/integrations/cloud/llm/types.d.ts.map +1 -0
- package/dist/integrations/cloud/llm/types.js +1 -0
- package/dist/integrations/cloud/llm/types.js.map +1 -0
- package/dist/integrations/cloud/llm/validate.d.ts +6 -0
- package/dist/integrations/cloud/llm/validate.d.ts.map +1 -0
- package/dist/integrations/cloud/llm/validate.js +63 -0
- package/dist/integrations/cloud/llm/validate.js.map +1 -0
- package/dist/logger.d.ts +4 -1
- package/dist/logger.d.ts.map +1 -1
- package/dist/logger.js +71 -30
- package/dist/logger.js.map +1 -1
- package/dist/pdf-parse.d.js +1 -0
- package/dist/pdf-parse.d.js.map +1 -0
- package/dist/plugins/loader.d.ts +20 -0
- package/dist/plugins/loader.d.ts.map +1 -0
- package/dist/plugins/loader.js +157 -0
- package/dist/plugins/loader.js.map +1 -0
- package/dist/plugins/registry.d.ts +26 -0
- package/dist/plugins/registry.d.ts.map +1 -0
- package/dist/plugins/registry.js +71 -0
- package/dist/plugins/registry.js.map +1 -0
- package/dist/plugins/validate.d.ts +9 -0
- package/dist/plugins/validate.d.ts.map +1 -0
- package/dist/plugins/validate.js +79 -0
- package/dist/plugins/validate.js.map +1 -0
- package/dist/providers/embed-provider.d.ts +11 -0
- package/dist/providers/embed-provider.d.ts.map +1 -0
- package/dist/providers/embed-provider.js +24 -0
- package/dist/providers/embed-provider.js.map +1 -0
- package/dist/providers/extract-provider.d.ts +23 -0
- package/dist/providers/extract-provider.d.ts.map +1 -0
- package/dist/providers/extract-provider.js +25 -0
- package/dist/providers/extract-provider.js.map +1 -0
- package/dist/providers/rerank-provider.d.ts +17 -0
- package/dist/providers/rerank-provider.d.ts.map +1 -0
- package/dist/providers/rerank-provider.js +41 -0
- package/dist/providers/rerank-provider.js.map +1 -0
- package/dist/providers/search-provider.d.ts +25 -0
- package/dist/providers/search-provider.d.ts.map +1 -0
- package/dist/providers/search-provider.js +44 -0
- package/dist/providers/search-provider.js.map +1 -0
- package/dist/providers/vector-store.d.ts +27 -0
- package/dist/providers/vector-store.d.ts.map +1 -0
- package/dist/providers/vector-store.js +27 -0
- package/dist/providers/vector-store.js.map +1 -0
- package/dist/python-env.d.ts +9 -0
- package/dist/python-env.d.ts.map +1 -0
- package/dist/python-env.js +13 -0
- package/dist/python-env.js.map +1 -0
- package/dist/repl/commands/agent.d.ts +5 -0
- package/dist/repl/commands/agent.d.ts.map +1 -0
- package/dist/repl/commands/agent.js +62 -0
- package/dist/repl/commands/agent.js.map +1 -0
- package/dist/repl/commands/cache.d.ts +4 -0
- package/dist/repl/commands/cache.d.ts.map +1 -0
- package/dist/repl/commands/cache.js +43 -0
- package/dist/repl/commands/cache.js.map +1 -0
- package/dist/repl/commands/crawl.d.ts +7 -0
- package/dist/repl/commands/crawl.d.ts.map +1 -0
- package/dist/repl/commands/crawl.js +44 -0
- package/dist/repl/commands/crawl.js.map +1 -0
- package/dist/repl/commands/extract.d.ts +5 -0
- package/dist/repl/commands/extract.d.ts.map +1 -0
- package/dist/repl/commands/extract.js +47 -0
- package/dist/repl/commands/extract.js.map +1 -0
- package/dist/repl/commands/fetch.d.ts +5 -0
- package/dist/repl/commands/fetch.d.ts.map +1 -0
- package/dist/repl/commands/fetch.js +67 -0
- package/dist/repl/commands/fetch.js.map +1 -0
- package/dist/repl/commands/find-similar.d.ts +5 -0
- package/dist/repl/commands/find-similar.d.ts.map +1 -0
- package/dist/repl/commands/find-similar.js +74 -0
- package/dist/repl/commands/find-similar.js.map +1 -0
- package/dist/repl/commands/research.d.ts +5 -0
- package/dist/repl/commands/research.d.ts.map +1 -0
- package/dist/repl/commands/research.js +65 -0
- package/dist/repl/commands/research.js.map +1 -0
- package/dist/repl/commands/search.d.ts +5 -0
- package/dist/repl/commands/search.d.ts.map +1 -0
- package/dist/repl/commands/search.js +74 -0
- package/dist/repl/commands/search.js.map +1 -0
- package/dist/repl/commands/types.d.ts +9 -0
- package/dist/repl/commands/types.d.ts.map +1 -0
- package/dist/repl/commands/types.js +1 -0
- package/dist/repl/commands/types.js.map +1 -0
- package/dist/repl/formatters.d.ts +13 -0
- package/dist/repl/formatters.d.ts.map +1 -0
- package/dist/repl/formatters.js +283 -0
- package/dist/repl/formatters.js.map +1 -0
- package/dist/repl/parser.d.ts +9 -0
- package/dist/repl/parser.d.ts.map +1 -0
- package/dist/repl/parser.js +86 -0
- package/dist/repl/parser.js.map +1 -0
- package/dist/repl/shell.d.ts +8 -0
- package/dist/repl/shell.d.ts.map +1 -0
- package/dist/repl/shell.js +184 -0
- package/dist/repl/shell.js.map +1 -0
- package/dist/research/branch-exploration.d.ts +14 -0
- package/dist/research/branch-exploration.d.ts.map +1 -0
- package/dist/research/branch-exploration.js +100 -0
- package/dist/research/branch-exploration.js.map +1 -0
- package/dist/research/brief.d.ts +6 -0
- package/dist/research/brief.d.ts.map +1 -0
- package/dist/research/brief.js +246 -0
- package/dist/research/brief.js.map +1 -0
- package/dist/research/citation-graph.d.ts +9 -0
- package/dist/research/citation-graph.d.ts.map +1 -0
- package/dist/research/citation-graph.js +114 -0
- package/dist/research/citation-graph.js.map +1 -0
- package/dist/research/decompose.d.ts +14 -0
- package/dist/research/decompose.d.ts.map +1 -0
- package/dist/research/decompose.js +439 -0
- package/dist/research/decompose.js.map +1 -0
- package/dist/research/pipeline.d.ts +5 -0
- package/dist/research/pipeline.d.ts.map +1 -0
- package/dist/research/pipeline.js +269 -0
- package/dist/research/pipeline.js.map +1 -0
- package/dist/research/synthesis-local.d.ts +19 -0
- package/dist/research/synthesis-local.d.ts.map +1 -0
- package/dist/research/synthesis-local.js +62 -0
- package/dist/research/synthesis-local.js.map +1 -0
- package/dist/research/synthesize.d.ts +10 -0
- package/dist/research/synthesize.d.ts.map +1 -0
- package/dist/research/synthesize.js +137 -0
- package/dist/research/synthesize.js.map +1 -0
- package/dist/search/answer-synthesis.d.ts +33 -0
- package/dist/search/answer-synthesis.d.ts.map +1 -0
- package/dist/search/answer-synthesis.js +244 -0
- package/dist/search/answer-synthesis.js.map +1 -0
- package/dist/search/context-formatter.d.ts +3 -0
- package/dist/search/context-formatter.d.ts.map +1 -0
- package/dist/search/context-formatter.js +56 -0
- package/dist/search/context-formatter.js.map +1 -0
- package/dist/search/dedup.d.ts +1 -0
- package/dist/search/dedup.d.ts.map +1 -1
- package/dist/search/dedup.js +40 -32
- package/dist/search/dedup.js.map +1 -1
- package/dist/search/engines/arxiv.d.ts +7 -0
- package/dist/search/engines/arxiv.d.ts.map +1 -0
- package/dist/search/engines/arxiv.js +70 -0
- package/dist/search/engines/arxiv.js.map +1 -0
- package/dist/search/engines/bing-news.d.ts +7 -0
- package/dist/search/engines/bing-news.d.ts.map +1 -0
- package/dist/search/engines/bing-news.js +97 -0
- package/dist/search/engines/bing-news.js.map +1 -0
- package/dist/search/engines/bing.d.ts +1 -0
- package/dist/search/engines/bing.d.ts.map +1 -1
- package/dist/search/engines/bing.js +100 -44
- package/dist/search/engines/bing.js.map +1 -1
- package/dist/search/engines/devdocs.d.ts +6 -0
- package/dist/search/engines/devdocs.d.ts.map +1 -0
- package/dist/search/engines/devdocs.js +56 -0
- package/dist/search/engines/devdocs.js.map +1 -0
- package/dist/search/engines/duckduckgo.d.ts.map +1 -1
- package/dist/search/engines/duckduckgo.js +56 -44
- package/dist/search/engines/duckduckgo.js.map +1 -1
- package/dist/search/engines/github-code.d.ts +7 -0
- package/dist/search/engines/github-code.d.ts.map +1 -0
- package/dist/search/engines/github-code.js +55 -0
- package/dist/search/engines/github-code.js.map +1 -0
- package/dist/search/engines/hn-algolia.d.ts +7 -0
- package/dist/search/engines/hn-algolia.d.ts.map +1 -0
- package/dist/search/engines/hn-algolia.js +76 -0
- package/dist/search/engines/hn-algolia.js.map +1 -0
- package/dist/search/engines/lobsters.d.ts +7 -0
- package/dist/search/engines/lobsters.d.ts.map +1 -0
- package/dist/search/engines/lobsters.js +83 -0
- package/dist/search/engines/lobsters.js.map +1 -0
- package/dist/search/engines/mdn.d.ts +7 -0
- package/dist/search/engines/mdn.d.ts.map +1 -0
- package/dist/search/engines/mdn.js +48 -0
- package/dist/search/engines/mdn.js.map +1 -0
- package/dist/search/engines/semantic-scholar.d.ts +7 -0
- package/dist/search/engines/semantic-scholar.d.ts.map +1 -0
- package/dist/search/engines/semantic-scholar.js +69 -0
- package/dist/search/engines/semantic-scholar.js.map +1 -0
- package/dist/search/engines/stackoverflow.d.ts +7 -0
- package/dist/search/engines/stackoverflow.d.ts.map +1 -0
- package/dist/search/engines/stackoverflow.js +73 -0
- package/dist/search/engines/stackoverflow.js.map +1 -0
- package/dist/search/engines/startpage.d.ts.map +1 -1
- package/dist/search/engines/startpage.js +65 -46
- package/dist/search/engines/startpage.js.map +1 -1
- package/dist/search/evidence.d.ts +25 -0
- package/dist/search/evidence.d.ts.map +1 -0
- package/dist/search/evidence.js +220 -0
- package/dist/search/evidence.js.map +1 -0
- package/dist/search/filters.d.ts.map +1 -1
- package/dist/search/filters.js +58 -54
- package/dist/search/filters.js.map +1 -1
- package/dist/search/find-similar/crawl-rank.d.ts +9 -0
- package/dist/search/find-similar/crawl-rank.d.ts.map +1 -0
- package/dist/search/find-similar/crawl-rank.js +272 -0
- package/dist/search/find-similar/crawl-rank.js.map +1 -0
- package/dist/search/find-similar/mode.d.ts +4 -0
- package/dist/search/find-similar/mode.d.ts.map +1 -0
- package/dist/search/find-similar/mode.js +12 -0
- package/dist/search/find-similar/mode.js.map +1 -0
- package/dist/search/find-similar.d.ts +5 -0
- package/dist/search/find-similar.d.ts.map +1 -0
- package/dist/search/find-similar.js +509 -0
- package/dist/search/find-similar.js.map +1 -0
- package/dist/search/highlights.d.ts +19 -0
- package/dist/search/highlights.d.ts.map +1 -0
- package/dist/search/highlights.js +167 -0
- package/dist/search/highlights.js.map +1 -0
- package/dist/search/language-filter.d.ts +29 -0
- package/dist/search/language-filter.d.ts.map +1 -0
- package/dist/search/language-filter.js +126 -0
- package/dist/search/language-filter.js.map +1 -0
- package/dist/search/legacy/searxng-orchestrator.d.ts +4 -0
- package/dist/search/legacy/searxng-orchestrator.d.ts.map +1 -0
- package/dist/search/legacy/searxng-orchestrator.js +501 -0
- package/dist/search/legacy/searxng-orchestrator.js.map +1 -0
- package/dist/search/legacy/searxng-provider.d.ts +7 -0
- package/dist/search/legacy/searxng-provider.d.ts.map +1 -0
- package/dist/search/legacy/searxng-provider.js +11 -0
- package/dist/search/legacy/searxng-provider.js.map +1 -0
- package/dist/search/multi-query.d.ts +25 -0
- package/dist/search/multi-query.d.ts.map +1 -0
- package/dist/search/multi-query.js +228 -0
- package/dist/search/multi-query.js.map +1 -0
- package/dist/search/query.js +32 -34
- package/dist/search/query.js.map +1 -1
- package/dist/search/rerank.d.ts +3 -1
- package/dist/search/rerank.d.ts.map +1 -1
- package/dist/search/rerank.js +44 -35
- package/dist/search/rerank.js.map +1 -1
- package/dist/search/reranker/authority-boost.d.ts +3 -0
- package/dist/search/reranker/authority-boost.d.ts.map +1 -0
- package/dist/search/reranker/authority-boost.js +179 -0
- package/dist/search/reranker/authority-boost.js.map +1 -0
- package/dist/search/reranker/consensus-boost.d.ts +3 -0
- package/dist/search/reranker/consensus-boost.d.ts.map +1 -0
- package/dist/search/reranker/consensus-boost.js +27 -0
- package/dist/search/reranker/consensus-boost.js.map +1 -0
- package/dist/search/reranker/recency-boost.d.ts +3 -0
- package/dist/search/reranker/recency-boost.d.ts.map +1 -0
- package/dist/search/reranker/recency-boost.js +13 -0
- package/dist/search/reranker/recency-boost.js.map +1 -0
- package/dist/search/reranker/recency.d.ts +3 -0
- package/dist/search/reranker/recency.d.ts.map +1 -0
- package/dist/search/reranker/recency.js +23 -0
- package/dist/search/reranker/recency.js.map +1 -0
- package/dist/search/reranker/transformers-rerank-provider.d.ts +13 -0
- package/dist/search/reranker/transformers-rerank-provider.d.ts.map +1 -0
- package/dist/search/reranker/transformers-rerank-provider.js +94 -0
- package/dist/search/reranker/transformers-rerank-provider.js.map +1 -0
- package/dist/search/rrf.d.ts +17 -0
- package/dist/search/rrf.d.ts.map +1 -0
- package/dist/search/rrf.js +39 -0
- package/dist/search/rrf.js.map +1 -0
- package/dist/search/sampling.d.ts +25 -0
- package/dist/search/sampling.d.ts.map +1 -0
- package/dist/search/sampling.js +52 -0
- package/dist/search/sampling.js.map +1 -0
- package/dist/search/searxng.d.ts.map +1 -1
- package/dist/search/searxng.js +69 -79
- package/dist/search/searxng.js.map +1 -1
- package/dist/search/tokens.d.ts +3 -0
- package/dist/search/tokens.d.ts.map +1 -0
- package/dist/search/tokens.js +39 -0
- package/dist/search/tokens.js.map +1 -0
- package/dist/search/truncate.d.ts +6 -0
- package/dist/search/truncate.d.ts.map +1 -0
- package/dist/search/truncate.js +26 -0
- package/dist/search/truncate.js.map +1 -0
- package/dist/search/url-unwrap.d.ts +3 -0
- package/dist/search/url-unwrap.d.ts.map +1 -0
- package/dist/search/url-unwrap.js +43 -0
- package/dist/search/url-unwrap.js.map +1 -0
- package/dist/search/v1/context-rank.d.ts +13 -0
- package/dist/search/v1/context-rank.d.ts.map +1 -0
- package/dist/search/v1/context-rank.js +74 -0
- package/dist/search/v1/context-rank.js.map +1 -0
- package/dist/search/v1/engine-base.d.ts +27 -0
- package/dist/search/v1/engine-base.d.ts.map +1 -0
- package/dist/search/v1/engine-base.js +110 -0
- package/dist/search/v1/engine-base.js.map +1 -0
- package/dist/search/v1/intent-router.d.ts +22 -0
- package/dist/search/v1/intent-router.d.ts.map +1 -0
- package/dist/search/v1/intent-router.js +138 -0
- package/dist/search/v1/intent-router.js.map +1 -0
- package/dist/search/v1/orchestrator.d.ts +24 -0
- package/dist/search/v1/orchestrator.d.ts.map +1 -0
- package/dist/search/v1/orchestrator.js +163 -0
- package/dist/search/v1/orchestrator.js.map +1 -0
- package/dist/search/v1/recency-boost.d.ts +9 -0
- package/dist/search/v1/recency-boost.d.ts.map +1 -0
- package/dist/search/v1/recency-boost.js +37 -0
- package/dist/search/v1/recency-boost.js.map +1 -0
- package/dist/search/v1/recent-cache-dedup.d.ts +6 -0
- package/dist/search/v1/recent-cache-dedup.d.ts.map +1 -0
- package/dist/search/v1/recent-cache-dedup.js +85 -0
- package/dist/search/v1/recent-cache-dedup.js.map +1 -0
- package/dist/search/v1/rss/feed-config.d.ts +21 -0
- package/dist/search/v1/rss/feed-config.d.ts.map +1 -0
- package/dist/search/v1/rss/feed-config.js +90 -0
- package/dist/search/v1/rss/feed-config.js.map +1 -0
- package/dist/search/v1/rss/feed-parser.d.ts +14 -0
- package/dist/search/v1/rss/feed-parser.d.ts.map +1 -0
- package/dist/search/v1/rss/feed-parser.js +104 -0
- package/dist/search/v1/rss/feed-parser.js.map +1 -0
- package/dist/search/v1/rss/feed-poller.d.ts +22 -0
- package/dist/search/v1/rss/feed-poller.d.ts.map +1 -0
- package/dist/search/v1/rss/feed-poller.js +102 -0
- package/dist/search/v1/rss/feed-poller.js.map +1 -0
- package/dist/search/v1/rss/feed-store.d.ts +30 -0
- package/dist/search/v1/rss/feed-store.d.ts.map +1 -0
- package/dist/search/v1/rss/feed-store.js +134 -0
- package/dist/search/v1/rss/feed-store.js.map +1 -0
- package/dist/search/v1/rss/rss-engine.d.ts +6 -0
- package/dist/search/v1/rss/rss-engine.d.ts.map +1 -0
- package/dist/search/v1/rss/rss-engine.js +28 -0
- package/dist/search/v1/rss/rss-engine.js.map +1 -0
- package/dist/search/v1/v1-provider.d.ts +7 -0
- package/dist/search/v1/v1-provider.d.ts.map +1 -0
- package/dist/search/v1/v1-provider.js +68 -0
- package/dist/search/v1/v1-provider.js.map +1 -0
- package/dist/search/v1/verticals/code.d.ts +4 -0
- package/dist/search/v1/verticals/code.d.ts.map +1 -0
- package/dist/search/v1/verticals/code.js +20 -0
- package/dist/search/v1/verticals/code.js.map +1 -0
- package/dist/search/v1/verticals/docs.d.ts +4 -0
- package/dist/search/v1/verticals/docs.d.ts.map +1 -0
- package/dist/search/v1/verticals/docs.js +20 -0
- package/dist/search/v1/verticals/docs.js.map +1 -0
- package/dist/search/v1/verticals/general.d.ts +4 -0
- package/dist/search/v1/verticals/general.d.ts.map +1 -0
- package/dist/search/v1/verticals/general.js +22 -0
- package/dist/search/v1/verticals/general.js.map +1 -0
- package/dist/search/v1/verticals/news.d.ts +10 -0
- package/dist/search/v1/verticals/news.d.ts.map +1 -0
- package/dist/search/v1/verticals/news.js +52 -0
- package/dist/search/v1/verticals/news.js.map +1 -0
- package/dist/search/v1/verticals/papers.d.ts +4 -0
- package/dist/search/v1/verticals/papers.d.ts.map +1 -0
- package/dist/search/v1/verticals/papers.js +23 -0
- package/dist/search/v1/verticals/papers.js.map +1 -0
- package/dist/search/validator.js +31 -31
- package/dist/search/validator.js.map +1 -1
- package/dist/searxng/bootstrap.d.ts +30 -0
- package/dist/searxng/bootstrap.d.ts.map +1 -1
- package/dist/searxng/bootstrap.js +223 -85
- package/dist/searxng/bootstrap.js.map +1 -1
- package/dist/searxng/docker.d.ts.map +1 -1
- package/dist/searxng/docker.js +69 -60
- package/dist/searxng/docker.js.map +1 -1
- package/dist/searxng/process.d.ts +13 -1
- package/dist/searxng/process.d.ts.map +1 -1
- package/dist/searxng/process.js +231 -164
- package/dist/searxng/process.js.map +1 -1
- package/dist/server/backend-status.d.ts +13 -0
- package/dist/server/backend-status.d.ts.map +1 -0
- package/dist/server/backend-status.js +40 -0
- package/dist/server/backend-status.js.map +1 -0
- package/dist/server/tool-schemas.d.ts +549 -0
- package/dist/server/tool-schemas.d.ts.map +1 -0
- package/dist/server/tool-schemas.js +464 -0
- package/dist/server/tool-schemas.js.map +1 -0
- package/dist/server/warmup-on-start.d.ts +9 -0
- package/dist/server/warmup-on-start.d.ts.map +1 -0
- package/dist/server/warmup-on-start.js +55 -0
- package/dist/server/warmup-on-start.js.map +1 -0
- package/dist/server.d.ts +17 -0
- package/dist/server.d.ts.map +1 -1
- package/dist/server.js +454 -297
- package/dist/server.js.map +1 -1
- package/dist/tools/agent.d.ts +5 -0
- package/dist/tools/agent.d.ts.map +1 -0
- package/dist/tools/agent.js +128 -0
- package/dist/tools/agent.js.map +1 -0
- package/dist/tools/cache.d.ts +2 -1
- package/dist/tools/cache.d.ts.map +1 -1
- package/dist/tools/cache.js +177 -44
- package/dist/tools/cache.js.map +1 -1
- package/dist/tools/crawl.d.ts.map +1 -1
- package/dist/tools/crawl.js +171 -88
- package/dist/tools/crawl.js.map +1 -1
- package/dist/tools/extract.d.ts +2 -2
- package/dist/tools/extract.d.ts.map +1 -1
- package/dist/tools/extract.js +175 -59
- package/dist/tools/extract.js.map +1 -1
- package/dist/tools/fetch.d.ts +2 -2
- package/dist/tools/fetch.d.ts.map +1 -1
- package/dist/tools/fetch.js +174 -68
- package/dist/tools/fetch.js.map +1 -1
- package/dist/tools/find-similar.d.ts +5 -0
- package/dist/tools/find-similar.d.ts.map +1 -0
- package/dist/tools/find-similar.js +127 -0
- package/dist/tools/find-similar.js.map +1 -0
- package/dist/tools/research.d.ts +5 -0
- package/dist/tools/research.d.ts.map +1 -0
- package/dist/tools/research.js +107 -0
- package/dist/tools/research.js.map +1 -0
- package/dist/tools/search.d.ts +10 -2
- package/dist/tools/search.d.ts.map +1 -1
- package/dist/tools/search.js +13 -158
- package/dist/tools/search.js.map +1 -1
- package/dist/types.d.ts +350 -7
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js +6 -1
- package/dist/types.js.map +1 -1
- package/dist/util/mode.d.ts +4 -0
- package/dist/util/mode.d.ts.map +1 -0
- package/dist/util/mode.js +34 -0
- package/dist/util/mode.js.map +1 -0
- package/package.json +78 -8
- package/dist/extraction/trafilatura.d.ts +0 -6
- package/dist/extraction/trafilatura.d.ts.map +0 -1
- package/dist/extraction/trafilatura.js +0 -105
- package/dist/extraction/trafilatura.js.map +0 -1
- package/dist/search/flashrank.d.ts +0 -12
- package/dist/search/flashrank.d.ts.map +0 -1
- package/dist/search/flashrank.js +0 -63
- package/dist/search/flashrank.js.map +0 -1
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import { join } from "node:path";
|
|
2
|
+
import { mkdirSync } from "node:fs";
|
|
3
|
+
import { SmartRouter } from "../fetch/router.js";
|
|
4
|
+
import { BrowserPool } from "../fetch/browser-pool.js";
|
|
5
|
+
import { httpFetch } from "../fetch/http-client.js";
|
|
6
|
+
import { initDatabase, closeDatabase } from "../cache/db.js";
|
|
7
|
+
import { SearxngClient } from "../search/searxng.js";
|
|
8
|
+
import { DuckDuckGoEngine } from "../search/engines/duckduckgo.js";
|
|
9
|
+
import { BingEngine } from "../search/engines/bing.js";
|
|
10
|
+
import { StartpageEngine } from "../search/engines/startpage.js";
|
|
11
|
+
import { resolveSearchBackend, getBootstrapState } from "../searxng/bootstrap.js";
|
|
12
|
+
import { SearxngProcess } from "../searxng/process.js";
|
|
13
|
+
import { BackendStatus } from "../server/backend-status.js";
|
|
14
|
+
import { getConfig } from "../config.js";
|
|
15
|
+
import { createLogger } from "../logger.js";
|
|
16
|
+
import { startShell } from "../repl/shell.js";
|
|
17
|
+
const log = createLogger("cli");
|
|
18
|
+
async function runShell(args) {
|
|
19
|
+
const config = getConfig();
|
|
20
|
+
const jsonMode = args.includes("--json");
|
|
21
|
+
mkdirSync(config.dataDir, { recursive: true });
|
|
22
|
+
initDatabase(join(config.dataDir, "wigolo.db"));
|
|
23
|
+
const httpClient = {
|
|
24
|
+
fetch: (url, options) => httpFetch(url, options)
|
|
25
|
+
};
|
|
26
|
+
const browserPool = new BrowserPool();
|
|
27
|
+
const router = new SmartRouter(httpClient, browserPool);
|
|
28
|
+
const backendStatus = new BackendStatus();
|
|
29
|
+
const searchEngines = [
|
|
30
|
+
new BingEngine(),
|
|
31
|
+
new DuckDuckGoEngine(),
|
|
32
|
+
new StartpageEngine()
|
|
33
|
+
];
|
|
34
|
+
let searxngProcess = null;
|
|
35
|
+
try {
|
|
36
|
+
const backend = await resolveSearchBackend();
|
|
37
|
+
if (backend.type === "external" && backend.url) {
|
|
38
|
+
searchEngines.unshift(new SearxngClient(backend.url));
|
|
39
|
+
backendStatus.markHealthy();
|
|
40
|
+
log.info("shell using external SearXNG", { url: backend.url });
|
|
41
|
+
} else if (backend.type === "native" && backend.searxngPath) {
|
|
42
|
+
const state = getBootstrapState(config.dataDir);
|
|
43
|
+
if (state?.status === "ready") {
|
|
44
|
+
searxngProcess = new SearxngProcess(backend.searxngPath, config.dataDir, {
|
|
45
|
+
onUnhealthy: (reason) => {
|
|
46
|
+
backendStatus.markUnhealthy(reason);
|
|
47
|
+
const idx = searchEngines.findIndex((e) => e.name === "searxng");
|
|
48
|
+
if (idx >= 0) searchEngines.splice(idx, 1);
|
|
49
|
+
log.warn("SearXNG unhealthy in shell", { reason });
|
|
50
|
+
},
|
|
51
|
+
onHealthy: () => {
|
|
52
|
+
const url2 = searxngProcess?.getUrl();
|
|
53
|
+
if (!url2) return;
|
|
54
|
+
backendStatus.markHealthy();
|
|
55
|
+
if (!searchEngines.some((e) => e.name === "searxng")) {
|
|
56
|
+
searchEngines.unshift(new SearxngClient(url2));
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
});
|
|
60
|
+
const url = await searxngProcess.start();
|
|
61
|
+
if (url) {
|
|
62
|
+
searchEngines.unshift(new SearxngClient(url));
|
|
63
|
+
backendStatus.markHealthy();
|
|
64
|
+
log.info("SearXNG ready for shell", { url });
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
} catch (err) {
|
|
69
|
+
log.warn("SearXNG setup failed for shell, using direct scraping", { error: String(err) });
|
|
70
|
+
backendStatus.markUnhealthy(`SearXNG setup failed: ${String(err)}`);
|
|
71
|
+
}
|
|
72
|
+
try {
|
|
73
|
+
await startShell(
|
|
74
|
+
{ router, engines: searchEngines, backendStatus },
|
|
75
|
+
{ jsonMode }
|
|
76
|
+
);
|
|
77
|
+
} finally {
|
|
78
|
+
if (searxngProcess) await searxngProcess.stop();
|
|
79
|
+
await browserPool.shutdown();
|
|
80
|
+
closeDatabase();
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
export {
|
|
84
|
+
runShell
|
|
85
|
+
};
|
|
86
|
+
//# sourceMappingURL=shell.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/cli/shell.ts"],"sourcesContent":["import { join } from 'node:path';\nimport { mkdirSync } from 'node:fs';\nimport { SmartRouter, type HttpClient } from '../fetch/router.js';\nimport { BrowserPool } from '../fetch/browser-pool.js';\nimport { httpFetch } from '../fetch/http-client.js';\nimport { initDatabase, closeDatabase } from '../cache/db.js';\nimport { SearxngClient } from '../search/searxng.js';\nimport { DuckDuckGoEngine } from '../search/engines/duckduckgo.js';\nimport { BingEngine } from '../search/engines/bing.js';\nimport { StartpageEngine } from '../search/engines/startpage.js';\nimport { resolveSearchBackend, getBootstrapState } from '../searxng/bootstrap.js';\nimport { SearxngProcess } from '../searxng/process.js';\nimport { BackendStatus } from '../server/backend-status.js';\nimport { getConfig } from '../config.js';\nimport { createLogger } from '../logger.js';\nimport { startShell } from '../repl/shell.js';\nimport type { SearchEngine } from '../types.js';\n\nconst log = createLogger('cli');\n\nexport async function runShell(args: string[]): Promise<void> {\n const config = getConfig();\n const jsonMode = args.includes('--json');\n\n mkdirSync(config.dataDir, { recursive: true });\n initDatabase(join(config.dataDir, 'wigolo.db'));\n\n const httpClient: HttpClient = {\n fetch: (url, options) => httpFetch(url, options),\n };\n const browserPool = new BrowserPool();\n const router = new SmartRouter(httpClient, browserPool);\n const backendStatus = new BackendStatus();\n\n const searchEngines: SearchEngine[] = [\n new BingEngine(),\n new DuckDuckGoEngine(),\n new StartpageEngine(),\n ];\n\n let searxngProcess: SearxngProcess | null = null;\n\n try {\n const backend = await resolveSearchBackend();\n\n if (backend.type === 'external' && backend.url) {\n searchEngines.unshift(new SearxngClient(backend.url));\n backendStatus.markHealthy();\n log.info('shell using external SearXNG', { url: backend.url });\n } else if (backend.type === 'native' && backend.searxngPath) {\n const state = getBootstrapState(config.dataDir);\n if (state?.status === 'ready') {\n searxngProcess = new SearxngProcess(backend.searxngPath, config.dataDir, {\n onUnhealthy: (reason) => {\n backendStatus.markUnhealthy(reason);\n const idx = searchEngines.findIndex(e => e.name === 'searxng');\n if (idx >= 0) searchEngines.splice(idx, 1);\n log.warn('SearXNG unhealthy in shell', { reason });\n },\n onHealthy: () => {\n const url = searxngProcess?.getUrl();\n if (!url) return;\n backendStatus.markHealthy();\n if (!searchEngines.some(e => e.name === 'searxng')) {\n searchEngines.unshift(new SearxngClient(url));\n }\n },\n });\n const url = await searxngProcess.start();\n if (url) {\n searchEngines.unshift(new SearxngClient(url));\n backendStatus.markHealthy();\n log.info('SearXNG ready for shell', { url });\n }\n }\n }\n } catch (err) {\n log.warn('SearXNG setup failed for shell, using direct scraping', { error: String(err) });\n backendStatus.markUnhealthy(`SearXNG setup failed: ${String(err)}`);\n }\n\n try {\n await startShell(\n { router, engines: searchEngines, backendStatus },\n { jsonMode },\n );\n } finally {\n if (searxngProcess) await searxngProcess.stop();\n await browserPool.shutdown();\n closeDatabase();\n }\n}\n"],"mappings":"AAAA,SAAS,YAAY;AACrB,SAAS,iBAAiB;AAC1B,SAAS,mBAAoC;AAC7C,SAAS,mBAAmB;AAC5B,SAAS,iBAAiB;AAC1B,SAAS,cAAc,qBAAqB;AAC5C,SAAS,qBAAqB;AAC9B,SAAS,wBAAwB;AACjC,SAAS,kBAAkB;AAC3B,SAAS,uBAAuB;AAChC,SAAS,sBAAsB,yBAAyB;AACxD,SAAS,sBAAsB;AAC/B,SAAS,qBAAqB;AAC9B,SAAS,iBAAiB;AAC1B,SAAS,oBAAoB;AAC7B,SAAS,kBAAkB;AAG3B,MAAM,MAAM,aAAa,KAAK;AAE9B,eAAsB,SAAS,MAA+B;AAC5D,QAAM,SAAS,UAAU;AACzB,QAAM,WAAW,KAAK,SAAS,QAAQ;AAEvC,YAAU,OAAO,SAAS,EAAE,WAAW,KAAK,CAAC;AAC7C,eAAa,KAAK,OAAO,SAAS,WAAW,CAAC;AAE9C,QAAM,aAAyB;AAAA,IAC7B,OAAO,CAAC,KAAK,YAAY,UAAU,KAAK,OAAO;AAAA,EACjD;AACA,QAAM,cAAc,IAAI,YAAY;AACpC,QAAM,SAAS,IAAI,YAAY,YAAY,WAAW;AACtD,QAAM,gBAAgB,IAAI,cAAc;AAExC,QAAM,gBAAgC;AAAA,IACpC,IAAI,WAAW;AAAA,IACf,IAAI,iBAAiB;AAAA,IACrB,IAAI,gBAAgB;AAAA,EACtB;AAEA,MAAI,iBAAwC;AAE5C,MAAI;AACF,UAAM,UAAU,MAAM,qBAAqB;AAE3C,QAAI,QAAQ,SAAS,cAAc,QAAQ,KAAK;AAC9C,oBAAc,QAAQ,IAAI,cAAc,QAAQ,GAAG,CAAC;AACpD,oBAAc,YAAY;AAC1B,UAAI,KAAK,gCAAgC,EAAE,KAAK,QAAQ,IAAI,CAAC;AAAA,IAC/D,WAAW,QAAQ,SAAS,YAAY,QAAQ,aAAa;AAC3D,YAAM,QAAQ,kBAAkB,OAAO,OAAO;AAC9C,UAAI,OAAO,WAAW,SAAS;AAC7B,yBAAiB,IAAI,eAAe,QAAQ,aAAa,OAAO,SAAS;AAAA,UACvE,aAAa,CAAC,WAAW;AACvB,0BAAc,cAAc,MAAM;AAClC,kBAAM,MAAM,cAAc,UAAU,OAAK,EAAE,SAAS,SAAS;AAC7D,gBAAI,OAAO,EAAG,eAAc,OAAO,KAAK,CAAC;AACzC,gBAAI,KAAK,8BAA8B,EAAE,OAAO,CAAC;AAAA,UACnD;AAAA,UACA,WAAW,MAAM;AACf,kBAAMA,OAAM,gBAAgB,OAAO;AACnC,gBAAI,CAACA,KAAK;AACV,0BAAc,YAAY;AAC1B,gBAAI,CAAC,cAAc,KAAK,OAAK,EAAE,SAAS,SAAS,GAAG;AAClD,4BAAc,QAAQ,IAAI,cAAcA,IAAG,CAAC;AAAA,YAC9C;AAAA,UACF;AAAA,QACF,CAAC;AACD,cAAM,MAAM,MAAM,eAAe,MAAM;AACvC,YAAI,KAAK;AACP,wBAAc,QAAQ,IAAI,cAAc,GAAG,CAAC;AAC5C,wBAAc,YAAY;AAC1B,cAAI,KAAK,2BAA2B,EAAE,IAAI,CAAC;AAAA,QAC7C;AAAA,MACF;AAAA,IACF;AAAA,EACF,SAAS,KAAK;AACZ,QAAI,KAAK,yDAAyD,EAAE,OAAO,OAAO,GAAG,EAAE,CAAC;AACxF,kBAAc,cAAc,yBAAyB,OAAO,GAAG,CAAC,EAAE;AAAA,EACpE;AAEA,MAAI;AACF,UAAM;AAAA,MACJ,EAAE,QAAQ,SAAS,eAAe,cAAc;AAAA,MAChD,EAAE,SAAS;AAAA,IACb;AAAA,EACF,UAAE;AACA,QAAI,eAAgB,OAAM,eAAe,KAAK;AAC9C,UAAM,YAAY,SAAS;AAC3B,kBAAc;AAAA,EAChB;AACF;","names":["url"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shutdown.d.ts","sourceRoot":"","sources":["../../src/cli/shutdown.ts"],"names":[],"mappings":"AAcA,wBAAsB,WAAW,IAAI,OAAO,CAAC,IAAI,CAAC,CAgBjD"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { closeDatabase } from "../cache/db.js";
|
|
2
|
+
import { resetEmbeddingService } from "../embedding/embed.js";
|
|
3
|
+
import { disposeRerankProvider } from "../providers/rerank-provider.js";
|
|
4
|
+
import { createLogger } from "../logger.js";
|
|
5
|
+
const log = createLogger("cli");
|
|
6
|
+
async function shutdownCli() {
|
|
7
|
+
try {
|
|
8
|
+
await disposeRerankProvider();
|
|
9
|
+
} catch (err) {
|
|
10
|
+
log.debug("rerank dispose failed", { error: err instanceof Error ? err.message : String(err) });
|
|
11
|
+
}
|
|
12
|
+
try {
|
|
13
|
+
resetEmbeddingService();
|
|
14
|
+
} catch (err) {
|
|
15
|
+
log.debug("embedding reset failed", { error: err instanceof Error ? err.message : String(err) });
|
|
16
|
+
}
|
|
17
|
+
try {
|
|
18
|
+
closeDatabase();
|
|
19
|
+
} catch (err) {
|
|
20
|
+
log.debug("database close failed", { error: err instanceof Error ? err.message : String(err) });
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
export {
|
|
24
|
+
shutdownCli
|
|
25
|
+
};
|
|
26
|
+
//# sourceMappingURL=shutdown.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/cli/shutdown.ts"],"sourcesContent":["import { closeDatabase } from '../cache/db.js';\nimport { resetEmbeddingService } from '../embedding/embed.js';\nimport { disposeRerankProvider } from '../providers/rerank-provider.js';\nimport { createLogger } from '../logger.js';\n\nconst log = createLogger('cli');\n\n// Release native resources (ONNX sessions, sqlite-vec, embedding subprocess)\n// before the process exits. Without explicit teardown, libc++ destructors\n// race during shutdown and surface as `mutex lock failed: Invalid argument`\n// on macOS — the cosmetic-but-loud SIGABRT noted in v0.1.1 bench.\n//\n// Best-effort: every step swallows its own errors so a partial failure\n// doesn't block subsequent cleanup steps.\nexport async function shutdownCli(): Promise<void> {\n try {\n await disposeRerankProvider();\n } catch (err) {\n log.debug('rerank dispose failed', { error: err instanceof Error ? err.message : String(err) });\n }\n try {\n resetEmbeddingService();\n } catch (err) {\n log.debug('embedding reset failed', { error: err instanceof Error ? err.message : String(err) });\n }\n try {\n closeDatabase();\n } catch (err) {\n log.debug('database close failed', { error: err instanceof Error ? err.message : String(err) });\n }\n}\n"],"mappings":"AAAA,SAAS,qBAAqB;AAC9B,SAAS,6BAA6B;AACtC,SAAS,6BAA6B;AACtC,SAAS,oBAAoB;AAE7B,MAAM,MAAM,aAAa,KAAK;AAS9B,eAAsB,cAA6B;AACjD,MAAI;AACF,UAAM,sBAAsB;AAAA,EAC9B,SAAS,KAAK;AACZ,QAAI,MAAM,yBAAyB,EAAE,OAAO,eAAe,QAAQ,IAAI,UAAU,OAAO,GAAG,EAAE,CAAC;AAAA,EAChG;AACA,MAAI;AACF,0BAAsB;AAAA,EACxB,SAAS,KAAK;AACZ,QAAI,MAAM,0BAA0B,EAAE,OAAO,eAAe,QAAQ,IAAI,UAAU,OAAO,GAAG,EAAE,CAAC;AAAA,EACjG;AACA,MAAI;AACF,kBAAc;AAAA,EAChB,SAAS,KAAK;AACZ,QAAI,MAAM,yBAAyB,EAAE,OAAO,eAAe,QAAQ,IAAI,UAAU,OAAO,GAAG,EAAE,CAAC;AAAA,EAChG;AACF;","names":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"status.d.ts","sourceRoot":"","sources":["../../src/cli/status.ts"],"names":[],"mappings":"AAYA,wBAAsB,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,CAyBhE"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { createRequire } from "node:module";
|
|
2
|
+
import { getConfig } from "../config.js";
|
|
3
|
+
import { getBootstrapState } from "../searxng/bootstrap.js";
|
|
4
|
+
import { readCacheStats } from "./tui/status-cache.js";
|
|
5
|
+
import { probePythonPackages } from "./tui/status-python.js";
|
|
6
|
+
import { readConnectedAgents } from "./tui/status-agents.js";
|
|
7
|
+
import { formatStatus } from "./tui/status-format.js";
|
|
8
|
+
const require2 = createRequire(import.meta.url);
|
|
9
|
+
const pkg = require2("../../package.json");
|
|
10
|
+
async function runStatus(_args) {
|
|
11
|
+
const dataDir = getConfig().dataDir;
|
|
12
|
+
const bootstrap = getBootstrapState(dataDir);
|
|
13
|
+
const searxng = bootstrap === null ? "pending" : bootstrap.status === "ready" ? "ready" : bootstrap.status === "failed" ? "failed" : "pending";
|
|
14
|
+
const python = probePythonPackages(dataDir);
|
|
15
|
+
const cache = readCacheStats(dataDir);
|
|
16
|
+
const agents = readConnectedAgents({});
|
|
17
|
+
const bag = {
|
|
18
|
+
version: pkg.version ?? "0.0.0",
|
|
19
|
+
searxng,
|
|
20
|
+
reranker: python.reranker,
|
|
21
|
+
embeddings: python.embeddings,
|
|
22
|
+
cache,
|
|
23
|
+
agents
|
|
24
|
+
};
|
|
25
|
+
process.stderr.write(formatStatus(bag));
|
|
26
|
+
return 0;
|
|
27
|
+
}
|
|
28
|
+
export {
|
|
29
|
+
runStatus
|
|
30
|
+
};
|
|
31
|
+
//# sourceMappingURL=status.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/cli/status.ts"],"sourcesContent":["import { createRequire } from 'node:module';\nimport { getConfig } from '../config.js';\nimport { getBootstrapState } from '../searxng/bootstrap.js';\nimport { readCacheStats } from './tui/status-cache.js';\nimport { probePythonPackages } from './tui/status-python.js';\nimport { readConnectedAgents } from './tui/status-agents.js';\nimport { formatStatus, type StatusBag } from './tui/status-format.js';\n\nconst require = createRequire(import.meta.url);\ninterface PackageJson { version?: string }\nconst pkg = require('../../package.json') as PackageJson;\n\nexport async function runStatus(_args: string[]): Promise<number> {\n const dataDir = getConfig().dataDir;\n\n const bootstrap = getBootstrapState(dataDir);\n const searxng: StatusBag['searxng'] =\n bootstrap === null ? 'pending' :\n bootstrap.status === 'ready' ? 'ready' :\n bootstrap.status === 'failed' ? 'failed' :\n 'pending';\n\n const python = probePythonPackages(dataDir);\n const cache = readCacheStats(dataDir);\n const agents = readConnectedAgents({});\n\n const bag: StatusBag = {\n version: pkg.version ?? '0.0.0',\n searxng,\n reranker: python.reranker,\n embeddings: python.embeddings,\n cache,\n agents,\n };\n\n process.stderr.write(formatStatus(bag));\n return 0;\n}\n"],"mappings":"AAAA,SAAS,qBAAqB;AAC9B,SAAS,iBAAiB;AAC1B,SAAS,yBAAyB;AAClC,SAAS,sBAAsB;AAC/B,SAAS,2BAA2B;AACpC,SAAS,2BAA2B;AACpC,SAAS,oBAAoC;AAE7C,MAAMA,WAAU,cAAc,YAAY,GAAG;AAE7C,MAAM,MAAMA,SAAQ,oBAAoB;AAExC,eAAsB,UAAU,OAAkC;AAChE,QAAM,UAAU,UAAU,EAAE;AAE5B,QAAM,YAAY,kBAAkB,OAAO;AAC3C,QAAM,UACJ,cAAc,OAAO,YACrB,UAAU,WAAW,UAAU,UAC/B,UAAU,WAAW,WAAW,WAChC;AAEF,QAAM,SAAS,oBAAoB,OAAO;AAC1C,QAAM,QAAQ,eAAe,OAAO;AACpC,QAAM,SAAS,oBAAoB,CAAC,CAAC;AAErC,QAAM,MAAiB;AAAA,IACrB,SAAS,IAAI,WAAW;AAAA,IACxB;AAAA,IACA,UAAU,OAAO;AAAA,IACjB,YAAY,OAAO;AAAA,IACnB;AAAA,IACA;AAAA,EACF;AAEA,UAAQ,OAAO,MAAM,aAAa,GAAG,CAAC;AACtC,SAAO;AACT;","names":["require"]}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export interface TelemetryEvent {
|
|
2
|
+
ts: string;
|
|
3
|
+
event: string;
|
|
4
|
+
props?: Record<string, unknown>;
|
|
5
|
+
}
|
|
6
|
+
export declare function isTelemetryEnabled(): boolean;
|
|
7
|
+
export declare function configureRemote(endpoint: string | undefined): void;
|
|
8
|
+
export declare function emit(event: string, props?: Record<string, unknown>): void;
|
|
9
|
+
export declare function _resetTelemetryForTest(): void;
|
|
10
|
+
//# sourceMappingURL=telemetry.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"telemetry.d.ts","sourceRoot":"","sources":["../../src/cli/telemetry.ts"],"names":[],"mappings":"AAaA,MAAM,WAAW,cAAc;IAC7B,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACjC;AAID,wBAAgB,kBAAkB,IAAI,OAAO,CAE5C;AAED,wBAAgB,eAAe,CAAC,QAAQ,EAAE,MAAM,GAAG,SAAS,GAAG,IAAI,CAElE;AAoCD,wBAAgB,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAQzE;AAED,wBAAgB,sBAAsB,IAAI,IAAI,CAE7C"}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { appendFileSync, mkdirSync } from "node:fs";
|
|
2
|
+
import { join } from "node:path";
|
|
3
|
+
import { getConfig } from "../config.js";
|
|
4
|
+
let _endpoint;
|
|
5
|
+
function isTelemetryEnabled() {
|
|
6
|
+
return process.env.WIGOLO_TELEMETRY === "1";
|
|
7
|
+
}
|
|
8
|
+
function configureRemote(endpoint) {
|
|
9
|
+
_endpoint = endpoint;
|
|
10
|
+
}
|
|
11
|
+
function utcDateStamp(d) {
|
|
12
|
+
const y = d.getUTCFullYear().toString().padStart(4, "0");
|
|
13
|
+
const m = (d.getUTCMonth() + 1).toString().padStart(2, "0");
|
|
14
|
+
const day = d.getUTCDate().toString().padStart(2, "0");
|
|
15
|
+
return `${y}${m}${day}`;
|
|
16
|
+
}
|
|
17
|
+
function writeLocal(event) {
|
|
18
|
+
try {
|
|
19
|
+
const dir = join(getConfig().dataDir, "telemetry");
|
|
20
|
+
mkdirSync(dir, { recursive: true });
|
|
21
|
+
const file = join(dir, `events-${utcDateStamp(new Date(event.ts))}.ndjson`);
|
|
22
|
+
appendFileSync(file, JSON.stringify(event) + "\n");
|
|
23
|
+
} catch {
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
function postRemote(endpoint, event) {
|
|
27
|
+
try {
|
|
28
|
+
const result = fetch(endpoint, {
|
|
29
|
+
method: "POST",
|
|
30
|
+
body: JSON.stringify(event),
|
|
31
|
+
headers: { "Content-Type": "application/json" }
|
|
32
|
+
});
|
|
33
|
+
if (result && typeof result.catch === "function") {
|
|
34
|
+
result.catch(() => {
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
} catch {
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
function emit(event, props) {
|
|
41
|
+
if (!isTelemetryEnabled()) return;
|
|
42
|
+
const evt = props !== void 0 ? { ts: (/* @__PURE__ */ new Date()).toISOString(), event, props } : { ts: (/* @__PURE__ */ new Date()).toISOString(), event };
|
|
43
|
+
writeLocal(evt);
|
|
44
|
+
const endpoint = _endpoint ?? process.env.WIGOLO_TELEMETRY_ENDPOINT;
|
|
45
|
+
if (endpoint) postRemote(endpoint, evt);
|
|
46
|
+
}
|
|
47
|
+
function _resetTelemetryForTest() {
|
|
48
|
+
_endpoint = void 0;
|
|
49
|
+
}
|
|
50
|
+
export {
|
|
51
|
+
_resetTelemetryForTest,
|
|
52
|
+
configureRemote,
|
|
53
|
+
emit,
|
|
54
|
+
isTelemetryEnabled
|
|
55
|
+
};
|
|
56
|
+
//# sourceMappingURL=telemetry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/cli/telemetry.ts"],"sourcesContent":["/**\n * Opt-in telemetry — Phase 14 of v1 engine overhaul.\n *\n * Off by default. Enabled when `WIGOLO_TELEMETRY=1`. Writes one NDJSON line\n * per event to `${dataDir}/telemetry/events-YYYYMMDD.ndjson`. Optionally\n * fire-and-forget POSTs to a remote endpoint when configured.\n *\n * Telemetry must NEVER throw or block the host — all errors are swallowed.\n */\nimport { appendFileSync, mkdirSync } from 'node:fs';\nimport { join } from 'node:path';\nimport { getConfig } from '../config.js';\n\nexport interface TelemetryEvent {\n ts: string;\n event: string;\n props?: Record<string, unknown>;\n}\n\nlet _endpoint: string | undefined;\n\nexport function isTelemetryEnabled(): boolean {\n return process.env.WIGOLO_TELEMETRY === '1';\n}\n\nexport function configureRemote(endpoint: string | undefined): void {\n _endpoint = endpoint;\n}\n\nfunction utcDateStamp(d: Date): string {\n const y = d.getUTCFullYear().toString().padStart(4, '0');\n const m = (d.getUTCMonth() + 1).toString().padStart(2, '0');\n const day = d.getUTCDate().toString().padStart(2, '0');\n return `${y}${m}${day}`;\n}\n\nfunction writeLocal(event: TelemetryEvent): void {\n try {\n const dir = join(getConfig().dataDir, 'telemetry');\n mkdirSync(dir, { recursive: true });\n const file = join(dir, `events-${utcDateStamp(new Date(event.ts))}.ndjson`);\n appendFileSync(file, JSON.stringify(event) + '\\n');\n } catch {\n // Telemetry must never throw.\n }\n}\n\nfunction postRemote(endpoint: string, event: TelemetryEvent): void {\n try {\n const result = fetch(endpoint, {\n method: 'POST',\n body: JSON.stringify(event),\n headers: { 'Content-Type': 'application/json' },\n });\n // Fire-and-forget: swallow rejections so callers never see them.\n if (result && typeof (result as Promise<unknown>).catch === 'function') {\n (result as Promise<unknown>).catch(() => { /* ignore */ });\n }\n } catch {\n // Sync throw from fetch — also swallowed.\n }\n}\n\nexport function emit(event: string, props?: Record<string, unknown>): void {\n if (!isTelemetryEnabled()) return;\n const evt: TelemetryEvent = props !== undefined\n ? { ts: new Date().toISOString(), event, props }\n : { ts: new Date().toISOString(), event };\n writeLocal(evt);\n const endpoint = _endpoint ?? process.env.WIGOLO_TELEMETRY_ENDPOINT;\n if (endpoint) postRemote(endpoint, evt);\n}\n\nexport function _resetTelemetryForTest(): void {\n _endpoint = undefined;\n}\n"],"mappings":"AASA,SAAS,gBAAgB,iBAAiB;AAC1C,SAAS,YAAY;AACrB,SAAS,iBAAiB;AAQ1B,IAAI;AAEG,SAAS,qBAA8B;AAC5C,SAAO,QAAQ,IAAI,qBAAqB;AAC1C;AAEO,SAAS,gBAAgB,UAAoC;AAClE,cAAY;AACd;AAEA,SAAS,aAAa,GAAiB;AACrC,QAAM,IAAI,EAAE,eAAe,EAAE,SAAS,EAAE,SAAS,GAAG,GAAG;AACvD,QAAM,KAAK,EAAE,YAAY,IAAI,GAAG,SAAS,EAAE,SAAS,GAAG,GAAG;AAC1D,QAAM,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,SAAS,GAAG,GAAG;AACrD,SAAO,GAAG,CAAC,GAAG,CAAC,GAAG,GAAG;AACvB;AAEA,SAAS,WAAW,OAA6B;AAC/C,MAAI;AACF,UAAM,MAAM,KAAK,UAAU,EAAE,SAAS,WAAW;AACjD,cAAU,KAAK,EAAE,WAAW,KAAK,CAAC;AAClC,UAAM,OAAO,KAAK,KAAK,UAAU,aAAa,IAAI,KAAK,MAAM,EAAE,CAAC,CAAC,SAAS;AAC1E,mBAAe,MAAM,KAAK,UAAU,KAAK,IAAI,IAAI;AAAA,EACnD,QAAQ;AAAA,EAER;AACF;AAEA,SAAS,WAAW,UAAkB,OAA6B;AACjE,MAAI;AACF,UAAM,SAAS,MAAM,UAAU;AAAA,MAC7B,QAAQ;AAAA,MACR,MAAM,KAAK,UAAU,KAAK;AAAA,MAC1B,SAAS,EAAE,gBAAgB,mBAAmB;AAAA,IAChD,CAAC;AAED,QAAI,UAAU,OAAQ,OAA4B,UAAU,YAAY;AACtE,MAAC,OAA4B,MAAM,MAAM;AAAA,MAAe,CAAC;AAAA,IAC3D;AAAA,EACF,QAAQ;AAAA,EAER;AACF;AAEO,SAAS,KAAK,OAAe,OAAuC;AACzE,MAAI,CAAC,mBAAmB,EAAG;AAC3B,QAAM,MAAsB,UAAU,SAClC,EAAE,KAAI,oBAAI,KAAK,GAAE,YAAY,GAAG,OAAO,MAAM,IAC7C,EAAE,KAAI,oBAAI,KAAK,GAAE,YAAY,GAAG,MAAM;AAC1C,aAAW,GAAG;AACd,QAAM,WAAW,aAAa,QAAQ,IAAI;AAC1C,MAAI,SAAU,YAAW,UAAU,GAAG;AACxC;AAEO,SAAS,yBAA+B;AAC7C,cAAY;AACd;","names":[]}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
export type AgentId = 'claude-code' | 'cursor' | 'vscode' | 'zed' | 'gemini-cli' | 'windsurf' | 'codex' | 'opencode';
|
|
2
|
+
export type InstallType = 'cli-command' | 'config-file' | 'config-toml';
|
|
3
|
+
export interface AgentDescriptor {
|
|
4
|
+
id: AgentId;
|
|
5
|
+
displayName: string;
|
|
6
|
+
installType: InstallType;
|
|
7
|
+
/** Returns true when wigolo can plausibly install into this agent on this machine. */
|
|
8
|
+
detect(opts: {
|
|
9
|
+
cwd: string;
|
|
10
|
+
home: string;
|
|
11
|
+
}): boolean;
|
|
12
|
+
/**
|
|
13
|
+
* Returns the path wigolo will write its MCP config to (or read from for status).
|
|
14
|
+
* Returns null for cli-command agents (Claude Code).
|
|
15
|
+
*/
|
|
16
|
+
configPath(opts: {
|
|
17
|
+
cwd: string;
|
|
18
|
+
home: string;
|
|
19
|
+
}): string | null;
|
|
20
|
+
}
|
|
21
|
+
export interface DetectedAgent {
|
|
22
|
+
id: AgentId;
|
|
23
|
+
displayName: string;
|
|
24
|
+
detected: boolean;
|
|
25
|
+
configPath: string | null;
|
|
26
|
+
installType: InstallType;
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=agents-types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agents-types.d.ts","sourceRoot":"","sources":["../../../src/cli/tui/agents-types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,OAAO,GACf,aAAa,GACb,QAAQ,GACR,QAAQ,GACR,KAAK,GACL,YAAY,GACZ,UAAU,GACV,OAAO,GACP,UAAU,CAAC;AAEf,MAAM,MAAM,WAAW,GAAG,aAAa,GAAG,aAAa,GAAG,aAAa,CAAC;AAExE,MAAM,WAAW,eAAe;IAC9B,EAAE,EAAE,OAAO,CAAC;IACZ,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,WAAW,CAAC;IACzB,sFAAsF;IACtF,MAAM,CAAC,IAAI,EAAE;QAAE,GAAG,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,GAAG,OAAO,CAAC;IACrD;;;OAGG;IACH,UAAU,CAAC,IAAI,EAAE;QAAE,GAAG,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,GAAG,MAAM,GAAG,IAAI,CAAC;CAChE;AAED,MAAM,WAAW,aAAa;IAC5B,EAAE,EAAE,OAAO,CAAC;IACZ,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,OAAO,CAAC;IAClB,UAAU,EAAE,MAAM,GAAG,IAAI,CAAC;IAC1B,WAAW,EAAE,WAAW,CAAC;CAC1B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
//# sourceMappingURL=agents-types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { AgentDescriptor, DetectedAgent } from './agents-types.js';
|
|
2
|
+
import { fileExists } from './detect-helpers.js';
|
|
3
|
+
export type { AgentId, AgentDescriptor, DetectedAgent, InstallType } from './agents-types.js';
|
|
4
|
+
export declare const AGENTS: readonly AgentDescriptor[];
|
|
5
|
+
export interface DetectAgentsOptions {
|
|
6
|
+
cwd?: string;
|
|
7
|
+
home?: string;
|
|
8
|
+
}
|
|
9
|
+
export declare function detectAgents(opts?: DetectAgentsOptions): DetectedAgent[];
|
|
10
|
+
export { fileExists };
|
|
11
|
+
//# sourceMappingURL=agents.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agents.d.ts","sourceRoot":"","sources":["../../../src/cli/tui/agents.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AACxE,OAAO,EAA2B,UAAU,EAAmB,MAAM,qBAAqB,CAAC;AAE3F,YAAY,EAAE,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAyF9F,eAAO,MAAM,MAAM,EAAE,SAAS,eAAe,EAS5C,CAAC;AAEF,MAAM,WAAW,mBAAmB;IAClC,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,MAAM,CAAC;CACf;AAED,wBAAgB,YAAY,CAAC,IAAI,GAAE,mBAAwB,GAAG,aAAa,EAAE,CAY5E;AAED,OAAO,EAAE,UAAU,EAAE,CAAC"}
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import { join } from "node:path";
|
|
2
|
+
import { binaryInPath, dirExists, fileExists, getHome, getCwd } from "./detect-helpers.js";
|
|
3
|
+
const claudeCode = {
|
|
4
|
+
id: "claude-code",
|
|
5
|
+
displayName: "Claude Code",
|
|
6
|
+
installType: "cli-command",
|
|
7
|
+
detect: () => binaryInPath("claude") !== null,
|
|
8
|
+
configPath: () => null
|
|
9
|
+
};
|
|
10
|
+
const cursor = {
|
|
11
|
+
id: "cursor",
|
|
12
|
+
displayName: "Cursor",
|
|
13
|
+
installType: "config-file",
|
|
14
|
+
detect: ({ cwd, home }) => dirExists(join(cwd, ".cursor")) || dirExists(join(home, ".cursor")) || binaryInPath("cursor") !== null,
|
|
15
|
+
configPath: ({ cwd, home }) => {
|
|
16
|
+
if (dirExists(join(cwd, ".cursor"))) return join(cwd, ".cursor", "mcp.json");
|
|
17
|
+
return join(home, ".cursor", "mcp.json");
|
|
18
|
+
}
|
|
19
|
+
};
|
|
20
|
+
const vscode = {
|
|
21
|
+
id: "vscode",
|
|
22
|
+
displayName: "VS Code (Copilot)",
|
|
23
|
+
installType: "config-file",
|
|
24
|
+
detect: ({ cwd, home }) => dirExists(join(cwd, ".vscode")) || dirExists(join(home, ".vscode")) || binaryInPath("code") !== null,
|
|
25
|
+
configPath: ({ cwd, home }) => {
|
|
26
|
+
if (dirExists(join(cwd, ".vscode"))) return join(cwd, ".vscode", "mcp.json");
|
|
27
|
+
return join(home, ".vscode", "mcp.json");
|
|
28
|
+
}
|
|
29
|
+
};
|
|
30
|
+
const zed = {
|
|
31
|
+
id: "zed",
|
|
32
|
+
displayName: "Zed",
|
|
33
|
+
installType: "config-file",
|
|
34
|
+
detect: ({ home }) => dirExists(join(home, ".config", "zed")) || binaryInPath("zed") !== null,
|
|
35
|
+
configPath: ({ home }) => join(home, ".config", "zed", "settings.json")
|
|
36
|
+
};
|
|
37
|
+
const geminiCli = {
|
|
38
|
+
id: "gemini-cli",
|
|
39
|
+
displayName: "Gemini CLI",
|
|
40
|
+
installType: "config-file",
|
|
41
|
+
detect: ({ home }) => binaryInPath("gemini") !== null || dirExists(join(home, ".gemini")),
|
|
42
|
+
configPath: ({ home }) => join(home, ".gemini", "settings.json")
|
|
43
|
+
};
|
|
44
|
+
const windsurf = {
|
|
45
|
+
id: "windsurf",
|
|
46
|
+
displayName: "Windsurf",
|
|
47
|
+
installType: "config-file",
|
|
48
|
+
detect: ({ home }) => dirExists(join(home, ".codeium", "windsurf")) || dirExists(join(home, ".windsurf")) || binaryInPath("windsurf") !== null,
|
|
49
|
+
configPath: ({ home }) => join(home, ".codeium", "windsurf", "mcp_config.json")
|
|
50
|
+
};
|
|
51
|
+
const codex = {
|
|
52
|
+
id: "codex",
|
|
53
|
+
displayName: "Codex (OpenAI CLI)",
|
|
54
|
+
installType: "config-toml",
|
|
55
|
+
detect: ({ home }) => binaryInPath("codex") !== null || dirExists(join(home, ".codex")),
|
|
56
|
+
configPath: ({ home }) => join(home, ".codex", "config.toml")
|
|
57
|
+
};
|
|
58
|
+
const opencode = {
|
|
59
|
+
id: "opencode",
|
|
60
|
+
displayName: "OpenCode",
|
|
61
|
+
installType: "config-file",
|
|
62
|
+
detect: ({ home }) => binaryInPath("opencode") !== null || dirExists(join(home, ".config", "opencode")),
|
|
63
|
+
configPath: ({ home }) => join(home, ".config", "opencode", "config.json")
|
|
64
|
+
};
|
|
65
|
+
const AGENTS = [
|
|
66
|
+
claudeCode,
|
|
67
|
+
cursor,
|
|
68
|
+
vscode,
|
|
69
|
+
zed,
|
|
70
|
+
geminiCli,
|
|
71
|
+
windsurf,
|
|
72
|
+
codex,
|
|
73
|
+
opencode
|
|
74
|
+
];
|
|
75
|
+
function detectAgents(opts = {}) {
|
|
76
|
+
const env = {
|
|
77
|
+
cwd: opts.cwd ?? getCwd(),
|
|
78
|
+
home: opts.home ?? getHome()
|
|
79
|
+
};
|
|
80
|
+
return AGENTS.map((d) => ({
|
|
81
|
+
id: d.id,
|
|
82
|
+
displayName: d.displayName,
|
|
83
|
+
detected: d.detect(env),
|
|
84
|
+
configPath: d.configPath(env),
|
|
85
|
+
installType: d.installType
|
|
86
|
+
}));
|
|
87
|
+
}
|
|
88
|
+
export {
|
|
89
|
+
AGENTS,
|
|
90
|
+
detectAgents,
|
|
91
|
+
fileExists
|
|
92
|
+
};
|
|
93
|
+
//# sourceMappingURL=agents.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/cli/tui/agents.ts"],"sourcesContent":["import { join } from 'node:path';\nimport type { AgentDescriptor, DetectedAgent } from './agents-types.js';\nimport { binaryInPath, dirExists, fileExists, getHome, getCwd } from './detect-helpers.js';\n\nexport type { AgentId, AgentDescriptor, DetectedAgent, InstallType } from './agents-types.js';\n\nconst claudeCode: AgentDescriptor = {\n id: 'claude-code',\n displayName: 'Claude Code',\n installType: 'cli-command',\n detect: () => binaryInPath('claude') !== null,\n configPath: () => null,\n};\n\nconst cursor: AgentDescriptor = {\n id: 'cursor',\n displayName: 'Cursor',\n installType: 'config-file',\n detect: ({ cwd, home }) =>\n dirExists(join(cwd, '.cursor')) ||\n dirExists(join(home, '.cursor')) ||\n binaryInPath('cursor') !== null,\n configPath: ({ cwd, home }) => {\n if (dirExists(join(cwd, '.cursor'))) return join(cwd, '.cursor', 'mcp.json');\n return join(home, '.cursor', 'mcp.json');\n },\n};\n\nconst vscode: AgentDescriptor = {\n id: 'vscode',\n displayName: 'VS Code (Copilot)',\n installType: 'config-file',\n detect: ({ cwd, home }) =>\n dirExists(join(cwd, '.vscode')) ||\n dirExists(join(home, '.vscode')) ||\n binaryInPath('code') !== null,\n configPath: ({ cwd, home }) => {\n if (dirExists(join(cwd, '.vscode'))) return join(cwd, '.vscode', 'mcp.json');\n return join(home, '.vscode', 'mcp.json');\n },\n};\n\nconst zed: AgentDescriptor = {\n id: 'zed',\n displayName: 'Zed',\n installType: 'config-file',\n detect: ({ home }) =>\n dirExists(join(home, '.config', 'zed')) ||\n binaryInPath('zed') !== null,\n configPath: ({ home }) => join(home, '.config', 'zed', 'settings.json'),\n};\n\nconst geminiCli: AgentDescriptor = {\n id: 'gemini-cli',\n displayName: 'Gemini CLI',\n installType: 'config-file',\n detect: ({ home }) =>\n binaryInPath('gemini') !== null ||\n dirExists(join(home, '.gemini')),\n configPath: ({ home }) => join(home, '.gemini', 'settings.json'),\n};\n\nconst windsurf: AgentDescriptor = {\n id: 'windsurf',\n displayName: 'Windsurf',\n installType: 'config-file',\n detect: ({ home }) =>\n dirExists(join(home, '.codeium', 'windsurf')) ||\n dirExists(join(home, '.windsurf')) ||\n binaryInPath('windsurf') !== null,\n configPath: ({ home }) => join(home, '.codeium', 'windsurf', 'mcp_config.json'),\n};\n\nconst codex: AgentDescriptor = {\n id: 'codex',\n displayName: 'Codex (OpenAI CLI)',\n installType: 'config-toml',\n detect: ({ home }) =>\n binaryInPath('codex') !== null ||\n dirExists(join(home, '.codex')),\n configPath: ({ home }) => join(home, '.codex', 'config.toml'),\n};\n\nconst opencode: AgentDescriptor = {\n id: 'opencode',\n displayName: 'OpenCode',\n installType: 'config-file',\n detect: ({ home }) =>\n binaryInPath('opencode') !== null ||\n dirExists(join(home, '.config', 'opencode')),\n configPath: ({ home }) => join(home, '.config', 'opencode', 'config.json'),\n};\n\nexport const AGENTS: readonly AgentDescriptor[] = [\n claudeCode,\n cursor,\n vscode,\n zed,\n geminiCli,\n windsurf,\n codex,\n opencode,\n];\n\nexport interface DetectAgentsOptions {\n cwd?: string;\n home?: string;\n}\n\nexport function detectAgents(opts: DetectAgentsOptions = {}): DetectedAgent[] {\n const env = {\n cwd: opts.cwd ?? getCwd(),\n home: opts.home ?? getHome(),\n };\n return AGENTS.map((d) => ({\n id: d.id,\n displayName: d.displayName,\n detected: d.detect(env),\n configPath: d.configPath(env),\n installType: d.installType,\n }));\n}\n\nexport { fileExists };\n"],"mappings":"AAAA,SAAS,YAAY;AAErB,SAAS,cAAc,WAAW,YAAY,SAAS,cAAc;AAIrE,MAAM,aAA8B;AAAA,EAClC,IAAI;AAAA,EACJ,aAAa;AAAA,EACb,aAAa;AAAA,EACb,QAAQ,MAAM,aAAa,QAAQ,MAAM;AAAA,EACzC,YAAY,MAAM;AACpB;AAEA,MAAM,SAA0B;AAAA,EAC9B,IAAI;AAAA,EACJ,aAAa;AAAA,EACb,aAAa;AAAA,EACb,QAAQ,CAAC,EAAE,KAAK,KAAK,MACnB,UAAU,KAAK,KAAK,SAAS,CAAC,KAC9B,UAAU,KAAK,MAAM,SAAS,CAAC,KAC/B,aAAa,QAAQ,MAAM;AAAA,EAC7B,YAAY,CAAC,EAAE,KAAK,KAAK,MAAM;AAC7B,QAAI,UAAU,KAAK,KAAK,SAAS,CAAC,EAAG,QAAO,KAAK,KAAK,WAAW,UAAU;AAC3E,WAAO,KAAK,MAAM,WAAW,UAAU;AAAA,EACzC;AACF;AAEA,MAAM,SAA0B;AAAA,EAC9B,IAAI;AAAA,EACJ,aAAa;AAAA,EACb,aAAa;AAAA,EACb,QAAQ,CAAC,EAAE,KAAK,KAAK,MACnB,UAAU,KAAK,KAAK,SAAS,CAAC,KAC9B,UAAU,KAAK,MAAM,SAAS,CAAC,KAC/B,aAAa,MAAM,MAAM;AAAA,EAC3B,YAAY,CAAC,EAAE,KAAK,KAAK,MAAM;AAC7B,QAAI,UAAU,KAAK,KAAK,SAAS,CAAC,EAAG,QAAO,KAAK,KAAK,WAAW,UAAU;AAC3E,WAAO,KAAK,MAAM,WAAW,UAAU;AAAA,EACzC;AACF;AAEA,MAAM,MAAuB;AAAA,EAC3B,IAAI;AAAA,EACJ,aAAa;AAAA,EACb,aAAa;AAAA,EACb,QAAQ,CAAC,EAAE,KAAK,MACd,UAAU,KAAK,MAAM,WAAW,KAAK,CAAC,KACtC,aAAa,KAAK,MAAM;AAAA,EAC1B,YAAY,CAAC,EAAE,KAAK,MAAM,KAAK,MAAM,WAAW,OAAO,eAAe;AACxE;AAEA,MAAM,YAA6B;AAAA,EACjC,IAAI;AAAA,EACJ,aAAa;AAAA,EACb,aAAa;AAAA,EACb,QAAQ,CAAC,EAAE,KAAK,MACd,aAAa,QAAQ,MAAM,QAC3B,UAAU,KAAK,MAAM,SAAS,CAAC;AAAA,EACjC,YAAY,CAAC,EAAE,KAAK,MAAM,KAAK,MAAM,WAAW,eAAe;AACjE;AAEA,MAAM,WAA4B;AAAA,EAChC,IAAI;AAAA,EACJ,aAAa;AAAA,EACb,aAAa;AAAA,EACb,QAAQ,CAAC,EAAE,KAAK,MACd,UAAU,KAAK,MAAM,YAAY,UAAU,CAAC,KAC5C,UAAU,KAAK,MAAM,WAAW,CAAC,KACjC,aAAa,UAAU,MAAM;AAAA,EAC/B,YAAY,CAAC,EAAE,KAAK,MAAM,KAAK,MAAM,YAAY,YAAY,iBAAiB;AAChF;AAEA,MAAM,QAAyB;AAAA,EAC7B,IAAI;AAAA,EACJ,aAAa;AAAA,EACb,aAAa;AAAA,EACb,QAAQ,CAAC,EAAE,KAAK,MACd,aAAa,OAAO,MAAM,QAC1B,UAAU,KAAK,MAAM,QAAQ,CAAC;AAAA,EAChC,YAAY,CAAC,EAAE,KAAK,MAAM,KAAK,MAAM,UAAU,aAAa;AAC9D;AAEA,MAAM,WAA4B;AAAA,EAChC,IAAI;AAAA,EACJ,aAAa;AAAA,EACb,aAAa;AAAA,EACb,QAAQ,CAAC,EAAE,KAAK,MACd,aAAa,UAAU,MAAM,QAC7B,UAAU,KAAK,MAAM,WAAW,UAAU,CAAC;AAAA,EAC7C,YAAY,CAAC,EAAE,KAAK,MAAM,KAAK,MAAM,WAAW,YAAY,aAAa;AAC3E;AAEO,MAAM,SAAqC;AAAA,EAChD;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF;AAOO,SAAS,aAAa,OAA4B,CAAC,GAAoB;AAC5E,QAAM,MAAM;AAAA,IACV,KAAK,KAAK,OAAO,OAAO;AAAA,IACxB,MAAM,KAAK,QAAQ,QAAQ;AAAA,EAC7B;AACA,SAAO,OAAO,IAAI,CAAC,OAAO;AAAA,IACxB,IAAI,EAAE;AAAA,IACN,aAAa,EAAE;AAAA,IACf,UAAU,EAAE,OAAO,GAAG;AAAA,IACtB,YAAY,EAAE,WAAW,GAAG;AAAA,IAC5B,aAAa,EAAE;AAAA,EACjB,EAAE;AACJ;","names":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"banner.d.ts","sourceRoot":"","sources":["../../../src/cli/tui/banner.ts"],"names":[],"mappings":"AAUA,wBAAgB,YAAY,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,CAMpD;AAQD,wBAAgB,iBAAiB,IAAI,IAAI,CAKxC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import chalk from "chalk";
|
|
2
|
+
const BANNER_LINES = [
|
|
3
|
+
" \u2566 \u2566\u2566\u2554\u2550\u2557\u2554\u2550\u2557\u2566 \u2554\u2550\u2557",
|
|
4
|
+
" \u2551\u2551\u2551\u2551\u2551 \u2566\u2551 \u2551\u2551 \u2551 \u2551",
|
|
5
|
+
" \u255A\u2569\u255D\u2569\u255A\u2550\u255D\u255A\u2550\u255D\u2569\u2550\u255D\u255A\u2550\u255D"
|
|
6
|
+
];
|
|
7
|
+
const TAGLINE = "Local-first web intelligence for AI agents";
|
|
8
|
+
function renderBanner(version) {
|
|
9
|
+
const colored = BANNER_LINES.map((line) => chalk.cyan(line)).join("\n");
|
|
10
|
+
const tagline = chalk.gray(` ${TAGLINE}`);
|
|
11
|
+
const versionText = version ? chalk.gray(` v${version}`) : "";
|
|
12
|
+
return [colored, tagline, versionText, ""].filter((l) => l !== "").join("\n") + "\n";
|
|
13
|
+
}
|
|
14
|
+
const ADD_MCP_BANNER_LINES = [
|
|
15
|
+
" \u2554\u2550\u2557\u2554\u2566\u2557\u2554\u2566\u2557 \u2554\u2566\u2557\u2554\u2550\u2557\u2554\u2550\u2557",
|
|
16
|
+
" \u2560\u2550\u2563 \u2551\u2551 \u2551\u2551 \u2551\u2551\u2551\u2551 \u2560\u2550\u255D",
|
|
17
|
+
" \u2569 \u2569\u2550\u2569\u255D\u2550\u2569\u255D \u2569 \u2569\u255A\u2550\u255D\u2569 "
|
|
18
|
+
];
|
|
19
|
+
function printAddMcpBanner() {
|
|
20
|
+
for (const line of ADD_MCP_BANNER_LINES) {
|
|
21
|
+
process.stderr.write(`${line}
|
|
22
|
+
`);
|
|
23
|
+
}
|
|
24
|
+
process.stderr.write(" ADD MCP \u2014 Wire wigolo into your AI tools.\n\n");
|
|
25
|
+
}
|
|
26
|
+
export {
|
|
27
|
+
printAddMcpBanner,
|
|
28
|
+
renderBanner
|
|
29
|
+
};
|
|
30
|
+
//# sourceMappingURL=banner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/cli/tui/banner.ts"],"sourcesContent":["import chalk from 'chalk';\n\nconst BANNER_LINES: readonly string[] = [\n ' ╦ ╦╦╔═╗╔═╗╦ ╔═╗',\n ' ║║║║║ ╦║ ║║ ║ ║',\n ' ╚╩╝╩╚═╝╚═╝╩═╝╚═╝',\n];\n\nconst TAGLINE = 'Local-first web intelligence for AI agents';\n\nexport function renderBanner(version: string): string {\n const colored = BANNER_LINES.map(line => chalk.cyan(line)).join('\\n');\n const tagline = chalk.gray(` ${TAGLINE}`);\n const versionText = version ? chalk.gray(` v${version}`) : '';\n\n return [colored, tagline, versionText, ''].filter(l => l !== '').join('\\n') + '\\n';\n}\n\nconst ADD_MCP_BANNER_LINES: readonly string[] = [\n ' ╔═╗╔╦╗╔╦╗ ╔╦╗╔═╗╔═╗',\n ' ╠═╣ ║║ ║║ ║║║║ ╠═╝',\n ' ╩ ╩═╩╝═╩╝ ╩ ╩╚═╝╩ ',\n];\n\nexport function printAddMcpBanner(): void {\n for (const line of ADD_MCP_BANNER_LINES) {\n process.stderr.write(`${line}\\n`);\n }\n process.stderr.write(' ADD MCP — Wire wigolo into your AI tools.\\n\\n');\n}\n"],"mappings":"AAAA,OAAO,WAAW;AAElB,MAAM,eAAkC;AAAA,EACtC;AAAA,EACA;AAAA,EACA;AACF;AAEA,MAAM,UAAU;AAET,SAAS,aAAa,SAAyB;AACpD,QAAM,UAAU,aAAa,IAAI,UAAQ,MAAM,KAAK,IAAI,CAAC,EAAE,KAAK,IAAI;AACpE,QAAM,UAAU,MAAM,KAAK,KAAK,OAAO,EAAE;AACzC,QAAM,cAAc,UAAU,MAAM,KAAK,MAAM,OAAO,EAAE,IAAI;AAE5D,SAAO,CAAC,SAAS,SAAS,aAAa,EAAE,EAAE,OAAO,OAAK,MAAM,EAAE,EAAE,KAAK,IAAI,IAAI;AAChF;AAEA,MAAM,uBAA0C;AAAA,EAC9C;AAAA,EACA;AAAA,EACA;AACF;AAEO,SAAS,oBAA0B;AACxC,aAAW,QAAQ,sBAAsB;AACvC,YAAQ,OAAO,MAAM,GAAG,IAAI;AAAA,CAAI;AAAA,EAClC;AACA,UAAQ,OAAO,MAAM,sDAAiD;AACxE;","names":[]}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { AgentId } from '../agents.js';
|
|
2
|
+
export interface AgentResult {
|
|
3
|
+
id: string;
|
|
4
|
+
displayName: string;
|
|
5
|
+
ok: boolean;
|
|
6
|
+
message?: string;
|
|
7
|
+
}
|
|
8
|
+
interface AgentSelectProps {
|
|
9
|
+
onComplete: (selectedIds: AgentId[], results: AgentResult[]) => void;
|
|
10
|
+
}
|
|
11
|
+
export declare function AgentSelect({ onComplete }: AgentSelectProps): import("react/jsx-runtime").JSX.Element;
|
|
12
|
+
export {};
|
|
13
|
+
//# sourceMappingURL=AgentSelect.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AgentSelect.d.ts","sourceRoot":"","sources":["../../../../src/cli/tui/components/AgentSelect.tsx"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,OAAO,EAAiB,MAAM,cAAc,CAAC;AAE3D,MAAM,WAAW,WAAW;IAC1B,EAAE,EAAE,MAAM,CAAC;IACX,WAAW,EAAE,MAAM,CAAC;IACpB,EAAE,EAAE,OAAO,CAAC;IACZ,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AAED,UAAU,gBAAgB;IACxB,UAAU,EAAE,CAAC,WAAW,EAAE,OAAO,EAAE,EAAE,OAAO,EAAE,WAAW,EAAE,KAAK,IAAI,CAAC;CACtE;AAsED,wBAAgB,WAAW,CAAC,EAAE,UAAU,EAAE,EAAE,gBAAgB,2CA4E3D"}
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useState, useEffect } from "react";
|
|
3
|
+
import { Box, Text, useInput } from "ink";
|
|
4
|
+
import { Spinner } from "@inkjs/ui";
|
|
5
|
+
import { useAgentDetect } from "../hooks/useAgentDetect.js";
|
|
6
|
+
import { applyConfigs } from "../config-writer.js";
|
|
7
|
+
function CheckboxList({
|
|
8
|
+
items,
|
|
9
|
+
onSubmit
|
|
10
|
+
}) {
|
|
11
|
+
const [cursor, setCursor] = useState(0);
|
|
12
|
+
const [checked, setChecked] = useState(
|
|
13
|
+
() => new Set(items.filter((i) => i.checked).map((i) => i.id))
|
|
14
|
+
);
|
|
15
|
+
const [error, setError] = useState("");
|
|
16
|
+
useInput((input, key) => {
|
|
17
|
+
if (key.upArrow) {
|
|
18
|
+
setCursor((c) => c > 0 ? c - 1 : items.length - 1);
|
|
19
|
+
setError("");
|
|
20
|
+
} else if (key.downArrow) {
|
|
21
|
+
setCursor((c) => c < items.length - 1 ? c + 1 : 0);
|
|
22
|
+
setError("");
|
|
23
|
+
} else if (input === " ") {
|
|
24
|
+
const id = items[cursor].id;
|
|
25
|
+
setChecked((prev) => {
|
|
26
|
+
const next = new Set(prev);
|
|
27
|
+
if (next.has(id)) next.delete(id);
|
|
28
|
+
else next.add(id);
|
|
29
|
+
return next;
|
|
30
|
+
});
|
|
31
|
+
setError("");
|
|
32
|
+
} else if (key.return) {
|
|
33
|
+
const selected = items.filter((i) => checked.has(i.id)).map((i) => i.id);
|
|
34
|
+
if (selected.length === 0) {
|
|
35
|
+
setError("Select at least one agent");
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
onSubmit(selected);
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
return /* @__PURE__ */ jsxs(Box, { flexDirection: "column", children: [
|
|
42
|
+
items.map((item, i) => {
|
|
43
|
+
const isFocused = i === cursor;
|
|
44
|
+
const isChecked = checked.has(item.id);
|
|
45
|
+
return /* @__PURE__ */ jsxs(Text, { children: [
|
|
46
|
+
isFocused ? /* @__PURE__ */ jsx(Text, { color: "cyan", children: "\u276F " }) : " ",
|
|
47
|
+
isChecked ? /* @__PURE__ */ jsx(Text, { color: "green", children: "[\u2713] " }) : /* @__PURE__ */ jsx(Text, { dimColor: true, children: "[ ] " }),
|
|
48
|
+
/* @__PURE__ */ jsx(Text, { bold: isFocused, children: item.label })
|
|
49
|
+
] }, item.id);
|
|
50
|
+
}),
|
|
51
|
+
error && /* @__PURE__ */ jsx(Box, { marginTop: 1, children: /* @__PURE__ */ jsxs(Text, { color: "red", children: [
|
|
52
|
+
" ",
|
|
53
|
+
error
|
|
54
|
+
] }) })
|
|
55
|
+
] });
|
|
56
|
+
}
|
|
57
|
+
function AgentSelect({ onComplete }) {
|
|
58
|
+
const { agents, done: detectDone } = useAgentDetect();
|
|
59
|
+
const [configuring, setConfiguring] = useState(false);
|
|
60
|
+
const [results, setResults] = useState([]);
|
|
61
|
+
const [configDone, setConfigDone] = useState(false);
|
|
62
|
+
useEffect(() => {
|
|
63
|
+
if (configDone) {
|
|
64
|
+
const ids = results.filter((r) => r.ok).map((r) => r.id);
|
|
65
|
+
const timer = setTimeout(() => onComplete(ids, results), 400);
|
|
66
|
+
return () => clearTimeout(timer);
|
|
67
|
+
}
|
|
68
|
+
}, [configDone, results, onComplete]);
|
|
69
|
+
if (!detectDone) {
|
|
70
|
+
return /* @__PURE__ */ jsx(Box, { paddingX: 2, children: /* @__PURE__ */ jsx(Spinner, { label: "Detecting AI tools..." }) });
|
|
71
|
+
}
|
|
72
|
+
if (configuring) {
|
|
73
|
+
return /* @__PURE__ */ jsxs(Box, { flexDirection: "column", paddingX: 2, children: [
|
|
74
|
+
/* @__PURE__ */ jsx(Text, { bold: true, children: "Configuring agents..." }),
|
|
75
|
+
/* @__PURE__ */ jsxs(Box, { flexDirection: "column", marginTop: 1, children: [
|
|
76
|
+
results.map((r) => /* @__PURE__ */ jsxs(Text, { children: [
|
|
77
|
+
" ",
|
|
78
|
+
r.ok ? /* @__PURE__ */ jsx(Text, { color: "green", children: "\u2713" }) : /* @__PURE__ */ jsx(Text, { color: "red", children: "\u2717" }),
|
|
79
|
+
" ",
|
|
80
|
+
r.displayName,
|
|
81
|
+
r.message && !r.ok ? /* @__PURE__ */ jsxs(Text, { color: "red", children: [
|
|
82
|
+
" \u2014 ",
|
|
83
|
+
r.message
|
|
84
|
+
] }) : null
|
|
85
|
+
] }, r.id)),
|
|
86
|
+
!configDone && /* @__PURE__ */ jsx(Box, { marginTop: 1, children: /* @__PURE__ */ jsx(Spinner, { label: "Writing configs..." }) })
|
|
87
|
+
] })
|
|
88
|
+
] });
|
|
89
|
+
}
|
|
90
|
+
const checklistItems = agents.map((a) => ({
|
|
91
|
+
id: a.id,
|
|
92
|
+
label: a.detected ? `${a.displayName} (detected)` : a.displayName,
|
|
93
|
+
checked: a.id === "claude-code" && a.detected
|
|
94
|
+
}));
|
|
95
|
+
async function handleSubmit(selectedIds) {
|
|
96
|
+
setConfiguring(true);
|
|
97
|
+
const configResults = await applyConfigs(agents, selectedIds);
|
|
98
|
+
const mapped = configResults.map((r) => ({
|
|
99
|
+
id: r.id,
|
|
100
|
+
displayName: r.displayName,
|
|
101
|
+
ok: r.ok,
|
|
102
|
+
message: r.message
|
|
103
|
+
}));
|
|
104
|
+
setResults(mapped);
|
|
105
|
+
setConfigDone(true);
|
|
106
|
+
}
|
|
107
|
+
return /* @__PURE__ */ jsxs(Box, { flexDirection: "column", paddingX: 2, children: [
|
|
108
|
+
/* @__PURE__ */ jsx(Text, { bold: true, children: "Connect to AI Tools" }),
|
|
109
|
+
/* @__PURE__ */ jsx(Text, { dimColor: true, children: "\u2191/\u2193 navigate \xB7 space toggle \xB7 enter confirm" }),
|
|
110
|
+
/* @__PURE__ */ jsx(Box, { marginTop: 1, children: /* @__PURE__ */ jsx(CheckboxList, { items: checklistItems, onSubmit: handleSubmit }) })
|
|
111
|
+
] });
|
|
112
|
+
}
|
|
113
|
+
export {
|
|
114
|
+
AgentSelect
|
|
115
|
+
};
|
|
116
|
+
//# sourceMappingURL=AgentSelect.js.map
|