ruflo 3.5.1 → 3.5.3
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/dist/rvf.manifest.json +295 -0
- package/package.json +16 -2
- package/src/chat-ui/Dockerfile +25 -0
- package/src/chat-ui/patch-mcp-url-safety.sh +28 -0
- package/src/chat-ui/static/chatui/icon-144x144.png +0 -0
- package/src/chat-ui/static/chatui/omni-welcome.gif +0 -0
- package/src/config/config.example.json +76 -0
- package/src/mcp-bridge/Dockerfile +45 -0
- package/src/mcp-bridge/index.js +1668 -0
- package/src/mcp-bridge/mcp-stdio-kernel.js +159 -0
- package/src/mcp-bridge/package.json +17 -0
- package/src/mcp-bridge/test-harness.js +470 -0
- package/src/nginx/Dockerfile +10 -0
- package/src/nginx/nginx.conf +67 -0
- package/src/nginx/static/favicon-dark.svg +4 -0
- package/src/nginx/static/favicon.svg +4 -0
- package/src/nginx/static/icon.svg +5 -0
- package/src/nginx/static/logo.svg +9 -0
- package/src/nginx/static/manifest.json +22 -0
- package/src/nginx/static/welcome.js +184 -0
- package/src/ruvocal/.claude/skills/add-model-descriptions/SKILL.md +73 -0
- package/src/ruvocal/.devcontainer/Dockerfile +9 -0
- package/src/ruvocal/.devcontainer/devcontainer.json +36 -0
- package/src/ruvocal/.dockerignore +13 -0
- package/src/ruvocal/.env +194 -0
- package/src/ruvocal/.env.ci +1 -0
- package/src/ruvocal/.eslintignore +13 -0
- package/src/ruvocal/.eslintrc.cjs +45 -0
- package/src/ruvocal/.github/ISSUE_TEMPLATE/bug-report--chat-ui-.md +43 -0
- package/src/ruvocal/.github/ISSUE_TEMPLATE/config-support.md +9 -0
- package/src/ruvocal/.github/ISSUE_TEMPLATE/feature-request--chat-ui-.md +17 -0
- package/src/ruvocal/.github/ISSUE_TEMPLATE/huggingchat.md +11 -0
- package/src/ruvocal/.github/release.yml +16 -0
- package/src/ruvocal/.github/workflows/build-docs.yml +18 -0
- package/src/ruvocal/.github/workflows/build-image.yml +142 -0
- package/src/ruvocal/.github/workflows/build-pr-docs.yml +20 -0
- package/src/ruvocal/.github/workflows/deploy-dev.yml +63 -0
- package/src/ruvocal/.github/workflows/deploy-prod.yml +78 -0
- package/src/ruvocal/.github/workflows/lint-and-test.yml +84 -0
- package/src/ruvocal/.github/workflows/slugify.yaml +72 -0
- package/src/ruvocal/.github/workflows/trufflehog.yml +17 -0
- package/src/ruvocal/.github/workflows/upload-pr-documentation.yml +16 -0
- package/src/ruvocal/.husky/lint-stage-config.js +4 -0
- package/src/ruvocal/.husky/pre-commit +2 -0
- package/src/ruvocal/.prettierignore +14 -0
- package/src/ruvocal/.prettierrc +7 -0
- package/src/ruvocal/.vscode/launch.json +11 -0
- package/src/ruvocal/.vscode/settings.json +14 -0
- package/src/ruvocal/CLAUDE.md +126 -0
- package/src/ruvocal/Dockerfile +93 -0
- package/src/ruvocal/LICENSE +203 -0
- package/src/ruvocal/PRIVACY.md +41 -0
- package/src/ruvocal/README.md +190 -0
- package/src/ruvocal/chart/Chart.yaml +5 -0
- package/src/ruvocal/chart/env/dev.yaml +260 -0
- package/src/ruvocal/chart/env/prod.yaml +273 -0
- package/src/ruvocal/chart/templates/_helpers.tpl +22 -0
- package/src/ruvocal/chart/templates/config.yaml +10 -0
- package/src/ruvocal/chart/templates/deployment.yaml +81 -0
- package/src/ruvocal/chart/templates/hpa.yaml +45 -0
- package/src/ruvocal/chart/templates/infisical.yaml +24 -0
- package/src/ruvocal/chart/templates/ingress-internal.yaml +32 -0
- package/src/ruvocal/chart/templates/ingress.yaml +32 -0
- package/src/ruvocal/chart/templates/network-policy.yaml +36 -0
- package/src/ruvocal/chart/templates/service-account.yaml +13 -0
- package/src/ruvocal/chart/templates/service-monitor.yaml +17 -0
- package/src/ruvocal/chart/templates/service.yaml +21 -0
- package/src/ruvocal/chart/values.yaml +73 -0
- package/src/ruvocal/docker-compose.yml +21 -0
- package/src/ruvocal/docs/adr/ADR-029-HUGGINGFACE-CHAT-UI-CLOUD-RUN.md +1236 -0
- package/src/ruvocal/docs/adr/ADR-033-RUVECTOR-RUFLO-MCP-INTEGRATION.md +111 -0
- package/src/ruvocal/docs/adr/ADR-034-OPTIONAL-MCP-BACKENDS.md +117 -0
- package/src/ruvocal/docs/adr/ADR-035-MCP-TOOL-GROUPS.md +186 -0
- package/src/ruvocal/docs/adr/ADR-037-AUTOPILOT-CHAT-MODE.md +1500 -0
- package/src/ruvocal/docs/adr/ADR-038-RUVOCAL-FORK.md +286 -0
- package/src/ruvocal/docs/source/_toctree.yml +30 -0
- package/src/ruvocal/docs/source/configuration/common-issues.md +38 -0
- package/src/ruvocal/docs/source/configuration/llm-router.md +105 -0
- package/src/ruvocal/docs/source/configuration/mcp-tools.md +84 -0
- package/src/ruvocal/docs/source/configuration/metrics.md +9 -0
- package/src/ruvocal/docs/source/configuration/open-id.md +57 -0
- package/src/ruvocal/docs/source/configuration/overview.md +89 -0
- package/src/ruvocal/docs/source/configuration/theming.md +20 -0
- package/src/ruvocal/docs/source/developing/architecture.md +48 -0
- package/src/ruvocal/docs/source/index.md +53 -0
- package/src/ruvocal/docs/source/installation/docker.md +43 -0
- package/src/ruvocal/docs/source/installation/helm.md +43 -0
- package/src/ruvocal/docs/source/installation/local.md +62 -0
- package/src/ruvocal/entrypoint.sh +19 -0
- package/src/ruvocal/mcp-bridge/.claude-flow/agents/store.json +27 -0
- package/src/ruvocal/mcp-bridge/.claude-flow/daemon-state.json +130 -0
- package/src/ruvocal/mcp-bridge/.claude-flow/daemon.log +0 -0
- package/src/ruvocal/mcp-bridge/.claude-flow/daemon.pid +1 -0
- package/src/ruvocal/mcp-bridge/.claude-flow/tasks/store.json +21 -0
- package/src/ruvocal/mcp-bridge/.swarm/hnsw.index +0 -0
- package/src/ruvocal/mcp-bridge/.swarm/hnsw.metadata.json +1 -0
- package/src/ruvocal/mcp-bridge/.swarm/memory.db +0 -0
- package/src/ruvocal/mcp-bridge/.swarm/model-router-state.json +14 -0
- package/src/ruvocal/mcp-bridge/.swarm/schema.sql +305 -0
- package/src/ruvocal/mcp-bridge/Dockerfile +45 -0
- package/src/ruvocal/mcp-bridge/cloudbuild.yaml +49 -0
- package/src/ruvocal/mcp-bridge/index.js +1864 -0
- package/src/ruvocal/mcp-bridge/mcp-stdio-kernel.js +159 -0
- package/src/ruvocal/mcp-bridge/package-lock.json +762 -0
- package/src/ruvocal/mcp-bridge/package.json +17 -0
- package/src/ruvocal/mcp-bridge/test-harness.js +470 -0
- package/src/ruvocal/models/add-your-models-here.txt +1 -0
- package/src/ruvocal/package-lock.json +11741 -0
- package/src/ruvocal/package.json +121 -0
- package/src/ruvocal/postcss.config.js +6 -0
- package/src/ruvocal/rvf.manifest.json +204 -0
- package/src/ruvocal/scripts/config.ts +64 -0
- package/src/ruvocal/scripts/generate-welcome.mjs +181 -0
- package/src/ruvocal/scripts/populate.ts +288 -0
- package/src/ruvocal/scripts/samples.txt +194 -0
- package/src/ruvocal/scripts/setups/vitest-setup-client.ts +0 -0
- package/src/ruvocal/scripts/setups/vitest-setup-server.ts +44 -0
- package/src/ruvocal/scripts/updateLocalEnv.ts +48 -0
- package/src/ruvocal/src/ambient.d.ts +7 -0
- package/src/ruvocal/src/app.d.ts +29 -0
- package/src/ruvocal/src/app.html +53 -0
- package/src/ruvocal/src/hooks.server.ts +32 -0
- package/src/ruvocal/src/hooks.ts +6 -0
- package/src/ruvocal/src/lib/APIClient.ts +148 -0
- package/src/ruvocal/src/lib/actions/clickOutside.ts +18 -0
- package/src/ruvocal/src/lib/actions/snapScrollToBottom.ts +346 -0
- package/src/ruvocal/src/lib/buildPrompt.ts +33 -0
- package/src/ruvocal/src/lib/components/AnnouncementBanner.svelte +20 -0
- package/src/ruvocal/src/lib/components/BackgroundGenerationPoller.svelte +168 -0
- package/src/ruvocal/src/lib/components/CodeBlock.svelte +73 -0
- package/src/ruvocal/src/lib/components/CopyToClipBoardBtn.svelte +92 -0
- package/src/ruvocal/src/lib/components/DeleteConversationModal.svelte +75 -0
- package/src/ruvocal/src/lib/components/EditConversationModal.svelte +100 -0
- package/src/ruvocal/src/lib/components/ExpandNavigation.svelte +22 -0
- package/src/ruvocal/src/lib/components/HoverTooltip.svelte +44 -0
- package/src/ruvocal/src/lib/components/HtmlPreviewModal.svelte +143 -0
- package/src/ruvocal/src/lib/components/InfiniteScroll.svelte +50 -0
- package/src/ruvocal/src/lib/components/MobileNav.svelte +300 -0
- package/src/ruvocal/src/lib/components/Modal.svelte +115 -0
- package/src/ruvocal/src/lib/components/ModelCardMetadata.svelte +71 -0
- package/src/ruvocal/src/lib/components/NavConversationItem.svelte +151 -0
- package/src/ruvocal/src/lib/components/NavMenu.svelte +295 -0
- package/src/ruvocal/src/lib/components/Pagination.svelte +97 -0
- package/src/ruvocal/src/lib/components/PaginationArrow.svelte +27 -0
- package/src/ruvocal/src/lib/components/Portal.svelte +24 -0
- package/src/ruvocal/src/lib/components/RetryBtn.svelte +18 -0
- package/src/ruvocal/src/lib/components/RuFloUniverse.svelte +185 -0
- package/src/ruvocal/src/lib/components/ScrollToBottomBtn.svelte +47 -0
- package/src/ruvocal/src/lib/components/ScrollToPreviousBtn.svelte +77 -0
- package/src/ruvocal/src/lib/components/ShareConversationModal.svelte +182 -0
- package/src/ruvocal/src/lib/components/StopGeneratingBtn.svelte +69 -0
- package/src/ruvocal/src/lib/components/SubscribeModal.svelte +87 -0
- package/src/ruvocal/src/lib/components/Switch.svelte +36 -0
- package/src/ruvocal/src/lib/components/SystemPromptModal.svelte +44 -0
- package/src/ruvocal/src/lib/components/Toast.svelte +27 -0
- package/src/ruvocal/src/lib/components/Tooltip.svelte +30 -0
- package/src/ruvocal/src/lib/components/WelcomeModal.svelte +46 -0
- package/src/ruvocal/src/lib/components/chat/Alternatives.svelte +77 -0
- package/src/ruvocal/src/lib/components/chat/BlockWrapper.svelte +72 -0
- package/src/ruvocal/src/lib/components/chat/ChatInput.svelte +490 -0
- package/src/ruvocal/src/lib/components/chat/ChatIntroduction.svelte +123 -0
- package/src/ruvocal/src/lib/components/chat/ChatMessage.svelte +548 -0
- package/src/ruvocal/src/lib/components/chat/ChatWindow.svelte +939 -0
- package/src/ruvocal/src/lib/components/chat/FileDropzone.svelte +92 -0
- package/src/ruvocal/src/lib/components/chat/ImageLightbox.svelte +66 -0
- package/src/ruvocal/src/lib/components/chat/MarkdownBlock.svelte +23 -0
- package/src/ruvocal/src/lib/components/chat/MarkdownRenderer.svelte +69 -0
- package/src/ruvocal/src/lib/components/chat/MarkdownRenderer.svelte.test.ts +58 -0
- package/src/ruvocal/src/lib/components/chat/MessageAvatar.svelte +103 -0
- package/src/ruvocal/src/lib/components/chat/ModelSwitch.svelte +64 -0
- package/src/ruvocal/src/lib/components/chat/OpenReasoningResults.svelte +81 -0
- package/src/ruvocal/src/lib/components/chat/TaskGroup.svelte +88 -0
- package/src/ruvocal/src/lib/components/chat/ToolUpdate.svelte +273 -0
- package/src/ruvocal/src/lib/components/chat/UploadedFile.svelte +253 -0
- package/src/ruvocal/src/lib/components/chat/UrlFetchModal.svelte +203 -0
- package/src/ruvocal/src/lib/components/chat/VoiceRecorder.svelte +214 -0
- package/src/ruvocal/src/lib/components/icons/IconBurger.svelte +20 -0
- package/src/ruvocal/src/lib/components/icons/IconCheap.svelte +20 -0
- package/src/ruvocal/src/lib/components/icons/IconChevron.svelte +24 -0
- package/src/ruvocal/src/lib/components/icons/IconDazzled.svelte +40 -0
- package/src/ruvocal/src/lib/components/icons/IconFast.svelte +20 -0
- package/src/ruvocal/src/lib/components/icons/IconLoading.svelte +22 -0
- package/src/ruvocal/src/lib/components/icons/IconMCP.svelte +28 -0
- package/src/ruvocal/src/lib/components/icons/IconMoon.svelte +21 -0
- package/src/ruvocal/src/lib/components/icons/IconNew.svelte +20 -0
- package/src/ruvocal/src/lib/components/icons/IconOmni.svelte +90 -0
- package/src/ruvocal/src/lib/components/icons/IconPaperclip.svelte +24 -0
- package/src/ruvocal/src/lib/components/icons/IconPro.svelte +37 -0
- package/src/ruvocal/src/lib/components/icons/IconShare.svelte +21 -0
- package/src/ruvocal/src/lib/components/icons/IconSun.svelte +93 -0
- package/src/ruvocal/src/lib/components/icons/Logo.svelte +68 -0
- package/src/ruvocal/src/lib/components/icons/LogoHuggingFaceBorderless.svelte +54 -0
- package/src/ruvocal/src/lib/components/mcp/AddServerForm.svelte +250 -0
- package/src/ruvocal/src/lib/components/mcp/MCPServerManager.svelte +185 -0
- package/src/ruvocal/src/lib/components/mcp/ServerCard.svelte +203 -0
- package/src/ruvocal/src/lib/components/players/AudioPlayer.svelte +82 -0
- package/src/ruvocal/src/lib/components/voice/AudioWaveform.svelte +96 -0
- package/src/ruvocal/src/lib/constants/mcpExamples.ts +135 -0
- package/src/ruvocal/src/lib/constants/mime.ts +11 -0
- package/src/ruvocal/src/lib/constants/pagination.ts +1 -0
- package/src/ruvocal/src/lib/constants/publicSepToken.ts +1 -0
- package/src/ruvocal/src/lib/constants/routerExamples.ts +209 -0
- package/src/ruvocal/src/lib/createShareLink.ts +27 -0
- package/src/ruvocal/src/lib/jobs/refresh-conversation-stats.ts +297 -0
- package/src/ruvocal/src/lib/migrations/lock.ts +56 -0
- package/src/ruvocal/src/lib/migrations/migrations.spec.ts +74 -0
- package/src/ruvocal/src/lib/migrations/migrations.ts +109 -0
- package/src/ruvocal/src/lib/migrations/routines/01-update-search-assistants.ts +50 -0
- package/src/ruvocal/src/lib/migrations/routines/02-update-assistants-models.ts +48 -0
- package/src/ruvocal/src/lib/migrations/routines/04-update-message-updates.ts +151 -0
- package/src/ruvocal/src/lib/migrations/routines/05-update-message-files.ts +56 -0
- package/src/ruvocal/src/lib/migrations/routines/06-trim-message-updates.ts +56 -0
- package/src/ruvocal/src/lib/migrations/routines/08-update-featured-to-review.ts +32 -0
- package/src/ruvocal/src/lib/migrations/routines/09-delete-empty-conversations.spec.ts +214 -0
- package/src/ruvocal/src/lib/migrations/routines/09-delete-empty-conversations.ts +88 -0
- package/src/ruvocal/src/lib/migrations/routines/10-update-reports-assistantid.ts +29 -0
- package/src/ruvocal/src/lib/migrations/routines/index.ts +15 -0
- package/src/ruvocal/src/lib/server/__tests__/conversation-stop-generating.spec.ts +103 -0
- package/src/ruvocal/src/lib/server/abortRegistry.ts +57 -0
- package/src/ruvocal/src/lib/server/abortedGenerations.ts +43 -0
- package/src/ruvocal/src/lib/server/adminToken.ts +62 -0
- package/src/ruvocal/src/lib/server/api/__tests__/conversations-id.spec.ts +296 -0
- package/src/ruvocal/src/lib/server/api/__tests__/conversations-message.spec.ts +216 -0
- package/src/ruvocal/src/lib/server/api/__tests__/conversations.spec.ts +235 -0
- package/src/ruvocal/src/lib/server/api/__tests__/misc.spec.ts +72 -0
- package/src/ruvocal/src/lib/server/api/__tests__/testHelpers.ts +86 -0
- package/src/ruvocal/src/lib/server/api/__tests__/user-reports.spec.ts +78 -0
- package/src/ruvocal/src/lib/server/api/__tests__/user.spec.ts +239 -0
- package/src/ruvocal/src/lib/server/api/types.ts +37 -0
- package/src/ruvocal/src/lib/server/api/utils/requireAuth.ts +22 -0
- package/src/ruvocal/src/lib/server/api/utils/resolveConversation.ts +69 -0
- package/src/ruvocal/src/lib/server/api/utils/resolveModel.ts +27 -0
- package/src/ruvocal/src/lib/server/api/utils/superjsonResponse.ts +15 -0
- package/src/ruvocal/src/lib/server/apiToken.ts +11 -0
- package/src/ruvocal/src/lib/server/auth.ts +554 -0
- package/src/ruvocal/src/lib/server/config.ts +187 -0
- package/src/ruvocal/src/lib/server/conversation.ts +83 -0
- package/src/ruvocal/src/lib/server/database/__tests__/rvf.spec.ts +709 -0
- package/src/ruvocal/src/lib/server/database/postgres.ts +700 -0
- package/src/ruvocal/src/lib/server/database/rvf.ts +1078 -0
- package/src/ruvocal/src/lib/server/database.ts +145 -0
- package/src/ruvocal/src/lib/server/endpoints/document.ts +68 -0
- package/src/ruvocal/src/lib/server/endpoints/endpoints.ts +43 -0
- package/src/ruvocal/src/lib/server/endpoints/images.ts +211 -0
- package/src/ruvocal/src/lib/server/endpoints/openai/endpointOai.ts +266 -0
- package/src/ruvocal/src/lib/server/endpoints/openai/openAIChatToTextGenerationStream.ts +212 -0
- package/src/ruvocal/src/lib/server/endpoints/openai/openAICompletionToTextGenerationStream.ts +32 -0
- package/src/ruvocal/src/lib/server/endpoints/preprocessMessages.ts +61 -0
- package/src/ruvocal/src/lib/server/exitHandler.ts +59 -0
- package/src/ruvocal/src/lib/server/files/downloadFile.ts +34 -0
- package/src/ruvocal/src/lib/server/files/uploadFile.ts +29 -0
- package/src/ruvocal/src/lib/server/findRepoRoot.ts +13 -0
- package/src/ruvocal/src/lib/server/fonts/Inter-Black.ttf +0 -0
- package/src/ruvocal/src/lib/server/fonts/Inter-Bold.ttf +0 -0
- package/src/ruvocal/src/lib/server/fonts/Inter-ExtraBold.ttf +0 -0
- package/src/ruvocal/src/lib/server/fonts/Inter-ExtraLight.ttf +0 -0
- package/src/ruvocal/src/lib/server/fonts/Inter-Light.ttf +0 -0
- package/src/ruvocal/src/lib/server/fonts/Inter-Medium.ttf +0 -0
- package/src/ruvocal/src/lib/server/fonts/Inter-Regular.ttf +0 -0
- package/src/ruvocal/src/lib/server/fonts/Inter-SemiBold.ttf +0 -0
- package/src/ruvocal/src/lib/server/fonts/Inter-Thin.ttf +0 -0
- package/src/ruvocal/src/lib/server/generateFromDefaultEndpoint.ts +46 -0
- package/src/ruvocal/src/lib/server/hooks/error.ts +37 -0
- package/src/ruvocal/src/lib/server/hooks/fetch.ts +22 -0
- package/src/ruvocal/src/lib/server/hooks/handle.ts +250 -0
- package/src/ruvocal/src/lib/server/hooks/init.ts +51 -0
- package/src/ruvocal/src/lib/server/isURLLocal.spec.ts +31 -0
- package/src/ruvocal/src/lib/server/isURLLocal.ts +74 -0
- package/src/ruvocal/src/lib/server/logger.ts +42 -0
- package/src/ruvocal/src/lib/server/mcp/clientPool.ts +70 -0
- package/src/ruvocal/src/lib/server/mcp/hf.ts +32 -0
- package/src/ruvocal/src/lib/server/mcp/httpClient.ts +122 -0
- package/src/ruvocal/src/lib/server/mcp/registry.ts +76 -0
- package/src/ruvocal/src/lib/server/mcp/tools.ts +196 -0
- package/src/ruvocal/src/lib/server/metrics.ts +255 -0
- package/src/ruvocal/src/lib/server/models.ts +518 -0
- package/src/ruvocal/src/lib/server/requestContext.ts +55 -0
- package/src/ruvocal/src/lib/server/router/arch.ts +230 -0
- package/src/ruvocal/src/lib/server/router/endpoint.ts +316 -0
- package/src/ruvocal/src/lib/server/router/multimodal.ts +28 -0
- package/src/ruvocal/src/lib/server/router/policy.ts +49 -0
- package/src/ruvocal/src/lib/server/router/toolsRoute.ts +51 -0
- package/src/ruvocal/src/lib/server/router/types.ts +21 -0
- package/src/ruvocal/src/lib/server/sendSlack.ts +23 -0
- package/src/ruvocal/src/lib/server/textGeneration/generate.ts +258 -0
- package/src/ruvocal/src/lib/server/textGeneration/index.ts +95 -0
- package/src/ruvocal/src/lib/server/textGeneration/mcp/fileRefs.ts +155 -0
- package/src/ruvocal/src/lib/server/textGeneration/mcp/routerResolution.ts +108 -0
- package/src/ruvocal/src/lib/server/textGeneration/mcp/runMcpFlow.ts +822 -0
- package/src/ruvocal/src/lib/server/textGeneration/mcp/toolInvocation.ts +349 -0
- package/src/ruvocal/src/lib/server/textGeneration/reasoning.ts +23 -0
- package/src/ruvocal/src/lib/server/textGeneration/title.ts +83 -0
- package/src/ruvocal/src/lib/server/textGeneration/types.ts +26 -0
- package/src/ruvocal/src/lib/server/textGeneration/utils/prepareFiles.ts +88 -0
- package/src/ruvocal/src/lib/server/textGeneration/utils/routing.ts +21 -0
- package/src/ruvocal/src/lib/server/textGeneration/utils/toolPrompt.ts +49 -0
- package/src/ruvocal/src/lib/server/urlSafety.ts +72 -0
- package/src/ruvocal/src/lib/server/usageLimits.ts +30 -0
- package/src/ruvocal/src/lib/stores/autopilotStore.svelte.ts +175 -0
- package/src/ruvocal/src/lib/stores/backgroundGenerations.svelte.ts +32 -0
- package/src/ruvocal/src/lib/stores/backgroundGenerations.ts +1 -0
- package/src/ruvocal/src/lib/stores/errors.ts +9 -0
- package/src/ruvocal/src/lib/stores/isAborted.ts +3 -0
- package/src/ruvocal/src/lib/stores/isPro.ts +4 -0
- package/src/ruvocal/src/lib/stores/loading.ts +3 -0
- package/src/ruvocal/src/lib/stores/mcpServers.ts +345 -0
- package/src/ruvocal/src/lib/stores/pendingChatInput.ts +3 -0
- package/src/ruvocal/src/lib/stores/pendingMessage.ts +9 -0
- package/src/ruvocal/src/lib/stores/settings.ts +182 -0
- package/src/ruvocal/src/lib/stores/shareModal.ts +13 -0
- package/src/ruvocal/src/lib/stores/titleUpdate.ts +8 -0
- package/src/ruvocal/src/lib/switchTheme.ts +124 -0
- package/src/ruvocal/src/lib/types/AbortedGeneration.ts +8 -0
- package/src/ruvocal/src/lib/types/Assistant.ts +31 -0
- package/src/ruvocal/src/lib/types/AssistantStats.ts +11 -0
- package/src/ruvocal/src/lib/types/ConfigKey.ts +4 -0
- package/src/ruvocal/src/lib/types/ConvSidebar.ts +9 -0
- package/src/ruvocal/src/lib/types/Conversation.ts +27 -0
- package/src/ruvocal/src/lib/types/ConversationStats.ts +13 -0
- package/src/ruvocal/src/lib/types/Message.ts +41 -0
- package/src/ruvocal/src/lib/types/MessageEvent.ts +10 -0
- package/src/ruvocal/src/lib/types/MessageUpdate.ts +139 -0
- package/src/ruvocal/src/lib/types/MigrationResult.ts +7 -0
- package/src/ruvocal/src/lib/types/Model.ts +23 -0
- package/src/ruvocal/src/lib/types/Report.ts +12 -0
- package/src/ruvocal/src/lib/types/Review.ts +6 -0
- package/src/ruvocal/src/lib/types/Semaphore.ts +19 -0
- package/src/ruvocal/src/lib/types/Session.ts +22 -0
- package/src/ruvocal/src/lib/types/Settings.ts +86 -0
- package/src/ruvocal/src/lib/types/SharedConversation.ts +9 -0
- package/src/ruvocal/src/lib/types/Template.ts +6 -0
- package/src/ruvocal/src/lib/types/Timestamps.ts +4 -0
- package/src/ruvocal/src/lib/types/TokenCache.ts +6 -0
- package/src/ruvocal/src/lib/types/Tool.ts +74 -0
- package/src/ruvocal/src/lib/types/UrlDependency.ts +5 -0
- package/src/ruvocal/src/lib/types/User.ts +14 -0
- package/src/ruvocal/src/lib/utils/PublicConfig.svelte.ts +75 -0
- package/src/ruvocal/src/lib/utils/auth.ts +17 -0
- package/src/ruvocal/src/lib/utils/chunk.ts +33 -0
- package/src/ruvocal/src/lib/utils/cookiesAreEnabled.ts +13 -0
- package/src/ruvocal/src/lib/utils/debounce.ts +17 -0
- package/src/ruvocal/src/lib/utils/deepestChild.ts +6 -0
- package/src/ruvocal/src/lib/utils/favicon.ts +21 -0
- package/src/ruvocal/src/lib/utils/fetchJSON.ts +23 -0
- package/src/ruvocal/src/lib/utils/file2base64.ts +14 -0
- package/src/ruvocal/src/lib/utils/formatUserCount.ts +37 -0
- package/src/ruvocal/src/lib/utils/generationState.spec.ts +75 -0
- package/src/ruvocal/src/lib/utils/generationState.ts +26 -0
- package/src/ruvocal/src/lib/utils/getHref.ts +41 -0
- package/src/ruvocal/src/lib/utils/getReturnFromGenerator.ts +7 -0
- package/src/ruvocal/src/lib/utils/haptics.ts +64 -0
- package/src/ruvocal/src/lib/utils/hashConv.ts +12 -0
- package/src/ruvocal/src/lib/utils/hf.ts +17 -0
- package/src/ruvocal/src/lib/utils/isDesktop.ts +7 -0
- package/src/ruvocal/src/lib/utils/isUrl.ts +8 -0
- package/src/ruvocal/src/lib/utils/isVirtualKeyboard.ts +16 -0
- package/src/ruvocal/src/lib/utils/loadAttachmentsFromUrls.ts +115 -0
- package/src/ruvocal/src/lib/utils/marked.spec.ts +96 -0
- package/src/ruvocal/src/lib/utils/marked.ts +531 -0
- package/src/ruvocal/src/lib/utils/mcpValidation.ts +147 -0
- package/src/ruvocal/src/lib/utils/mergeAsyncGenerators.ts +38 -0
- package/src/ruvocal/src/lib/utils/messageUpdates.spec.ts +262 -0
- package/src/ruvocal/src/lib/utils/messageUpdates.ts +324 -0
- package/src/ruvocal/src/lib/utils/mime.ts +56 -0
- package/src/ruvocal/src/lib/utils/models.ts +14 -0
- package/src/ruvocal/src/lib/utils/parseBlocks.ts +120 -0
- package/src/ruvocal/src/lib/utils/parseIncompleteMarkdown.ts +644 -0
- package/src/ruvocal/src/lib/utils/parseStringToList.ts +10 -0
- package/src/ruvocal/src/lib/utils/randomUuid.ts +14 -0
- package/src/ruvocal/src/lib/utils/searchTokens.ts +33 -0
- package/src/ruvocal/src/lib/utils/sha256.ts +7 -0
- package/src/ruvocal/src/lib/utils/stringifyError.ts +12 -0
- package/src/ruvocal/src/lib/utils/sum.ts +3 -0
- package/src/ruvocal/src/lib/utils/template.spec.ts +59 -0
- package/src/ruvocal/src/lib/utils/template.ts +53 -0
- package/src/ruvocal/src/lib/utils/timeout.ts +9 -0
- package/src/ruvocal/src/lib/utils/toolProgress.spec.ts +46 -0
- package/src/ruvocal/src/lib/utils/toolProgress.ts +11 -0
- package/src/ruvocal/src/lib/utils/tree/addChildren.spec.ts +102 -0
- package/src/ruvocal/src/lib/utils/tree/addChildren.ts +48 -0
- package/src/ruvocal/src/lib/utils/tree/addSibling.spec.ts +81 -0
- package/src/ruvocal/src/lib/utils/tree/addSibling.ts +41 -0
- package/src/ruvocal/src/lib/utils/tree/buildSubtree.spec.ts +110 -0
- package/src/ruvocal/src/lib/utils/tree/buildSubtree.ts +24 -0
- package/src/ruvocal/src/lib/utils/tree/convertLegacyConversation.spec.ts +31 -0
- package/src/ruvocal/src/lib/utils/tree/convertLegacyConversation.ts +36 -0
- package/src/ruvocal/src/lib/utils/tree/isMessageId.spec.ts +15 -0
- package/src/ruvocal/src/lib/utils/tree/isMessageId.ts +5 -0
- package/src/ruvocal/src/lib/utils/tree/tree.d.ts +14 -0
- package/src/ruvocal/src/lib/utils/tree/treeHelpers.spec.ts +167 -0
- package/src/ruvocal/src/lib/utils/updates.ts +39 -0
- package/src/ruvocal/src/lib/utils/urlParams.ts +13 -0
- package/src/ruvocal/src/lib/workers/autopilotWorker.ts +221 -0
- package/src/ruvocal/src/lib/workers/detailFetchWorker.ts +100 -0
- package/src/ruvocal/src/lib/workers/markdownWorker.ts +61 -0
- package/src/ruvocal/src/routes/+error.svelte +20 -0
- package/src/ruvocal/src/routes/+layout.svelte +324 -0
- package/src/ruvocal/src/routes/+layout.ts +91 -0
- package/src/ruvocal/src/routes/+page.svelte +168 -0
- package/src/ruvocal/src/routes/.well-known/oauth-cimd/+server.ts +37 -0
- package/src/ruvocal/src/routes/__debug/openai/+server.ts +21 -0
- package/src/ruvocal/src/routes/admin/export/+server.ts +159 -0
- package/src/ruvocal/src/routes/admin/stats/compute/+server.ts +16 -0
- package/src/ruvocal/src/routes/api/conversation/[id]/+server.ts +40 -0
- package/src/ruvocal/src/routes/api/conversation/[id]/message/[messageId]/+server.ts +42 -0
- package/src/ruvocal/src/routes/api/conversations/+server.ts +48 -0
- package/src/ruvocal/src/routes/api/fetch-url/+server.ts +147 -0
- package/src/ruvocal/src/routes/api/mcp/health/+server.ts +292 -0
- package/src/ruvocal/src/routes/api/mcp/servers/+server.ts +32 -0
- package/src/ruvocal/src/routes/api/models/+server.ts +25 -0
- package/src/ruvocal/src/routes/api/transcribe/+server.ts +104 -0
- package/src/ruvocal/src/routes/api/user/+server.ts +15 -0
- package/src/ruvocal/src/routes/api/user/validate-token/+server.ts +20 -0
- package/src/ruvocal/src/routes/api/v2/conversations/+server.ts +48 -0
- package/src/ruvocal/src/routes/api/v2/conversations/[id]/+server.ts +94 -0
- package/src/ruvocal/src/routes/api/v2/conversations/[id]/message/[messageId]/+server.ts +43 -0
- package/src/ruvocal/src/routes/api/v2/conversations/import-share/+server.ts +23 -0
- package/src/ruvocal/src/routes/api/v2/debug/config/+server.ts +16 -0
- package/src/ruvocal/src/routes/api/v2/debug/refresh/+server.ts +30 -0
- package/src/ruvocal/src/routes/api/v2/export/+server.ts +196 -0
- package/src/ruvocal/src/routes/api/v2/feature-flags/+server.ts +14 -0
- package/src/ruvocal/src/routes/api/v2/models/+server.ts +38 -0
- package/src/ruvocal/src/routes/api/v2/models/[namespace]/+server.ts +8 -0
- package/src/ruvocal/src/routes/api/v2/models/[namespace]/[model]/+server.ts +8 -0
- package/src/ruvocal/src/routes/api/v2/models/[namespace]/[model]/subscribe/+server.ts +28 -0
- package/src/ruvocal/src/routes/api/v2/models/[namespace]/subscribe/+server.ts +28 -0
- package/src/ruvocal/src/routes/api/v2/models/old/+server.ts +7 -0
- package/src/ruvocal/src/routes/api/v2/models/refresh/+server.ts +33 -0
- package/src/ruvocal/src/routes/api/v2/public-config/+server.ts +7 -0
- package/src/ruvocal/src/routes/api/v2/user/+server.ts +17 -0
- package/src/ruvocal/src/routes/api/v2/user/billing-orgs/+server.ts +73 -0
- package/src/ruvocal/src/routes/api/v2/user/reports/+server.ts +17 -0
- package/src/ruvocal/src/routes/api/v2/user/settings/+server.ts +103 -0
- package/src/ruvocal/src/routes/conversation/+server.ts +115 -0
- package/src/ruvocal/src/routes/conversation/[id]/+page.svelte +582 -0
- package/src/ruvocal/src/routes/conversation/[id]/+page.ts +60 -0
- package/src/ruvocal/src/routes/conversation/[id]/+server.ts +736 -0
- package/src/ruvocal/src/routes/conversation/[id]/message/[messageId]/prompt/+server.ts +66 -0
- package/src/ruvocal/src/routes/conversation/[id]/output/[sha256]/+server.ts +58 -0
- package/src/ruvocal/src/routes/conversation/[id]/share/+server.ts +69 -0
- package/src/ruvocal/src/routes/conversation/[id]/stop-generating/+server.ts +35 -0
- package/src/ruvocal/src/routes/healthcheck/+server.ts +3 -0
- package/src/ruvocal/src/routes/login/+server.ts +5 -0
- package/src/ruvocal/src/routes/login/callback/+server.ts +103 -0
- package/src/ruvocal/src/routes/login/callback/updateUser.spec.ts +157 -0
- package/src/ruvocal/src/routes/login/callback/updateUser.ts +215 -0
- package/src/ruvocal/src/routes/logout/+server.ts +18 -0
- package/src/ruvocal/src/routes/metrics/+server.ts +18 -0
- package/src/ruvocal/src/routes/models/+page.svelte +233 -0
- package/src/ruvocal/src/routes/models/[...model]/+page.svelte +161 -0
- package/src/ruvocal/src/routes/models/[...model]/+page.ts +14 -0
- package/src/ruvocal/src/routes/models/[...model]/thumbnail.png/+server.ts +64 -0
- package/src/ruvocal/src/routes/models/[...model]/thumbnail.png/ModelThumbnail.svelte +28 -0
- package/src/ruvocal/src/routes/privacy/+page.svelte +11 -0
- package/src/ruvocal/src/routes/r/[id]/+page.ts +34 -0
- package/src/ruvocal/src/routes/settings/(nav)/+layout.svelte +282 -0
- package/src/ruvocal/src/routes/settings/(nav)/+layout.ts +1 -0
- package/src/ruvocal/src/routes/settings/(nav)/+page.svelte +0 -0
- package/src/ruvocal/src/routes/settings/(nav)/+server.ts +53 -0
- package/src/ruvocal/src/routes/settings/(nav)/[...model]/+page.svelte +464 -0
- package/src/ruvocal/src/routes/settings/(nav)/[...model]/+page.ts +14 -0
- package/src/ruvocal/src/routes/settings/(nav)/application/+page.svelte +362 -0
- package/src/ruvocal/src/routes/settings/+layout.svelte +40 -0
- package/src/ruvocal/src/styles/highlight-js.css +195 -0
- package/src/ruvocal/src/styles/main.css +144 -0
- package/src/ruvocal/static/chatui/apple-touch-icon.png +0 -0
- package/src/ruvocal/static/chatui/favicon-dark.svg +3 -0
- package/src/ruvocal/static/chatui/favicon-dev.svg +3 -0
- package/src/ruvocal/static/chatui/favicon.ico +0 -0
- package/src/ruvocal/static/chatui/favicon.svg +3 -0
- package/src/ruvocal/static/chatui/icon-128x128.png +0 -0
- package/src/ruvocal/static/chatui/icon-144x144.png +0 -0
- package/src/ruvocal/static/chatui/icon-192x192.png +0 -0
- package/src/ruvocal/static/chatui/icon-256x256.png +0 -0
- package/src/ruvocal/static/chatui/icon-36x36.png +0 -0
- package/src/ruvocal/static/chatui/icon-48x48.png +0 -0
- package/src/ruvocal/static/chatui/icon-512x512.png +0 -0
- package/src/ruvocal/static/chatui/icon-72x72.png +0 -0
- package/src/ruvocal/static/chatui/icon-96x96.png +0 -0
- package/src/ruvocal/static/chatui/icon.svg +3 -0
- package/src/ruvocal/static/chatui/logo.svg +7 -0
- package/src/ruvocal/static/chatui/manifest.json +54 -0
- package/src/ruvocal/static/chatui/omni-welcome.gif +0 -0
- package/src/ruvocal/static/chatui/omni-welcome.png +0 -0
- package/src/ruvocal/static/chatui/welcome.js +184 -0
- package/src/ruvocal/static/chatui/welcome.svg +1 -0
- package/src/ruvocal/static/huggingchat/apple-touch-icon.png +0 -0
- package/src/ruvocal/static/huggingchat/assistants-thumbnail.png +0 -0
- package/src/ruvocal/static/huggingchat/castle-example.jpg +0 -0
- package/src/ruvocal/static/huggingchat/favicon-dark.svg +4 -0
- package/src/ruvocal/static/huggingchat/favicon-dev.svg +4 -0
- package/src/ruvocal/static/huggingchat/favicon.ico +0 -0
- package/src/ruvocal/static/huggingchat/favicon.svg +4 -0
- package/src/ruvocal/static/huggingchat/fulltext-logo.svg +2 -0
- package/src/ruvocal/static/huggingchat/icon-128x128.png +0 -0
- package/src/ruvocal/static/huggingchat/icon-144x144.png +0 -0
- package/src/ruvocal/static/huggingchat/icon-192x192.png +0 -0
- package/src/ruvocal/static/huggingchat/icon-256x256.png +0 -0
- package/src/ruvocal/static/huggingchat/icon-36x36.png +0 -0
- package/src/ruvocal/static/huggingchat/icon-48x48.png +0 -0
- package/src/ruvocal/static/huggingchat/icon-512x512.png +0 -0
- package/src/ruvocal/static/huggingchat/icon-72x72.png +0 -0
- package/src/ruvocal/static/huggingchat/icon-96x96.png +0 -0
- package/src/ruvocal/static/huggingchat/icon.svg +4 -0
- package/src/ruvocal/static/huggingchat/logo.svg +4 -0
- package/src/ruvocal/static/huggingchat/manifest.json +54 -0
- package/src/ruvocal/static/huggingchat/omni-welcome.gif +0 -0
- package/src/ruvocal/static/huggingchat/routes.chat.json +226 -0
- package/src/ruvocal/static/huggingchat/thumbnail.png +0 -0
- package/src/ruvocal/static/huggingchat/tools-thumbnail.png +0 -0
- package/src/ruvocal/static/robots.txt +10 -0
- package/src/ruvocal/stub/@reflink/reflink/index.js +0 -0
- package/src/ruvocal/stub/@reflink/reflink/package.json +5 -0
- package/src/ruvocal/svelte.config.js +53 -0
- package/src/ruvocal/tailwind.config.cjs +30 -0
- package/src/ruvocal/tsconfig.json +19 -0
- package/src/ruvocal/vite.config.ts +87 -0
- package/src/scripts/deploy.sh +116 -0
- package/src/scripts/generate-config.js +245 -0
- package/src/scripts/generate-welcome.js +187 -0
- package/src/scripts/package-rvf.sh +116 -0
|
@@ -0,0 +1,286 @@
|
|
|
1
|
+
# ADR-038: RuVocal — HF Chat UI Fork with Self-Contained RVF Document Store
|
|
2
|
+
|
|
3
|
+
**Status:** Implemented
|
|
4
|
+
**Date:** 2026-03-05
|
|
5
|
+
**Updated:** 2026-03-05
|
|
6
|
+
**Related:** ADR-029 (HF Chat UI Integration), ADR-035 (MCP Tool Groups), ADR-037 (Autopilot Mode)
|
|
7
|
+
|
|
8
|
+
## Context
|
|
9
|
+
|
|
10
|
+
The current `chat-ui-mcp` package uses the upstream HuggingFace Chat UI (`ghcr.io/huggingface/chat-ui-db:latest`) which bundles MongoDB for conversation storage. This creates several problems:
|
|
11
|
+
|
|
12
|
+
1. **External dependency** — MongoDB requires a running server, connection management, and separate backup strategy.
|
|
13
|
+
2. **Container bloat** — MongoDB adds ~500MB to the container image.
|
|
14
|
+
3. **Upstream lock-in** — Using a pre-built Docker image means we can't modify the SvelteKit app.
|
|
15
|
+
4. **Operational complexity** — Two databases (MongoDB + PostgreSQL) to maintain.
|
|
16
|
+
|
|
17
|
+
We initially considered PostgreSQL (ruvector-postgres) as the replacement, but pivoted to a lighter approach: a self-contained RVF (RuVector Format) document store that persists to a single JSON file on disk. This eliminates all external database dependencies while preserving the full MongoDB Collection API.
|
|
18
|
+
|
|
19
|
+
## Decision
|
|
20
|
+
|
|
21
|
+
Fork HuggingFace Chat UI as **RuVocal** (`/workspaces/dev/packages/ruvocal`), replacing MongoDB with a pure TypeScript in-memory document store persisted to a single `.rvf.json` file.
|
|
22
|
+
|
|
23
|
+
### Name
|
|
24
|
+
|
|
25
|
+
**RuVocal** = **Ru**Vector + **Vocal** (voice/conversation). A conversational AI interface powered by ruvector.
|
|
26
|
+
|
|
27
|
+
## Architecture
|
|
28
|
+
|
|
29
|
+
```
|
|
30
|
+
┌─────────────────────────────────────────────────────────────────┐
|
|
31
|
+
│ RuVocal Stack │
|
|
32
|
+
│ │
|
|
33
|
+
│ ┌──────────────────┐ ┌──────────────────┐ │
|
|
34
|
+
│ │ RuVocal UI │ │ MCP Bridge │ │
|
|
35
|
+
│ │ (SvelteKit 2) │───▶│ (Node.js) │ │
|
|
36
|
+
│ │ │ │ │ │
|
|
37
|
+
│ │ - Chat UI │ │ - Tool proxy │ │
|
|
38
|
+
│ │ - Autopilot │ │ - Autopilot SSE │ │
|
|
39
|
+
│ │ - Task cards │ │ - System prompt │ │
|
|
40
|
+
│ │ - Auth (OIDC) │ │ - 201 tools │ │
|
|
41
|
+
│ └────────┬─────────┘ └──────────────────┘ │
|
|
42
|
+
│ │ │
|
|
43
|
+
│ ▼ │
|
|
44
|
+
│ ┌──────────────────────────────────────────┐ │
|
|
45
|
+
│ │ RVF Document Store │ │
|
|
46
|
+
│ │ (In-Memory + Disk Persist) │ │
|
|
47
|
+
│ │ │ │
|
|
48
|
+
│ │ File: db/ruvocal.rvf.json │ │
|
|
49
|
+
│ │ │ │
|
|
50
|
+
│ │ Collections (16): │ │
|
|
51
|
+
│ │ - conversations (chat sessions) │ │
|
|
52
|
+
│ │ - users (auth/profiles) │ │
|
|
53
|
+
│ │ - sessions (auth sessions) │ │
|
|
54
|
+
│ │ - settings (user preferences) │ │
|
|
55
|
+
│ │ - assistants (custom assistants) │ │
|
|
56
|
+
│ │ - reports (abuse reports) │ │
|
|
57
|
+
│ │ - messageEvents (feedback/votes) │ │
|
|
58
|
+
│ │ - semaphores (rate limiting) │ │
|
|
59
|
+
│ │ - tokens (token cache) │ │
|
|
60
|
+
│ │ - config (runtime config) │ │
|
|
61
|
+
│ │ - migrationResults (migration tracking) │ │
|
|
62
|
+
│ │ - tools (tool registry) │ │
|
|
63
|
+
│ │ - _files (GridFS replacement) │ │
|
|
64
|
+
│ │ + per-tenant namespaced collections │ │
|
|
65
|
+
│ │ │ │
|
|
66
|
+
│ │ Features: │ │
|
|
67
|
+
│ │ - MongoDB-compatible Collection API │ │
|
|
68
|
+
│ │ - Multi-tenant data isolation │ │
|
|
69
|
+
│ │ - Debounced auto-save (500ms) │ │
|
|
70
|
+
│ │ - Zero external dependencies │ │
|
|
71
|
+
│ └───────────────────────────────────────────┘ │
|
|
72
|
+
└─────────────────────────────────────────────────────────────────┘
|
|
73
|
+
```
|
|
74
|
+
|
|
75
|
+
## RVF Document Store (`rvf.ts`)
|
|
76
|
+
|
|
77
|
+
### Storage Format
|
|
78
|
+
|
|
79
|
+
```json
|
|
80
|
+
{
|
|
81
|
+
"rvf_version": "2.0",
|
|
82
|
+
"format": "rvf-database",
|
|
83
|
+
"collections": {
|
|
84
|
+
"conversations": { "id1": {...}, "id2": {...} },
|
|
85
|
+
"users": { ... },
|
|
86
|
+
...
|
|
87
|
+
},
|
|
88
|
+
"tenants": {
|
|
89
|
+
"tenant-a": { "conversations": {...}, ... },
|
|
90
|
+
"tenant-b": { "conversations": {...}, ... }
|
|
91
|
+
},
|
|
92
|
+
"metadata": {
|
|
93
|
+
"created_at": "2026-03-05T...",
|
|
94
|
+
"updated_at": "2026-03-05T...",
|
|
95
|
+
"doc_count": 1234,
|
|
96
|
+
"multi_tenant": true
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
```
|
|
100
|
+
|
|
101
|
+
### MongoDB-Compatible API
|
|
102
|
+
|
|
103
|
+
The `RvfCollection<T>` class implements the full MongoDB Collection interface used by all 56 importing files in HF Chat UI:
|
|
104
|
+
|
|
105
|
+
```typescript
|
|
106
|
+
class RvfCollection<T> {
|
|
107
|
+
// CRUD
|
|
108
|
+
findOne(filter, options?): Promise<T | null>;
|
|
109
|
+
find(filter, options?): RvfCursor<T>;
|
|
110
|
+
insertOne(doc): Promise<{ insertedId: ObjectId }>;
|
|
111
|
+
insertMany(docs): Promise<{ insertedIds: ObjectId[] }>;
|
|
112
|
+
updateOne(filter, update, options?): Promise<UpdateResult>;
|
|
113
|
+
updateMany(filter, update): Promise<UpdateResult>;
|
|
114
|
+
deleteOne(filter): Promise<DeleteResult>;
|
|
115
|
+
deleteMany(filter): Promise<DeleteResult>;
|
|
116
|
+
countDocuments(filter?): Promise<number>;
|
|
117
|
+
distinct(field, filter?): Promise<unknown[]>;
|
|
118
|
+
bulkWrite(ops): Promise<BulkWriteResult>;
|
|
119
|
+
findOneAndUpdate(filter, update, options?): Promise<{ value: T | null }>;
|
|
120
|
+
findOneAndDelete(filter): Promise<{ value: T | null }>;
|
|
121
|
+
|
|
122
|
+
// Aggregation
|
|
123
|
+
aggregate(pipeline, options?): { next(): Promise<T | null>; toArray(): Promise<T[]> };
|
|
124
|
+
|
|
125
|
+
// Indexes (no-ops — in-memory store doesn't need them)
|
|
126
|
+
createIndex(spec, options?): Promise<void>;
|
|
127
|
+
listIndexes(): { toArray(): Promise<IndexInfo[]> };
|
|
128
|
+
|
|
129
|
+
// Multi-tenant
|
|
130
|
+
forTenant(tenantId: string): RvfCollection<T>;
|
|
131
|
+
}
|
|
132
|
+
```
|
|
133
|
+
|
|
134
|
+
### Query Operators Implemented
|
|
135
|
+
|
|
136
|
+
| Operator | Description |
|
|
137
|
+
|----------|-------------|
|
|
138
|
+
| `$or` | Logical OR |
|
|
139
|
+
| `$and` | Logical AND |
|
|
140
|
+
| `$not` | Logical NOT |
|
|
141
|
+
| `$exists` | Field existence |
|
|
142
|
+
| `$gt`, `$gte`, `$lt`, `$lte` | Comparison |
|
|
143
|
+
| `$ne` | Not equal |
|
|
144
|
+
| `$in`, `$nin` | Array membership |
|
|
145
|
+
| `$regex`, `$options` | Regular expression |
|
|
146
|
+
|
|
147
|
+
### Update Operators Implemented
|
|
148
|
+
|
|
149
|
+
| Operator | Description |
|
|
150
|
+
|----------|-------------|
|
|
151
|
+
| `$set` | Set field value |
|
|
152
|
+
| `$unset` | Remove field |
|
|
153
|
+
| `$inc` | Increment numeric field |
|
|
154
|
+
| `$push` | Push to array (with `$each`) |
|
|
155
|
+
| `$pull` | Remove from array |
|
|
156
|
+
| `$addToSet` | Add unique to array |
|
|
157
|
+
| `$setOnInsert` | Set on upsert only |
|
|
158
|
+
|
|
159
|
+
### Cursor API
|
|
160
|
+
|
|
161
|
+
```typescript
|
|
162
|
+
class RvfCursor<T> {
|
|
163
|
+
sort(spec): this;
|
|
164
|
+
limit(n): this;
|
|
165
|
+
skip(n): this;
|
|
166
|
+
project<U>(spec): RvfCursor<U>;
|
|
167
|
+
batchSize(n): this;
|
|
168
|
+
map<U>(fn): RvfCursor<U>;
|
|
169
|
+
toArray(): Promise<T[]>;
|
|
170
|
+
hasNext(): Promise<boolean>;
|
|
171
|
+
next(): Promise<T | null>;
|
|
172
|
+
tryNext(): Promise<T | null>;
|
|
173
|
+
[Symbol.asyncIterator](): AsyncGenerator<T>;
|
|
174
|
+
}
|
|
175
|
+
```
|
|
176
|
+
|
|
177
|
+
### Aggregation Pipeline Stages
|
|
178
|
+
|
|
179
|
+
| Stage | Description |
|
|
180
|
+
|-------|-------------|
|
|
181
|
+
| `$match` | Filter documents |
|
|
182
|
+
| `$sort` | Sort results |
|
|
183
|
+
| `$limit` | Limit result count |
|
|
184
|
+
| `$skip` | Skip results |
|
|
185
|
+
| `$project` | Include/exclude fields |
|
|
186
|
+
| `$group` | Group with `$sum`, `$count` |
|
|
187
|
+
|
|
188
|
+
## Multi-Tenant Support
|
|
189
|
+
|
|
190
|
+
Tenant isolation is built into the store at the collection level:
|
|
191
|
+
|
|
192
|
+
```typescript
|
|
193
|
+
// Global collection (default)
|
|
194
|
+
const conversations = new RvfCollection<Conversation>("conversations");
|
|
195
|
+
|
|
196
|
+
// Tenant-scoped view — fully isolated data
|
|
197
|
+
const tenantConvs = conversations.forTenant("tenant-abc");
|
|
198
|
+
await tenantConvs.insertOne({ title: "Hello" });
|
|
199
|
+
|
|
200
|
+
// Won't find tenant data
|
|
201
|
+
await conversations.findOne({ title: "Hello" }); // null
|
|
202
|
+
|
|
203
|
+
// Stats
|
|
204
|
+
listTenants(); // ["tenant-abc"]
|
|
205
|
+
getTenantStats(); // { "tenant-abc": { collections: 1, documents: 1 } }
|
|
206
|
+
```
|
|
207
|
+
|
|
208
|
+
Tenant data is persisted separately in the RVF file under the `tenants` key.
|
|
209
|
+
|
|
210
|
+
## Performance Benchmarks (47 tests, all passing)
|
|
211
|
+
|
|
212
|
+
| Operation | Dataset | Time | Throughput |
|
|
213
|
+
|-----------|---------|------|------------|
|
|
214
|
+
| Insert | 10,000 docs | 63ms | ~159k ops/s |
|
|
215
|
+
| Find (range) | 10,000 docs | 5ms | 1,000 results |
|
|
216
|
+
| UpdateMany | 10,000 docs | 15ms | 5,000 matched |
|
|
217
|
+
| Aggregate | 10,000 docs | 28ms | match+sort+limit |
|
|
218
|
+
| Concurrent (5 ops) | 1,000 docs | 1.9ms | mixed read/write |
|
|
219
|
+
| Multi-tenant insert | 10×1,000 docs | 25ms | 10 tenants |
|
|
220
|
+
| Single tenant query | 1,000 docs | 0.5ms | 499 results |
|
|
221
|
+
|
|
222
|
+
## Test Coverage
|
|
223
|
+
|
|
224
|
+
47 tests across 9 test suites:
|
|
225
|
+
|
|
226
|
+
- **CRUD** (13 tests): insertOne/Many, updateOne/Many, deleteOne/Many, countDocuments, distinct, findOneAndUpdate/Delete, bulkWrite
|
|
227
|
+
- **Query Operators** (7 tests): $gt/$gte/$lt/$lte, $ne, $in/$nin, $exists, $or/$and, $regex, $not
|
|
228
|
+
- **Update Operators** (6 tests): $inc, $push, $push+$each, $pull, $addToSet, $unset
|
|
229
|
+
- **Cursor** (4 tests): sort/limit/skip, async iterator, tryNext/hasNext/next, map
|
|
230
|
+
- **Aggregation** (3 tests): $match+$sort+$limit, aggregate().next(), $group+$sum
|
|
231
|
+
- **GridFS** (2 tests): upload+download, delete
|
|
232
|
+
- **Multi-tenant** (2 tests): isolation, listTenants+stats
|
|
233
|
+
- **Persistence** (1 test): flush to disk and reload
|
|
234
|
+
- **ObjectId** (3 tests): equals, createFromHexString, toJSON
|
|
235
|
+
- **Benchmarks** (6 tests): insert, find, update, aggregate, concurrent, multi-tenant
|
|
236
|
+
|
|
237
|
+
## Files Modified
|
|
238
|
+
|
|
239
|
+
| File | Change |
|
|
240
|
+
|------|--------|
|
|
241
|
+
| `src/lib/server/database/rvf.ts` | NEW — RVF document store (850+ lines) |
|
|
242
|
+
| `src/lib/server/database.ts` | REWRITTEN — Uses RvfCollection instead of MongoDB |
|
|
243
|
+
| `src/lib/server/config.ts` | MODIFIED — RvfCollection types |
|
|
244
|
+
| `src/lib/migrations/migrations.ts` | REWRITTEN — No MongoDB sessions/transactions |
|
|
245
|
+
| `scripts/setups/vitest-setup-server.ts` | REWRITTEN — No MongoMemoryServer |
|
|
246
|
+
| `src/lib/server/database/__tests__/rvf.spec.ts` | NEW — 47 tests + benchmarks |
|
|
247
|
+
|
|
248
|
+
## Environment Variables
|
|
249
|
+
|
|
250
|
+
```bash
|
|
251
|
+
# RVF store path (defaults to db/ruvocal.rvf.json)
|
|
252
|
+
RVF_DB_PATH=/data/ruvocal
|
|
253
|
+
|
|
254
|
+
# Empty string = in-memory only (for tests)
|
|
255
|
+
RVF_DB_PATH=
|
|
256
|
+
|
|
257
|
+
# Everything else stays the same
|
|
258
|
+
PUBLIC_APP_NAME=RuVocal
|
|
259
|
+
PUBLIC_ORIGIN=https://chat.example.com
|
|
260
|
+
OPENAI_BASE_URL=https://openrouter.ai/api/v1
|
|
261
|
+
```
|
|
262
|
+
|
|
263
|
+
## Benefits
|
|
264
|
+
|
|
265
|
+
| Aspect | MongoDB (upstream) | RVF Store (RuVocal) |
|
|
266
|
+
|--------|-------------------|---------------------|
|
|
267
|
+
| **Dependencies** | MongoDB server required | Zero — pure TypeScript |
|
|
268
|
+
| **Container size** | +500MB for MongoDB | 0 extra |
|
|
269
|
+
| **Persistence** | Network database | Single JSON file |
|
|
270
|
+
| **Startup time** | Seconds (connection) | Instant |
|
|
271
|
+
| **Multi-tenant** | Not built-in | Native tenant isolation |
|
|
272
|
+
| **Backup** | mongodump | cp ruvocal.rvf.json |
|
|
273
|
+
| **UI customization** | Cannot modify upstream | Full SvelteKit source |
|
|
274
|
+
| **Test speed** | MongoMemoryServer (~2s) | In-memory (~300ms) |
|
|
275
|
+
|
|
276
|
+
## Risks
|
|
277
|
+
|
|
278
|
+
1. **In-memory limitation** — All data lives in RAM; unsuitable for datasets >100MB
|
|
279
|
+
2. **Single-writer** — No concurrent process writes (single Node process assumed)
|
|
280
|
+
3. **Upstream sync** — Forking means manual merge of upstream HF Chat UI updates
|
|
281
|
+
|
|
282
|
+
## Mitigation
|
|
283
|
+
|
|
284
|
+
1. For large deployments, future upgrade path to ruvector-postgres (PostgresAdapter already exists at `postgres.ts`)
|
|
285
|
+
2. The debounced save + flush-on-exit pattern prevents data loss; WAL logging can be added if needed
|
|
286
|
+
3. Keep fork minimal — only database layer changed, UI components untouched
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
- local: index
|
|
2
|
+
title: Chat UI
|
|
3
|
+
- title: Installation
|
|
4
|
+
sections:
|
|
5
|
+
- local: installation/local
|
|
6
|
+
title: Local
|
|
7
|
+
- local: installation/docker
|
|
8
|
+
title: Docker
|
|
9
|
+
- local: installation/helm
|
|
10
|
+
title: Helm
|
|
11
|
+
- title: Configuration
|
|
12
|
+
sections:
|
|
13
|
+
- local: configuration/overview
|
|
14
|
+
title: Overview
|
|
15
|
+
- local: configuration/theming
|
|
16
|
+
title: Theming
|
|
17
|
+
- local: configuration/open-id
|
|
18
|
+
title: OpenID
|
|
19
|
+
- local: configuration/mcp-tools
|
|
20
|
+
title: MCP Tools
|
|
21
|
+
- local: configuration/llm-router
|
|
22
|
+
title: LLM Router
|
|
23
|
+
- local: configuration/metrics
|
|
24
|
+
title: Metrics
|
|
25
|
+
- local: configuration/common-issues
|
|
26
|
+
title: Common Issues
|
|
27
|
+
- title: Developing
|
|
28
|
+
sections:
|
|
29
|
+
- local: developing/architecture
|
|
30
|
+
title: Architecture
|
|
@@ -0,0 +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
|
|
@@ -0,0 +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.
|
|
@@ -0,0 +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.
|
|
@@ -0,0 +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>
|
|
@@ -0,0 +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
|
+
```
|