ruflo 3.5.2 → 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,23 @@
1
+ import { error, type RequestHandler } from "@sveltejs/kit";
2
+ import { superjsonResponse } from "$lib/server/api/utils/superjsonResponse";
3
+ import { requireAuth } from "$lib/server/api/utils/requireAuth";
4
+ import { createConversationFromShare } from "$lib/server/conversation";
5
+
6
+ export const POST: RequestHandler = async ({ locals, request }) => {
7
+ requireAuth(locals);
8
+
9
+ const body = await request.json();
10
+ const shareId = body?.shareId;
11
+
12
+ if (!shareId || typeof shareId !== "string" || shareId.length === 0) {
13
+ error(400, "shareId is required");
14
+ }
15
+
16
+ const conversationId = await createConversationFromShare(
17
+ shareId,
18
+ locals,
19
+ request.headers.get("User-Agent") ?? undefined
20
+ );
21
+
22
+ return superjsonResponse({ conversationId });
23
+ };
@@ -0,0 +1,16 @@
1
+ import type { RequestHandler } from "@sveltejs/kit";
2
+ import { superjsonResponse } from "$lib/server/api/utils/superjsonResponse";
3
+ import { config } from "$lib/server/config";
4
+ import { requireAdmin } from "$lib/server/api/utils/requireAuth";
5
+
6
+ export const GET: RequestHandler = async ({ locals }) => {
7
+ requireAdmin(locals);
8
+ const { models } = await import("$lib/server/models");
9
+ return superjsonResponse({
10
+ OPENAI_BASE_URL: config.OPENAI_BASE_URL,
11
+ OPENAI_API_KEY_SET: Boolean(config.OPENAI_API_KEY || config.HF_TOKEN),
12
+ LEGACY_HF_TOKEN_SET: Boolean(config.HF_TOKEN && !config.OPENAI_API_KEY),
13
+ MODELS_COUNT: models.length,
14
+ NODE_VERSION: process.versions.node,
15
+ });
16
+ };
@@ -0,0 +1,30 @@
1
+ import type { RequestHandler } from "@sveltejs/kit";
2
+ import { superjsonResponse } from "$lib/server/api/utils/superjsonResponse";
3
+ import { config } from "$lib/server/config";
4
+ import { requireAdmin } from "$lib/server/api/utils/requireAuth";
5
+
6
+ export const GET: RequestHandler = async ({ locals }) => {
7
+ requireAdmin(locals);
8
+ const base = (config.OPENAI_BASE_URL || "https://router.huggingface.co/v1").replace(/\/$/, "");
9
+ const res = await fetch(`${base}/models`);
10
+ const body = await res.text();
11
+ let parsed: unknown;
12
+ try {
13
+ parsed = JSON.parse(body);
14
+ } catch {
15
+ parsed = undefined;
16
+ }
17
+ return superjsonResponse({
18
+ status: res.status,
19
+ ok: res.ok,
20
+ base,
21
+ length: (() => {
22
+ if (parsed && typeof parsed === "object" && "data" in parsed) {
23
+ const data = (parsed as { data?: unknown }).data;
24
+ return Array.isArray(data) ? data.length : null;
25
+ }
26
+ return null;
27
+ })(),
28
+ sample: body.slice(0, 2000),
29
+ });
30
+ };
@@ -0,0 +1,196 @@
1
+ import { error, type RequestHandler } from "@sveltejs/kit";
2
+ import { collections } from "$lib/server/database";
3
+ import { authCondition } from "$lib/server/auth";
4
+ import { config } from "$lib/server/config";
5
+ import yazl from "yazl";
6
+ import { downloadFile } from "$lib/server/files/downloadFile";
7
+ import mimeTypes from "mime-types";
8
+ import { logger } from "$lib/server/logger";
9
+
10
+ export const GET: RequestHandler = async ({ locals }) => {
11
+ if (!locals.user) {
12
+ error(401, "Not logged in");
13
+ }
14
+
15
+ if (!locals.isAdmin) {
16
+ error(403, "Not admin");
17
+ }
18
+
19
+ if (config.ENABLE_DATA_EXPORT !== "true") {
20
+ error(403, "Data export is not enabled");
21
+ }
22
+
23
+ const nExports = await collections.messageEvents.countDocuments({
24
+ userId: locals.user._id,
25
+ type: "export",
26
+ expiresAt: { $gt: new Date() },
27
+ });
28
+
29
+ if (nExports >= 1) {
30
+ error(
31
+ 429,
32
+ "You have already exported your data recently. Please wait 1 hour before exporting again."
33
+ );
34
+ }
35
+
36
+ const stats: {
37
+ nConversations: number;
38
+ nMessages: number;
39
+ nFiles: number;
40
+ nAssistants: number;
41
+ nAvatars: number;
42
+ } = {
43
+ nConversations: 0,
44
+ nMessages: 0,
45
+ nFiles: 0,
46
+ nAssistants: 0,
47
+ nAvatars: 0,
48
+ };
49
+
50
+ const zipfile = new yazl.ZipFile();
51
+
52
+ const promises = [
53
+ collections.conversations
54
+ .find({ ...authCondition(locals) })
55
+ .toArray()
56
+ .then(async (conversations) => {
57
+ const formattedConversations = await Promise.all(
58
+ conversations.map(async (conversation) => {
59
+ stats.nConversations++;
60
+ const hashes: string[] = [];
61
+ conversation.messages.forEach(async (message) => {
62
+ stats.nMessages++;
63
+ if (message.files) {
64
+ message.files.forEach((file) => {
65
+ hashes.push(file.value);
66
+ });
67
+ }
68
+ });
69
+ const files = await Promise.all(
70
+ hashes.map(async (hash) => {
71
+ try {
72
+ const fileData = await downloadFile(hash, conversation._id);
73
+ return fileData;
74
+ } catch {
75
+ return null;
76
+ }
77
+ })
78
+ );
79
+
80
+ const filenames: string[] = [];
81
+ files.forEach((file) => {
82
+ if (!file) return;
83
+
84
+ const extension = mimeTypes.extension(file.mime) || null;
85
+ const convId = conversation._id.toString();
86
+ const fileId = file.name.split("-")[1].slice(0, 8);
87
+ const fileName = `file-${convId}-${fileId}` + (extension ? `.${extension}` : "");
88
+ filenames.push(fileName);
89
+ zipfile.addBuffer(Buffer.from(file.value, "base64"), fileName);
90
+ stats.nFiles++;
91
+ });
92
+
93
+ return {
94
+ ...conversation,
95
+ messages: conversation.messages.map((message) => {
96
+ return {
97
+ ...message,
98
+ files: filenames,
99
+ updates: undefined,
100
+ };
101
+ }),
102
+ };
103
+ })
104
+ );
105
+
106
+ zipfile.addBuffer(
107
+ Buffer.from(JSON.stringify(formattedConversations, null, 2)),
108
+ "conversations.json"
109
+ );
110
+ }),
111
+ collections.assistants
112
+ .find({ createdById: locals.user._id })
113
+ .toArray()
114
+ .then(async (assistants) => {
115
+ const formattedAssistants = await Promise.all(
116
+ assistants.map(async (assistant) => {
117
+ if (assistant.avatar) {
118
+ const fileId = collections.bucket.find({
119
+ filename: assistant._id.toString(),
120
+ });
121
+
122
+ const content = await fileId.next().then(async (file) => {
123
+ if (!file?._id) return;
124
+
125
+ const fileStream = collections.bucket.openDownloadStream(file?._id);
126
+
127
+ const fileBuffer = await new Promise<Buffer>((resolve, reject) => {
128
+ const chunks: Uint8Array[] = [];
129
+ fileStream.on("data", (chunk) => chunks.push(chunk));
130
+ fileStream.on("error", reject);
131
+ fileStream.on("end", () => resolve(Buffer.concat(chunks)));
132
+ });
133
+
134
+ return fileBuffer;
135
+ });
136
+
137
+ if (!content) return;
138
+
139
+ zipfile.addBuffer(content, `avatar-${assistant._id.toString()}.jpg`);
140
+ stats.nAvatars++;
141
+ }
142
+
143
+ stats.nAssistants++;
144
+
145
+ return {
146
+ _id: assistant._id.toString(),
147
+ name: assistant.name,
148
+ createdById: assistant.createdById.toString(),
149
+ createdByName: assistant.createdByName,
150
+ avatar: `avatar-${assistant._id.toString()}.jpg`,
151
+ modelId: assistant.modelId,
152
+ preprompt: assistant.preprompt,
153
+ description: assistant.description,
154
+ dynamicPrompt: assistant.dynamicPrompt,
155
+ exampleInputs: assistant.exampleInputs,
156
+ generateSettings: assistant.generateSettings,
157
+ createdAt: assistant.createdAt.toISOString(),
158
+ updatedAt: assistant.updatedAt.toISOString(),
159
+ };
160
+ })
161
+ );
162
+
163
+ zipfile.addBuffer(
164
+ Buffer.from(JSON.stringify(formattedAssistants, null, 2)),
165
+ "assistants.json"
166
+ );
167
+ }),
168
+ ];
169
+
170
+ Promise.all(promises).then(async () => {
171
+ logger.info(
172
+ {
173
+ userId: locals.user?._id,
174
+ ...stats,
175
+ },
176
+ "Exported user data"
177
+ );
178
+ zipfile.end();
179
+ if (locals.user?._id) {
180
+ await collections.messageEvents.insertOne({
181
+ userId: locals.user?._id,
182
+ type: "export",
183
+ createdAt: new Date(),
184
+ expiresAt: new Date(Date.now() + 1000 * 60 * 60), // 1 hour
185
+ });
186
+ }
187
+ });
188
+
189
+ // @ts-expect-error - zipfile.outputStream is not typed correctly
190
+ return new Response(zipfile.outputStream, {
191
+ headers: {
192
+ "Content-Type": "application/zip",
193
+ "Content-Disposition": 'attachment; filename="export.zip"',
194
+ },
195
+ });
196
+ };
@@ -0,0 +1,14 @@
1
+ import type { RequestHandler } from "@sveltejs/kit";
2
+ import { superjsonResponse } from "$lib/server/api/utils/superjsonResponse";
3
+ import { loginEnabled } from "$lib/server/auth";
4
+ import { config } from "$lib/server/config";
5
+ import type { FeatureFlags } from "$lib/server/api/types";
6
+
7
+ export const GET: RequestHandler = async ({ locals }) => {
8
+ return superjsonResponse({
9
+ enableAssistants: config.ENABLE_ASSISTANTS === "true",
10
+ loginEnabled,
11
+ isAdmin: locals.isAdmin,
12
+ transcriptionEnabled: !!config.get("TRANSCRIPTION_MODEL"),
13
+ } satisfies FeatureFlags);
14
+ };
@@ -0,0 +1,38 @@
1
+ import type { RequestHandler } from "@sveltejs/kit";
2
+ import { superjsonResponse } from "$lib/server/api/utils/superjsonResponse";
3
+ import type { GETModelsResponse } from "$lib/server/api/types";
4
+
5
+ export const GET: RequestHandler = async () => {
6
+ try {
7
+ const { models } = await import("$lib/server/models");
8
+ return superjsonResponse(
9
+ models
10
+ .filter((m) => m.unlisted == false)
11
+ .map((model) => ({
12
+ id: model.id,
13
+ name: model.name,
14
+ websiteUrl: model.websiteUrl,
15
+ modelUrl: model.modelUrl,
16
+ datasetName: model.datasetName,
17
+ datasetUrl: model.datasetUrl,
18
+ displayName: model.displayName,
19
+ description: model.description,
20
+ logoUrl: model.logoUrl,
21
+ providers: model.providers as unknown as Array<
22
+ { provider: string } & Record<string, unknown>
23
+ >,
24
+ promptExamples: model.promptExamples,
25
+ parameters: model.parameters,
26
+ preprompt: model.preprompt,
27
+ multimodal: model.multimodal,
28
+ multimodalAcceptedMimetypes: model.multimodalAcceptedMimetypes,
29
+ supportsTools: (model as unknown as { supportsTools?: boolean }).supportsTools ?? false,
30
+ unlisted: model.unlisted,
31
+ hasInferenceAPI: model.hasInferenceAPI,
32
+ isRouter: model.isRouter,
33
+ })) satisfies GETModelsResponse
34
+ );
35
+ } catch {
36
+ return superjsonResponse([] as GETModelsResponse);
37
+ }
38
+ };
@@ -0,0 +1,8 @@
1
+ import type { RequestHandler } from "@sveltejs/kit";
2
+ import { superjsonResponse } from "$lib/server/api/utils/superjsonResponse";
3
+ import { resolveModel } from "$lib/server/api/utils/resolveModel";
4
+
5
+ export const GET: RequestHandler = async ({ params }) => {
6
+ const model = await resolveModel(params.namespace ?? "");
7
+ return superjsonResponse(model);
8
+ };
@@ -0,0 +1,8 @@
1
+ import type { RequestHandler } from "@sveltejs/kit";
2
+ import { superjsonResponse } from "$lib/server/api/utils/superjsonResponse";
3
+ import { resolveModel } from "$lib/server/api/utils/resolveModel";
4
+
5
+ export const GET: RequestHandler = async ({ params }) => {
6
+ const model = await resolveModel(params.namespace ?? "", params.model ?? "");
7
+ return superjsonResponse(model);
8
+ };
@@ -0,0 +1,28 @@
1
+ import { error, type RequestHandler } from "@sveltejs/kit";
2
+ import { resolveModel } from "$lib/server/api/utils/resolveModel";
3
+ import { collections } from "$lib/server/database";
4
+ import { authCondition } from "$lib/server/auth";
5
+
6
+ export const POST: RequestHandler = async ({ params, locals }) => {
7
+ if (!locals.sessionId) {
8
+ error(401, "Unauthorized");
9
+ }
10
+
11
+ const model = await resolveModel(params.namespace ?? "", params.model ?? "");
12
+
13
+ await collections.settings.updateOne(
14
+ authCondition(locals),
15
+ {
16
+ $set: {
17
+ activeModel: model.id,
18
+ updatedAt: new Date(),
19
+ },
20
+ $setOnInsert: {
21
+ createdAt: new Date(),
22
+ },
23
+ },
24
+ { upsert: true }
25
+ );
26
+
27
+ return new Response();
28
+ };
@@ -0,0 +1,28 @@
1
+ import { error, type RequestHandler } from "@sveltejs/kit";
2
+ import { resolveModel } from "$lib/server/api/utils/resolveModel";
3
+ import { collections } from "$lib/server/database";
4
+ import { authCondition } from "$lib/server/auth";
5
+
6
+ export const POST: RequestHandler = async ({ params, locals }) => {
7
+ if (!locals.sessionId) {
8
+ error(401, "Unauthorized");
9
+ }
10
+
11
+ const model = await resolveModel(params.namespace ?? "");
12
+
13
+ await collections.settings.updateOne(
14
+ authCondition(locals),
15
+ {
16
+ $set: {
17
+ activeModel: model.id,
18
+ updatedAt: new Date(),
19
+ },
20
+ $setOnInsert: {
21
+ createdAt: new Date(),
22
+ },
23
+ },
24
+ { upsert: true }
25
+ );
26
+
27
+ return new Response();
28
+ };
@@ -0,0 +1,7 @@
1
+ import type { RequestHandler } from "@sveltejs/kit";
2
+ import { superjsonResponse } from "$lib/server/api/utils/superjsonResponse";
3
+ import type { GETOldModelsResponse } from "$lib/server/api/types";
4
+
5
+ export const GET: RequestHandler = async () => {
6
+ return superjsonResponse([] as GETOldModelsResponse);
7
+ };
@@ -0,0 +1,33 @@
1
+ import { error, type RequestHandler } from "@sveltejs/kit";
2
+ import { superjsonResponse } from "$lib/server/api/utils/superjsonResponse";
3
+ import { requireAdmin } from "$lib/server/api/utils/requireAuth";
4
+ import { refreshModels, lastModelRefreshSummary } from "$lib/server/models";
5
+
6
+ export const POST: RequestHandler = async ({ locals }) => {
7
+ requireAdmin(locals);
8
+
9
+ const previous = lastModelRefreshSummary;
10
+
11
+ try {
12
+ const summary = await refreshModels();
13
+ return superjsonResponse({
14
+ refreshedAt: summary.refreshedAt.toISOString(),
15
+ durationMs: summary.durationMs,
16
+ added: summary.added,
17
+ removed: summary.removed,
18
+ changed: summary.changed,
19
+ total: summary.total,
20
+ hadChanges:
21
+ summary.added.length > 0 || summary.removed.length > 0 || summary.changed.length > 0,
22
+ previous:
23
+ previous.refreshedAt.getTime() > 0
24
+ ? {
25
+ refreshedAt: previous.refreshedAt.toISOString(),
26
+ total: previous.total,
27
+ }
28
+ : null,
29
+ });
30
+ } catch {
31
+ error(502, "Model refresh failed");
32
+ }
33
+ };
@@ -0,0 +1,7 @@
1
+ import type { RequestHandler } from "@sveltejs/kit";
2
+ import { superjsonResponse } from "$lib/server/api/utils/superjsonResponse";
3
+ import { config } from "$lib/server/config";
4
+
5
+ export const GET: RequestHandler = async () => {
6
+ return superjsonResponse(await config.getPublicConfig());
7
+ };
@@ -0,0 +1,17 @@
1
+ import type { RequestHandler } from "@sveltejs/kit";
2
+ import { superjsonResponse } from "$lib/server/api/utils/superjsonResponse";
3
+
4
+ export const GET: RequestHandler = async ({ locals }) => {
5
+ return superjsonResponse(
6
+ locals.user
7
+ ? {
8
+ id: locals.user._id.toString(),
9
+ username: locals.user.username,
10
+ avatarUrl: locals.user.avatarUrl,
11
+ email: locals.user.email,
12
+ isAdmin: locals.user.isAdmin ?? false,
13
+ isEarlyAccess: locals.user.isEarlyAccess ?? false,
14
+ }
15
+ : null
16
+ );
17
+ };
@@ -0,0 +1,73 @@
1
+ import { error, type RequestHandler } from "@sveltejs/kit";
2
+ import { superjsonResponse } from "$lib/server/api/utils/superjsonResponse";
3
+ import { config } from "$lib/server/config";
4
+ import { collections } from "$lib/server/database";
5
+ import { authCondition } from "$lib/server/auth";
6
+ import { logger } from "$lib/server/logger";
7
+
8
+ export const GET: RequestHandler = async ({ locals }) => {
9
+ if (!config.isHuggingChat) {
10
+ error(404, "Not available");
11
+ }
12
+
13
+ if (!locals.user) {
14
+ error(401, "Login required");
15
+ }
16
+
17
+ if (!locals.token) {
18
+ error(401, "OAuth token not available. Please log out and log back in.");
19
+ }
20
+
21
+ try {
22
+ const response = await fetch("https://huggingface.co/oauth/userinfo", {
23
+ headers: { Authorization: `Bearer ${locals.token}` },
24
+ });
25
+
26
+ if (!response.ok) {
27
+ logger.error(`Failed to fetch billing orgs: ${response.status}`);
28
+ error(502, "Failed to fetch billing information");
29
+ }
30
+
31
+ const data = await response.json();
32
+
33
+ const settings = await collections.settings.findOne(authCondition(locals));
34
+ const currentBillingOrg = settings?.billingOrganization;
35
+
36
+ const billingOrgs = (data.orgs ?? [])
37
+ .filter((org: { canPay?: boolean }) => org.canPay === true)
38
+ .map((org: { sub: string; name: string; preferred_username: string }) => ({
39
+ sub: org.sub,
40
+ name: org.name,
41
+ preferred_username: org.preferred_username,
42
+ }));
43
+
44
+ const isCurrentOrgValid =
45
+ !currentBillingOrg ||
46
+ billingOrgs.some(
47
+ (org: { preferred_username: string }) => org.preferred_username === currentBillingOrg
48
+ );
49
+
50
+ if (!isCurrentOrgValid && currentBillingOrg) {
51
+ logger.info(
52
+ `Clearing invalid billingOrganization '${currentBillingOrg}' for user ${locals.user._id}`
53
+ );
54
+ await collections.settings.updateOne(authCondition(locals), {
55
+ $unset: { billingOrganization: "" },
56
+ $set: { updatedAt: new Date() },
57
+ });
58
+ }
59
+
60
+ return superjsonResponse({
61
+ userCanPay: data.canPay ?? false,
62
+ organizations: billingOrgs,
63
+ currentBillingOrg: isCurrentOrgValid ? currentBillingOrg : undefined,
64
+ });
65
+ } catch (err) {
66
+ // Re-throw SvelteKit HttpErrors
67
+ if (err && typeof err === "object" && "status" in err) {
68
+ throw err;
69
+ }
70
+ logger.error(err, "Error fetching billing orgs:");
71
+ error(500, "Internal server error");
72
+ }
73
+ };
@@ -0,0 +1,17 @@
1
+ import type { RequestHandler } from "@sveltejs/kit";
2
+ import { superjsonResponse } from "$lib/server/api/utils/superjsonResponse";
3
+ import { collections } from "$lib/server/database";
4
+
5
+ export const GET: RequestHandler = async ({ locals }) => {
6
+ if (!locals.user || !locals.sessionId) {
7
+ return superjsonResponse([]);
8
+ }
9
+
10
+ const reports = await collections.reports
11
+ .find({
12
+ createdBy: locals.user?._id ?? locals.sessionId,
13
+ })
14
+ .toArray();
15
+
16
+ return superjsonResponse(reports);
17
+ };
@@ -0,0 +1,103 @@
1
+ import type { RequestHandler } from "@sveltejs/kit";
2
+ import { superjsonResponse } from "$lib/server/api/utils/superjsonResponse";
3
+ import { collections } from "$lib/server/database";
4
+ import { authCondition } from "$lib/server/auth";
5
+ import { requireAuth } from "$lib/server/api/utils/requireAuth";
6
+ import { defaultModel, models, validateModel } from "$lib/server/models";
7
+ import { DEFAULT_SETTINGS, type SettingsEditable } from "$lib/types/Settings";
8
+ import { resolveStreamingMode } from "$lib/utils/messageUpdates";
9
+ import { z } from "zod";
10
+
11
+ const settingsSchema = z.object({
12
+ shareConversationsWithModelAuthors: z
13
+ .boolean()
14
+ .default(DEFAULT_SETTINGS.shareConversationsWithModelAuthors),
15
+ welcomeModalSeen: z.boolean().optional(),
16
+ activeModel: z.string().default(DEFAULT_SETTINGS.activeModel),
17
+ customPrompts: z.record(z.string()).default({}),
18
+ multimodalOverrides: z.record(z.boolean()).default({}),
19
+ toolsOverrides: z.record(z.boolean()).default({}),
20
+ providerOverrides: z.record(z.string()).default({}),
21
+ streamingMode: z.enum(["raw", "smooth"]).optional(),
22
+ directPaste: z.boolean().default(false),
23
+ hapticsEnabled: z.boolean().default(true),
24
+ hidePromptExamples: z.record(z.boolean()).default({}),
25
+ autopilotEnabled: z.boolean().default(true),
26
+ billingOrganization: z.string().optional(),
27
+ });
28
+
29
+ export const GET: RequestHandler = async ({ locals }) => {
30
+ requireAuth(locals);
31
+ const settings = await collections.settings.findOne(authCondition(locals));
32
+
33
+ if (settings && !validateModel(models).safeParse(settings?.activeModel).success) {
34
+ settings.activeModel = defaultModel.id;
35
+ await collections.settings.updateOne(authCondition(locals), {
36
+ $set: { activeModel: defaultModel.id },
37
+ });
38
+ }
39
+
40
+ // if the model is unlisted, set the active model to the default model
41
+ if (
42
+ settings?.activeModel &&
43
+ models.find((m) => m.id === settings?.activeModel)?.unlisted === true
44
+ ) {
45
+ settings.activeModel = defaultModel.id;
46
+ await collections.settings.updateOne(authCondition(locals), {
47
+ $set: { activeModel: defaultModel.id },
48
+ });
49
+ }
50
+
51
+ const streamingMode = resolveStreamingMode(settings ?? {});
52
+
53
+ return superjsonResponse({
54
+ welcomeModalSeen: !!settings?.welcomeModalSeenAt,
55
+ welcomeModalSeenAt: settings?.welcomeModalSeenAt ?? null,
56
+
57
+ activeModel: settings?.activeModel ?? DEFAULT_SETTINGS.activeModel,
58
+ streamingMode,
59
+ directPaste: settings?.directPaste ?? DEFAULT_SETTINGS.directPaste,
60
+ hapticsEnabled: settings?.hapticsEnabled ?? DEFAULT_SETTINGS.hapticsEnabled,
61
+ hidePromptExamples: settings?.hidePromptExamples ?? DEFAULT_SETTINGS.hidePromptExamples,
62
+ shareConversationsWithModelAuthors:
63
+ settings?.shareConversationsWithModelAuthors ??
64
+ DEFAULT_SETTINGS.shareConversationsWithModelAuthors,
65
+
66
+ customPrompts: settings?.customPrompts ?? {},
67
+ multimodalOverrides: settings?.multimodalOverrides ?? {},
68
+ toolsOverrides: settings?.toolsOverrides ?? {},
69
+ providerOverrides: settings?.providerOverrides ?? {},
70
+ autopilotEnabled: settings?.autopilotEnabled ?? DEFAULT_SETTINGS.autopilotEnabled,
71
+ billingOrganization: settings?.billingOrganization ?? undefined,
72
+ });
73
+ };
74
+
75
+ export const POST: RequestHandler = async ({ locals, request }) => {
76
+ requireAuth(locals);
77
+ const body = await request.json();
78
+
79
+ const { welcomeModalSeen, ...parsedSettings } = settingsSchema.parse(body);
80
+ const streamingMode = resolveStreamingMode(parsedSettings);
81
+
82
+ const settings = {
83
+ ...parsedSettings,
84
+ streamingMode,
85
+ } satisfies SettingsEditable;
86
+
87
+ await collections.settings.updateOne(
88
+ authCondition(locals),
89
+ {
90
+ $set: {
91
+ ...settings,
92
+ ...(welcomeModalSeen && { welcomeModalSeenAt: new Date() }),
93
+ updatedAt: new Date(),
94
+ },
95
+ $setOnInsert: {
96
+ createdAt: new Date(),
97
+ },
98
+ },
99
+ { upsert: true }
100
+ );
101
+
102
+ return new Response();
103
+ };