ruflo 3.10.45 → 3.11.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +412 -412
- package/bin/ruflo.js +77 -77
- package/package.json +113 -113
- package/src/chat-ui/Dockerfile +25 -25
- package/src/chat-ui/patch-mcp-url-safety.sh +28 -28
- package/src/config/config.example.json +76 -76
- package/src/mcp-bridge/Dockerfile +45 -45
- package/src/mcp-bridge/index.js +1692 -1692
- package/src/mcp-bridge/mcp-stdio-kernel.js +159 -159
- package/src/mcp-bridge/package.json +17 -17
- package/src/mcp-bridge/test-harness.js +470 -470
- package/src/nginx/Dockerfile +10 -10
- package/src/nginx/nginx.conf +67 -67
- package/src/nginx/static/favicon-dark.svg +4 -4
- package/src/nginx/static/favicon.svg +4 -4
- package/src/nginx/static/icon.svg +5 -5
- package/src/nginx/static/logo.svg +9 -9
- package/src/nginx/static/manifest.json +22 -22
- package/src/nginx/static/welcome.js +184 -184
- package/src/ruvocal/.claude/skills/add-model-descriptions/SKILL.md +73 -73
- package/src/ruvocal/.claude-flow/daemon-state.json +135 -0
- package/src/ruvocal/.claude-flow/data/pending-insights.jsonl +0 -0
- package/src/ruvocal/.claude-flow/data/ranked-context.json +5 -0
- package/src/ruvocal/.claude-flow/logs/daemon.log +31 -0
- package/src/ruvocal/.claude-flow/logs/headless/audit_1777949411822_juxau0_prompt.log +989 -0
- package/src/ruvocal/.claude-flow/logs/headless/audit_1777949411822_juxau0_result.log +67 -0
- package/src/ruvocal/.claude-flow/logs/headless/audit_1777950042278_jvj5xq_prompt.log +989 -0
- package/src/ruvocal/.claude-flow/logs/headless/audit_1777950042278_jvj5xq_result.log +93 -0
- package/src/ruvocal/.claude-flow/logs/headless/optimize_1777949531823_yt5yc2_prompt.log +1498 -0
- package/src/ruvocal/.claude-flow/logs/headless/optimize_1777949531823_yt5yc2_result.log +93 -0
- package/src/ruvocal/.claude-flow/logs/headless/testgaps_1777949771821_elw1j4_prompt.log +1498 -0
- package/src/ruvocal/.claude-flow/logs/headless/testgaps_1777949771821_elw1j4_result.log +100 -0
- package/src/ruvocal/.claude-flow/metrics/codebase-map.json +11 -0
- package/src/ruvocal/.claude-flow/metrics/consolidation.json +6 -0
- package/src/ruvocal/.claude-flow/neural/stats.json +6 -0
- package/src/ruvocal/.claude-flow/sessions/current.json +13 -0
- package/src/ruvocal/.devcontainer/Dockerfile +9 -9
- package/src/ruvocal/.devcontainer/devcontainer.json +36 -36
- package/src/ruvocal/.dockerignore +16 -16
- package/src/ruvocal/.eslintignore +13 -13
- package/src/ruvocal/.eslintrc.cjs +45 -45
- package/src/ruvocal/.gcloudignore +18 -18
- package/src/ruvocal/.github/ISSUE_TEMPLATE/bug-report--chat-ui-.md +43 -43
- package/src/ruvocal/.github/ISSUE_TEMPLATE/config-support.md +9 -9
- package/src/ruvocal/.github/ISSUE_TEMPLATE/feature-request--chat-ui-.md +17 -17
- package/src/ruvocal/.github/ISSUE_TEMPLATE/huggingchat.md +11 -11
- package/src/ruvocal/.github/release.yml +16 -16
- package/src/ruvocal/.github/workflows/build-docs.yml +18 -18
- package/src/ruvocal/.github/workflows/build-image.yml +142 -142
- package/src/ruvocal/.github/workflows/build-pr-docs.yml +20 -20
- package/src/ruvocal/.github/workflows/deploy-dev.yml +63 -63
- package/src/ruvocal/.github/workflows/deploy-prod.yml +78 -78
- package/src/ruvocal/.github/workflows/lint-and-test.yml +84 -84
- package/src/ruvocal/.github/workflows/slugify.yaml +72 -72
- package/src/ruvocal/.github/workflows/trufflehog.yml +17 -17
- package/src/ruvocal/.github/workflows/upload-pr-documentation.yml +16 -16
- package/src/ruvocal/.husky/lint-stage-config.js +4 -4
- package/src/ruvocal/.husky/pre-commit +2 -2
- package/src/ruvocal/.prettierignore +14 -14
- package/src/ruvocal/.prettierrc +7 -7
- package/src/ruvocal/.swarm/attestation.db +0 -0
- package/src/ruvocal/.swarm/hnsw.index +0 -0
- package/src/ruvocal/.swarm/hnsw.metadata.json +1 -0
- package/src/ruvocal/.swarm/memory.db +0 -0
- package/src/ruvocal/.swarm/schema.sql +305 -0
- package/src/ruvocal/CLAUDE.md +126 -126
- package/src/ruvocal/Dockerfile +96 -96
- package/src/ruvocal/LICENSE +202 -202
- package/src/ruvocal/PRIVACY.md +41 -41
- package/src/ruvocal/README.md +164 -164
- package/src/ruvocal/chart/Chart.yaml +5 -5
- package/src/ruvocal/chart/env/dev.yaml +260 -260
- package/src/ruvocal/chart/env/prod.yaml +273 -273
- package/src/ruvocal/chart/templates/_helpers.tpl +22 -22
- package/src/ruvocal/chart/templates/config.yaml +10 -10
- package/src/ruvocal/chart/templates/deployment.yaml +81 -81
- package/src/ruvocal/chart/templates/hpa.yaml +45 -45
- package/src/ruvocal/chart/templates/infisical.yaml +24 -24
- package/src/ruvocal/chart/templates/ingress-internal.yaml +32 -32
- package/src/ruvocal/chart/templates/ingress.yaml +32 -32
- package/src/ruvocal/chart/templates/network-policy.yaml +36 -36
- package/src/ruvocal/chart/templates/service-account.yaml +13 -13
- package/src/ruvocal/chart/templates/service-monitor.yaml +17 -17
- package/src/ruvocal/chart/templates/service.yaml +21 -21
- package/src/ruvocal/chart/values.yaml +73 -73
- package/src/ruvocal/cloudbuild.yaml +68 -68
- package/src/ruvocal/config/branding.env.example +19 -19
- package/src/ruvocal/docker-compose.yml +21 -21
- package/src/ruvocal/docs/adr/ADR-029-HUGGINGFACE-CHAT-UI-CLOUD-RUN.md +1236 -1236
- package/src/ruvocal/docs/adr/ADR-033-RUVECTOR-RUFLO-MCP-INTEGRATION.md +111 -111
- package/src/ruvocal/docs/adr/ADR-034-OPTIONAL-MCP-BACKENDS.md +117 -117
- package/src/ruvocal/docs/adr/ADR-035-MCP-TOOL-GROUPS.md +186 -186
- package/src/ruvocal/docs/adr/ADR-037-AUTOPILOT-CHAT-MODE.md +1500 -1500
- package/src/ruvocal/docs/adr/ADR-038-RUVOCAL-FORK.md +286 -286
- package/src/ruvocal/docs/source/_toctree.yml +30 -30
- package/src/ruvocal/docs/source/configuration/common-issues.md +38 -38
- package/src/ruvocal/docs/source/configuration/llm-router.md +105 -105
- package/src/ruvocal/docs/source/configuration/mcp-tools.md +84 -84
- package/src/ruvocal/docs/source/configuration/metrics.md +9 -9
- package/src/ruvocal/docs/source/configuration/open-id.md +57 -57
- package/src/ruvocal/docs/source/configuration/overview.md +89 -89
- package/src/ruvocal/docs/source/configuration/theming.md +20 -20
- package/src/ruvocal/docs/source/developing/architecture.md +48 -48
- package/src/ruvocal/docs/source/index.md +53 -53
- package/src/ruvocal/docs/source/installation/docker.md +43 -43
- package/src/ruvocal/docs/source/installation/helm.md +43 -43
- package/src/ruvocal/docs/source/installation/local.md +62 -62
- package/src/ruvocal/entrypoint.sh +18 -18
- package/src/ruvocal/mcp-bridge/Dockerfile +45 -45
- package/src/ruvocal/mcp-bridge/cloudbuild.yaml +49 -49
- package/src/ruvocal/mcp-bridge/index.js +1902 -1902
- package/src/ruvocal/mcp-bridge/mcp-stdio-kernel.js +159 -159
- package/src/ruvocal/mcp-bridge/package-lock.json +762 -762
- package/src/ruvocal/mcp-bridge/package.json +17 -17
- package/src/ruvocal/mcp-bridge/test-harness.js +470 -470
- package/src/ruvocal/package-lock.json +11741 -11741
- package/src/ruvocal/package.json +121 -121
- package/src/ruvocal/postcss.config.js +6 -6
- package/src/ruvocal/rvf.manifest.json +204 -204
- package/src/ruvocal/scripts/config.ts +64 -64
- package/src/ruvocal/scripts/generate-welcome.mjs +181 -181
- package/src/ruvocal/scripts/populate.ts +288 -288
- package/src/ruvocal/scripts/samples.txt +194 -194
- package/src/ruvocal/scripts/setups/vitest-setup-server.ts +44 -44
- package/src/ruvocal/scripts/updateLocalEnv.ts +48 -48
- package/src/ruvocal/src/ambient.d.ts +7 -7
- package/src/ruvocal/src/app.d.ts +29 -29
- package/src/ruvocal/src/app.html +53 -53
- package/src/ruvocal/src/hooks.server.ts +32 -32
- package/src/ruvocal/src/hooks.ts +6 -6
- package/src/ruvocal/src/lib/APIClient.ts +148 -148
- package/src/ruvocal/src/lib/actions/clickOutside.ts +18 -18
- package/src/ruvocal/src/lib/actions/snapScrollToBottom.ts +346 -346
- package/src/ruvocal/src/lib/buildPrompt.ts +33 -33
- package/src/ruvocal/src/lib/components/AnnouncementBanner.svelte +20 -20
- package/src/ruvocal/src/lib/components/BackgroundGenerationPoller.svelte +168 -168
- package/src/ruvocal/src/lib/components/CodeBlock.svelte +73 -73
- package/src/ruvocal/src/lib/components/CopyToClipBoardBtn.svelte +92 -92
- package/src/ruvocal/src/lib/components/DeleteConversationModal.svelte +75 -75
- package/src/ruvocal/src/lib/components/EditConversationModal.svelte +100 -100
- package/src/ruvocal/src/lib/components/ExpandNavigation.svelte +22 -22
- package/src/ruvocal/src/lib/components/FoundationBackground.svelte +242 -242
- package/src/ruvocal/src/lib/components/HoverTooltip.svelte +44 -44
- package/src/ruvocal/src/lib/components/HtmlPreviewModal.svelte +143 -143
- package/src/ruvocal/src/lib/components/InfiniteScroll.svelte +50 -50
- package/src/ruvocal/src/lib/components/MobileNav.svelte +300 -300
- package/src/ruvocal/src/lib/components/Modal.svelte +115 -115
- package/src/ruvocal/src/lib/components/ModelCardMetadata.svelte +71 -71
- package/src/ruvocal/src/lib/components/NavConversationItem.svelte +151 -151
- package/src/ruvocal/src/lib/components/NavMenu.svelte +313 -313
- package/src/ruvocal/src/lib/components/Pagination.svelte +97 -97
- package/src/ruvocal/src/lib/components/PaginationArrow.svelte +27 -27
- package/src/ruvocal/src/lib/components/Portal.svelte +24 -24
- package/src/ruvocal/src/lib/components/RetryBtn.svelte +18 -18
- package/src/ruvocal/src/lib/components/RuFloUniverse.svelte +185 -185
- package/src/ruvocal/src/lib/components/RufloHelpModal.svelte +411 -411
- package/src/ruvocal/src/lib/components/ScrollToBottomBtn.svelte +47 -47
- package/src/ruvocal/src/lib/components/ScrollToPreviousBtn.svelte +77 -77
- package/src/ruvocal/src/lib/components/ShareConversationModal.svelte +182 -182
- package/src/ruvocal/src/lib/components/StopGeneratingBtn.svelte +69 -69
- package/src/ruvocal/src/lib/components/SubscribeModal.svelte +87 -87
- package/src/ruvocal/src/lib/components/Switch.svelte +36 -36
- package/src/ruvocal/src/lib/components/SystemPromptModal.svelte +44 -44
- package/src/ruvocal/src/lib/components/Toast.svelte +27 -27
- package/src/ruvocal/src/lib/components/Tooltip.svelte +30 -30
- package/src/ruvocal/src/lib/components/WelcomeModal.svelte +46 -46
- package/src/ruvocal/src/lib/components/chat/Alternatives.svelte +77 -77
- package/src/ruvocal/src/lib/components/chat/BlockWrapper.svelte +72 -72
- package/src/ruvocal/src/lib/components/chat/ChatInput.svelte +490 -490
- package/src/ruvocal/src/lib/components/chat/ChatIntroduction.svelte +123 -123
- package/src/ruvocal/src/lib/components/chat/ChatMessage.svelte +548 -548
- package/src/ruvocal/src/lib/components/chat/ChatWindow.svelte +1057 -1057
- package/src/ruvocal/src/lib/components/chat/FileDropzone.svelte +92 -92
- package/src/ruvocal/src/lib/components/chat/ImageLightbox.svelte +66 -66
- package/src/ruvocal/src/lib/components/chat/MarkdownBlock.svelte +23 -23
- package/src/ruvocal/src/lib/components/chat/MarkdownRenderer.svelte +69 -69
- package/src/ruvocal/src/lib/components/chat/MarkdownRenderer.svelte.test.ts +58 -58
- package/src/ruvocal/src/lib/components/chat/MessageAvatar.svelte +103 -103
- package/src/ruvocal/src/lib/components/chat/ModelSwitch.svelte +64 -64
- package/src/ruvocal/src/lib/components/chat/OpenReasoningResults.svelte +81 -81
- package/src/ruvocal/src/lib/components/chat/TaskGroup.svelte +88 -88
- package/src/ruvocal/src/lib/components/chat/ToolUpdate.svelte +273 -273
- package/src/ruvocal/src/lib/components/chat/UploadedFile.svelte +253 -253
- package/src/ruvocal/src/lib/components/chat/UrlFetchModal.svelte +203 -203
- package/src/ruvocal/src/lib/components/chat/VoiceRecorder.svelte +214 -214
- package/src/ruvocal/src/lib/components/icons/IconBurger.svelte +20 -20
- package/src/ruvocal/src/lib/components/icons/IconCheap.svelte +20 -20
- package/src/ruvocal/src/lib/components/icons/IconChevron.svelte +24 -24
- package/src/ruvocal/src/lib/components/icons/IconDazzled.svelte +40 -40
- package/src/ruvocal/src/lib/components/icons/IconFast.svelte +20 -20
- package/src/ruvocal/src/lib/components/icons/IconLoading.svelte +22 -22
- package/src/ruvocal/src/lib/components/icons/IconMCP.svelte +28 -28
- package/src/ruvocal/src/lib/components/icons/IconMoon.svelte +21 -21
- package/src/ruvocal/src/lib/components/icons/IconNew.svelte +20 -20
- package/src/ruvocal/src/lib/components/icons/IconOmni.svelte +90 -90
- package/src/ruvocal/src/lib/components/icons/IconPaperclip.svelte +24 -24
- package/src/ruvocal/src/lib/components/icons/IconPro.svelte +37 -37
- package/src/ruvocal/src/lib/components/icons/IconShare.svelte +21 -21
- package/src/ruvocal/src/lib/components/icons/IconSun.svelte +93 -93
- package/src/ruvocal/src/lib/components/icons/Logo.svelte +68 -68
- package/src/ruvocal/src/lib/components/icons/LogoHuggingFaceBorderless.svelte +54 -54
- package/src/ruvocal/src/lib/components/mcp/AddServerForm.svelte +250 -250
- package/src/ruvocal/src/lib/components/mcp/MCPServerManager.svelte +185 -185
- package/src/ruvocal/src/lib/components/mcp/ServerCard.svelte +203 -203
- package/src/ruvocal/src/lib/components/players/AudioPlayer.svelte +82 -82
- package/src/ruvocal/src/lib/components/voice/AudioWaveform.svelte +96 -96
- package/src/ruvocal/src/lib/components/wasm/GalleryPanel.svelte +357 -357
- package/src/ruvocal/src/lib/constants/mcpExamples.ts +114 -114
- package/src/ruvocal/src/lib/constants/mime.ts +11 -11
- package/src/ruvocal/src/lib/constants/pagination.ts +1 -1
- package/src/ruvocal/src/lib/constants/publicSepToken.ts +1 -1
- package/src/ruvocal/src/lib/constants/routerExamples.ts +133 -133
- package/src/ruvocal/src/lib/constants/rvagentPresets.ts +206 -206
- package/src/ruvocal/src/lib/createShareLink.ts +27 -27
- package/src/ruvocal/src/lib/jobs/refresh-conversation-stats.ts +297 -297
- package/src/ruvocal/src/lib/migrations/lock.ts +56 -56
- package/src/ruvocal/src/lib/migrations/migrations.spec.ts +74 -74
- package/src/ruvocal/src/lib/migrations/migrations.ts +109 -109
- package/src/ruvocal/src/lib/migrations/routines/01-update-search-assistants.ts +50 -50
- package/src/ruvocal/src/lib/migrations/routines/02-update-assistants-models.ts +48 -48
- package/src/ruvocal/src/lib/migrations/routines/04-update-message-updates.ts +151 -151
- package/src/ruvocal/src/lib/migrations/routines/05-update-message-files.ts +56 -56
- package/src/ruvocal/src/lib/migrations/routines/06-trim-message-updates.ts +56 -56
- package/src/ruvocal/src/lib/migrations/routines/08-update-featured-to-review.ts +32 -32
- package/src/ruvocal/src/lib/migrations/routines/09-delete-empty-conversations.spec.ts +214 -214
- package/src/ruvocal/src/lib/migrations/routines/09-delete-empty-conversations.ts +88 -88
- package/src/ruvocal/src/lib/migrations/routines/10-update-reports-assistantid.ts +29 -29
- package/src/ruvocal/src/lib/migrations/routines/index.ts +15 -15
- package/src/ruvocal/src/lib/server/__tests__/conversation-stop-generating.spec.ts +103 -103
- package/src/ruvocal/src/lib/server/abortRegistry.ts +57 -57
- package/src/ruvocal/src/lib/server/abortedGenerations.ts +43 -43
- package/src/ruvocal/src/lib/server/adminToken.ts +62 -62
- package/src/ruvocal/src/lib/server/api/__tests__/conversations-id.spec.ts +296 -296
- package/src/ruvocal/src/lib/server/api/__tests__/conversations-message.spec.ts +216 -216
- package/src/ruvocal/src/lib/server/api/__tests__/conversations.spec.ts +235 -235
- package/src/ruvocal/src/lib/server/api/__tests__/misc.spec.ts +72 -72
- package/src/ruvocal/src/lib/server/api/__tests__/testHelpers.ts +86 -86
- package/src/ruvocal/src/lib/server/api/__tests__/user-reports.spec.ts +78 -78
- package/src/ruvocal/src/lib/server/api/__tests__/user.spec.ts +239 -239
- package/src/ruvocal/src/lib/server/api/types.ts +37 -37
- package/src/ruvocal/src/lib/server/api/utils/requireAuth.ts +22 -22
- package/src/ruvocal/src/lib/server/api/utils/resolveConversation.ts +69 -69
- package/src/ruvocal/src/lib/server/api/utils/resolveModel.ts +27 -27
- package/src/ruvocal/src/lib/server/api/utils/superjsonResponse.ts +15 -15
- package/src/ruvocal/src/lib/server/apiToken.ts +11 -11
- package/src/ruvocal/src/lib/server/auth.ts +554 -554
- package/src/ruvocal/src/lib/server/config.ts +187 -187
- package/src/ruvocal/src/lib/server/conversation.ts +83 -83
- package/src/ruvocal/src/lib/server/database/__tests__/rvf.spec.ts +709 -709
- package/src/ruvocal/src/lib/server/database/postgres.ts +700 -700
- package/src/ruvocal/src/lib/server/database/rvf.ts +1078 -1078
- package/src/ruvocal/src/lib/server/database.ts +145 -145
- package/src/ruvocal/src/lib/server/endpoints/document.ts +68 -68
- package/src/ruvocal/src/lib/server/endpoints/endpoints.ts +43 -43
- package/src/ruvocal/src/lib/server/endpoints/images.ts +211 -211
- package/src/ruvocal/src/lib/server/endpoints/openai/endpointOai.ts +266 -266
- package/src/ruvocal/src/lib/server/endpoints/openai/openAIChatToTextGenerationStream.ts +212 -212
- package/src/ruvocal/src/lib/server/endpoints/openai/openAICompletionToTextGenerationStream.ts +32 -32
- package/src/ruvocal/src/lib/server/endpoints/preprocessMessages.ts +61 -61
- package/src/ruvocal/src/lib/server/exitHandler.ts +59 -59
- package/src/ruvocal/src/lib/server/files/downloadFile.ts +34 -34
- package/src/ruvocal/src/lib/server/files/uploadFile.ts +29 -29
- package/src/ruvocal/src/lib/server/findRepoRoot.ts +13 -13
- package/src/ruvocal/src/lib/server/generateFromDefaultEndpoint.ts +46 -46
- package/src/ruvocal/src/lib/server/hooks/error.ts +37 -37
- package/src/ruvocal/src/lib/server/hooks/fetch.ts +22 -22
- package/src/ruvocal/src/lib/server/hooks/handle.ts +250 -250
- package/src/ruvocal/src/lib/server/hooks/init.ts +51 -51
- package/src/ruvocal/src/lib/server/isURLLocal.spec.ts +31 -31
- package/src/ruvocal/src/lib/server/isURLLocal.ts +74 -74
- package/src/ruvocal/src/lib/server/logger.ts +42 -42
- package/src/ruvocal/src/lib/server/mcp/clientPool.spec.ts +175 -175
- package/src/ruvocal/src/lib/server/mcp/hf.ts +32 -32
- package/src/ruvocal/src/lib/server/mcp/httpClient.ts +122 -122
- package/src/ruvocal/src/lib/server/mcp/registry.ts +76 -76
- package/src/ruvocal/src/lib/server/mcp/tools.ts +196 -196
- package/src/ruvocal/src/lib/server/metrics.ts +255 -255
- package/src/ruvocal/src/lib/server/models.ts +518 -518
- package/src/ruvocal/src/lib/server/requestContext.ts +55 -55
- package/src/ruvocal/src/lib/server/router/arch.ts +230 -230
- package/src/ruvocal/src/lib/server/router/endpoint.ts +316 -316
- package/src/ruvocal/src/lib/server/router/multimodal.ts +28 -28
- package/src/ruvocal/src/lib/server/router/policy.ts +49 -49
- package/src/ruvocal/src/lib/server/router/toolsRoute.ts +51 -51
- package/src/ruvocal/src/lib/server/router/types.ts +21 -21
- package/src/ruvocal/src/lib/server/sendSlack.ts +23 -23
- package/src/ruvocal/src/lib/server/textGeneration/generate.ts +258 -258
- package/src/ruvocal/src/lib/server/textGeneration/index.ts +96 -96
- package/src/ruvocal/src/lib/server/textGeneration/mcp/fileRefs.ts +155 -155
- package/src/ruvocal/src/lib/server/textGeneration/mcp/routerResolution.ts +108 -108
- package/src/ruvocal/src/lib/server/textGeneration/mcp/runMcpFlow.ts +831 -831
- package/src/ruvocal/src/lib/server/textGeneration/mcp/toolInvocation.ts +349 -349
- package/src/ruvocal/src/lib/server/textGeneration/mcp/wasmTools.test.ts +633 -633
- package/src/ruvocal/src/lib/server/textGeneration/reasoning.ts +23 -23
- package/src/ruvocal/src/lib/server/textGeneration/title.ts +83 -83
- package/src/ruvocal/src/lib/server/textGeneration/types.ts +28 -28
- package/src/ruvocal/src/lib/server/textGeneration/utils/prepareFiles.ts +88 -88
- package/src/ruvocal/src/lib/server/textGeneration/utils/routing.ts +21 -21
- package/src/ruvocal/src/lib/server/textGeneration/utils/toolPrompt.ts +49 -49
- package/src/ruvocal/src/lib/server/urlSafety.ts +77 -77
- package/src/ruvocal/src/lib/server/usageLimits.ts +30 -30
- package/src/ruvocal/src/lib/stores/autopilotStore.svelte.ts +175 -175
- package/src/ruvocal/src/lib/stores/backgroundGenerations.svelte.ts +32 -32
- package/src/ruvocal/src/lib/stores/backgroundGenerations.ts +1 -1
- package/src/ruvocal/src/lib/stores/errors.ts +9 -9
- package/src/ruvocal/src/lib/stores/isAborted.ts +3 -3
- package/src/ruvocal/src/lib/stores/isPro.ts +4 -4
- package/src/ruvocal/src/lib/stores/loading.ts +3 -3
- package/src/ruvocal/src/lib/stores/mcpServers.ts +534 -534
- package/src/ruvocal/src/lib/stores/pendingChatInput.ts +3 -3
- package/src/ruvocal/src/lib/stores/pendingMessage.ts +9 -9
- package/src/ruvocal/src/lib/stores/settings.ts +182 -182
- package/src/ruvocal/src/lib/stores/shareModal.ts +13 -13
- package/src/ruvocal/src/lib/stores/titleUpdate.ts +8 -8
- package/src/ruvocal/src/lib/stores/wasmMcp.ts +472 -472
- package/src/ruvocal/src/lib/switchTheme.ts +124 -124
- package/src/ruvocal/src/lib/types/AbortedGeneration.ts +8 -8
- package/src/ruvocal/src/lib/types/Assistant.ts +31 -31
- package/src/ruvocal/src/lib/types/AssistantStats.ts +11 -11
- package/src/ruvocal/src/lib/types/ConfigKey.ts +4 -4
- package/src/ruvocal/src/lib/types/ConvSidebar.ts +9 -9
- package/src/ruvocal/src/lib/types/Conversation.ts +27 -27
- package/src/ruvocal/src/lib/types/ConversationStats.ts +13 -13
- package/src/ruvocal/src/lib/types/Message.ts +41 -41
- package/src/ruvocal/src/lib/types/MessageEvent.ts +10 -10
- package/src/ruvocal/src/lib/types/MessageUpdate.ts +139 -139
- package/src/ruvocal/src/lib/types/MigrationResult.ts +7 -7
- package/src/ruvocal/src/lib/types/Model.ts +23 -23
- package/src/ruvocal/src/lib/types/Report.ts +12 -12
- package/src/ruvocal/src/lib/types/Review.ts +6 -6
- package/src/ruvocal/src/lib/types/Semaphore.ts +19 -19
- package/src/ruvocal/src/lib/types/Session.ts +22 -22
- package/src/ruvocal/src/lib/types/Settings.ts +93 -93
- package/src/ruvocal/src/lib/types/SharedConversation.ts +9 -9
- package/src/ruvocal/src/lib/types/Template.ts +6 -6
- package/src/ruvocal/src/lib/types/Timestamps.ts +4 -4
- package/src/ruvocal/src/lib/types/TokenCache.ts +6 -6
- package/src/ruvocal/src/lib/types/Tool.ts +77 -77
- package/src/ruvocal/src/lib/types/UrlDependency.ts +5 -5
- package/src/ruvocal/src/lib/types/User.ts +14 -14
- package/src/ruvocal/src/lib/utils/PublicConfig.svelte.ts +75 -75
- package/src/ruvocal/src/lib/utils/auth.ts +17 -17
- package/src/ruvocal/src/lib/utils/chunk.ts +33 -33
- package/src/ruvocal/src/lib/utils/cookiesAreEnabled.ts +13 -13
- package/src/ruvocal/src/lib/utils/debounce.ts +17 -17
- package/src/ruvocal/src/lib/utils/deepestChild.ts +6 -6
- package/src/ruvocal/src/lib/utils/favicon.ts +21 -21
- package/src/ruvocal/src/lib/utils/fetchJSON.ts +23 -23
- package/src/ruvocal/src/lib/utils/file2base64.ts +14 -14
- package/src/ruvocal/src/lib/utils/formatUserCount.ts +37 -37
- package/src/ruvocal/src/lib/utils/generationState.spec.ts +75 -75
- package/src/ruvocal/src/lib/utils/generationState.ts +26 -26
- package/src/ruvocal/src/lib/utils/getHref.ts +41 -41
- package/src/ruvocal/src/lib/utils/getReturnFromGenerator.ts +7 -7
- package/src/ruvocal/src/lib/utils/haptics.ts +64 -64
- package/src/ruvocal/src/lib/utils/hashConv.ts +12 -12
- package/src/ruvocal/src/lib/utils/hf.ts +17 -17
- package/src/ruvocal/src/lib/utils/isDesktop.ts +7 -7
- package/src/ruvocal/src/lib/utils/isUrl.ts +8 -8
- package/src/ruvocal/src/lib/utils/isVirtualKeyboard.ts +16 -16
- package/src/ruvocal/src/lib/utils/loadAttachmentsFromUrls.ts +115 -115
- package/src/ruvocal/src/lib/utils/marked.spec.ts +96 -96
- package/src/ruvocal/src/lib/utils/marked.ts +531 -531
- package/src/ruvocal/src/lib/utils/mcpValidation.ts +147 -147
- package/src/ruvocal/src/lib/utils/mergeAsyncGenerators.ts +38 -38
- package/src/ruvocal/src/lib/utils/messageUpdates.spec.ts +262 -262
- package/src/ruvocal/src/lib/utils/messageUpdates.ts +324 -324
- package/src/ruvocal/src/lib/utils/mime.ts +56 -56
- package/src/ruvocal/src/lib/utils/models.ts +14 -14
- package/src/ruvocal/src/lib/utils/parseBlocks.ts +120 -120
- package/src/ruvocal/src/lib/utils/parseIncompleteMarkdown.ts +644 -644
- package/src/ruvocal/src/lib/utils/parseStringToList.ts +10 -10
- package/src/ruvocal/src/lib/utils/randomUuid.ts +14 -14
- package/src/ruvocal/src/lib/utils/searchTokens.ts +33 -33
- package/src/ruvocal/src/lib/utils/sha256.ts +7 -7
- package/src/ruvocal/src/lib/utils/stringifyError.ts +12 -12
- package/src/ruvocal/src/lib/utils/sum.ts +3 -3
- package/src/ruvocal/src/lib/utils/template.spec.ts +59 -59
- package/src/ruvocal/src/lib/utils/template.ts +53 -53
- package/src/ruvocal/src/lib/utils/timeout.ts +9 -9
- package/src/ruvocal/src/lib/utils/toolProgress.spec.ts +46 -46
- package/src/ruvocal/src/lib/utils/toolProgress.ts +11 -11
- package/src/ruvocal/src/lib/utils/tree/addChildren.spec.ts +102 -102
- package/src/ruvocal/src/lib/utils/tree/addChildren.ts +48 -48
- package/src/ruvocal/src/lib/utils/tree/addSibling.spec.ts +81 -81
- package/src/ruvocal/src/lib/utils/tree/addSibling.ts +41 -41
- package/src/ruvocal/src/lib/utils/tree/buildSubtree.spec.ts +110 -110
- package/src/ruvocal/src/lib/utils/tree/buildSubtree.ts +24 -24
- package/src/ruvocal/src/lib/utils/tree/convertLegacyConversation.spec.ts +31 -31
- package/src/ruvocal/src/lib/utils/tree/convertLegacyConversation.ts +36 -36
- package/src/ruvocal/src/lib/utils/tree/isMessageId.spec.ts +15 -15
- package/src/ruvocal/src/lib/utils/tree/isMessageId.ts +5 -5
- package/src/ruvocal/src/lib/utils/tree/tree.d.ts +14 -14
- package/src/ruvocal/src/lib/utils/tree/treeHelpers.spec.ts +167 -167
- package/src/ruvocal/src/lib/utils/updates.ts +39 -39
- package/src/ruvocal/src/lib/utils/urlParams.ts +13 -13
- package/src/ruvocal/src/lib/wasm/idb.ts +438 -438
- package/src/ruvocal/src/lib/wasm/index.ts +1213 -1213
- package/src/ruvocal/src/lib/wasm/tests/wasm-capabilities.test.ts +565 -565
- package/src/ruvocal/src/lib/wasm/wasm.worker.ts +332 -332
- package/src/ruvocal/src/lib/wasm/workerClient.ts +166 -166
- package/src/ruvocal/src/lib/workers/autopilotWorker.ts +221 -221
- package/src/ruvocal/src/lib/workers/detailFetchWorker.ts +100 -100
- package/src/ruvocal/src/lib/workers/markdownWorker.ts +61 -61
- package/src/ruvocal/src/routes/+error.svelte +20 -20
- package/src/ruvocal/src/routes/+layout.svelte +324 -324
- package/src/ruvocal/src/routes/+layout.ts +91 -91
- package/src/ruvocal/src/routes/+page.svelte +168 -168
- package/src/ruvocal/src/routes/.well-known/oauth-cimd/+server.ts +37 -37
- package/src/ruvocal/src/routes/__debug/openai/+server.ts +21 -21
- package/src/ruvocal/src/routes/admin/export/+server.ts +159 -159
- package/src/ruvocal/src/routes/admin/stats/compute/+server.ts +16 -16
- package/src/ruvocal/src/routes/api/conversation/[id]/+server.ts +40 -40
- package/src/ruvocal/src/routes/api/conversation/[id]/message/[messageId]/+server.ts +42 -42
- package/src/ruvocal/src/routes/api/conversations/+server.ts +48 -48
- package/src/ruvocal/src/routes/api/fetch-url/+server.ts +147 -147
- package/src/ruvocal/src/routes/api/mcp/health/+server.ts +292 -292
- package/src/ruvocal/src/routes/api/mcp/servers/+server.ts +32 -32
- package/src/ruvocal/src/routes/api/models/+server.ts +25 -25
- package/src/ruvocal/src/routes/api/transcribe/+server.ts +104 -104
- package/src/ruvocal/src/routes/api/user/+server.ts +15 -15
- package/src/ruvocal/src/routes/api/user/validate-token/+server.ts +20 -20
- package/src/ruvocal/src/routes/api/v2/conversations/+server.ts +48 -48
- package/src/ruvocal/src/routes/api/v2/conversations/[id]/+server.ts +94 -94
- package/src/ruvocal/src/routes/api/v2/conversations/[id]/message/[messageId]/+server.ts +43 -43
- package/src/ruvocal/src/routes/api/v2/conversations/import-share/+server.ts +23 -23
- package/src/ruvocal/src/routes/api/v2/debug/config/+server.ts +16 -16
- package/src/ruvocal/src/routes/api/v2/debug/refresh/+server.ts +30 -30
- package/src/ruvocal/src/routes/api/v2/export/+server.ts +196 -196
- package/src/ruvocal/src/routes/api/v2/feature-flags/+server.ts +14 -14
- package/src/ruvocal/src/routes/api/v2/models/+server.ts +38 -38
- package/src/ruvocal/src/routes/api/v2/models/[namespace]/+server.ts +8 -8
- package/src/ruvocal/src/routes/api/v2/models/[namespace]/[model]/+server.ts +8 -8
- package/src/ruvocal/src/routes/api/v2/models/[namespace]/[model]/subscribe/+server.ts +28 -28
- package/src/ruvocal/src/routes/api/v2/models/[namespace]/subscribe/+server.ts +28 -28
- package/src/ruvocal/src/routes/api/v2/models/old/+server.ts +7 -7
- package/src/ruvocal/src/routes/api/v2/models/refresh/+server.ts +33 -33
- package/src/ruvocal/src/routes/api/v2/public-config/+server.ts +7 -7
- package/src/ruvocal/src/routes/api/v2/user/+server.ts +17 -17
- package/src/ruvocal/src/routes/api/v2/user/billing-orgs/+server.ts +73 -73
- package/src/ruvocal/src/routes/api/v2/user/reports/+server.ts +17 -17
- package/src/ruvocal/src/routes/api/v2/user/settings/+server.ts +110 -110
- package/src/ruvocal/src/routes/conversation/+server.ts +115 -115
- package/src/ruvocal/src/routes/conversation/[id]/+page.svelte +586 -586
- package/src/ruvocal/src/routes/conversation/[id]/+page.ts +60 -60
- package/src/ruvocal/src/routes/conversation/[id]/+server.ts +740 -740
- package/src/ruvocal/src/routes/conversation/[id]/message/[messageId]/prompt/+server.ts +66 -66
- package/src/ruvocal/src/routes/conversation/[id]/share/+server.ts +69 -69
- package/src/ruvocal/src/routes/conversation/[id]/stop-generating/+server.ts +35 -35
- package/src/ruvocal/src/routes/healthcheck/+server.ts +3 -3
- package/src/ruvocal/src/routes/login/+server.ts +5 -5
- package/src/ruvocal/src/routes/login/callback/+server.ts +103 -103
- package/src/ruvocal/src/routes/login/callback/updateUser.spec.ts +157 -157
- package/src/ruvocal/src/routes/login/callback/updateUser.ts +215 -215
- package/src/ruvocal/src/routes/logout/+server.ts +18 -18
- package/src/ruvocal/src/routes/metrics/+server.ts +18 -18
- package/src/ruvocal/src/routes/models/+page.svelte +233 -233
- package/src/ruvocal/src/routes/models/[...model]/+page.svelte +161 -161
- package/src/ruvocal/src/routes/models/[...model]/+page.ts +14 -14
- package/src/ruvocal/src/routes/models/[...model]/thumbnail.png/+server.ts +64 -64
- package/src/ruvocal/src/routes/models/[...model]/thumbnail.png/ModelThumbnail.svelte +28 -28
- package/src/ruvocal/src/routes/privacy/+page.svelte +11 -11
- package/src/ruvocal/src/routes/r/[id]/+page.ts +34 -34
- package/src/ruvocal/src/routes/settings/(nav)/+layout.svelte +282 -282
- package/src/ruvocal/src/routes/settings/(nav)/+layout.ts +1 -1
- package/src/ruvocal/src/routes/settings/(nav)/+server.ts +59 -59
- package/src/ruvocal/src/routes/settings/(nav)/[...model]/+page.svelte +464 -464
- package/src/ruvocal/src/routes/settings/(nav)/[...model]/+page.ts +14 -14
- package/src/ruvocal/src/routes/settings/(nav)/application/+page.svelte +362 -362
- package/src/ruvocal/src/routes/settings/+layout.svelte +40 -40
- package/src/ruvocal/src/styles/highlight-js.css +195 -195
- package/src/ruvocal/src/styles/main.css +144 -144
- package/src/ruvocal/static/chatui/favicon-dark.svg +3 -3
- package/src/ruvocal/static/chatui/favicon-dev.svg +3 -3
- package/src/ruvocal/static/chatui/favicon.svg +3 -3
- package/src/ruvocal/static/chatui/icon.svg +3 -3
- package/src/ruvocal/static/chatui/logo.svg +7 -7
- package/src/ruvocal/static/chatui/manifest.json +54 -54
- package/src/ruvocal/static/chatui/welcome.js +184 -184
- package/src/ruvocal/static/huggingchat/favicon-dark.svg +4 -4
- package/src/ruvocal/static/huggingchat/favicon-dev.svg +4 -4
- package/src/ruvocal/static/huggingchat/favicon.svg +4 -4
- package/src/ruvocal/static/huggingchat/fulltext-logo.svg +1 -1
- package/src/ruvocal/static/huggingchat/icon.svg +4 -4
- package/src/ruvocal/static/huggingchat/logo.svg +4 -4
- package/src/ruvocal/static/huggingchat/manifest.json +54 -54
- package/src/ruvocal/static/huggingchat/routes.chat.json +226 -226
- package/src/ruvocal/static/robots.txt +10 -10
- package/src/ruvocal/static/wasm/rvagent_wasm.js +1539 -1539
- package/src/ruvocal/stub/@reflink/reflink/package.json +5 -5
- package/src/ruvocal/svelte.config.js +53 -53
- package/src/ruvocal/tailwind.config.cjs +30 -30
- package/src/ruvocal/tsconfig.json +19 -19
- package/src/ruvocal/vite.config.ts +87 -87
- package/src/scripts/deploy.sh +116 -116
- package/src/scripts/generate-config.js +245 -245
- package/src/scripts/generate-welcome.js +187 -187
- package/src/scripts/package-rvf.sh +116 -116
|
@@ -1,38 +1,38 @@
|
|
|
1
|
-
# Common Issues
|
|
2
|
-
|
|
3
|
-
## 403: You don't have access to this conversation
|
|
4
|
-
|
|
5
|
-
This usually happens when running Chat UI over HTTP without proper cookie configuration.
|
|
6
|
-
|
|
7
|
-
**Recommended:** Set up a reverse proxy (NGINX, Caddy) to handle HTTPS.
|
|
8
|
-
|
|
9
|
-
**Alternative:** If you must run over HTTP, configure cookies:
|
|
10
|
-
|
|
11
|
-
```ini
|
|
12
|
-
COOKIE_SECURE=false
|
|
13
|
-
COOKIE_SAMESITE=lax
|
|
14
|
-
```
|
|
15
|
-
|
|
16
|
-
Also ensure `PUBLIC_ORIGIN` matches your actual URL:
|
|
17
|
-
|
|
18
|
-
```ini
|
|
19
|
-
PUBLIC_ORIGIN=http://localhost:5173
|
|
20
|
-
```
|
|
21
|
-
|
|
22
|
-
## Models not loading
|
|
23
|
-
|
|
24
|
-
If models aren't appearing in the UI:
|
|
25
|
-
|
|
26
|
-
1. Verify `OPENAI_BASE_URL` is correct and accessible
|
|
27
|
-
2. Check that `OPENAI_API_KEY` is valid
|
|
28
|
-
3. Ensure the endpoint returns models at `${OPENAI_BASE_URL}/models`
|
|
29
|
-
|
|
30
|
-
## Database connection errors
|
|
31
|
-
|
|
32
|
-
For development, you can skip MongoDB entirely - Chat UI will use an embedded database.
|
|
33
|
-
|
|
34
|
-
For production, verify:
|
|
35
|
-
|
|
36
|
-
- `MONGODB_URL` is a valid connection string
|
|
37
|
-
- Your IP is whitelisted (for MongoDB Atlas)
|
|
38
|
-
- The database user has read/write permissions
|
|
1
|
+
# Common Issues
|
|
2
|
+
|
|
3
|
+
## 403: You don't have access to this conversation
|
|
4
|
+
|
|
5
|
+
This usually happens when running Chat UI over HTTP without proper cookie configuration.
|
|
6
|
+
|
|
7
|
+
**Recommended:** Set up a reverse proxy (NGINX, Caddy) to handle HTTPS.
|
|
8
|
+
|
|
9
|
+
**Alternative:** If you must run over HTTP, configure cookies:
|
|
10
|
+
|
|
11
|
+
```ini
|
|
12
|
+
COOKIE_SECURE=false
|
|
13
|
+
COOKIE_SAMESITE=lax
|
|
14
|
+
```
|
|
15
|
+
|
|
16
|
+
Also ensure `PUBLIC_ORIGIN` matches your actual URL:
|
|
17
|
+
|
|
18
|
+
```ini
|
|
19
|
+
PUBLIC_ORIGIN=http://localhost:5173
|
|
20
|
+
```
|
|
21
|
+
|
|
22
|
+
## Models not loading
|
|
23
|
+
|
|
24
|
+
If models aren't appearing in the UI:
|
|
25
|
+
|
|
26
|
+
1. Verify `OPENAI_BASE_URL` is correct and accessible
|
|
27
|
+
2. Check that `OPENAI_API_KEY` is valid
|
|
28
|
+
3. Ensure the endpoint returns models at `${OPENAI_BASE_URL}/models`
|
|
29
|
+
|
|
30
|
+
## Database connection errors
|
|
31
|
+
|
|
32
|
+
For development, you can skip MongoDB entirely - Chat UI will use an embedded database.
|
|
33
|
+
|
|
34
|
+
For production, verify:
|
|
35
|
+
|
|
36
|
+
- `MONGODB_URL` is a valid connection string
|
|
37
|
+
- Your IP is whitelisted (for MongoDB Atlas)
|
|
38
|
+
- The database user has read/write permissions
|
|
@@ -1,105 +1,105 @@
|
|
|
1
|
-
# LLM Router
|
|
2
|
-
|
|
3
|
-
Chat UI includes an intelligent routing system that automatically selects the best model for each request. When enabled, users see a virtual "Omni" model that routes to specialized models based on the conversation context.
|
|
4
|
-
|
|
5
|
-
The router uses [katanemo/Arch-Router-1.5B](https://huggingface.co/katanemo/Arch-Router-1.5B) for route selection.
|
|
6
|
-
|
|
7
|
-
## Configuration
|
|
8
|
-
|
|
9
|
-
### Basic Setup
|
|
10
|
-
|
|
11
|
-
```ini
|
|
12
|
-
# Arch router endpoint (OpenAI-compatible)
|
|
13
|
-
LLM_ROUTER_ARCH_BASE_URL=https://router.huggingface.co/v1
|
|
14
|
-
LLM_ROUTER_ARCH_MODEL=katanemo/Arch-Router-1.5B
|
|
15
|
-
|
|
16
|
-
# Path to your routes policy JSON
|
|
17
|
-
LLM_ROUTER_ROUTES_PATH=./config/routes.json
|
|
18
|
-
```
|
|
19
|
-
|
|
20
|
-
### Routes Policy
|
|
21
|
-
|
|
22
|
-
Create a JSON file defining your routes. Each route specifies:
|
|
23
|
-
|
|
24
|
-
```json
|
|
25
|
-
[
|
|
26
|
-
{
|
|
27
|
-
"name": "coding",
|
|
28
|
-
"description": "Programming, debugging, code review",
|
|
29
|
-
"primary_model": "Qwen/Qwen3-Coder-480B-A35B-Instruct",
|
|
30
|
-
"fallback_models": ["meta-llama/Llama-3.3-70B-Instruct"]
|
|
31
|
-
},
|
|
32
|
-
{
|
|
33
|
-
"name": "casual_conversation",
|
|
34
|
-
"description": "General chat, questions, explanations",
|
|
35
|
-
"primary_model": "meta-llama/Llama-3.3-70B-Instruct"
|
|
36
|
-
}
|
|
37
|
-
]
|
|
38
|
-
```
|
|
39
|
-
|
|
40
|
-
### Fallback Behavior
|
|
41
|
-
|
|
42
|
-
```ini
|
|
43
|
-
# Route to use when Arch returns "other"
|
|
44
|
-
LLM_ROUTER_OTHER_ROUTE=casual_conversation
|
|
45
|
-
|
|
46
|
-
# Model to use if Arch selection fails entirely
|
|
47
|
-
LLM_ROUTER_FALLBACK_MODEL=meta-llama/Llama-3.3-70B-Instruct
|
|
48
|
-
|
|
49
|
-
# Selection timeout (milliseconds)
|
|
50
|
-
LLM_ROUTER_ARCH_TIMEOUT_MS=10000
|
|
51
|
-
```
|
|
52
|
-
|
|
53
|
-
## Multimodal Routing
|
|
54
|
-
|
|
55
|
-
When a user sends an image, the router can bypass Arch and route directly to a vision model:
|
|
56
|
-
|
|
57
|
-
```ini
|
|
58
|
-
LLM_ROUTER_ENABLE_MULTIMODAL=true
|
|
59
|
-
LLM_ROUTER_MULTIMODAL_MODEL=meta-llama/Llama-3.2-90B-Vision-Instruct
|
|
60
|
-
```
|
|
61
|
-
|
|
62
|
-
## Tools Routing
|
|
63
|
-
|
|
64
|
-
When a user has MCP servers enabled, the router can automatically select a tools-capable model:
|
|
65
|
-
|
|
66
|
-
```ini
|
|
67
|
-
LLM_ROUTER_ENABLE_TOOLS=true
|
|
68
|
-
LLM_ROUTER_TOOLS_MODEL=meta-llama/Llama-3.3-70B-Instruct
|
|
69
|
-
```
|
|
70
|
-
|
|
71
|
-
## UI Customization
|
|
72
|
-
|
|
73
|
-
Customize how the router appears in the model selector:
|
|
74
|
-
|
|
75
|
-
```ini
|
|
76
|
-
PUBLIC_LLM_ROUTER_ALIAS_ID=omni
|
|
77
|
-
PUBLIC_LLM_ROUTER_DISPLAY_NAME=Omni
|
|
78
|
-
PUBLIC_LLM_ROUTER_LOGO_URL=https://example.com/logo.png
|
|
79
|
-
```
|
|
80
|
-
|
|
81
|
-
## How It Works
|
|
82
|
-
|
|
83
|
-
When a user selects Omni:
|
|
84
|
-
|
|
85
|
-
1. Chat UI sends the conversation context to the Arch router
|
|
86
|
-
2. Arch analyzes the content and returns a route name
|
|
87
|
-
3. Chat UI maps the route to the corresponding model
|
|
88
|
-
4. The request streams from the selected model
|
|
89
|
-
5. On errors, fallback models are tried in order
|
|
90
|
-
|
|
91
|
-
The route selection is displayed in the UI so users can see which model was chosen.
|
|
92
|
-
|
|
93
|
-
## Message Length Limits
|
|
94
|
-
|
|
95
|
-
To optimize router performance, message content is trimmed before sending to Arch:
|
|
96
|
-
|
|
97
|
-
```ini
|
|
98
|
-
# Max characters for assistant messages (default: 500)
|
|
99
|
-
LLM_ROUTER_MAX_ASSISTANT_LENGTH=500
|
|
100
|
-
|
|
101
|
-
# Max characters for previous user messages (default: 400)
|
|
102
|
-
LLM_ROUTER_MAX_PREV_USER_LENGTH=400
|
|
103
|
-
```
|
|
104
|
-
|
|
105
|
-
The latest user message is never trimmed.
|
|
1
|
+
# LLM Router
|
|
2
|
+
|
|
3
|
+
Chat UI includes an intelligent routing system that automatically selects the best model for each request. When enabled, users see a virtual "Omni" model that routes to specialized models based on the conversation context.
|
|
4
|
+
|
|
5
|
+
The router uses [katanemo/Arch-Router-1.5B](https://huggingface.co/katanemo/Arch-Router-1.5B) for route selection.
|
|
6
|
+
|
|
7
|
+
## Configuration
|
|
8
|
+
|
|
9
|
+
### Basic Setup
|
|
10
|
+
|
|
11
|
+
```ini
|
|
12
|
+
# Arch router endpoint (OpenAI-compatible)
|
|
13
|
+
LLM_ROUTER_ARCH_BASE_URL=https://router.huggingface.co/v1
|
|
14
|
+
LLM_ROUTER_ARCH_MODEL=katanemo/Arch-Router-1.5B
|
|
15
|
+
|
|
16
|
+
# Path to your routes policy JSON
|
|
17
|
+
LLM_ROUTER_ROUTES_PATH=./config/routes.json
|
|
18
|
+
```
|
|
19
|
+
|
|
20
|
+
### Routes Policy
|
|
21
|
+
|
|
22
|
+
Create a JSON file defining your routes. Each route specifies:
|
|
23
|
+
|
|
24
|
+
```json
|
|
25
|
+
[
|
|
26
|
+
{
|
|
27
|
+
"name": "coding",
|
|
28
|
+
"description": "Programming, debugging, code review",
|
|
29
|
+
"primary_model": "Qwen/Qwen3-Coder-480B-A35B-Instruct",
|
|
30
|
+
"fallback_models": ["meta-llama/Llama-3.3-70B-Instruct"]
|
|
31
|
+
},
|
|
32
|
+
{
|
|
33
|
+
"name": "casual_conversation",
|
|
34
|
+
"description": "General chat, questions, explanations",
|
|
35
|
+
"primary_model": "meta-llama/Llama-3.3-70B-Instruct"
|
|
36
|
+
}
|
|
37
|
+
]
|
|
38
|
+
```
|
|
39
|
+
|
|
40
|
+
### Fallback Behavior
|
|
41
|
+
|
|
42
|
+
```ini
|
|
43
|
+
# Route to use when Arch returns "other"
|
|
44
|
+
LLM_ROUTER_OTHER_ROUTE=casual_conversation
|
|
45
|
+
|
|
46
|
+
# Model to use if Arch selection fails entirely
|
|
47
|
+
LLM_ROUTER_FALLBACK_MODEL=meta-llama/Llama-3.3-70B-Instruct
|
|
48
|
+
|
|
49
|
+
# Selection timeout (milliseconds)
|
|
50
|
+
LLM_ROUTER_ARCH_TIMEOUT_MS=10000
|
|
51
|
+
```
|
|
52
|
+
|
|
53
|
+
## Multimodal Routing
|
|
54
|
+
|
|
55
|
+
When a user sends an image, the router can bypass Arch and route directly to a vision model:
|
|
56
|
+
|
|
57
|
+
```ini
|
|
58
|
+
LLM_ROUTER_ENABLE_MULTIMODAL=true
|
|
59
|
+
LLM_ROUTER_MULTIMODAL_MODEL=meta-llama/Llama-3.2-90B-Vision-Instruct
|
|
60
|
+
```
|
|
61
|
+
|
|
62
|
+
## Tools Routing
|
|
63
|
+
|
|
64
|
+
When a user has MCP servers enabled, the router can automatically select a tools-capable model:
|
|
65
|
+
|
|
66
|
+
```ini
|
|
67
|
+
LLM_ROUTER_ENABLE_TOOLS=true
|
|
68
|
+
LLM_ROUTER_TOOLS_MODEL=meta-llama/Llama-3.3-70B-Instruct
|
|
69
|
+
```
|
|
70
|
+
|
|
71
|
+
## UI Customization
|
|
72
|
+
|
|
73
|
+
Customize how the router appears in the model selector:
|
|
74
|
+
|
|
75
|
+
```ini
|
|
76
|
+
PUBLIC_LLM_ROUTER_ALIAS_ID=omni
|
|
77
|
+
PUBLIC_LLM_ROUTER_DISPLAY_NAME=Omni
|
|
78
|
+
PUBLIC_LLM_ROUTER_LOGO_URL=https://example.com/logo.png
|
|
79
|
+
```
|
|
80
|
+
|
|
81
|
+
## How It Works
|
|
82
|
+
|
|
83
|
+
When a user selects Omni:
|
|
84
|
+
|
|
85
|
+
1. Chat UI sends the conversation context to the Arch router
|
|
86
|
+
2. Arch analyzes the content and returns a route name
|
|
87
|
+
3. Chat UI maps the route to the corresponding model
|
|
88
|
+
4. The request streams from the selected model
|
|
89
|
+
5. On errors, fallback models are tried in order
|
|
90
|
+
|
|
91
|
+
The route selection is displayed in the UI so users can see which model was chosen.
|
|
92
|
+
|
|
93
|
+
## Message Length Limits
|
|
94
|
+
|
|
95
|
+
To optimize router performance, message content is trimmed before sending to Arch:
|
|
96
|
+
|
|
97
|
+
```ini
|
|
98
|
+
# Max characters for assistant messages (default: 500)
|
|
99
|
+
LLM_ROUTER_MAX_ASSISTANT_LENGTH=500
|
|
100
|
+
|
|
101
|
+
# Max characters for previous user messages (default: 400)
|
|
102
|
+
LLM_ROUTER_MAX_PREV_USER_LENGTH=400
|
|
103
|
+
```
|
|
104
|
+
|
|
105
|
+
The latest user message is never trimmed.
|
|
@@ -1,84 +1,84 @@
|
|
|
1
|
-
# MCP Tools
|
|
2
|
-
|
|
3
|
-
Chat UI supports tool calling via the [Model Context Protocol (MCP)](https://modelcontextprotocol.io/). MCP servers expose tools that models can invoke during conversations.
|
|
4
|
-
|
|
5
|
-
## Server Types
|
|
6
|
-
|
|
7
|
-
Chat UI supports two types of MCP servers:
|
|
8
|
-
|
|
9
|
-
### Base Servers (Admin-configured)
|
|
10
|
-
|
|
11
|
-
Base servers are configured by the administrator via environment variables. They appear for all users and can be enabled/disabled per-user but not removed.
|
|
12
|
-
|
|
13
|
-
```ini
|
|
14
|
-
MCP_SERVERS=[
|
|
15
|
-
{"name": "Web Search (Exa)", "url": "https://mcp.exa.ai/mcp"},
|
|
16
|
-
{"name": "Hugging Face", "url": "https://hf.co/mcp"}
|
|
17
|
-
]
|
|
18
|
-
```
|
|
19
|
-
|
|
20
|
-
Each server entry requires:
|
|
21
|
-
|
|
22
|
-
- `name` - Display name shown in the UI
|
|
23
|
-
- `url` - MCP server endpoint URL
|
|
24
|
-
- `headers` (optional) - Custom headers for authentication
|
|
25
|
-
|
|
26
|
-
### User Servers (Added from UI)
|
|
27
|
-
|
|
28
|
-
Users can add their own MCP servers directly from the UI:
|
|
29
|
-
|
|
30
|
-
1. Open the chat input and click the **+** button (or go to Settings)
|
|
31
|
-
2. Select **MCP Servers**
|
|
32
|
-
3. Click **Add Server**
|
|
33
|
-
4. Enter the server name and URL
|
|
34
|
-
5. Run **Health Check** to verify connectivity
|
|
35
|
-
|
|
36
|
-
User-added servers are stored in the browser and can be removed at any time. They work alongside base servers.
|
|
37
|
-
|
|
38
|
-
## User Token Forwarding
|
|
39
|
-
|
|
40
|
-
When users are logged in via Hugging Face, you can forward their access token to MCP servers:
|
|
41
|
-
|
|
42
|
-
```ini
|
|
43
|
-
MCP_FORWARD_HF_USER_TOKEN=true
|
|
44
|
-
```
|
|
45
|
-
|
|
46
|
-
This allows MCP servers to access user-specific resources on their behalf.
|
|
47
|
-
|
|
48
|
-
## Using Tools
|
|
49
|
-
|
|
50
|
-
1. Enable the servers you want to use from the MCP Servers panel
|
|
51
|
-
2. Start chatting - models will automatically use tools when appropriate
|
|
52
|
-
|
|
53
|
-
### Model Requirements
|
|
54
|
-
|
|
55
|
-
Not all models support tool calling. To enable tools for a specific model, add it to your `MODELS` override:
|
|
56
|
-
|
|
57
|
-
```ini
|
|
58
|
-
MODELS=`[
|
|
59
|
-
{
|
|
60
|
-
"id": "meta-llama/Llama-3.3-70B-Instruct",
|
|
61
|
-
"supportsTools": true
|
|
62
|
-
}
|
|
63
|
-
]`
|
|
64
|
-
```
|
|
65
|
-
|
|
66
|
-
## Tool Execution Flow
|
|
67
|
-
|
|
68
|
-
When a model decides to use a tool:
|
|
69
|
-
|
|
70
|
-
1. The model generates a tool call with parameters
|
|
71
|
-
2. Chat UI executes the call against the MCP server
|
|
72
|
-
3. Results are displayed in the chat as a collapsible "tool" block
|
|
73
|
-
4. Results are fed back to the model for follow-up responses
|
|
74
|
-
|
|
75
|
-
## Integration with LLM Router
|
|
76
|
-
|
|
77
|
-
When using the [LLM Router](./llm-router), you can configure automatic routing to a tools-capable model:
|
|
78
|
-
|
|
79
|
-
```ini
|
|
80
|
-
LLM_ROUTER_ENABLE_TOOLS=true
|
|
81
|
-
LLM_ROUTER_TOOLS_MODEL=meta-llama/Llama-3.3-70B-Instruct
|
|
82
|
-
```
|
|
83
|
-
|
|
84
|
-
When a user has MCP servers enabled and selects the Omni model, the router will automatically use the specified tools model.
|
|
1
|
+
# MCP Tools
|
|
2
|
+
|
|
3
|
+
Chat UI supports tool calling via the [Model Context Protocol (MCP)](https://modelcontextprotocol.io/). MCP servers expose tools that models can invoke during conversations.
|
|
4
|
+
|
|
5
|
+
## Server Types
|
|
6
|
+
|
|
7
|
+
Chat UI supports two types of MCP servers:
|
|
8
|
+
|
|
9
|
+
### Base Servers (Admin-configured)
|
|
10
|
+
|
|
11
|
+
Base servers are configured by the administrator via environment variables. They appear for all users and can be enabled/disabled per-user but not removed.
|
|
12
|
+
|
|
13
|
+
```ini
|
|
14
|
+
MCP_SERVERS=[
|
|
15
|
+
{"name": "Web Search (Exa)", "url": "https://mcp.exa.ai/mcp"},
|
|
16
|
+
{"name": "Hugging Face", "url": "https://hf.co/mcp"}
|
|
17
|
+
]
|
|
18
|
+
```
|
|
19
|
+
|
|
20
|
+
Each server entry requires:
|
|
21
|
+
|
|
22
|
+
- `name` - Display name shown in the UI
|
|
23
|
+
- `url` - MCP server endpoint URL
|
|
24
|
+
- `headers` (optional) - Custom headers for authentication
|
|
25
|
+
|
|
26
|
+
### User Servers (Added from UI)
|
|
27
|
+
|
|
28
|
+
Users can add their own MCP servers directly from the UI:
|
|
29
|
+
|
|
30
|
+
1. Open the chat input and click the **+** button (or go to Settings)
|
|
31
|
+
2. Select **MCP Servers**
|
|
32
|
+
3. Click **Add Server**
|
|
33
|
+
4. Enter the server name and URL
|
|
34
|
+
5. Run **Health Check** to verify connectivity
|
|
35
|
+
|
|
36
|
+
User-added servers are stored in the browser and can be removed at any time. They work alongside base servers.
|
|
37
|
+
|
|
38
|
+
## User Token Forwarding
|
|
39
|
+
|
|
40
|
+
When users are logged in via Hugging Face, you can forward their access token to MCP servers:
|
|
41
|
+
|
|
42
|
+
```ini
|
|
43
|
+
MCP_FORWARD_HF_USER_TOKEN=true
|
|
44
|
+
```
|
|
45
|
+
|
|
46
|
+
This allows MCP servers to access user-specific resources on their behalf.
|
|
47
|
+
|
|
48
|
+
## Using Tools
|
|
49
|
+
|
|
50
|
+
1. Enable the servers you want to use from the MCP Servers panel
|
|
51
|
+
2. Start chatting - models will automatically use tools when appropriate
|
|
52
|
+
|
|
53
|
+
### Model Requirements
|
|
54
|
+
|
|
55
|
+
Not all models support tool calling. To enable tools for a specific model, add it to your `MODELS` override:
|
|
56
|
+
|
|
57
|
+
```ini
|
|
58
|
+
MODELS=`[
|
|
59
|
+
{
|
|
60
|
+
"id": "meta-llama/Llama-3.3-70B-Instruct",
|
|
61
|
+
"supportsTools": true
|
|
62
|
+
}
|
|
63
|
+
]`
|
|
64
|
+
```
|
|
65
|
+
|
|
66
|
+
## Tool Execution Flow
|
|
67
|
+
|
|
68
|
+
When a model decides to use a tool:
|
|
69
|
+
|
|
70
|
+
1. The model generates a tool call with parameters
|
|
71
|
+
2. Chat UI executes the call against the MCP server
|
|
72
|
+
3. Results are displayed in the chat as a collapsible "tool" block
|
|
73
|
+
4. Results are fed back to the model for follow-up responses
|
|
74
|
+
|
|
75
|
+
## Integration with LLM Router
|
|
76
|
+
|
|
77
|
+
When using the [LLM Router](./llm-router), you can configure automatic routing to a tools-capable model:
|
|
78
|
+
|
|
79
|
+
```ini
|
|
80
|
+
LLM_ROUTER_ENABLE_TOOLS=true
|
|
81
|
+
LLM_ROUTER_TOOLS_MODEL=meta-llama/Llama-3.3-70B-Instruct
|
|
82
|
+
```
|
|
83
|
+
|
|
84
|
+
When a user has MCP servers enabled and selects the Omni model, the router will automatically use the specified tools model.
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
# Metrics
|
|
2
|
-
|
|
3
|
-
The server can expose prometheus metrics on port `5565` but is off by default. You may enable the metrics server with `METRICS_ENABLED=true` and change the port with `METRICS_PORT=1234`.
|
|
4
|
-
|
|
5
|
-
<Tip>
|
|
6
|
-
|
|
7
|
-
In development with `npm run dev`, the metrics server does not shutdown gracefully due to Sveltekit not providing hooks for restart. It's recommended to disable the metrics server in this case.
|
|
8
|
-
|
|
9
|
-
</Tip>
|
|
1
|
+
# Metrics
|
|
2
|
+
|
|
3
|
+
The server can expose prometheus metrics on port `5565` but is off by default. You may enable the metrics server with `METRICS_ENABLED=true` and change the port with `METRICS_PORT=1234`.
|
|
4
|
+
|
|
5
|
+
<Tip>
|
|
6
|
+
|
|
7
|
+
In development with `npm run dev`, the metrics server does not shutdown gracefully due to Sveltekit not providing hooks for restart. It's recommended to disable the metrics server in this case.
|
|
8
|
+
|
|
9
|
+
</Tip>
|
|
@@ -1,57 +1,57 @@
|
|
|
1
|
-
# OpenID
|
|
2
|
-
|
|
3
|
-
By default, users are attributed a unique ID based on their browser session. To authenticate users with OpenID Connect, configure the following:
|
|
4
|
-
|
|
5
|
-
```ini
|
|
6
|
-
OPENID_CLIENT_ID=your_client_id
|
|
7
|
-
OPENID_CLIENT_SECRET=your_client_secret
|
|
8
|
-
OPENID_SCOPES="openid profile"
|
|
9
|
-
```
|
|
10
|
-
|
|
11
|
-
Use the provider URL for standard OpenID Connect discovery:
|
|
12
|
-
|
|
13
|
-
```ini
|
|
14
|
-
OPENID_PROVIDER_URL=https://your-provider.com
|
|
15
|
-
```
|
|
16
|
-
|
|
17
|
-
Advanced: you can also provide a client metadata document via `OPENID_CONFIG`. This value must be a JSON/JSON5 object (for example, a CIMD document) and is parsed server‑side to populate OpenID settings.
|
|
18
|
-
|
|
19
|
-
**Redirect URI:** `https://your-domain.com/login/callback`
|
|
20
|
-
|
|
21
|
-
## Access Control
|
|
22
|
-
|
|
23
|
-
Restrict access to specific users:
|
|
24
|
-
|
|
25
|
-
```ini
|
|
26
|
-
# Allow only specific email addresses
|
|
27
|
-
ALLOWED_USER_EMAILS=["user@example.com", "admin@example.com"]
|
|
28
|
-
|
|
29
|
-
# Allow all users from specific domains
|
|
30
|
-
ALLOWED_USER_DOMAINS=["example.com", "company.org"]
|
|
31
|
-
```
|
|
32
|
-
|
|
33
|
-
## Hugging Face Login
|
|
34
|
-
|
|
35
|
-
For Hugging Face authentication, you can use automatic client registration:
|
|
36
|
-
|
|
37
|
-
```ini
|
|
38
|
-
OPENID_CLIENT_ID=__CIMD__
|
|
39
|
-
```
|
|
40
|
-
|
|
41
|
-
This creates an OAuth app automatically when deployed. See the [CIMD spec](https://datatracker.ietf.org/doc/draft-ietf-oauth-client-id-metadata-document/) for details.
|
|
42
|
-
|
|
43
|
-
## User Token Forwarding
|
|
44
|
-
|
|
45
|
-
When users log in via Hugging Face, you can forward their token for inference:
|
|
46
|
-
|
|
47
|
-
```ini
|
|
48
|
-
USE_USER_TOKEN=true
|
|
49
|
-
```
|
|
50
|
-
|
|
51
|
-
## Auto-Login
|
|
52
|
-
|
|
53
|
-
Force authentication on all routes:
|
|
54
|
-
|
|
55
|
-
```ini
|
|
56
|
-
AUTOMATIC_LOGIN=true
|
|
57
|
-
```
|
|
1
|
+
# OpenID
|
|
2
|
+
|
|
3
|
+
By default, users are attributed a unique ID based on their browser session. To authenticate users with OpenID Connect, configure the following:
|
|
4
|
+
|
|
5
|
+
```ini
|
|
6
|
+
OPENID_CLIENT_ID=your_client_id
|
|
7
|
+
OPENID_CLIENT_SECRET=your_client_secret
|
|
8
|
+
OPENID_SCOPES="openid profile"
|
|
9
|
+
```
|
|
10
|
+
|
|
11
|
+
Use the provider URL for standard OpenID Connect discovery:
|
|
12
|
+
|
|
13
|
+
```ini
|
|
14
|
+
OPENID_PROVIDER_URL=https://your-provider.com
|
|
15
|
+
```
|
|
16
|
+
|
|
17
|
+
Advanced: you can also provide a client metadata document via `OPENID_CONFIG`. This value must be a JSON/JSON5 object (for example, a CIMD document) and is parsed server‑side to populate OpenID settings.
|
|
18
|
+
|
|
19
|
+
**Redirect URI:** `https://your-domain.com/login/callback`
|
|
20
|
+
|
|
21
|
+
## Access Control
|
|
22
|
+
|
|
23
|
+
Restrict access to specific users:
|
|
24
|
+
|
|
25
|
+
```ini
|
|
26
|
+
# Allow only specific email addresses
|
|
27
|
+
ALLOWED_USER_EMAILS=["user@example.com", "admin@example.com"]
|
|
28
|
+
|
|
29
|
+
# Allow all users from specific domains
|
|
30
|
+
ALLOWED_USER_DOMAINS=["example.com", "company.org"]
|
|
31
|
+
```
|
|
32
|
+
|
|
33
|
+
## Hugging Face Login
|
|
34
|
+
|
|
35
|
+
For Hugging Face authentication, you can use automatic client registration:
|
|
36
|
+
|
|
37
|
+
```ini
|
|
38
|
+
OPENID_CLIENT_ID=__CIMD__
|
|
39
|
+
```
|
|
40
|
+
|
|
41
|
+
This creates an OAuth app automatically when deployed. See the [CIMD spec](https://datatracker.ietf.org/doc/draft-ietf-oauth-client-id-metadata-document/) for details.
|
|
42
|
+
|
|
43
|
+
## User Token Forwarding
|
|
44
|
+
|
|
45
|
+
When users log in via Hugging Face, you can forward their token for inference:
|
|
46
|
+
|
|
47
|
+
```ini
|
|
48
|
+
USE_USER_TOKEN=true
|
|
49
|
+
```
|
|
50
|
+
|
|
51
|
+
## Auto-Login
|
|
52
|
+
|
|
53
|
+
Force authentication on all routes:
|
|
54
|
+
|
|
55
|
+
```ini
|
|
56
|
+
AUTOMATIC_LOGIN=true
|
|
57
|
+
```
|