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.
Files changed (521) hide show
  1. package/dist/rvf.manifest.json +295 -0
  2. package/package.json +16 -2
  3. package/src/chat-ui/Dockerfile +25 -0
  4. package/src/chat-ui/patch-mcp-url-safety.sh +28 -0
  5. package/src/chat-ui/static/chatui/icon-144x144.png +0 -0
  6. package/src/chat-ui/static/chatui/omni-welcome.gif +0 -0
  7. package/src/config/config.example.json +76 -0
  8. package/src/mcp-bridge/Dockerfile +45 -0
  9. package/src/mcp-bridge/index.js +1668 -0
  10. package/src/mcp-bridge/mcp-stdio-kernel.js +159 -0
  11. package/src/mcp-bridge/package.json +17 -0
  12. package/src/mcp-bridge/test-harness.js +470 -0
  13. package/src/nginx/Dockerfile +10 -0
  14. package/src/nginx/nginx.conf +67 -0
  15. package/src/nginx/static/favicon-dark.svg +4 -0
  16. package/src/nginx/static/favicon.svg +4 -0
  17. package/src/nginx/static/icon.svg +5 -0
  18. package/src/nginx/static/logo.svg +9 -0
  19. package/src/nginx/static/manifest.json +22 -0
  20. package/src/nginx/static/welcome.js +184 -0
  21. package/src/ruvocal/.claude/skills/add-model-descriptions/SKILL.md +73 -0
  22. package/src/ruvocal/.devcontainer/Dockerfile +9 -0
  23. package/src/ruvocal/.devcontainer/devcontainer.json +36 -0
  24. package/src/ruvocal/.dockerignore +13 -0
  25. package/src/ruvocal/.env +194 -0
  26. package/src/ruvocal/.env.ci +1 -0
  27. package/src/ruvocal/.eslintignore +13 -0
  28. package/src/ruvocal/.eslintrc.cjs +45 -0
  29. package/src/ruvocal/.github/ISSUE_TEMPLATE/bug-report--chat-ui-.md +43 -0
  30. package/src/ruvocal/.github/ISSUE_TEMPLATE/config-support.md +9 -0
  31. package/src/ruvocal/.github/ISSUE_TEMPLATE/feature-request--chat-ui-.md +17 -0
  32. package/src/ruvocal/.github/ISSUE_TEMPLATE/huggingchat.md +11 -0
  33. package/src/ruvocal/.github/release.yml +16 -0
  34. package/src/ruvocal/.github/workflows/build-docs.yml +18 -0
  35. package/src/ruvocal/.github/workflows/build-image.yml +142 -0
  36. package/src/ruvocal/.github/workflows/build-pr-docs.yml +20 -0
  37. package/src/ruvocal/.github/workflows/deploy-dev.yml +63 -0
  38. package/src/ruvocal/.github/workflows/deploy-prod.yml +78 -0
  39. package/src/ruvocal/.github/workflows/lint-and-test.yml +84 -0
  40. package/src/ruvocal/.github/workflows/slugify.yaml +72 -0
  41. package/src/ruvocal/.github/workflows/trufflehog.yml +17 -0
  42. package/src/ruvocal/.github/workflows/upload-pr-documentation.yml +16 -0
  43. package/src/ruvocal/.husky/lint-stage-config.js +4 -0
  44. package/src/ruvocal/.husky/pre-commit +2 -0
  45. package/src/ruvocal/.prettierignore +14 -0
  46. package/src/ruvocal/.prettierrc +7 -0
  47. package/src/ruvocal/.vscode/launch.json +11 -0
  48. package/src/ruvocal/.vscode/settings.json +14 -0
  49. package/src/ruvocal/CLAUDE.md +126 -0
  50. package/src/ruvocal/Dockerfile +93 -0
  51. package/src/ruvocal/LICENSE +203 -0
  52. package/src/ruvocal/PRIVACY.md +41 -0
  53. package/src/ruvocal/README.md +190 -0
  54. package/src/ruvocal/chart/Chart.yaml +5 -0
  55. package/src/ruvocal/chart/env/dev.yaml +260 -0
  56. package/src/ruvocal/chart/env/prod.yaml +273 -0
  57. package/src/ruvocal/chart/templates/_helpers.tpl +22 -0
  58. package/src/ruvocal/chart/templates/config.yaml +10 -0
  59. package/src/ruvocal/chart/templates/deployment.yaml +81 -0
  60. package/src/ruvocal/chart/templates/hpa.yaml +45 -0
  61. package/src/ruvocal/chart/templates/infisical.yaml +24 -0
  62. package/src/ruvocal/chart/templates/ingress-internal.yaml +32 -0
  63. package/src/ruvocal/chart/templates/ingress.yaml +32 -0
  64. package/src/ruvocal/chart/templates/network-policy.yaml +36 -0
  65. package/src/ruvocal/chart/templates/service-account.yaml +13 -0
  66. package/src/ruvocal/chart/templates/service-monitor.yaml +17 -0
  67. package/src/ruvocal/chart/templates/service.yaml +21 -0
  68. package/src/ruvocal/chart/values.yaml +73 -0
  69. package/src/ruvocal/docker-compose.yml +21 -0
  70. package/src/ruvocal/docs/adr/ADR-029-HUGGINGFACE-CHAT-UI-CLOUD-RUN.md +1236 -0
  71. package/src/ruvocal/docs/adr/ADR-033-RUVECTOR-RUFLO-MCP-INTEGRATION.md +111 -0
  72. package/src/ruvocal/docs/adr/ADR-034-OPTIONAL-MCP-BACKENDS.md +117 -0
  73. package/src/ruvocal/docs/adr/ADR-035-MCP-TOOL-GROUPS.md +186 -0
  74. package/src/ruvocal/docs/adr/ADR-037-AUTOPILOT-CHAT-MODE.md +1500 -0
  75. package/src/ruvocal/docs/adr/ADR-038-RUVOCAL-FORK.md +286 -0
  76. package/src/ruvocal/docs/source/_toctree.yml +30 -0
  77. package/src/ruvocal/docs/source/configuration/common-issues.md +38 -0
  78. package/src/ruvocal/docs/source/configuration/llm-router.md +105 -0
  79. package/src/ruvocal/docs/source/configuration/mcp-tools.md +84 -0
  80. package/src/ruvocal/docs/source/configuration/metrics.md +9 -0
  81. package/src/ruvocal/docs/source/configuration/open-id.md +57 -0
  82. package/src/ruvocal/docs/source/configuration/overview.md +89 -0
  83. package/src/ruvocal/docs/source/configuration/theming.md +20 -0
  84. package/src/ruvocal/docs/source/developing/architecture.md +48 -0
  85. package/src/ruvocal/docs/source/index.md +53 -0
  86. package/src/ruvocal/docs/source/installation/docker.md +43 -0
  87. package/src/ruvocal/docs/source/installation/helm.md +43 -0
  88. package/src/ruvocal/docs/source/installation/local.md +62 -0
  89. package/src/ruvocal/entrypoint.sh +19 -0
  90. package/src/ruvocal/mcp-bridge/.claude-flow/agents/store.json +27 -0
  91. package/src/ruvocal/mcp-bridge/.claude-flow/daemon-state.json +130 -0
  92. package/src/ruvocal/mcp-bridge/.claude-flow/daemon.log +0 -0
  93. package/src/ruvocal/mcp-bridge/.claude-flow/daemon.pid +1 -0
  94. package/src/ruvocal/mcp-bridge/.claude-flow/tasks/store.json +21 -0
  95. package/src/ruvocal/mcp-bridge/.swarm/hnsw.index +0 -0
  96. package/src/ruvocal/mcp-bridge/.swarm/hnsw.metadata.json +1 -0
  97. package/src/ruvocal/mcp-bridge/.swarm/memory.db +0 -0
  98. package/src/ruvocal/mcp-bridge/.swarm/model-router-state.json +14 -0
  99. package/src/ruvocal/mcp-bridge/.swarm/schema.sql +305 -0
  100. package/src/ruvocal/mcp-bridge/Dockerfile +45 -0
  101. package/src/ruvocal/mcp-bridge/cloudbuild.yaml +49 -0
  102. package/src/ruvocal/mcp-bridge/index.js +1864 -0
  103. package/src/ruvocal/mcp-bridge/mcp-stdio-kernel.js +159 -0
  104. package/src/ruvocal/mcp-bridge/package-lock.json +762 -0
  105. package/src/ruvocal/mcp-bridge/package.json +17 -0
  106. package/src/ruvocal/mcp-bridge/test-harness.js +470 -0
  107. package/src/ruvocal/models/add-your-models-here.txt +1 -0
  108. package/src/ruvocal/package-lock.json +11741 -0
  109. package/src/ruvocal/package.json +121 -0
  110. package/src/ruvocal/postcss.config.js +6 -0
  111. package/src/ruvocal/rvf.manifest.json +204 -0
  112. package/src/ruvocal/scripts/config.ts +64 -0
  113. package/src/ruvocal/scripts/generate-welcome.mjs +181 -0
  114. package/src/ruvocal/scripts/populate.ts +288 -0
  115. package/src/ruvocal/scripts/samples.txt +194 -0
  116. package/src/ruvocal/scripts/setups/vitest-setup-client.ts +0 -0
  117. package/src/ruvocal/scripts/setups/vitest-setup-server.ts +44 -0
  118. package/src/ruvocal/scripts/updateLocalEnv.ts +48 -0
  119. package/src/ruvocal/src/ambient.d.ts +7 -0
  120. package/src/ruvocal/src/app.d.ts +29 -0
  121. package/src/ruvocal/src/app.html +53 -0
  122. package/src/ruvocal/src/hooks.server.ts +32 -0
  123. package/src/ruvocal/src/hooks.ts +6 -0
  124. package/src/ruvocal/src/lib/APIClient.ts +148 -0
  125. package/src/ruvocal/src/lib/actions/clickOutside.ts +18 -0
  126. package/src/ruvocal/src/lib/actions/snapScrollToBottom.ts +346 -0
  127. package/src/ruvocal/src/lib/buildPrompt.ts +33 -0
  128. package/src/ruvocal/src/lib/components/AnnouncementBanner.svelte +20 -0
  129. package/src/ruvocal/src/lib/components/BackgroundGenerationPoller.svelte +168 -0
  130. package/src/ruvocal/src/lib/components/CodeBlock.svelte +73 -0
  131. package/src/ruvocal/src/lib/components/CopyToClipBoardBtn.svelte +92 -0
  132. package/src/ruvocal/src/lib/components/DeleteConversationModal.svelte +75 -0
  133. package/src/ruvocal/src/lib/components/EditConversationModal.svelte +100 -0
  134. package/src/ruvocal/src/lib/components/ExpandNavigation.svelte +22 -0
  135. package/src/ruvocal/src/lib/components/HoverTooltip.svelte +44 -0
  136. package/src/ruvocal/src/lib/components/HtmlPreviewModal.svelte +143 -0
  137. package/src/ruvocal/src/lib/components/InfiniteScroll.svelte +50 -0
  138. package/src/ruvocal/src/lib/components/MobileNav.svelte +300 -0
  139. package/src/ruvocal/src/lib/components/Modal.svelte +115 -0
  140. package/src/ruvocal/src/lib/components/ModelCardMetadata.svelte +71 -0
  141. package/src/ruvocal/src/lib/components/NavConversationItem.svelte +151 -0
  142. package/src/ruvocal/src/lib/components/NavMenu.svelte +295 -0
  143. package/src/ruvocal/src/lib/components/Pagination.svelte +97 -0
  144. package/src/ruvocal/src/lib/components/PaginationArrow.svelte +27 -0
  145. package/src/ruvocal/src/lib/components/Portal.svelte +24 -0
  146. package/src/ruvocal/src/lib/components/RetryBtn.svelte +18 -0
  147. package/src/ruvocal/src/lib/components/RuFloUniverse.svelte +185 -0
  148. package/src/ruvocal/src/lib/components/ScrollToBottomBtn.svelte +47 -0
  149. package/src/ruvocal/src/lib/components/ScrollToPreviousBtn.svelte +77 -0
  150. package/src/ruvocal/src/lib/components/ShareConversationModal.svelte +182 -0
  151. package/src/ruvocal/src/lib/components/StopGeneratingBtn.svelte +69 -0
  152. package/src/ruvocal/src/lib/components/SubscribeModal.svelte +87 -0
  153. package/src/ruvocal/src/lib/components/Switch.svelte +36 -0
  154. package/src/ruvocal/src/lib/components/SystemPromptModal.svelte +44 -0
  155. package/src/ruvocal/src/lib/components/Toast.svelte +27 -0
  156. package/src/ruvocal/src/lib/components/Tooltip.svelte +30 -0
  157. package/src/ruvocal/src/lib/components/WelcomeModal.svelte +46 -0
  158. package/src/ruvocal/src/lib/components/chat/Alternatives.svelte +77 -0
  159. package/src/ruvocal/src/lib/components/chat/BlockWrapper.svelte +72 -0
  160. package/src/ruvocal/src/lib/components/chat/ChatInput.svelte +490 -0
  161. package/src/ruvocal/src/lib/components/chat/ChatIntroduction.svelte +123 -0
  162. package/src/ruvocal/src/lib/components/chat/ChatMessage.svelte +548 -0
  163. package/src/ruvocal/src/lib/components/chat/ChatWindow.svelte +939 -0
  164. package/src/ruvocal/src/lib/components/chat/FileDropzone.svelte +92 -0
  165. package/src/ruvocal/src/lib/components/chat/ImageLightbox.svelte +66 -0
  166. package/src/ruvocal/src/lib/components/chat/MarkdownBlock.svelte +23 -0
  167. package/src/ruvocal/src/lib/components/chat/MarkdownRenderer.svelte +69 -0
  168. package/src/ruvocal/src/lib/components/chat/MarkdownRenderer.svelte.test.ts +58 -0
  169. package/src/ruvocal/src/lib/components/chat/MessageAvatar.svelte +103 -0
  170. package/src/ruvocal/src/lib/components/chat/ModelSwitch.svelte +64 -0
  171. package/src/ruvocal/src/lib/components/chat/OpenReasoningResults.svelte +81 -0
  172. package/src/ruvocal/src/lib/components/chat/TaskGroup.svelte +88 -0
  173. package/src/ruvocal/src/lib/components/chat/ToolUpdate.svelte +273 -0
  174. package/src/ruvocal/src/lib/components/chat/UploadedFile.svelte +253 -0
  175. package/src/ruvocal/src/lib/components/chat/UrlFetchModal.svelte +203 -0
  176. package/src/ruvocal/src/lib/components/chat/VoiceRecorder.svelte +214 -0
  177. package/src/ruvocal/src/lib/components/icons/IconBurger.svelte +20 -0
  178. package/src/ruvocal/src/lib/components/icons/IconCheap.svelte +20 -0
  179. package/src/ruvocal/src/lib/components/icons/IconChevron.svelte +24 -0
  180. package/src/ruvocal/src/lib/components/icons/IconDazzled.svelte +40 -0
  181. package/src/ruvocal/src/lib/components/icons/IconFast.svelte +20 -0
  182. package/src/ruvocal/src/lib/components/icons/IconLoading.svelte +22 -0
  183. package/src/ruvocal/src/lib/components/icons/IconMCP.svelte +28 -0
  184. package/src/ruvocal/src/lib/components/icons/IconMoon.svelte +21 -0
  185. package/src/ruvocal/src/lib/components/icons/IconNew.svelte +20 -0
  186. package/src/ruvocal/src/lib/components/icons/IconOmni.svelte +90 -0
  187. package/src/ruvocal/src/lib/components/icons/IconPaperclip.svelte +24 -0
  188. package/src/ruvocal/src/lib/components/icons/IconPro.svelte +37 -0
  189. package/src/ruvocal/src/lib/components/icons/IconShare.svelte +21 -0
  190. package/src/ruvocal/src/lib/components/icons/IconSun.svelte +93 -0
  191. package/src/ruvocal/src/lib/components/icons/Logo.svelte +68 -0
  192. package/src/ruvocal/src/lib/components/icons/LogoHuggingFaceBorderless.svelte +54 -0
  193. package/src/ruvocal/src/lib/components/mcp/AddServerForm.svelte +250 -0
  194. package/src/ruvocal/src/lib/components/mcp/MCPServerManager.svelte +185 -0
  195. package/src/ruvocal/src/lib/components/mcp/ServerCard.svelte +203 -0
  196. package/src/ruvocal/src/lib/components/players/AudioPlayer.svelte +82 -0
  197. package/src/ruvocal/src/lib/components/voice/AudioWaveform.svelte +96 -0
  198. package/src/ruvocal/src/lib/constants/mcpExamples.ts +135 -0
  199. package/src/ruvocal/src/lib/constants/mime.ts +11 -0
  200. package/src/ruvocal/src/lib/constants/pagination.ts +1 -0
  201. package/src/ruvocal/src/lib/constants/publicSepToken.ts +1 -0
  202. package/src/ruvocal/src/lib/constants/routerExamples.ts +209 -0
  203. package/src/ruvocal/src/lib/createShareLink.ts +27 -0
  204. package/src/ruvocal/src/lib/jobs/refresh-conversation-stats.ts +297 -0
  205. package/src/ruvocal/src/lib/migrations/lock.ts +56 -0
  206. package/src/ruvocal/src/lib/migrations/migrations.spec.ts +74 -0
  207. package/src/ruvocal/src/lib/migrations/migrations.ts +109 -0
  208. package/src/ruvocal/src/lib/migrations/routines/01-update-search-assistants.ts +50 -0
  209. package/src/ruvocal/src/lib/migrations/routines/02-update-assistants-models.ts +48 -0
  210. package/src/ruvocal/src/lib/migrations/routines/04-update-message-updates.ts +151 -0
  211. package/src/ruvocal/src/lib/migrations/routines/05-update-message-files.ts +56 -0
  212. package/src/ruvocal/src/lib/migrations/routines/06-trim-message-updates.ts +56 -0
  213. package/src/ruvocal/src/lib/migrations/routines/08-update-featured-to-review.ts +32 -0
  214. package/src/ruvocal/src/lib/migrations/routines/09-delete-empty-conversations.spec.ts +214 -0
  215. package/src/ruvocal/src/lib/migrations/routines/09-delete-empty-conversations.ts +88 -0
  216. package/src/ruvocal/src/lib/migrations/routines/10-update-reports-assistantid.ts +29 -0
  217. package/src/ruvocal/src/lib/migrations/routines/index.ts +15 -0
  218. package/src/ruvocal/src/lib/server/__tests__/conversation-stop-generating.spec.ts +103 -0
  219. package/src/ruvocal/src/lib/server/abortRegistry.ts +57 -0
  220. package/src/ruvocal/src/lib/server/abortedGenerations.ts +43 -0
  221. package/src/ruvocal/src/lib/server/adminToken.ts +62 -0
  222. package/src/ruvocal/src/lib/server/api/__tests__/conversations-id.spec.ts +296 -0
  223. package/src/ruvocal/src/lib/server/api/__tests__/conversations-message.spec.ts +216 -0
  224. package/src/ruvocal/src/lib/server/api/__tests__/conversations.spec.ts +235 -0
  225. package/src/ruvocal/src/lib/server/api/__tests__/misc.spec.ts +72 -0
  226. package/src/ruvocal/src/lib/server/api/__tests__/testHelpers.ts +86 -0
  227. package/src/ruvocal/src/lib/server/api/__tests__/user-reports.spec.ts +78 -0
  228. package/src/ruvocal/src/lib/server/api/__tests__/user.spec.ts +239 -0
  229. package/src/ruvocal/src/lib/server/api/types.ts +37 -0
  230. package/src/ruvocal/src/lib/server/api/utils/requireAuth.ts +22 -0
  231. package/src/ruvocal/src/lib/server/api/utils/resolveConversation.ts +69 -0
  232. package/src/ruvocal/src/lib/server/api/utils/resolveModel.ts +27 -0
  233. package/src/ruvocal/src/lib/server/api/utils/superjsonResponse.ts +15 -0
  234. package/src/ruvocal/src/lib/server/apiToken.ts +11 -0
  235. package/src/ruvocal/src/lib/server/auth.ts +554 -0
  236. package/src/ruvocal/src/lib/server/config.ts +187 -0
  237. package/src/ruvocal/src/lib/server/conversation.ts +83 -0
  238. package/src/ruvocal/src/lib/server/database/__tests__/rvf.spec.ts +709 -0
  239. package/src/ruvocal/src/lib/server/database/postgres.ts +700 -0
  240. package/src/ruvocal/src/lib/server/database/rvf.ts +1078 -0
  241. package/src/ruvocal/src/lib/server/database.ts +145 -0
  242. package/src/ruvocal/src/lib/server/endpoints/document.ts +68 -0
  243. package/src/ruvocal/src/lib/server/endpoints/endpoints.ts +43 -0
  244. package/src/ruvocal/src/lib/server/endpoints/images.ts +211 -0
  245. package/src/ruvocal/src/lib/server/endpoints/openai/endpointOai.ts +266 -0
  246. package/src/ruvocal/src/lib/server/endpoints/openai/openAIChatToTextGenerationStream.ts +212 -0
  247. package/src/ruvocal/src/lib/server/endpoints/openai/openAICompletionToTextGenerationStream.ts +32 -0
  248. package/src/ruvocal/src/lib/server/endpoints/preprocessMessages.ts +61 -0
  249. package/src/ruvocal/src/lib/server/exitHandler.ts +59 -0
  250. package/src/ruvocal/src/lib/server/files/downloadFile.ts +34 -0
  251. package/src/ruvocal/src/lib/server/files/uploadFile.ts +29 -0
  252. package/src/ruvocal/src/lib/server/findRepoRoot.ts +13 -0
  253. package/src/ruvocal/src/lib/server/fonts/Inter-Black.ttf +0 -0
  254. package/src/ruvocal/src/lib/server/fonts/Inter-Bold.ttf +0 -0
  255. package/src/ruvocal/src/lib/server/fonts/Inter-ExtraBold.ttf +0 -0
  256. package/src/ruvocal/src/lib/server/fonts/Inter-ExtraLight.ttf +0 -0
  257. package/src/ruvocal/src/lib/server/fonts/Inter-Light.ttf +0 -0
  258. package/src/ruvocal/src/lib/server/fonts/Inter-Medium.ttf +0 -0
  259. package/src/ruvocal/src/lib/server/fonts/Inter-Regular.ttf +0 -0
  260. package/src/ruvocal/src/lib/server/fonts/Inter-SemiBold.ttf +0 -0
  261. package/src/ruvocal/src/lib/server/fonts/Inter-Thin.ttf +0 -0
  262. package/src/ruvocal/src/lib/server/generateFromDefaultEndpoint.ts +46 -0
  263. package/src/ruvocal/src/lib/server/hooks/error.ts +37 -0
  264. package/src/ruvocal/src/lib/server/hooks/fetch.ts +22 -0
  265. package/src/ruvocal/src/lib/server/hooks/handle.ts +250 -0
  266. package/src/ruvocal/src/lib/server/hooks/init.ts +51 -0
  267. package/src/ruvocal/src/lib/server/isURLLocal.spec.ts +31 -0
  268. package/src/ruvocal/src/lib/server/isURLLocal.ts +74 -0
  269. package/src/ruvocal/src/lib/server/logger.ts +42 -0
  270. package/src/ruvocal/src/lib/server/mcp/clientPool.ts +70 -0
  271. package/src/ruvocal/src/lib/server/mcp/hf.ts +32 -0
  272. package/src/ruvocal/src/lib/server/mcp/httpClient.ts +122 -0
  273. package/src/ruvocal/src/lib/server/mcp/registry.ts +76 -0
  274. package/src/ruvocal/src/lib/server/mcp/tools.ts +196 -0
  275. package/src/ruvocal/src/lib/server/metrics.ts +255 -0
  276. package/src/ruvocal/src/lib/server/models.ts +518 -0
  277. package/src/ruvocal/src/lib/server/requestContext.ts +55 -0
  278. package/src/ruvocal/src/lib/server/router/arch.ts +230 -0
  279. package/src/ruvocal/src/lib/server/router/endpoint.ts +316 -0
  280. package/src/ruvocal/src/lib/server/router/multimodal.ts +28 -0
  281. package/src/ruvocal/src/lib/server/router/policy.ts +49 -0
  282. package/src/ruvocal/src/lib/server/router/toolsRoute.ts +51 -0
  283. package/src/ruvocal/src/lib/server/router/types.ts +21 -0
  284. package/src/ruvocal/src/lib/server/sendSlack.ts +23 -0
  285. package/src/ruvocal/src/lib/server/textGeneration/generate.ts +258 -0
  286. package/src/ruvocal/src/lib/server/textGeneration/index.ts +95 -0
  287. package/src/ruvocal/src/lib/server/textGeneration/mcp/fileRefs.ts +155 -0
  288. package/src/ruvocal/src/lib/server/textGeneration/mcp/routerResolution.ts +108 -0
  289. package/src/ruvocal/src/lib/server/textGeneration/mcp/runMcpFlow.ts +822 -0
  290. package/src/ruvocal/src/lib/server/textGeneration/mcp/toolInvocation.ts +349 -0
  291. package/src/ruvocal/src/lib/server/textGeneration/reasoning.ts +23 -0
  292. package/src/ruvocal/src/lib/server/textGeneration/title.ts +83 -0
  293. package/src/ruvocal/src/lib/server/textGeneration/types.ts +26 -0
  294. package/src/ruvocal/src/lib/server/textGeneration/utils/prepareFiles.ts +88 -0
  295. package/src/ruvocal/src/lib/server/textGeneration/utils/routing.ts +21 -0
  296. package/src/ruvocal/src/lib/server/textGeneration/utils/toolPrompt.ts +49 -0
  297. package/src/ruvocal/src/lib/server/urlSafety.ts +72 -0
  298. package/src/ruvocal/src/lib/server/usageLimits.ts +30 -0
  299. package/src/ruvocal/src/lib/stores/autopilotStore.svelte.ts +175 -0
  300. package/src/ruvocal/src/lib/stores/backgroundGenerations.svelte.ts +32 -0
  301. package/src/ruvocal/src/lib/stores/backgroundGenerations.ts +1 -0
  302. package/src/ruvocal/src/lib/stores/errors.ts +9 -0
  303. package/src/ruvocal/src/lib/stores/isAborted.ts +3 -0
  304. package/src/ruvocal/src/lib/stores/isPro.ts +4 -0
  305. package/src/ruvocal/src/lib/stores/loading.ts +3 -0
  306. package/src/ruvocal/src/lib/stores/mcpServers.ts +345 -0
  307. package/src/ruvocal/src/lib/stores/pendingChatInput.ts +3 -0
  308. package/src/ruvocal/src/lib/stores/pendingMessage.ts +9 -0
  309. package/src/ruvocal/src/lib/stores/settings.ts +182 -0
  310. package/src/ruvocal/src/lib/stores/shareModal.ts +13 -0
  311. package/src/ruvocal/src/lib/stores/titleUpdate.ts +8 -0
  312. package/src/ruvocal/src/lib/switchTheme.ts +124 -0
  313. package/src/ruvocal/src/lib/types/AbortedGeneration.ts +8 -0
  314. package/src/ruvocal/src/lib/types/Assistant.ts +31 -0
  315. package/src/ruvocal/src/lib/types/AssistantStats.ts +11 -0
  316. package/src/ruvocal/src/lib/types/ConfigKey.ts +4 -0
  317. package/src/ruvocal/src/lib/types/ConvSidebar.ts +9 -0
  318. package/src/ruvocal/src/lib/types/Conversation.ts +27 -0
  319. package/src/ruvocal/src/lib/types/ConversationStats.ts +13 -0
  320. package/src/ruvocal/src/lib/types/Message.ts +41 -0
  321. package/src/ruvocal/src/lib/types/MessageEvent.ts +10 -0
  322. package/src/ruvocal/src/lib/types/MessageUpdate.ts +139 -0
  323. package/src/ruvocal/src/lib/types/MigrationResult.ts +7 -0
  324. package/src/ruvocal/src/lib/types/Model.ts +23 -0
  325. package/src/ruvocal/src/lib/types/Report.ts +12 -0
  326. package/src/ruvocal/src/lib/types/Review.ts +6 -0
  327. package/src/ruvocal/src/lib/types/Semaphore.ts +19 -0
  328. package/src/ruvocal/src/lib/types/Session.ts +22 -0
  329. package/src/ruvocal/src/lib/types/Settings.ts +86 -0
  330. package/src/ruvocal/src/lib/types/SharedConversation.ts +9 -0
  331. package/src/ruvocal/src/lib/types/Template.ts +6 -0
  332. package/src/ruvocal/src/lib/types/Timestamps.ts +4 -0
  333. package/src/ruvocal/src/lib/types/TokenCache.ts +6 -0
  334. package/src/ruvocal/src/lib/types/Tool.ts +74 -0
  335. package/src/ruvocal/src/lib/types/UrlDependency.ts +5 -0
  336. package/src/ruvocal/src/lib/types/User.ts +14 -0
  337. package/src/ruvocal/src/lib/utils/PublicConfig.svelte.ts +75 -0
  338. package/src/ruvocal/src/lib/utils/auth.ts +17 -0
  339. package/src/ruvocal/src/lib/utils/chunk.ts +33 -0
  340. package/src/ruvocal/src/lib/utils/cookiesAreEnabled.ts +13 -0
  341. package/src/ruvocal/src/lib/utils/debounce.ts +17 -0
  342. package/src/ruvocal/src/lib/utils/deepestChild.ts +6 -0
  343. package/src/ruvocal/src/lib/utils/favicon.ts +21 -0
  344. package/src/ruvocal/src/lib/utils/fetchJSON.ts +23 -0
  345. package/src/ruvocal/src/lib/utils/file2base64.ts +14 -0
  346. package/src/ruvocal/src/lib/utils/formatUserCount.ts +37 -0
  347. package/src/ruvocal/src/lib/utils/generationState.spec.ts +75 -0
  348. package/src/ruvocal/src/lib/utils/generationState.ts +26 -0
  349. package/src/ruvocal/src/lib/utils/getHref.ts +41 -0
  350. package/src/ruvocal/src/lib/utils/getReturnFromGenerator.ts +7 -0
  351. package/src/ruvocal/src/lib/utils/haptics.ts +64 -0
  352. package/src/ruvocal/src/lib/utils/hashConv.ts +12 -0
  353. package/src/ruvocal/src/lib/utils/hf.ts +17 -0
  354. package/src/ruvocal/src/lib/utils/isDesktop.ts +7 -0
  355. package/src/ruvocal/src/lib/utils/isUrl.ts +8 -0
  356. package/src/ruvocal/src/lib/utils/isVirtualKeyboard.ts +16 -0
  357. package/src/ruvocal/src/lib/utils/loadAttachmentsFromUrls.ts +115 -0
  358. package/src/ruvocal/src/lib/utils/marked.spec.ts +96 -0
  359. package/src/ruvocal/src/lib/utils/marked.ts +531 -0
  360. package/src/ruvocal/src/lib/utils/mcpValidation.ts +147 -0
  361. package/src/ruvocal/src/lib/utils/mergeAsyncGenerators.ts +38 -0
  362. package/src/ruvocal/src/lib/utils/messageUpdates.spec.ts +262 -0
  363. package/src/ruvocal/src/lib/utils/messageUpdates.ts +324 -0
  364. package/src/ruvocal/src/lib/utils/mime.ts +56 -0
  365. package/src/ruvocal/src/lib/utils/models.ts +14 -0
  366. package/src/ruvocal/src/lib/utils/parseBlocks.ts +120 -0
  367. package/src/ruvocal/src/lib/utils/parseIncompleteMarkdown.ts +644 -0
  368. package/src/ruvocal/src/lib/utils/parseStringToList.ts +10 -0
  369. package/src/ruvocal/src/lib/utils/randomUuid.ts +14 -0
  370. package/src/ruvocal/src/lib/utils/searchTokens.ts +33 -0
  371. package/src/ruvocal/src/lib/utils/sha256.ts +7 -0
  372. package/src/ruvocal/src/lib/utils/stringifyError.ts +12 -0
  373. package/src/ruvocal/src/lib/utils/sum.ts +3 -0
  374. package/src/ruvocal/src/lib/utils/template.spec.ts +59 -0
  375. package/src/ruvocal/src/lib/utils/template.ts +53 -0
  376. package/src/ruvocal/src/lib/utils/timeout.ts +9 -0
  377. package/src/ruvocal/src/lib/utils/toolProgress.spec.ts +46 -0
  378. package/src/ruvocal/src/lib/utils/toolProgress.ts +11 -0
  379. package/src/ruvocal/src/lib/utils/tree/addChildren.spec.ts +102 -0
  380. package/src/ruvocal/src/lib/utils/tree/addChildren.ts +48 -0
  381. package/src/ruvocal/src/lib/utils/tree/addSibling.spec.ts +81 -0
  382. package/src/ruvocal/src/lib/utils/tree/addSibling.ts +41 -0
  383. package/src/ruvocal/src/lib/utils/tree/buildSubtree.spec.ts +110 -0
  384. package/src/ruvocal/src/lib/utils/tree/buildSubtree.ts +24 -0
  385. package/src/ruvocal/src/lib/utils/tree/convertLegacyConversation.spec.ts +31 -0
  386. package/src/ruvocal/src/lib/utils/tree/convertLegacyConversation.ts +36 -0
  387. package/src/ruvocal/src/lib/utils/tree/isMessageId.spec.ts +15 -0
  388. package/src/ruvocal/src/lib/utils/tree/isMessageId.ts +5 -0
  389. package/src/ruvocal/src/lib/utils/tree/tree.d.ts +14 -0
  390. package/src/ruvocal/src/lib/utils/tree/treeHelpers.spec.ts +167 -0
  391. package/src/ruvocal/src/lib/utils/updates.ts +39 -0
  392. package/src/ruvocal/src/lib/utils/urlParams.ts +13 -0
  393. package/src/ruvocal/src/lib/workers/autopilotWorker.ts +221 -0
  394. package/src/ruvocal/src/lib/workers/detailFetchWorker.ts +100 -0
  395. package/src/ruvocal/src/lib/workers/markdownWorker.ts +61 -0
  396. package/src/ruvocal/src/routes/+error.svelte +20 -0
  397. package/src/ruvocal/src/routes/+layout.svelte +324 -0
  398. package/src/ruvocal/src/routes/+layout.ts +91 -0
  399. package/src/ruvocal/src/routes/+page.svelte +168 -0
  400. package/src/ruvocal/src/routes/.well-known/oauth-cimd/+server.ts +37 -0
  401. package/src/ruvocal/src/routes/__debug/openai/+server.ts +21 -0
  402. package/src/ruvocal/src/routes/admin/export/+server.ts +159 -0
  403. package/src/ruvocal/src/routes/admin/stats/compute/+server.ts +16 -0
  404. package/src/ruvocal/src/routes/api/conversation/[id]/+server.ts +40 -0
  405. package/src/ruvocal/src/routes/api/conversation/[id]/message/[messageId]/+server.ts +42 -0
  406. package/src/ruvocal/src/routes/api/conversations/+server.ts +48 -0
  407. package/src/ruvocal/src/routes/api/fetch-url/+server.ts +147 -0
  408. package/src/ruvocal/src/routes/api/mcp/health/+server.ts +292 -0
  409. package/src/ruvocal/src/routes/api/mcp/servers/+server.ts +32 -0
  410. package/src/ruvocal/src/routes/api/models/+server.ts +25 -0
  411. package/src/ruvocal/src/routes/api/transcribe/+server.ts +104 -0
  412. package/src/ruvocal/src/routes/api/user/+server.ts +15 -0
  413. package/src/ruvocal/src/routes/api/user/validate-token/+server.ts +20 -0
  414. package/src/ruvocal/src/routes/api/v2/conversations/+server.ts +48 -0
  415. package/src/ruvocal/src/routes/api/v2/conversations/[id]/+server.ts +94 -0
  416. package/src/ruvocal/src/routes/api/v2/conversations/[id]/message/[messageId]/+server.ts +43 -0
  417. package/src/ruvocal/src/routes/api/v2/conversations/import-share/+server.ts +23 -0
  418. package/src/ruvocal/src/routes/api/v2/debug/config/+server.ts +16 -0
  419. package/src/ruvocal/src/routes/api/v2/debug/refresh/+server.ts +30 -0
  420. package/src/ruvocal/src/routes/api/v2/export/+server.ts +196 -0
  421. package/src/ruvocal/src/routes/api/v2/feature-flags/+server.ts +14 -0
  422. package/src/ruvocal/src/routes/api/v2/models/+server.ts +38 -0
  423. package/src/ruvocal/src/routes/api/v2/models/[namespace]/+server.ts +8 -0
  424. package/src/ruvocal/src/routes/api/v2/models/[namespace]/[model]/+server.ts +8 -0
  425. package/src/ruvocal/src/routes/api/v2/models/[namespace]/[model]/subscribe/+server.ts +28 -0
  426. package/src/ruvocal/src/routes/api/v2/models/[namespace]/subscribe/+server.ts +28 -0
  427. package/src/ruvocal/src/routes/api/v2/models/old/+server.ts +7 -0
  428. package/src/ruvocal/src/routes/api/v2/models/refresh/+server.ts +33 -0
  429. package/src/ruvocal/src/routes/api/v2/public-config/+server.ts +7 -0
  430. package/src/ruvocal/src/routes/api/v2/user/+server.ts +17 -0
  431. package/src/ruvocal/src/routes/api/v2/user/billing-orgs/+server.ts +73 -0
  432. package/src/ruvocal/src/routes/api/v2/user/reports/+server.ts +17 -0
  433. package/src/ruvocal/src/routes/api/v2/user/settings/+server.ts +103 -0
  434. package/src/ruvocal/src/routes/conversation/+server.ts +115 -0
  435. package/src/ruvocal/src/routes/conversation/[id]/+page.svelte +582 -0
  436. package/src/ruvocal/src/routes/conversation/[id]/+page.ts +60 -0
  437. package/src/ruvocal/src/routes/conversation/[id]/+server.ts +736 -0
  438. package/src/ruvocal/src/routes/conversation/[id]/message/[messageId]/prompt/+server.ts +66 -0
  439. package/src/ruvocal/src/routes/conversation/[id]/output/[sha256]/+server.ts +58 -0
  440. package/src/ruvocal/src/routes/conversation/[id]/share/+server.ts +69 -0
  441. package/src/ruvocal/src/routes/conversation/[id]/stop-generating/+server.ts +35 -0
  442. package/src/ruvocal/src/routes/healthcheck/+server.ts +3 -0
  443. package/src/ruvocal/src/routes/login/+server.ts +5 -0
  444. package/src/ruvocal/src/routes/login/callback/+server.ts +103 -0
  445. package/src/ruvocal/src/routes/login/callback/updateUser.spec.ts +157 -0
  446. package/src/ruvocal/src/routes/login/callback/updateUser.ts +215 -0
  447. package/src/ruvocal/src/routes/logout/+server.ts +18 -0
  448. package/src/ruvocal/src/routes/metrics/+server.ts +18 -0
  449. package/src/ruvocal/src/routes/models/+page.svelte +233 -0
  450. package/src/ruvocal/src/routes/models/[...model]/+page.svelte +161 -0
  451. package/src/ruvocal/src/routes/models/[...model]/+page.ts +14 -0
  452. package/src/ruvocal/src/routes/models/[...model]/thumbnail.png/+server.ts +64 -0
  453. package/src/ruvocal/src/routes/models/[...model]/thumbnail.png/ModelThumbnail.svelte +28 -0
  454. package/src/ruvocal/src/routes/privacy/+page.svelte +11 -0
  455. package/src/ruvocal/src/routes/r/[id]/+page.ts +34 -0
  456. package/src/ruvocal/src/routes/settings/(nav)/+layout.svelte +282 -0
  457. package/src/ruvocal/src/routes/settings/(nav)/+layout.ts +1 -0
  458. package/src/ruvocal/src/routes/settings/(nav)/+page.svelte +0 -0
  459. package/src/ruvocal/src/routes/settings/(nav)/+server.ts +53 -0
  460. package/src/ruvocal/src/routes/settings/(nav)/[...model]/+page.svelte +464 -0
  461. package/src/ruvocal/src/routes/settings/(nav)/[...model]/+page.ts +14 -0
  462. package/src/ruvocal/src/routes/settings/(nav)/application/+page.svelte +362 -0
  463. package/src/ruvocal/src/routes/settings/+layout.svelte +40 -0
  464. package/src/ruvocal/src/styles/highlight-js.css +195 -0
  465. package/src/ruvocal/src/styles/main.css +144 -0
  466. package/src/ruvocal/static/chatui/apple-touch-icon.png +0 -0
  467. package/src/ruvocal/static/chatui/favicon-dark.svg +3 -0
  468. package/src/ruvocal/static/chatui/favicon-dev.svg +3 -0
  469. package/src/ruvocal/static/chatui/favicon.ico +0 -0
  470. package/src/ruvocal/static/chatui/favicon.svg +3 -0
  471. package/src/ruvocal/static/chatui/icon-128x128.png +0 -0
  472. package/src/ruvocal/static/chatui/icon-144x144.png +0 -0
  473. package/src/ruvocal/static/chatui/icon-192x192.png +0 -0
  474. package/src/ruvocal/static/chatui/icon-256x256.png +0 -0
  475. package/src/ruvocal/static/chatui/icon-36x36.png +0 -0
  476. package/src/ruvocal/static/chatui/icon-48x48.png +0 -0
  477. package/src/ruvocal/static/chatui/icon-512x512.png +0 -0
  478. package/src/ruvocal/static/chatui/icon-72x72.png +0 -0
  479. package/src/ruvocal/static/chatui/icon-96x96.png +0 -0
  480. package/src/ruvocal/static/chatui/icon.svg +3 -0
  481. package/src/ruvocal/static/chatui/logo.svg +7 -0
  482. package/src/ruvocal/static/chatui/manifest.json +54 -0
  483. package/src/ruvocal/static/chatui/omni-welcome.gif +0 -0
  484. package/src/ruvocal/static/chatui/omni-welcome.png +0 -0
  485. package/src/ruvocal/static/chatui/welcome.js +184 -0
  486. package/src/ruvocal/static/chatui/welcome.svg +1 -0
  487. package/src/ruvocal/static/huggingchat/apple-touch-icon.png +0 -0
  488. package/src/ruvocal/static/huggingchat/assistants-thumbnail.png +0 -0
  489. package/src/ruvocal/static/huggingchat/castle-example.jpg +0 -0
  490. package/src/ruvocal/static/huggingchat/favicon-dark.svg +4 -0
  491. package/src/ruvocal/static/huggingchat/favicon-dev.svg +4 -0
  492. package/src/ruvocal/static/huggingchat/favicon.ico +0 -0
  493. package/src/ruvocal/static/huggingchat/favicon.svg +4 -0
  494. package/src/ruvocal/static/huggingchat/fulltext-logo.svg +2 -0
  495. package/src/ruvocal/static/huggingchat/icon-128x128.png +0 -0
  496. package/src/ruvocal/static/huggingchat/icon-144x144.png +0 -0
  497. package/src/ruvocal/static/huggingchat/icon-192x192.png +0 -0
  498. package/src/ruvocal/static/huggingchat/icon-256x256.png +0 -0
  499. package/src/ruvocal/static/huggingchat/icon-36x36.png +0 -0
  500. package/src/ruvocal/static/huggingchat/icon-48x48.png +0 -0
  501. package/src/ruvocal/static/huggingchat/icon-512x512.png +0 -0
  502. package/src/ruvocal/static/huggingchat/icon-72x72.png +0 -0
  503. package/src/ruvocal/static/huggingchat/icon-96x96.png +0 -0
  504. package/src/ruvocal/static/huggingchat/icon.svg +4 -0
  505. package/src/ruvocal/static/huggingchat/logo.svg +4 -0
  506. package/src/ruvocal/static/huggingchat/manifest.json +54 -0
  507. package/src/ruvocal/static/huggingchat/omni-welcome.gif +0 -0
  508. package/src/ruvocal/static/huggingchat/routes.chat.json +226 -0
  509. package/src/ruvocal/static/huggingchat/thumbnail.png +0 -0
  510. package/src/ruvocal/static/huggingchat/tools-thumbnail.png +0 -0
  511. package/src/ruvocal/static/robots.txt +10 -0
  512. package/src/ruvocal/stub/@reflink/reflink/index.js +0 -0
  513. package/src/ruvocal/stub/@reflink/reflink/package.json +5 -0
  514. package/src/ruvocal/svelte.config.js +53 -0
  515. package/src/ruvocal/tailwind.config.cjs +30 -0
  516. package/src/ruvocal/tsconfig.json +19 -0
  517. package/src/ruvocal/vite.config.ts +87 -0
  518. package/src/scripts/deploy.sh +116 -0
  519. package/src/scripts/generate-config.js +245 -0
  520. package/src/scripts/generate-welcome.js +187 -0
  521. 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
+ ```