@staticn0va/wigolo 0.1.0 → 0.1.1
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 +195 -73
- 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 +208 -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 +46 -1
- package/dist/cache/store.d.ts.map +1 -1
- package/dist/cache/store.js +362 -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 +318 -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/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 +58 -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/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 +185 -81
- package/dist/fetch/router.js.map +1 -1
- package/dist/index.js +97 -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/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/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/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 +16 -0
- package/dist/providers/rerank-provider.d.ts.map +1 -0
- package/dist/providers/rerank-provider.js +28 -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 +5 -0
- package/dist/research/brief.d.ts.map +1 -0
- package/dist/research/brief.js +242 -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 +16 -0
- package/dist/research/synthesis-local.d.ts.map +1 -0
- package/dist/research/synthesis-local.js +73 -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.js +49 -55
- 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 +12 -0
- package/dist/search/reranker/transformers-rerank-provider.d.ts.map +1 -0
- package/dist/search/reranker/transformers-rerank-provider.js +78 -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 +175 -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 +161 -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
package/dist/tools/fetch.js
CHANGED
|
@@ -1,76 +1,169 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { getCachedContent, cacheContent,
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
|
|
1
|
+
import { getExtractProvider } from "../providers/extract-provider.js";
|
|
2
|
+
import { getCachedContent, cacheContent, isCacheUsable } from "../cache/store.js";
|
|
3
|
+
import { getConfig } from "../config.js";
|
|
4
|
+
import { extractSection } from "../extraction/markdown.js";
|
|
5
|
+
import { detectChange } from "../cache/change-detector.js";
|
|
6
|
+
import { getEmbeddingService } from "../embedding/embed.js";
|
|
7
|
+
import { truncateSmartly, applyOutputBudget } from "../search/truncate.js";
|
|
8
|
+
import { buildEvidenceFromMarkdown } from "../search/evidence.js";
|
|
9
|
+
import { resolveMode } from "../util/mode.js";
|
|
10
|
+
import { createLogger } from "../logger.js";
|
|
11
|
+
const log = createLogger("fetch");
|
|
12
|
+
const DEFAULT_MAX_TOKENS_OUT = 4e3;
|
|
13
|
+
const DEFAULT_FETCH_BODY_TOKENS = 16e3;
|
|
14
|
+
async function attachEvidence(output, input, markdown) {
|
|
15
|
+
if (!markdown) return;
|
|
16
|
+
const includeFull = input.include_full_markdown ?? true;
|
|
17
|
+
const maxTokensOut = input.max_tokens_out ?? DEFAULT_MAX_TOKENS_OUT;
|
|
18
|
+
const evidence = await buildEvidenceFromMarkdown(
|
|
19
|
+
output.title || output.url,
|
|
20
|
+
output.title,
|
|
21
|
+
output.url,
|
|
22
|
+
markdown,
|
|
23
|
+
{ maxTokensOut, maxItems: 1 }
|
|
24
|
+
);
|
|
25
|
+
if (evidence.length > 0) output.evidence = evidence;
|
|
26
|
+
if (!includeFull) {
|
|
27
|
+
output.markdown = "";
|
|
28
|
+
} else if (output.markdown) {
|
|
29
|
+
output.markdown = applyOutputBudget(output.markdown, {
|
|
30
|
+
maxTokensOut: input.max_tokens_out ?? DEFAULT_FETCH_BODY_TOKENS,
|
|
31
|
+
maxChars: input.max_chars
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
}
|
|
6
35
|
function formatCachedResponse(cached, input) {
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
36
|
+
let markdown = cached.markdown;
|
|
37
|
+
let sectionMatched;
|
|
38
|
+
if (input.section) {
|
|
39
|
+
const result = extractSection(markdown, input.section, input.section_index);
|
|
40
|
+
markdown = result.content;
|
|
41
|
+
sectionMatched = result.matched;
|
|
42
|
+
}
|
|
43
|
+
if (input.max_chars && markdown.length > input.max_chars) {
|
|
44
|
+
markdown = markdown.slice(0, input.max_chars);
|
|
45
|
+
}
|
|
46
|
+
if (input.max_content_chars !== void 0) {
|
|
47
|
+
markdown = truncateSmartly(markdown, input.max_content_chars);
|
|
48
|
+
}
|
|
49
|
+
return {
|
|
50
|
+
url: cached.url,
|
|
51
|
+
title: cached.title,
|
|
52
|
+
markdown,
|
|
53
|
+
metadata: {
|
|
54
|
+
...JSON.parse(cached.metadata || "{}"),
|
|
55
|
+
...sectionMatched !== void 0 ? { section_matched: sectionMatched } : {}
|
|
56
|
+
},
|
|
57
|
+
links: JSON.parse(cached.links || "[]"),
|
|
58
|
+
images: JSON.parse(cached.images || "[]"),
|
|
59
|
+
cached: true,
|
|
60
|
+
cached_at: cached.fetchedAt
|
|
61
|
+
};
|
|
62
|
+
}
|
|
63
|
+
async function handleFetch(input, router) {
|
|
64
|
+
const mode = resolveMode(input.mode);
|
|
65
|
+
try {
|
|
66
|
+
if (!input.force_refresh) {
|
|
67
|
+
const cached = getCachedContent(input.url);
|
|
68
|
+
if (cached && (!input.actions || input.actions.length === 0)) {
|
|
69
|
+
const staleMaxSeconds = mode === "cache" ? getConfig().fastStaleMaxHours * 3600 : 0;
|
|
70
|
+
const { usable, stale } = isCacheUsable(cached, { staleMaxSeconds });
|
|
71
|
+
if (usable) {
|
|
72
|
+
log.info("Serving from cache", { url: input.url, stale });
|
|
73
|
+
const out2 = formatCachedResponse(cached, input);
|
|
74
|
+
if (stale) out2.stale = true;
|
|
75
|
+
const fullMarkdown = out2.markdown;
|
|
76
|
+
await attachEvidence(out2, input, fullMarkdown);
|
|
77
|
+
return { ok: true, data: out2 };
|
|
78
|
+
}
|
|
79
|
+
}
|
|
13
80
|
}
|
|
14
|
-
if (
|
|
15
|
-
|
|
81
|
+
if (mode === "cache") {
|
|
82
|
+
return {
|
|
83
|
+
ok: false,
|
|
84
|
+
error: "cache_miss",
|
|
85
|
+
error_reason: `URL not in cache: ${input.url}`,
|
|
86
|
+
stage: "fetch",
|
|
87
|
+
hint: "Use mode:default to fetch live, or run search/crawl first to populate cache"
|
|
88
|
+
};
|
|
16
89
|
}
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
90
|
+
const raw = await router.fetch(input.url, {
|
|
91
|
+
renderJs: input.render_js ?? "auto",
|
|
92
|
+
useAuth: input.use_auth ?? false,
|
|
93
|
+
headers: input.headers,
|
|
94
|
+
screenshot: input.screenshot,
|
|
95
|
+
actions: input.actions,
|
|
96
|
+
mode
|
|
97
|
+
});
|
|
98
|
+
if ("error" in raw && typeof raw.error === "string") {
|
|
99
|
+
const stageErr = raw;
|
|
100
|
+
return {
|
|
101
|
+
ok: false,
|
|
102
|
+
error: stageErr.error,
|
|
103
|
+
error_reason: stageErr.error_reason ?? stageErr.error,
|
|
104
|
+
stage: stageErr.stage ?? "fetch",
|
|
105
|
+
...stageErr.hint ? { hint: stageErr.hint } : {}
|
|
106
|
+
};
|
|
107
|
+
}
|
|
108
|
+
const extractor = await getExtractProvider();
|
|
109
|
+
const extraction = await extractor.extract(raw.html, raw.finalUrl, {
|
|
110
|
+
maxChars: input.max_chars,
|
|
111
|
+
section: input.section,
|
|
112
|
+
sectionIndex: input.section_index,
|
|
113
|
+
contentType: raw.contentType,
|
|
114
|
+
pdfBuffer: raw.rawBuffer
|
|
115
|
+
});
|
|
116
|
+
let changeResult;
|
|
31
117
|
try {
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
headers: input.headers,
|
|
41
|
-
screenshot: input.screenshot,
|
|
42
|
-
});
|
|
43
|
-
const extraction = await extractContent(raw.html, raw.finalUrl, {
|
|
44
|
-
maxChars: input.max_chars,
|
|
45
|
-
section: input.section,
|
|
46
|
-
sectionIndex: input.section_index,
|
|
47
|
-
contentType: raw.contentType,
|
|
48
|
-
pdfBuffer: raw.rawBuffer,
|
|
49
|
-
});
|
|
50
|
-
cacheContent(raw, extraction);
|
|
51
|
-
return {
|
|
52
|
-
url: raw.finalUrl,
|
|
53
|
-
title: extraction.title,
|
|
54
|
-
markdown: extraction.markdown,
|
|
55
|
-
metadata: extraction.metadata,
|
|
56
|
-
links: extraction.links,
|
|
57
|
-
images: extraction.images,
|
|
58
|
-
screenshot: raw.screenshot,
|
|
59
|
-
cached: false,
|
|
60
|
-
};
|
|
118
|
+
changeResult = detectChange(raw.finalUrl, extraction.markdown);
|
|
119
|
+
} catch (err) {
|
|
120
|
+
log.warn("change detection failed", { url: raw.finalUrl, error: String(err) });
|
|
121
|
+
}
|
|
122
|
+
try {
|
|
123
|
+
cacheContent(raw, extraction);
|
|
124
|
+
} catch (err) {
|
|
125
|
+
log.warn("failed to cache fetched content", { url: raw.finalUrl, error: String(err) });
|
|
61
126
|
}
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
links: [],
|
|
70
|
-
images: [],
|
|
71
|
-
cached: false,
|
|
72
|
-
error: err instanceof Error ? err.message : String(err),
|
|
73
|
-
};
|
|
127
|
+
try {
|
|
128
|
+
const embeddingService = getEmbeddingService();
|
|
129
|
+
if (embeddingService.isAvailable()) {
|
|
130
|
+
embeddingService.embedAsync(raw.finalUrl, extraction.markdown);
|
|
131
|
+
}
|
|
132
|
+
} catch (err) {
|
|
133
|
+
log.debug("embedding hook skipped", { error: String(err) });
|
|
74
134
|
}
|
|
135
|
+
const finalMarkdown = input.max_content_chars !== void 0 ? truncateSmartly(extraction.markdown, input.max_content_chars) : extraction.markdown;
|
|
136
|
+
const out = {
|
|
137
|
+
url: raw.finalUrl,
|
|
138
|
+
title: extraction.title,
|
|
139
|
+
markdown: finalMarkdown,
|
|
140
|
+
metadata: extraction.metadata,
|
|
141
|
+
links: extraction.links,
|
|
142
|
+
images: extraction.images,
|
|
143
|
+
screenshot: raw.screenshot,
|
|
144
|
+
cached: false,
|
|
145
|
+
action_results: raw.actionResults,
|
|
146
|
+
...raw.jsRequired ? { js_required: true } : {},
|
|
147
|
+
...changeResult?.changed ? {
|
|
148
|
+
changed: true,
|
|
149
|
+
previous_hash: changeResult.previousHash,
|
|
150
|
+
diff_summary: changeResult.diffSummary
|
|
151
|
+
} : {}
|
|
152
|
+
};
|
|
153
|
+
await attachEvidence(out, input, finalMarkdown);
|
|
154
|
+
return { ok: true, data: out };
|
|
155
|
+
} catch (err) {
|
|
156
|
+
log.error("Fetch failed", { url: input.url, error: String(err) });
|
|
157
|
+
const msg = err instanceof Error ? err.message : String(err);
|
|
158
|
+
return {
|
|
159
|
+
ok: false,
|
|
160
|
+
error: "fetch_failed",
|
|
161
|
+
error_reason: msg,
|
|
162
|
+
stage: "fetch"
|
|
163
|
+
};
|
|
164
|
+
}
|
|
75
165
|
}
|
|
166
|
+
export {
|
|
167
|
+
handleFetch
|
|
168
|
+
};
|
|
76
169
|
//# sourceMappingURL=fetch.js.map
|
package/dist/tools/fetch.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"fetch.js","sourceRoot":"","sources":["../../src/tools/fetch.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"sources":["../../src/tools/fetch.ts"],"sourcesContent":["import type { FetchInput, FetchOutput, CachedContent, StageResult } from '../types.js';\nimport type { SmartRouter } from '../fetch/router.js';\nimport { getExtractProvider } from '../providers/extract-provider.js';\nimport { getCachedContent, cacheContent, isCacheUsable } from '../cache/store.js';\nimport { getConfig } from '../config.js';\nimport { extractSection } from '../extraction/markdown.js';\nimport { detectChange } from '../cache/change-detector.js';\nimport { getEmbeddingService } from '../embedding/embed.js';\nimport { truncateSmartly, applyOutputBudget } from '../search/truncate.js';\nimport { buildEvidenceFromMarkdown } from '../search/evidence.js';\nimport { resolveMode } from '../util/mode.js';\nimport { createLogger } from '../logger.js';\n\nconst log = createLogger('fetch');\n\nconst DEFAULT_MAX_TOKENS_OUT = 4000;\n// Fetch is single-URL — users explicitly want the body. Keep a generous cap\n// that fits typical MCP tool-result limits (~25k tokens) but prevents huge\n// pages (full doc sites) from blowing the cap. Override via max_tokens_out.\nconst DEFAULT_FETCH_BODY_TOKENS = 16000;\n\nasync function attachEvidence(\n output: FetchOutput,\n input: FetchInput,\n markdown: string,\n): Promise<void> {\n if (!markdown) return;\n const includeFull = input.include_full_markdown ?? true;\n const maxTokensOut = input.max_tokens_out ?? DEFAULT_MAX_TOKENS_OUT;\n const evidence = await buildEvidenceFromMarkdown(\n output.title || output.url,\n output.title,\n output.url,\n markdown,\n { maxTokensOut, maxItems: 1 },\n );\n if (evidence.length > 0) output.evidence = evidence;\n if (!includeFull) {\n output.markdown = '';\n } else if (output.markdown) {\n output.markdown = applyOutputBudget(output.markdown, {\n maxTokensOut: input.max_tokens_out ?? DEFAULT_FETCH_BODY_TOKENS,\n maxChars: input.max_chars,\n });\n }\n}\n\nfunction formatCachedResponse(cached: CachedContent, input: FetchInput): FetchOutput {\n let markdown = cached.markdown;\n let sectionMatched: boolean | undefined;\n\n if (input.section) {\n const result = extractSection(markdown, input.section, input.section_index);\n markdown = result.content;\n sectionMatched = result.matched;\n }\n\n if (input.max_chars && markdown.length > input.max_chars) {\n markdown = markdown.slice(0, input.max_chars);\n }\n\n if (input.max_content_chars !== undefined) {\n markdown = truncateSmartly(markdown, input.max_content_chars);\n }\n\n return {\n url: cached.url,\n title: cached.title,\n markdown,\n metadata: {\n ...JSON.parse(cached.metadata || '{}'),\n ...(sectionMatched !== undefined ? { section_matched: sectionMatched } : {}),\n },\n links: JSON.parse(cached.links || '[]'),\n images: JSON.parse(cached.images || '[]'),\n cached: true,\n cached_at: cached.fetchedAt,\n };\n}\n\nexport async function handleFetch(\n input: FetchInput,\n router: SmartRouter,\n): Promise<StageResult<FetchOutput>> {\n const mode = resolveMode(input.mode);\n try {\n if (!input.force_refresh) {\n const cached = getCachedContent(input.url);\n if (cached && (!input.actions || input.actions.length === 0)) {\n const staleMaxSeconds = mode === 'cache' ? getConfig().fastStaleMaxHours * 3600 : 0;\n const { usable, stale } = isCacheUsable(cached, { staleMaxSeconds });\n if (usable) {\n log.info('Serving from cache', { url: input.url, stale });\n const out = formatCachedResponse(cached, input);\n if (stale) out.stale = true;\n const fullMarkdown = out.markdown;\n await attachEvidence(out, input, fullMarkdown);\n return { ok: true, data: out };\n }\n }\n }\n\n if (mode === 'cache') {\n return {\n ok: false,\n error: 'cache_miss',\n error_reason: `URL not in cache: ${input.url}`,\n stage: 'fetch',\n hint: 'Use mode:default to fetch live, or run search/crawl first to populate cache',\n };\n }\n\n const raw = await router.fetch(input.url, {\n renderJs: input.render_js ?? 'auto',\n useAuth: input.use_auth ?? false,\n headers: input.headers,\n screenshot: input.screenshot,\n actions: input.actions,\n mode,\n });\n\n // T11: stealth mode can return a StageError (e.g., playwright_not_installed,\n // playwright_fetch_failed). Surface it directly.\n if ('error' in raw && typeof (raw as { error?: unknown }).error === 'string') {\n const stageErr = raw as unknown as { error: string; error_reason?: string; stage?: string; hint?: string };\n return {\n ok: false,\n error: stageErr.error,\n error_reason: stageErr.error_reason ?? stageErr.error,\n stage: stageErr.stage ?? 'fetch',\n ...(stageErr.hint ? { hint: stageErr.hint } : {}),\n };\n }\n\n const extractor = await getExtractProvider();\n const extraction = await extractor.extract(raw.html, raw.finalUrl, {\n maxChars: input.max_chars,\n section: input.section,\n sectionIndex: input.section_index,\n contentType: raw.contentType,\n pdfBuffer: raw.rawBuffer,\n });\n\n let changeResult: { changed: boolean; previousHash?: string; diffSummary?: string } | undefined;\n try {\n changeResult = detectChange(raw.finalUrl, extraction.markdown);\n } catch (err) {\n log.warn('change detection failed', { url: raw.finalUrl, error: String(err) });\n }\n\n try {\n cacheContent(raw, extraction);\n } catch (err) {\n log.warn('failed to cache fetched content', { url: raw.finalUrl, error: String(err) });\n }\n\n try {\n const embeddingService = getEmbeddingService();\n if (embeddingService.isAvailable()) {\n embeddingService.embedAsync(raw.finalUrl, extraction.markdown);\n }\n } catch (err) {\n log.debug('embedding hook skipped', { error: String(err) });\n }\n\n const finalMarkdown = input.max_content_chars !== undefined\n ? truncateSmartly(extraction.markdown, input.max_content_chars)\n : extraction.markdown;\n\n const out: FetchOutput = {\n url: raw.finalUrl,\n title: extraction.title,\n markdown: finalMarkdown,\n metadata: extraction.metadata,\n links: extraction.links,\n images: extraction.images,\n screenshot: raw.screenshot,\n cached: false,\n action_results: raw.actionResults,\n ...(raw.jsRequired ? { js_required: true } : {}),\n ...(changeResult?.changed ? {\n changed: true,\n previous_hash: changeResult.previousHash,\n diff_summary: changeResult.diffSummary,\n } : {}),\n };\n\n await attachEvidence(out, input, finalMarkdown);\n return { ok: true, data: out };\n } catch (err) {\n log.error('Fetch failed', { url: input.url, error: String(err) });\n const msg = err instanceof Error ? err.message : String(err);\n return {\n ok: false,\n error: 'fetch_failed',\n error_reason: msg,\n stage: 'fetch',\n };\n }\n}\n"],"mappings":"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","names":["out"]}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { FindSimilarInput, FindSimilarOutput, SearchEngine, StageResult } from '../types.js';
|
|
2
|
+
import type { SmartRouter } from '../fetch/router.js';
|
|
3
|
+
import type { BackendStatus } from '../server/backend-status.js';
|
|
4
|
+
export declare function handleFindSimilar(input: FindSimilarInput, engines: SearchEngine[], router: SmartRouter, backendStatus?: BackendStatus): Promise<StageResult<FindSimilarOutput>>;
|
|
5
|
+
//# sourceMappingURL=find-similar.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"find-similar.d.ts","sourceRoot":"","sources":["../../src/tools/find-similar.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,gBAAgB,EAChB,iBAAiB,EACjB,YAAY,EAEZ,WAAW,EACZ,MAAM,aAAa,CAAC;AACrB,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;AAgBjE,wBAAsB,iBAAiB,CACrC,KAAK,EAAE,gBAAgB,EACvB,OAAO,EAAE,YAAY,EAAE,EACvB,MAAM,EAAE,WAAW,EACnB,aAAa,CAAC,EAAE,aAAa,GAC5B,OAAO,CAAC,WAAW,CAAC,iBAAiB,CAAC,CAAC,CAwFzC"}
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
import { findSimilar } from "../search/find-similar.js";
|
|
2
|
+
import {
|
|
3
|
+
buildEvidenceFromMarkdown,
|
|
4
|
+
applyTokenBudget,
|
|
5
|
+
applyAggregateMarkdownBudget
|
|
6
|
+
} from "../search/evidence.js";
|
|
7
|
+
import * as cacheStore from "../cache/store.js";
|
|
8
|
+
import * as searchTool from "./search.js";
|
|
9
|
+
import { createLogger } from "../logger.js";
|
|
10
|
+
const log = createLogger("search");
|
|
11
|
+
const MAX_RESULTS_CAP = 50;
|
|
12
|
+
const DEFAULT_MAX_TOKENS_OUT = 4e3;
|
|
13
|
+
async function handleFindSimilar(input, engines, router, backendStatus) {
|
|
14
|
+
try {
|
|
15
|
+
const url = input.url?.trim();
|
|
16
|
+
const concept = input.concept?.trim();
|
|
17
|
+
if (!url && !concept) {
|
|
18
|
+
return {
|
|
19
|
+
ok: false,
|
|
20
|
+
error: "invalid_input",
|
|
21
|
+
error_reason: "Either url or concept must be provided",
|
|
22
|
+
stage: "find_similar"
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
const sanitizedInput = {
|
|
26
|
+
...input,
|
|
27
|
+
max_results: input.max_results ? Math.min(input.max_results, MAX_RESULTS_CAP) : void 0
|
|
28
|
+
};
|
|
29
|
+
log.info("find_similar request", {
|
|
30
|
+
hasUrl: !!url,
|
|
31
|
+
hasConcept: !!concept,
|
|
32
|
+
maxResults: sanitizedInput.max_results,
|
|
33
|
+
includeCache: sanitizedInput.include_cache,
|
|
34
|
+
includeWeb: sanitizedInput.include_web
|
|
35
|
+
});
|
|
36
|
+
let cacheSeeded = false;
|
|
37
|
+
if (url) {
|
|
38
|
+
try {
|
|
39
|
+
const u = new URL(url);
|
|
40
|
+
const host = u.hostname;
|
|
41
|
+
const cachedCount = cacheStore.countCachedUrlsForDomain(host);
|
|
42
|
+
if (cachedCount < 5) {
|
|
43
|
+
const rawSeg = u.pathname.split("/").filter(Boolean).pop() ?? "";
|
|
44
|
+
let lastSeg = rawSeg;
|
|
45
|
+
try {
|
|
46
|
+
lastSeg = decodeURIComponent(rawSeg);
|
|
47
|
+
} catch {
|
|
48
|
+
}
|
|
49
|
+
const seedQuery = (lastSeg.replace(/[-_]/g, " ") + " " + host.replace(/^www\./, "").split(".")[0]).trim();
|
|
50
|
+
if (seedQuery.length > 0) {
|
|
51
|
+
try {
|
|
52
|
+
await searchTool.handleSearch(
|
|
53
|
+
{ query: seedQuery },
|
|
54
|
+
engines,
|
|
55
|
+
router,
|
|
56
|
+
backendStatus
|
|
57
|
+
);
|
|
58
|
+
cacheSeeded = true;
|
|
59
|
+
} catch (seedErr) {
|
|
60
|
+
log.warn("find_similar cold-start seed failed", {
|
|
61
|
+
error: seedErr instanceof Error ? seedErr.message : String(seedErr)
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
} catch (parseErr) {
|
|
67
|
+
log.warn("find_similar cold-start url parse failed", {
|
|
68
|
+
error: parseErr instanceof Error ? parseErr.message : String(parseErr)
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
const out = await findSimilar(sanitizedInput, engines, router, backendStatus);
|
|
73
|
+
await attachEvidence(out, input);
|
|
74
|
+
if (cacheSeeded) out.cache_seeded = true;
|
|
75
|
+
if (out.error) {
|
|
76
|
+
return {
|
|
77
|
+
ok: false,
|
|
78
|
+
error: out.error,
|
|
79
|
+
error_reason: out.error,
|
|
80
|
+
stage: "find_similar"
|
|
81
|
+
};
|
|
82
|
+
}
|
|
83
|
+
return { ok: true, data: out };
|
|
84
|
+
} catch (err) {
|
|
85
|
+
log.error("handleFindSimilar failed", { error: String(err) });
|
|
86
|
+
return {
|
|
87
|
+
ok: false,
|
|
88
|
+
error: "find_similar_failed",
|
|
89
|
+
error_reason: `find_similar handler error: ${err instanceof Error ? err.message : String(err)}`,
|
|
90
|
+
stage: "find_similar"
|
|
91
|
+
};
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
async function attachEvidence(out, input) {
|
|
95
|
+
if (out.results.length === 0) return;
|
|
96
|
+
const includeFull = input.include_full_markdown ?? false;
|
|
97
|
+
const maxTokensOut = input.max_tokens_out ?? DEFAULT_MAX_TOKENS_OUT;
|
|
98
|
+
const query = input.concept?.trim() || input.url?.trim() || out.results[0].title;
|
|
99
|
+
const collected = [];
|
|
100
|
+
for (const r of out.results) {
|
|
101
|
+
if (!r.markdown) continue;
|
|
102
|
+
const evs = await buildEvidenceFromMarkdown(query, r.title, r.url, r.markdown, {
|
|
103
|
+
maxItems: 1
|
|
104
|
+
});
|
|
105
|
+
collected.push(...evs);
|
|
106
|
+
}
|
|
107
|
+
const budgeted = applyTokenBudget(collected, maxTokensOut);
|
|
108
|
+
if (budgeted.length > 0) out.evidence = budgeted;
|
|
109
|
+
if (!includeFull) {
|
|
110
|
+
for (const r of out.results) {
|
|
111
|
+
r.markdown = "";
|
|
112
|
+
}
|
|
113
|
+
} else {
|
|
114
|
+
applyAggregateMarkdownBudget(
|
|
115
|
+
out.results,
|
|
116
|
+
(r) => r.markdown ?? "",
|
|
117
|
+
(r, body) => {
|
|
118
|
+
r.markdown = body;
|
|
119
|
+
},
|
|
120
|
+
{ maxTokensOut }
|
|
121
|
+
);
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
export {
|
|
125
|
+
handleFindSimilar
|
|
126
|
+
};
|
|
127
|
+
//# sourceMappingURL=find-similar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/tools/find-similar.ts"],"sourcesContent":["import type {\n FindSimilarInput,\n FindSimilarOutput,\n SearchEngine,\n EvidenceItem,\n StageResult,\n} from '../types.js';\nimport type { SmartRouter } from '../fetch/router.js';\nimport type { BackendStatus } from '../server/backend-status.js';\nimport { findSimilar } from '../search/find-similar.js';\nimport {\n buildEvidenceFromMarkdown,\n applyTokenBudget,\n applyAggregateMarkdownBudget,\n} from '../search/evidence.js';\nimport * as cacheStore from '../cache/store.js';\nimport * as searchTool from './search.js';\nimport { createLogger } from '../logger.js';\n\nconst log = createLogger('search');\n\nconst MAX_RESULTS_CAP = 50;\nconst DEFAULT_MAX_TOKENS_OUT = 4000;\n\nexport async function handleFindSimilar(\n input: FindSimilarInput,\n engines: SearchEngine[],\n router: SmartRouter,\n backendStatus?: BackendStatus,\n): Promise<StageResult<FindSimilarOutput>> {\n try {\n const url = input.url?.trim();\n const concept = input.concept?.trim();\n\n if (!url && !concept) {\n return {\n ok: false,\n error: 'invalid_input',\n error_reason: 'Either url or concept must be provided',\n stage: 'find_similar',\n };\n }\n\n const sanitizedInput: FindSimilarInput = {\n ...input,\n max_results: input.max_results\n ? Math.min(input.max_results, MAX_RESULTS_CAP)\n : undefined,\n };\n\n log.info('find_similar request', {\n hasUrl: !!url,\n hasConcept: !!concept,\n maxResults: sanitizedInput.max_results,\n includeCache: sanitizedInput.include_cache,\n includeWeb: sanitizedInput.include_web,\n });\n\n let cacheSeeded = false;\n if (url) {\n try {\n const u = new URL(url);\n const host = u.hostname;\n const cachedCount = cacheStore.countCachedUrlsForDomain(host);\n if (cachedCount < 5) {\n const rawSeg = u.pathname.split('/').filter(Boolean).pop() ?? '';\n let lastSeg = rawSeg;\n try { lastSeg = decodeURIComponent(rawSeg); } catch { /* leave raw */ }\n const seedQuery = (\n lastSeg.replace(/[-_]/g, ' ') +\n ' ' +\n host.replace(/^www\\./, '').split('.')[0]\n ).trim();\n if (seedQuery.length > 0) {\n try {\n await searchTool.handleSearch(\n { query: seedQuery },\n engines,\n router,\n backendStatus,\n );\n cacheSeeded = true;\n } catch (seedErr) {\n log.warn('find_similar cold-start seed failed', {\n error: seedErr instanceof Error ? seedErr.message : String(seedErr),\n });\n }\n }\n }\n } catch (parseErr) {\n log.warn('find_similar cold-start url parse failed', {\n error: parseErr instanceof Error ? parseErr.message : String(parseErr),\n });\n }\n }\n\n const out = await findSimilar(sanitizedInput, engines, router, backendStatus);\n await attachEvidence(out, input);\n if (cacheSeeded) out.cache_seeded = true;\n if (out.error) {\n return {\n ok: false,\n error: out.error,\n error_reason: out.error,\n stage: 'find_similar',\n };\n }\n return { ok: true, data: out };\n } catch (err) {\n log.error('handleFindSimilar failed', { error: String(err) });\n return {\n ok: false,\n error: 'find_similar_failed',\n error_reason: `find_similar handler error: ${err instanceof Error ? err.message : String(err)}`,\n stage: 'find_similar',\n };\n }\n}\n\nasync function attachEvidence(\n out: FindSimilarOutput,\n input: FindSimilarInput,\n): Promise<void> {\n if (out.results.length === 0) return;\n const includeFull = input.include_full_markdown ?? false;\n const maxTokensOut = input.max_tokens_out ?? DEFAULT_MAX_TOKENS_OUT;\n const query = input.concept?.trim() || input.url?.trim() || out.results[0].title;\n\n const collected: EvidenceItem[] = [];\n for (const r of out.results) {\n if (!r.markdown) continue;\n const evs = await buildEvidenceFromMarkdown(query, r.title, r.url, r.markdown, {\n maxItems: 1,\n });\n collected.push(...evs);\n }\n\n const budgeted = applyTokenBudget(collected, maxTokensOut);\n if (budgeted.length > 0) out.evidence = budgeted;\n\n if (!includeFull) {\n for (const r of out.results) {\n r.markdown = '';\n }\n } else {\n applyAggregateMarkdownBudget(\n out.results,\n (r) => r.markdown ?? '',\n (r, body) => { r.markdown = body; },\n { maxTokensOut },\n );\n }\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { ResearchInput, ResearchOutput, SearchEngine, StageResult } from '../types.js';
|
|
2
|
+
import type { SmartRouter } from '../fetch/router.js';
|
|
3
|
+
import type { SamplingCapableServer } from '../search/sampling.js';
|
|
4
|
+
export declare function handleResearch(input: ResearchInput, engines: SearchEngine[], router: SmartRouter, _backendStatus?: unknown, server?: SamplingCapableServer): Promise<StageResult<ResearchOutput>>;
|
|
5
|
+
//# sourceMappingURL=research.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"research.d.ts","sourceRoot":"","sources":["../../src/tools/research.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAEV,aAAa,EACb,cAAc,EACd,YAAY,EACZ,WAAW,EACZ,MAAM,aAAa,CAAC;AACrB,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAQnE,wBAAsB,cAAc,CAClC,KAAK,EAAE,aAAa,EACpB,OAAO,EAAE,YAAY,EAAE,EACvB,MAAM,EAAE,WAAW,EACnB,cAAc,CAAC,EAAE,OAAO,EACxB,MAAM,CAAC,EAAE,qBAAqB,GAC7B,OAAO,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC,CAkDtC"}
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
import { createLogger } from "../logger.js";
|
|
2
|
+
import { runResearchPipeline } from "../research/pipeline.js";
|
|
3
|
+
import {
|
|
4
|
+
buildEvidenceFromMarkdown,
|
|
5
|
+
applyTokenBudget,
|
|
6
|
+
applyAggregateMarkdownBudget
|
|
7
|
+
} from "../search/evidence.js";
|
|
8
|
+
import { applyOutputBudget } from "../search/truncate.js";
|
|
9
|
+
const log = createLogger("research");
|
|
10
|
+
const VALID_DEPTHS = /* @__PURE__ */ new Set(["quick", "standard", "comprehensive"]);
|
|
11
|
+
const MAX_SOURCES_LIMIT = 50;
|
|
12
|
+
const DEFAULT_MAX_TOKENS_OUT = 4e3;
|
|
13
|
+
async function handleResearch(input, engines, router, _backendStatus, server) {
|
|
14
|
+
try {
|
|
15
|
+
if (!input.question || typeof input.question !== "string" || input.question.trim().length === 0) {
|
|
16
|
+
return invalidInput("question is required and must be a non-empty string");
|
|
17
|
+
}
|
|
18
|
+
if (input.depth && !VALID_DEPTHS.has(input.depth)) {
|
|
19
|
+
return invalidInput(
|
|
20
|
+
`depth must be one of: quick, standard, comprehensive. Got: "${input.depth}"`
|
|
21
|
+
);
|
|
22
|
+
}
|
|
23
|
+
if (input.max_sources !== void 0) {
|
|
24
|
+
if (typeof input.max_sources !== "number" || input.max_sources < 1) {
|
|
25
|
+
return invalidInput("max_sources must be a positive number");
|
|
26
|
+
}
|
|
27
|
+
if (input.max_sources > MAX_SOURCES_LIMIT) {
|
|
28
|
+
return invalidInput(`max_sources must be at most ${MAX_SOURCES_LIMIT}`);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
log.info("research request received", {
|
|
32
|
+
question: input.question.slice(0, 100),
|
|
33
|
+
depth: input.depth ?? "standard",
|
|
34
|
+
max_sources: input.max_sources
|
|
35
|
+
});
|
|
36
|
+
const out = await runResearchPipeline(input, engines, router, server);
|
|
37
|
+
await attachEvidence(out, input);
|
|
38
|
+
if (out.error) {
|
|
39
|
+
return {
|
|
40
|
+
ok: false,
|
|
41
|
+
error: out.error,
|
|
42
|
+
error_reason: out.error,
|
|
43
|
+
stage: "research"
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
return { ok: true, data: out };
|
|
47
|
+
} catch (err) {
|
|
48
|
+
log.error("research handler failed", {
|
|
49
|
+
question: input.question?.slice(0, 100),
|
|
50
|
+
error: err instanceof Error ? err.message : String(err)
|
|
51
|
+
});
|
|
52
|
+
return {
|
|
53
|
+
ok: false,
|
|
54
|
+
error: "research_failed",
|
|
55
|
+
error_reason: err instanceof Error ? err.message : String(err),
|
|
56
|
+
stage: "research"
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
async function attachEvidence(out, input) {
|
|
61
|
+
if (input.max_tokens_out !== void 0 && out.report) {
|
|
62
|
+
out.report = applyOutputBudget(out.report, { maxTokensOut: input.max_tokens_out });
|
|
63
|
+
}
|
|
64
|
+
if (out.sources.length === 0) return;
|
|
65
|
+
const includeFull = input.include_full_markdown ?? false;
|
|
66
|
+
const maxTokensOut = input.max_tokens_out ?? DEFAULT_MAX_TOKENS_OUT;
|
|
67
|
+
const collected = [];
|
|
68
|
+
for (const s of out.sources) {
|
|
69
|
+
if (!s.markdown_content) continue;
|
|
70
|
+
const evs = await buildEvidenceFromMarkdown(
|
|
71
|
+
input.question,
|
|
72
|
+
s.title,
|
|
73
|
+
s.url,
|
|
74
|
+
s.markdown_content,
|
|
75
|
+
{ maxItems: 1 }
|
|
76
|
+
);
|
|
77
|
+
collected.push(...evs);
|
|
78
|
+
}
|
|
79
|
+
const budgeted = applyTokenBudget(collected, maxTokensOut);
|
|
80
|
+
if (budgeted.length > 0) out.evidence = budgeted;
|
|
81
|
+
if (!includeFull) {
|
|
82
|
+
for (const s of out.sources) {
|
|
83
|
+
s.markdown_content = "";
|
|
84
|
+
}
|
|
85
|
+
} else {
|
|
86
|
+
applyAggregateMarkdownBudget(
|
|
87
|
+
out.sources,
|
|
88
|
+
(s) => s.markdown_content ?? "",
|
|
89
|
+
(s, body) => {
|
|
90
|
+
s.markdown_content = body;
|
|
91
|
+
},
|
|
92
|
+
{ maxTokensOut }
|
|
93
|
+
);
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
function invalidInput(error_reason) {
|
|
97
|
+
return {
|
|
98
|
+
ok: false,
|
|
99
|
+
error: "invalid_input",
|
|
100
|
+
error_reason,
|
|
101
|
+
stage: "research"
|
|
102
|
+
};
|
|
103
|
+
}
|
|
104
|
+
export {
|
|
105
|
+
handleResearch
|
|
106
|
+
};
|
|
107
|
+
//# sourceMappingURL=research.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/tools/research.ts"],"sourcesContent":["import { createLogger } from '../logger.js';\nimport { runResearchPipeline } from '../research/pipeline.js';\nimport {\n buildEvidenceFromMarkdown,\n applyTokenBudget,\n applyAggregateMarkdownBudget,\n} from '../search/evidence.js';\nimport { applyOutputBudget } from '../search/truncate.js';\nimport type {\n EvidenceItem,\n ResearchInput,\n ResearchOutput,\n SearchEngine,\n StageResult,\n} from '../types.js';\nimport type { SmartRouter } from '../fetch/router.js';\nimport type { SamplingCapableServer } from '../search/sampling.js';\n\nconst log = createLogger('research');\n\nconst VALID_DEPTHS = new Set(['quick', 'standard', 'comprehensive']);\nconst MAX_SOURCES_LIMIT = 50;\nconst DEFAULT_MAX_TOKENS_OUT = 4000;\n\nexport async function handleResearch(\n input: ResearchInput,\n engines: SearchEngine[],\n router: SmartRouter,\n _backendStatus?: unknown,\n server?: SamplingCapableServer,\n): Promise<StageResult<ResearchOutput>> {\n try {\n if (!input.question || typeof input.question !== 'string' || input.question.trim().length === 0) {\n return invalidInput('question is required and must be a non-empty string');\n }\n\n if (input.depth && !VALID_DEPTHS.has(input.depth)) {\n return invalidInput(\n `depth must be one of: quick, standard, comprehensive. Got: \"${input.depth}\"`,\n );\n }\n\n if (input.max_sources !== undefined) {\n if (typeof input.max_sources !== 'number' || input.max_sources < 1) {\n return invalidInput('max_sources must be a positive number');\n }\n if (input.max_sources > MAX_SOURCES_LIMIT) {\n return invalidInput(`max_sources must be at most ${MAX_SOURCES_LIMIT}`);\n }\n }\n\n log.info('research request received', {\n question: input.question.slice(0, 100),\n depth: input.depth ?? 'standard',\n max_sources: input.max_sources,\n });\n\n const out = await runResearchPipeline(input, engines, router, server);\n await attachEvidence(out, input);\n if (out.error) {\n return {\n ok: false,\n error: out.error,\n error_reason: out.error,\n stage: 'research',\n };\n }\n return { ok: true, data: out };\n } catch (err) {\n log.error('research handler failed', {\n question: input.question?.slice(0, 100),\n error: err instanceof Error ? err.message : String(err),\n });\n return {\n ok: false,\n error: 'research_failed',\n error_reason: err instanceof Error ? err.message : String(err),\n stage: 'research',\n };\n }\n}\n\nasync function attachEvidence(out: ResearchOutput, input: ResearchInput): Promise<void> {\n // Always honour max_tokens_out for the report text, regardless of sources.\n if (input.max_tokens_out !== undefined && out.report) {\n out.report = applyOutputBudget(out.report, { maxTokensOut: input.max_tokens_out });\n }\n\n if (out.sources.length === 0) return;\n const includeFull = input.include_full_markdown ?? false;\n const maxTokensOut = input.max_tokens_out ?? DEFAULT_MAX_TOKENS_OUT;\n\n const collected: EvidenceItem[] = [];\n for (const s of out.sources) {\n if (!s.markdown_content) continue;\n const evs = await buildEvidenceFromMarkdown(\n input.question,\n s.title,\n s.url,\n s.markdown_content,\n { maxItems: 1 },\n );\n collected.push(...evs);\n }\n\n const budgeted = applyTokenBudget(collected, maxTokensOut);\n if (budgeted.length > 0) out.evidence = budgeted;\n\n if (!includeFull) {\n for (const s of out.sources) {\n s.markdown_content = '';\n }\n } else {\n applyAggregateMarkdownBudget(\n out.sources,\n (s) => s.markdown_content ?? '',\n (s, body) => { s.markdown_content = body; },\n { maxTokensOut },\n );\n }\n}\n\nfunction invalidInput(error_reason: string): StageResult<ResearchOutput> {\n return {\n ok: false,\n error: 'invalid_input',\n error_reason,\n stage: 'research',\n };\n}\n"],"mappings":"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","names":[]}
|
package/dist/tools/search.d.ts
CHANGED
|
@@ -1,4 +1,12 @@
|
|
|
1
|
-
import type { SearchInput, SearchOutput, SearchEngine } from '../types.js';
|
|
1
|
+
import type { SearchInput, SearchOutput, SearchEngine, ProgressCallback, StageResult } from '../types.js';
|
|
2
2
|
import type { SmartRouter } from '../fetch/router.js';
|
|
3
|
-
|
|
3
|
+
import type { BackendStatus } from '../server/backend-status.js';
|
|
4
|
+
import type { SamplingCapableServer } from '../search/sampling.js';
|
|
5
|
+
/**
|
|
6
|
+
* Thin handler — validates wiring args and delegates to the selected search
|
|
7
|
+
* provider (legacy SearXNG by default, V1 stub when `WIGOLO_SEARCH=v1`).
|
|
8
|
+
*
|
|
9
|
+
* All orchestration logic lives in `src/search/legacy/searxng-orchestrator.ts`.
|
|
10
|
+
*/
|
|
11
|
+
export declare function handleSearch(input: SearchInput, engines: SearchEngine[], router: SmartRouter, backendStatus?: BackendStatus, samplingServer?: SamplingCapableServer, onProgress?: ProgressCallback): Promise<StageResult<SearchOutput>>;
|
|
4
12
|
//# sourceMappingURL=search.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"search.d.ts","sourceRoot":"","sources":["../../src/tools/search.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"search.d.ts","sourceRoot":"","sources":["../../src/tools/search.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,WAAW,EACX,YAAY,EACZ,YAAY,EACZ,gBAAgB,EAChB,WAAW,EACZ,MAAM,aAAa,CAAC;AACrB,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;AACjE,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAGnE;;;;;GAKG;AACH,wBAAsB,YAAY,CAChC,KAAK,EAAE,WAAW,EAClB,OAAO,EAAE,YAAY,EAAE,EACvB,MAAM,EAAE,WAAW,EACnB,aAAa,CAAC,EAAE,aAAa,EAC7B,cAAc,CAAC,EAAE,qBAAqB,EACtC,UAAU,CAAC,EAAE,gBAAgB,GAC5B,OAAO,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC,CASpC"}
|