@lobehub/lobehub 2.0.0-next.2 → 2.0.0-next.21

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 (603) hide show
  1. package/.env.desktop +1 -2
  2. package/.env.example +0 -3
  3. package/.env.example.development +0 -2
  4. package/.github/workflows/claude-auto-testing.yml +73 -0
  5. package/.github/workflows/claude-translate-comments.yml +67 -0
  6. package/.github/workflows/desktop-pr-build.yml +18 -16
  7. package/.github/workflows/docker.yml +25 -20
  8. package/.github/workflows/e2e.yml +17 -3
  9. package/.github/workflows/release-desktop-beta.yml +12 -12
  10. package/.github/workflows/release.yml +3 -5
  11. package/.github/workflows/test.yml +47 -12
  12. package/.nvmrc +1 -1
  13. package/CHANGELOG.md +484 -0
  14. package/Dockerfile +1 -3
  15. package/README.md +2 -45
  16. package/README.zh-CN.md +2 -45
  17. package/apps/desktop/src/main/controllers/AuthCtr.ts +53 -39
  18. package/apps/desktop/src/main/controllers/__tests__/AuthCtr.test.ts +706 -0
  19. package/apps/desktop/src/main/utils/next-electron-rsc.ts +7 -5
  20. package/apps/desktop/tsconfig.json +0 -1
  21. package/changelog/v1.json +159 -0
  22. package/docs/development/database-schema.dbml +11 -1
  23. package/docs/self-hosting/advanced/auth/next-auth/auth0.mdx +2 -2
  24. package/docs/self-hosting/advanced/auth/next-auth/auth0.zh-CN.mdx +2 -2
  25. package/docs/self-hosting/advanced/auth/next-auth/authelia.mdx +2 -2
  26. package/docs/self-hosting/advanced/auth/next-auth/authelia.zh-CN.mdx +2 -2
  27. package/docs/self-hosting/advanced/auth/next-auth/authentik.mdx +2 -2
  28. package/docs/self-hosting/advanced/auth/next-auth/authentik.zh-CN.mdx +2 -2
  29. package/docs/self-hosting/advanced/auth/next-auth/casdoor.mdx +2 -2
  30. package/docs/self-hosting/advanced/auth/next-auth/casdoor.zh-CN.mdx +2 -2
  31. package/docs/self-hosting/advanced/auth/next-auth/cloudflare-zero-trust.mdx +2 -2
  32. package/docs/self-hosting/advanced/auth/next-auth/cloudflare-zero-trust.zh-CN.mdx +2 -2
  33. package/docs/self-hosting/advanced/auth/next-auth/github.mdx +2 -2
  34. package/docs/self-hosting/advanced/auth/next-auth/github.zh-CN.mdx +2 -2
  35. package/docs/self-hosting/advanced/auth/next-auth/google.mdx +32 -29
  36. package/docs/self-hosting/advanced/auth/next-auth/keycloak.mdx +2 -2
  37. package/docs/self-hosting/advanced/auth/next-auth/keycloak.zh-CN.mdx +2 -2
  38. package/docs/self-hosting/advanced/auth/next-auth/logto.mdx +5 -3
  39. package/docs/self-hosting/advanced/auth/next-auth/logto.zh-CN.mdx +5 -3
  40. package/docs/self-hosting/advanced/auth/next-auth/microsoft-entra-id.mdx +2 -2
  41. package/docs/self-hosting/advanced/auth/next-auth/microsoft-entra-id.zh-CN.mdx +2 -2
  42. package/docs/self-hosting/advanced/auth/next-auth/okta.mdx +2 -2
  43. package/docs/self-hosting/advanced/auth/next-auth/okta.zh-CN.mdx +2 -2
  44. package/docs/self-hosting/advanced/auth/next-auth/wechat.mdx +2 -2
  45. package/docs/self-hosting/advanced/auth/next-auth/wechat.zh-CN.mdx +2 -2
  46. package/docs/self-hosting/advanced/auth/next-auth/zitadel.mdx +2 -2
  47. package/docs/self-hosting/advanced/auth/next-auth/zitadel.zh-CN.mdx +2 -2
  48. package/docs/self-hosting/advanced/auth.mdx +32 -21
  49. package/docs/self-hosting/advanced/auth.zh-CN.mdx +30 -19
  50. package/docs/self-hosting/advanced/feature-flags.mdx +0 -1
  51. package/docs/self-hosting/advanced/feature-flags.zh-CN.mdx +0 -1
  52. package/docs/self-hosting/advanced/online-search.mdx +30 -25
  53. package/docs/self-hosting/advanced/online-search.zh-CN.mdx +25 -23
  54. package/e2e/src/features/discover/smoke.feature +34 -1
  55. package/e2e/src/steps/discover/smoke.steps.ts +116 -4
  56. package/e2e/tsconfig.json +0 -1
  57. package/locales/ar/models.json +15 -6
  58. package/locales/ar/oauth.json +1 -0
  59. package/locales/bg-BG/models.json +15 -6
  60. package/locales/bg-BG/oauth.json +1 -0
  61. package/locales/de-DE/models.json +15 -6
  62. package/locales/de-DE/oauth.json +1 -0
  63. package/locales/en-US/models.json +15 -6
  64. package/locales/en-US/oauth.json +1 -0
  65. package/locales/es-ES/models.json +15 -6
  66. package/locales/es-ES/oauth.json +1 -0
  67. package/locales/fa-IR/models.json +15 -6
  68. package/locales/fa-IR/oauth.json +1 -0
  69. package/locales/fr-FR/models.json +15 -6
  70. package/locales/fr-FR/oauth.json +1 -0
  71. package/locales/it-IT/models.json +15 -6
  72. package/locales/it-IT/oauth.json +1 -0
  73. package/locales/ja-JP/models.json +15 -6
  74. package/locales/ja-JP/oauth.json +1 -0
  75. package/locales/ko-KR/models.json +21 -12
  76. package/locales/ko-KR/oauth.json +1 -0
  77. package/locales/nl-NL/models.json +15 -6
  78. package/locales/nl-NL/oauth.json +1 -0
  79. package/locales/pl-PL/models.json +15 -6
  80. package/locales/pl-PL/oauth.json +1 -0
  81. package/locales/pt-BR/models.json +15 -6
  82. package/locales/pt-BR/oauth.json +1 -0
  83. package/locales/ru-RU/models.json +15 -6
  84. package/locales/ru-RU/oauth.json +1 -0
  85. package/locales/tr-TR/models.json +15 -6
  86. package/locales/tr-TR/oauth.json +1 -0
  87. package/locales/vi-VN/models.json +15 -6
  88. package/locales/vi-VN/oauth.json +1 -0
  89. package/locales/zh-CN/models.json +15 -6
  90. package/locales/zh-CN/oauth.json +1 -0
  91. package/locales/zh-TW/models.json +15 -6
  92. package/locales/zh-TW/oauth.json +1 -0
  93. package/next.config.ts +2 -3
  94. package/package.json +74 -80
  95. package/packages/const/src/index.ts +0 -1
  96. package/packages/const/src/models.ts +13 -0
  97. package/packages/const/src/url.ts +1 -4
  98. package/packages/const/src/version.ts +3 -3
  99. package/packages/context-engine/src/index.ts +1 -6
  100. package/packages/context-engine/src/processors/GroupMessageFlatten.ts +12 -2
  101. package/packages/context-engine/src/processors/__tests__/GroupMessageFlatten.test.ts +73 -9
  102. package/packages/context-engine/src/providers/index.ts +0 -2
  103. package/packages/database/migrations/0041_improve_index.sql +10 -0
  104. package/packages/database/migrations/meta/0041_snapshot.json +7784 -0
  105. package/packages/database/migrations/meta/_journal.json +7 -0
  106. package/packages/database/package.json +1 -1
  107. package/packages/database/src/core/migrations.json +17 -0
  108. package/packages/database/src/core/web-server.ts +2 -1
  109. package/packages/database/src/models/__tests__/message.grouping.test.ts +812 -0
  110. package/packages/database/src/models/__tests__/message.test.ts +322 -170
  111. package/packages/database/src/models/message.ts +62 -24
  112. package/packages/database/src/models/session.ts +60 -19
  113. package/packages/database/src/repositories/dataImporter/deprecated/__tests__/index.test.ts +2 -1
  114. package/packages/database/src/repositories/dataImporter/deprecated/index.ts +7 -1
  115. package/packages/database/src/schemas/agent.ts +10 -11
  116. package/packages/database/src/schemas/message.ts +5 -1
  117. package/packages/database/src/schemas/relations.ts +6 -4
  118. package/packages/database/src/schemas/session.ts +2 -0
  119. package/packages/database/src/schemas/topic.ts +6 -1
  120. package/packages/database/src/utils/__tests__/groupMessages.test.ts +145 -2
  121. package/packages/database/src/utils/groupMessages.ts +7 -5
  122. package/packages/electron-client-ipc/package.json +4 -1
  123. package/packages/file-loaders/package.json +1 -0
  124. package/packages/memory-extract/package.json +1 -1
  125. package/packages/model-bank/src/aiModels/anthropic.ts +0 -63
  126. package/packages/model-bank/src/aiModels/azure.ts +155 -0
  127. package/packages/model-bank/src/aiModels/bedrock.ts +44 -0
  128. package/packages/model-bank/src/aiModels/higress.ts +0 -55
  129. package/packages/model-bank/src/aiModels/infiniai.ts +21 -0
  130. package/packages/model-bank/src/aiModels/ollamacloud.ts +13 -0
  131. package/packages/model-bank/src/aiModels/siliconcloud.ts +19 -0
  132. package/packages/model-runtime/src/core/parameterResolver.ts +3 -0
  133. package/packages/model-runtime/src/core/streams/openai/__snapshots__/responsesStream.test.ts.snap +0 -38
  134. package/packages/model-runtime/src/providers/azureOpenai/index.ts +2 -1
  135. package/packages/model-runtime/src/providers/minimax/index.ts +5 -5
  136. package/packages/model-runtime/src/providers/search1api/index.test.ts +2 -2
  137. package/packages/model-runtime/src/utils/googleErrorParser.test.ts +125 -0
  138. package/packages/model-runtime/src/utils/googleErrorParser.ts +103 -77
  139. package/packages/types/src/message/common/base.ts +13 -0
  140. package/packages/types/src/message/common/image.ts +8 -0
  141. package/packages/types/src/message/common/metadata.ts +39 -0
  142. package/packages/types/src/message/common/tools.ts +10 -0
  143. package/packages/types/src/message/db/params.ts +47 -1
  144. package/packages/types/src/message/ui/chat.ts +4 -1
  145. package/packages/types/src/message/ui/params.ts +98 -4
  146. package/packages/types/src/search.ts +16 -0
  147. package/packages/types/src/serverConfig.ts +2 -6
  148. package/packages/types/src/user/index.ts +13 -1
  149. package/packages/types/src/user/settings/index.ts +22 -0
  150. package/packages/utils/src/apiKey.test.ts +139 -0
  151. package/packages/utils/src/client/clipboard.ts +2 -2
  152. package/packages/utils/src/client/exportFile.ts +10 -10
  153. package/packages/utils/src/client/parserPlaceholder.ts +18 -18
  154. package/packages/utils/src/client/topic.ts +10 -10
  155. package/packages/utils/src/client/xor-obfuscation.ts +11 -11
  156. package/packages/web-crawler/src/crawImpl/firecrawl.ts +39 -12
  157. package/packages/web-crawler/tsconfig.json +0 -1
  158. package/renovate.json +20 -3
  159. package/scripts/migrateServerDB/errorHint.js +1 -7
  160. package/scripts/migrateServerDB/index.ts +2 -1
  161. package/src/app/(backend)/webapi/revalidate/route.ts +1 -1
  162. package/src/app/[variants]/(auth)/signup/[[...signup]]/page.tsx +1 -8
  163. package/src/app/[variants]/(main)/(mobile)/me/(home)/__tests__/useCategory.test.tsx +9 -0
  164. package/src/app/[variants]/(main)/(mobile)/me/(home)/features/UserBanner.tsx +3 -6
  165. package/src/app/[variants]/(main)/(mobile)/me/(home)/layout.tsx +0 -2
  166. package/src/app/[variants]/(main)/_layout/Desktop/SideBar/TopActions.tsx +1 -4
  167. package/src/app/[variants]/(main)/chat/(workspace)/@conversation/features/ChatInput/V1Mobile/index.tsx +2 -2
  168. package/src/app/[variants]/(main)/chat/(workspace)/@conversation/features/ChatInput/V1Mobile/useSend.ts +6 -4
  169. package/src/app/[variants]/(main)/chat/(workspace)/@conversation/features/ChatInput/useSend.ts +15 -10
  170. package/src/app/[variants]/(main)/chat/@session/features/SessionListContent/List/Item/Actions.tsx +3 -28
  171. package/src/app/[variants]/(main)/chat/@session/features/SessionListContent/List/Item/index.tsx +4 -2
  172. package/src/app/[variants]/(main)/chat/_layout/Desktop/index.tsx +0 -2
  173. package/src/app/[variants]/(main)/chat/_layout/Mobile.tsx +1 -5
  174. package/src/app/[variants]/(main)/chat/settings/features/HeaderContent.tsx +2 -62
  175. package/src/app/[variants]/(main)/discover/(list)/features/Pagination.tsx +1 -0
  176. package/src/app/[variants]/(main)/discover/(list)/features/SortButton/index.tsx +1 -1
  177. package/src/app/[variants]/(main)/discover/(list)/mcp/features/List/Item.tsx +1 -0
  178. package/src/app/[variants]/(main)/discover/(list)/model/features/List/Item.tsx +1 -0
  179. package/src/app/[variants]/(main)/discover/(list)/provider/features/List/Item.tsx +1 -0
  180. package/src/app/[variants]/(main)/discover/components/CategoryMenu.tsx +9 -1
  181. package/src/app/[variants]/(main)/image/@topic/features/Topics/TopicList.tsx +1 -0
  182. package/src/app/[variants]/(main)/image/features/PromptInput/index.tsx +1 -1
  183. package/src/app/[variants]/(main)/image/page.tsx +0 -2
  184. package/src/app/[variants]/(main)/labs/components/LabCard.tsx +3 -1
  185. package/src/app/[variants]/(main)/profile/_layout/Desktop/index.tsx +23 -24
  186. package/src/app/[variants]/(main)/profile/_layout/Mobile/index.tsx +5 -9
  187. package/src/app/[variants]/(main)/settings/_layout/Desktop/index.tsx +0 -2
  188. package/src/app/[variants]/(main)/settings/_layout/Mobile/index.tsx +0 -2
  189. package/src/app/[variants]/(main)/settings/_layout/SettingsContent.tsx +0 -3
  190. package/src/app/[variants]/(main)/settings/provider/(list)/ProviderGrid/Card.tsx +1 -1
  191. package/src/app/[variants]/(main)/settings/provider/detail/azure/index.tsx +5 -7
  192. package/src/app/[variants]/layout.tsx +1 -0
  193. package/src/app/[variants]/loading/index.tsx +1 -10
  194. package/src/app/[variants]/oauth/ResultLayout.tsx +47 -0
  195. package/src/app/[variants]/oauth/callback/error/page.tsx +20 -33
  196. package/src/app/[variants]/oauth/callback/layout.tsx +1 -0
  197. package/src/app/[variants]/oauth/callback/success/page.tsx +8 -22
  198. package/src/app/[variants]/oauth/consent/[uid]/Consent/BuiltinConsent.tsx +47 -0
  199. package/src/app/[variants]/oauth/consent/[uid]/{Consent.tsx → Consent/index.tsx} +12 -1
  200. package/src/app/[variants]/oauth/consent/[uid]/Login.tsx +19 -2
  201. package/src/app/sitemap.tsx +7 -1
  202. package/src/components/InvalidAPIKey/APIKeyForm/Bedrock.tsx +8 -13
  203. package/src/components/Link.tsx +12 -0
  204. package/src/components/Thinking/index.tsx +4 -3
  205. package/src/config/db.ts +0 -5
  206. package/src/config/featureFlags/schema.test.ts +0 -2
  207. package/src/config/featureFlags/schema.ts +0 -6
  208. package/src/config/modelProviders/ai21.ts +1 -16
  209. package/src/config/modelProviders/ai302.ts +1 -128
  210. package/src/config/modelProviders/ai360.ts +1 -32
  211. package/src/config/modelProviders/anthropic.ts +1 -94
  212. package/src/config/modelProviders/azure.ts +1 -51
  213. package/src/config/modelProviders/baichuan.ts +1 -57
  214. package/src/config/modelProviders/bedrock.ts +1 -276
  215. package/src/config/modelProviders/cloudflare.ts +1 -64
  216. package/src/config/modelProviders/deepseek.ts +1 -19
  217. package/src/config/modelProviders/fireworksai.ts +1 -174
  218. package/src/config/modelProviders/giteeai.ts +1 -135
  219. package/src/config/modelProviders/github.ts +1 -254
  220. package/src/config/modelProviders/google.ts +1 -130
  221. package/src/config/modelProviders/groq.ts +1 -119
  222. package/src/config/modelProviders/higress.ts +1 -1736
  223. package/src/config/modelProviders/huggingface.ts +1 -54
  224. package/src/config/modelProviders/hunyuan.ts +1 -83
  225. package/src/config/modelProviders/infiniai.ts +1 -74
  226. package/src/config/modelProviders/internlm.ts +1 -20
  227. package/src/config/modelProviders/minimax.ts +1 -1
  228. package/src/config/modelProviders/mistral.ts +1 -95
  229. package/src/config/modelProviders/modelscope.ts +1 -27
  230. package/src/config/modelProviders/moonshot.ts +1 -29
  231. package/src/config/modelProviders/novita.ts +1 -105
  232. package/src/config/modelProviders/ollama.ts +1 -325
  233. package/src/config/modelProviders/openai.ts +1 -242
  234. package/src/config/modelProviders/openrouter.ts +1 -240
  235. package/src/config/modelProviders/perplexity.ts +1 -45
  236. package/src/config/modelProviders/ppio.ts +1 -152
  237. package/src/config/modelProviders/qiniu.ts +2 -19
  238. package/src/config/modelProviders/qwen.ts +1 -245
  239. package/src/config/modelProviders/search1api.ts +1 -34
  240. package/src/config/modelProviders/sensenova.ts +1 -69
  241. package/src/config/modelProviders/siliconcloud.ts +1 -417
  242. package/src/config/modelProviders/spark.ts +1 -59
  243. package/src/config/modelProviders/stepfun.ts +1 -98
  244. package/src/config/modelProviders/taichu.ts +1 -18
  245. package/src/config/modelProviders/togetherai.ts +1 -274
  246. package/src/config/modelProviders/upstage.ts +1 -28
  247. package/src/config/modelProviders/wenxin.ts +1 -140
  248. package/src/config/modelProviders/xai.ts +1 -38
  249. package/src/config/modelProviders/zeroone.ts +1 -81
  250. package/src/config/modelProviders/zhipu.ts +1 -108
  251. package/src/envs/app.ts +5 -8
  252. package/src/envs/auth.ts +0 -179
  253. package/src/features/AgentSetting/AgentPlugin/index.tsx +2 -2
  254. package/src/features/ChatInput/ActionBar/STT/browser.tsx +2 -2
  255. package/src/features/ChatInput/ActionBar/STT/openai.tsx +2 -2
  256. package/src/features/ChatInput/ActionBar/Tools/useControls.tsx +1 -3
  257. package/src/features/Conversation/Error/ErrorJsonViewer.tsx +4 -3
  258. package/src/features/Conversation/Error/OllamaBizError/index.tsx +7 -2
  259. package/src/features/Conversation/Error/index.tsx +15 -5
  260. package/src/features/Conversation/MarkdownElements/LobeArtifact/Render/index.tsx +2 -2
  261. package/src/features/Conversation/Messages/Assistant/Extra/index.tsx +2 -2
  262. package/src/features/Conversation/Messages/Assistant/MessageContent.tsx +5 -3
  263. package/src/features/Conversation/Messages/Assistant/Tool/Inspector/BuiltinPluginTitle.tsx +2 -2
  264. package/src/features/Conversation/Messages/Assistant/Tool/Inspector/ToolTitle.tsx +4 -2
  265. package/src/features/Conversation/Messages/Assistant/Tool/Render/CustomRender.tsx +2 -2
  266. package/src/features/Conversation/Messages/Assistant/Tool/Render/index.tsx +2 -2
  267. package/src/features/Conversation/Messages/Assistant/Tool/index.tsx +2 -2
  268. package/src/features/Conversation/Messages/Assistant/index.tsx +4 -4
  269. package/src/features/Conversation/Messages/Default.tsx +2 -2
  270. package/src/features/Conversation/Messages/User/Extra.tsx +2 -2
  271. package/src/features/Conversation/Messages/User/index.tsx +4 -4
  272. package/src/features/Conversation/Messages/index.tsx +3 -3
  273. package/src/features/Conversation/components/AutoScroll.tsx +2 -2
  274. package/src/features/Conversation/components/Extras/Usage/UsageDetail/index.tsx +9 -6
  275. package/src/features/DataImporter/index.tsx +15 -60
  276. package/src/features/DevPanel/PostgresViewer/usePgTable.ts +3 -2
  277. package/src/features/PluginTag/index.tsx +1 -3
  278. package/src/features/PluginsUI/Render/BuiltinType/index.test.tsx +37 -28
  279. package/src/features/Portal/Artifacts/Body/index.tsx +2 -2
  280. package/src/helpers/isCanUseFC.ts +0 -8
  281. package/src/hooks/useEnabledChatModels.ts +0 -8
  282. package/src/hooks/useInterceptingRoutes.test.ts +21 -3
  283. package/src/hooks/useModelContextWindowTokens.ts +0 -8
  284. package/src/hooks/useModelHasContextWindowToken.ts +1 -10
  285. package/src/hooks/useModelSupportFiles.ts +1 -11
  286. package/src/hooks/useModelSupportReasoning.ts +1 -11
  287. package/src/hooks/useModelSupportToolUse.ts +1 -11
  288. package/src/hooks/useModelSupportVision.ts +1 -11
  289. package/src/layout/AuthProvider/Clerk/index.tsx +2 -16
  290. package/src/libs/next-auth/auth.config.ts +3 -6
  291. package/src/libs/next-auth/sso-providers/auth0.ts +0 -7
  292. package/src/libs/next-auth/sso-providers/authelia.ts +3 -5
  293. package/src/libs/next-auth/sso-providers/authentik.ts +0 -7
  294. package/src/libs/next-auth/sso-providers/cloudflare-zero-trust.ts +3 -6
  295. package/src/libs/next-auth/sso-providers/cognito.ts +1 -5
  296. package/src/libs/next-auth/sso-providers/generic-oidc.ts +3 -5
  297. package/src/libs/next-auth/sso-providers/github.ts +0 -6
  298. package/src/libs/next-auth/sso-providers/google.ts +0 -2
  299. package/src/libs/next-auth/sso-providers/index.ts +0 -2
  300. package/src/libs/next-auth/sso-providers/keycloak.ts +0 -3
  301. package/src/libs/next-auth/sso-providers/logto.ts +3 -5
  302. package/src/libs/next-auth/sso-providers/okta.ts +0 -4
  303. package/src/libs/next-auth/sso-providers/zitadel.ts +0 -7
  304. package/src/libs/oidc-provider/provider.ts +1 -1
  305. package/src/libs/trpc/client/index.ts +0 -1
  306. package/src/libs/trpc/client/lambda.ts +8 -5
  307. package/src/libs/trpc/lambda/context.ts +4 -1
  308. package/src/locales/default/oauth.ts +1 -0
  309. package/src/server/globalConfig/index.ts +0 -23
  310. package/src/server/modules/AssistantStore/index.ts +1 -1
  311. package/src/server/modules/ModelRuntime/trace.ts +11 -4
  312. package/src/server/routers/desktop/mcp.ts +1 -3
  313. package/src/server/routers/lambda/__tests__/integration/message.integration.test.ts +0 -41
  314. package/src/server/routers/lambda/config/__snapshots__/index.test.ts.snap +175 -12
  315. package/src/server/routers/lambda/config/index.test.ts +38 -30
  316. package/src/server/routers/lambda/message.ts +17 -13
  317. package/src/server/routers/lambda/session.ts +8 -5
  318. package/src/server/routers/lambda/user.ts +24 -25
  319. package/src/server/routers/tools/mcp.ts +2 -3
  320. package/src/server/routers/tools/search.test.ts +1 -7
  321. package/src/server/routers/tools/search.ts +1 -4
  322. package/src/server/services/search/impls/firecrawl/index.ts +51 -11
  323. package/src/server/services/search/impls/firecrawl/type.ts +60 -9
  324. package/src/services/__tests__/tool.test.ts +0 -3
  325. package/src/services/aiModel/index.test.ts +0 -3
  326. package/src/services/aiModel/index.ts +1 -7
  327. package/src/services/aiProvider/index.test.ts +0 -3
  328. package/src/services/aiProvider/index.ts +1 -7
  329. package/src/services/chat/chat.test.ts +13 -40
  330. package/src/services/chat/contextEngineering.test.ts +0 -30
  331. package/src/services/chat/contextEngineering.ts +1 -12
  332. package/src/services/chat/helper.ts +7 -31
  333. package/src/services/chat/index.ts +5 -10
  334. package/src/services/chat/types.ts +1 -1
  335. package/src/services/chatGroup/index.ts +1 -10
  336. package/src/services/config.ts +1 -65
  337. package/src/services/export/index.ts +1 -4
  338. package/src/services/file/index.ts +1 -11
  339. package/src/services/import/index.ts +1 -7
  340. package/src/services/mcp.test.ts +777 -0
  341. package/src/services/message/index.ts +1 -11
  342. package/src/services/message/server.ts +7 -6
  343. package/src/services/message/type.ts +6 -3
  344. package/src/services/models.ts +2 -11
  345. package/src/services/plugin/index.ts +1 -11
  346. package/src/services/session/index.ts +1 -11
  347. package/src/services/tableViewer/client.ts +12 -15
  348. package/src/services/thread/index.ts +1 -7
  349. package/src/services/topic/index.ts +1 -11
  350. package/src/services/user/index.ts +1 -13
  351. package/src/store/chat/helpers.test.ts +99 -0
  352. package/src/store/chat/helpers.ts +21 -2
  353. package/src/store/chat/selectors.ts +1 -1
  354. package/src/store/chat/slices/aiChat/actions/__tests__/generateAIChat.test.ts +0 -241
  355. package/src/store/chat/slices/aiChat/actions/__tests__/generateAIChatV2.test.ts +26 -1
  356. package/src/store/chat/slices/aiChat/actions/__tests__/helpers.ts +3 -1
  357. package/src/store/chat/slices/aiChat/actions/generateAIChat.ts +45 -155
  358. package/src/store/chat/slices/builtinTool/actions/index.ts +1 -4
  359. package/src/store/chat/slices/message/action.test.ts +5 -1
  360. package/src/store/chat/slices/message/action.ts +102 -14
  361. package/src/store/chat/slices/message/reducer.test.ts +363 -5
  362. package/src/store/chat/slices/message/reducer.ts +87 -3
  363. package/src/store/chat/slices/message/{selectors.test.ts → selectors/chat.test.ts} +266 -30
  364. package/src/store/chat/slices/message/{selectors.ts → selectors/chat.ts} +29 -79
  365. package/src/store/chat/slices/message/selectors/index.ts +2 -0
  366. package/src/store/chat/slices/message/selectors/messageState.test.ts +36 -0
  367. package/src/store/chat/slices/message/selectors/messageState.ts +80 -0
  368. package/src/store/chat/slices/plugin/action.test.ts +34 -132
  369. package/src/store/chat/slices/plugin/action.ts +1 -44
  370. package/src/store/global/store.ts +1 -7
  371. package/src/store/tool/selectors/tool.test.ts +1 -1
  372. package/src/store/tool/selectors/tool.ts +6 -8
  373. package/src/store/tool/slices/builtin/action.test.ts +83 -35
  374. package/src/store/tool/slices/builtin/action.ts +0 -9
  375. package/src/store/tool/slices/builtin/selectors.test.ts +4 -30
  376. package/src/store/tool/slices/builtin/selectors.ts +15 -21
  377. package/src/store/user/initialState.ts +1 -7
  378. package/src/store/user/selectors.ts +1 -5
  379. package/src/store/user/slices/common/action.test.ts +1 -4
  380. package/src/store/user/slices/common/action.ts +5 -4
  381. package/src/store/user/slices/settings/selectors/index.ts +1 -0
  382. package/src/store/user/slices/settings/selectors/keyVaults.ts +21 -0
  383. package/src/store/user/store.ts +0 -3
  384. package/src/tools/index.ts +0 -6
  385. package/src/tools/renders.ts +0 -3
  386. package/src/tools/web-browsing/Portal/Search/Footer.tsx +2 -2
  387. package/src/tools/web-browsing/Render/Search/ConfigForm/Form.tsx +1 -1
  388. package/tsconfig.json +9 -3
  389. package/packages/const/src/guide.ts +0 -89
  390. package/packages/context-engine/src/providers/InboxGuide.ts +0 -102
  391. package/packages/context-engine/src/providers/__tests__/InboxGuideProvider.test.ts +0 -121
  392. package/packages/utils/src/_deprecated/__snapshots__/parseModels.test.ts.snap +0 -104
  393. package/packages/utils/src/_deprecated/parseModels.test.ts +0 -287
  394. package/packages/utils/src/_deprecated/parseModels.ts +0 -165
  395. package/src/app/(backend)/trpc/edge/[trpc]/route.ts +0 -26
  396. package/src/app/[variants]/(main)/(mobile)/me/data/features/Category.tsx +0 -48
  397. package/src/app/[variants]/(main)/(mobile)/me/data/features/Header.tsx +0 -33
  398. package/src/app/[variants]/(main)/(mobile)/me/data/layout.tsx +0 -13
  399. package/src/app/[variants]/(main)/(mobile)/me/data/loading.tsx +0 -5
  400. package/src/app/[variants]/(main)/(mobile)/me/data/page.tsx +0 -29
  401. package/src/app/[variants]/(main)/chat/features/Migration/DBReader.ts +0 -290
  402. package/src/app/[variants]/(main)/chat/features/Migration/ExportConfigButton.tsx +0 -35
  403. package/src/app/[variants]/(main)/chat/features/Migration/Failed.tsx +0 -120
  404. package/src/app/[variants]/(main)/chat/features/Migration/Modal.tsx +0 -81
  405. package/src/app/[variants]/(main)/chat/features/Migration/Start.tsx +0 -108
  406. package/src/app/[variants]/(main)/chat/features/Migration/UpgradeButton.tsx +0 -71
  407. package/src/app/[variants]/(main)/chat/features/Migration/const.ts +0 -15
  408. package/src/app/[variants]/(main)/chat/features/Migration/index.tsx +0 -50
  409. package/src/app/[variants]/(main)/settings/llm/ProviderList/Azure/index.tsx +0 -93
  410. package/src/app/[variants]/(main)/settings/llm/ProviderList/Bedrock/index.tsx +0 -70
  411. package/src/app/[variants]/(main)/settings/llm/ProviderList/Cloudflare/index.tsx +0 -39
  412. package/src/app/[variants]/(main)/settings/llm/ProviderList/Github/index.tsx +0 -52
  413. package/src/app/[variants]/(main)/settings/llm/ProviderList/HuggingFace/index.tsx +0 -52
  414. package/src/app/[variants]/(main)/settings/llm/ProviderList/Ollama/index.tsx +0 -20
  415. package/src/app/[variants]/(main)/settings/llm/ProviderList/OpenAI/index.tsx +0 -17
  416. package/src/app/[variants]/(main)/settings/llm/ProviderList/providers.tsx +0 -132
  417. package/src/app/[variants]/(main)/settings/llm/components/Checker.tsx +0 -118
  418. package/src/app/[variants]/(main)/settings/llm/components/ProviderConfig/index.tsx +0 -303
  419. package/src/app/[variants]/(main)/settings/llm/components/ProviderModelList/CustomModelOption.tsx +0 -98
  420. package/src/app/[variants]/(main)/settings/llm/components/ProviderModelList/ModelConfigModal/Form.tsx +0 -104
  421. package/src/app/[variants]/(main)/settings/llm/components/ProviderModelList/ModelConfigModal/index.tsx +0 -77
  422. package/src/app/[variants]/(main)/settings/llm/components/ProviderModelList/ModelFetcher.tsx +0 -105
  423. package/src/app/[variants]/(main)/settings/llm/components/ProviderModelList/Option.tsx +0 -68
  424. package/src/app/[variants]/(main)/settings/llm/components/ProviderModelList/index.tsx +0 -146
  425. package/src/app/[variants]/(main)/settings/llm/const.ts +0 -20
  426. package/src/app/[variants]/(main)/settings/llm/features/Footer.tsx +0 -35
  427. package/src/app/[variants]/(main)/settings/llm/index.tsx +0 -30
  428. package/src/app/[variants]/(main)/settings/llm/type.ts +0 -5
  429. package/src/app/[variants]/loading/Client/Content.tsx +0 -48
  430. package/src/app/[variants]/loading/Client/Error.tsx +0 -27
  431. package/src/app/[variants]/loading/Client/Redirect.tsx +0 -47
  432. package/src/app/[variants]/loading/Client/index.tsx +0 -22
  433. package/src/components/InnerLink.tsx +0 -20
  434. package/src/database/_deprecated/core/__tests__/db-upgrade.test.ts +0 -42
  435. package/src/database/_deprecated/core/__tests__/db.test.ts +0 -79
  436. package/src/database/_deprecated/core/__tests__/model.test.ts +0 -55
  437. package/src/database/_deprecated/core/db.ts +0 -246
  438. package/src/database/_deprecated/core/index.ts +0 -2
  439. package/src/database/_deprecated/core/migrations/migrateSettingsToUser/fixtures/input.json +0 -55
  440. package/src/database/_deprecated/core/migrations/migrateSettingsToUser/fixtures/output.json +0 -60
  441. package/src/database/_deprecated/core/migrations/migrateSettingsToUser/index.test.ts +0 -14
  442. package/src/database/_deprecated/core/migrations/migrateSettingsToUser/index.ts +0 -22
  443. package/src/database/_deprecated/core/migrations/migrateSettingsToUser/type.ts +0 -105
  444. package/src/database/_deprecated/core/model.ts +0 -218
  445. package/src/database/_deprecated/core/schemas.ts +0 -88
  446. package/src/database/_deprecated/core/types/db.ts +0 -15
  447. package/src/database/_deprecated/models/__DEBUG.ts +0 -124
  448. package/src/database/_deprecated/models/__tests__/file.test.ts +0 -83
  449. package/src/database/_deprecated/models/__tests__/message.test.ts +0 -426
  450. package/src/database/_deprecated/models/__tests__/plugin.test.ts +0 -81
  451. package/src/database/_deprecated/models/__tests__/session.test.ts +0 -253
  452. package/src/database/_deprecated/models/__tests__/sessionGroup.test.ts +0 -220
  453. package/src/database/_deprecated/models/__tests__/topic.test.ts +0 -523
  454. package/src/database/_deprecated/models/__tests__/user.test.ts +0 -82
  455. package/src/database/_deprecated/models/file.ts +0 -51
  456. package/src/database/_deprecated/models/message.ts +0 -277
  457. package/src/database/_deprecated/models/plugin.ts +0 -62
  458. package/src/database/_deprecated/models/session.ts +0 -271
  459. package/src/database/_deprecated/models/sessionGroup.ts +0 -93
  460. package/src/database/_deprecated/models/topic.ts +0 -250
  461. package/src/database/_deprecated/models/user.ts +0 -69
  462. package/src/database/_deprecated/schemas/files.ts +0 -39
  463. package/src/database/_deprecated/schemas/message.ts +0 -50
  464. package/src/database/_deprecated/schemas/plugin.ts +0 -12
  465. package/src/database/_deprecated/schemas/session.ts +0 -54
  466. package/src/database/_deprecated/schemas/sessionGroup.ts +0 -8
  467. package/src/database/_deprecated/schemas/topic.ts +0 -12
  468. package/src/database/_deprecated/schemas/user.ts +0 -40
  469. package/src/envs/__tests__/auth.test.ts +0 -200
  470. package/src/features/DataImporter/_deprecated.ts +0 -43
  471. package/src/features/InitClientDB/EnableModal.tsx +0 -118
  472. package/src/features/InitClientDB/ErrorResult.tsx +0 -143
  473. package/src/features/InitClientDB/InitIndicator.tsx +0 -124
  474. package/src/features/InitClientDB/PGliteIcon.tsx +0 -28
  475. package/src/features/InitClientDB/features/DatabaseRepair/Backup.tsx +0 -75
  476. package/src/features/InitClientDB/features/DatabaseRepair/Diagnosis.tsx +0 -98
  477. package/src/features/InitClientDB/features/DatabaseRepair/Repair.tsx +0 -218
  478. package/src/features/InitClientDB/features/DatabaseRepair/index.tsx +0 -91
  479. package/src/features/InitClientDB/index.tsx +0 -37
  480. package/src/hooks/_header.ts +0 -23
  481. package/src/libs/next-auth/sso-providers/azure-ad.ts +0 -33
  482. package/src/libs/trpc/client/edge.ts +0 -26
  483. package/src/libs/trpc/edge/context.ts +0 -71
  484. package/src/libs/trpc/edge/index.ts +0 -45
  485. package/src/libs/trpc/edge/init.ts +0 -26
  486. package/src/libs/trpc/edge/middleware/jwtPayload.test.ts +0 -75
  487. package/src/libs/trpc/edge/middleware/jwtPayload.ts +0 -14
  488. package/src/migrations/FromV0ToV1.ts +0 -10
  489. package/src/migrations/FromV1ToV2/fixtures/input-v1-session.json +0 -191
  490. package/src/migrations/FromV1ToV2/fixtures/output-v2.json +0 -202
  491. package/src/migrations/FromV1ToV2/index.ts +0 -82
  492. package/src/migrations/FromV1ToV2/migrations.test.ts +0 -224
  493. package/src/migrations/FromV1ToV2/types/v1.ts +0 -78
  494. package/src/migrations/FromV1ToV2/types/v2.ts +0 -52
  495. package/src/migrations/FromV2ToV3/fixtures/input-v2-session.json +0 -72
  496. package/src/migrations/FromV2ToV3/fixtures/output-v3-from-v1.json +0 -203
  497. package/src/migrations/FromV2ToV3/fixtures/output-v3.json +0 -74
  498. package/src/migrations/FromV2ToV3/index.ts +0 -30
  499. package/src/migrations/FromV2ToV3/migrations.test.ts +0 -42
  500. package/src/migrations/FromV2ToV3/types/v3.ts +0 -27
  501. package/src/migrations/FromV3ToV4/fixtures/azure-input-v3.json +0 -79
  502. package/src/migrations/FromV3ToV4/fixtures/azure-output-v4.json +0 -75
  503. package/src/migrations/FromV3ToV4/fixtures/ollama-input-v3.json +0 -85
  504. package/src/migrations/FromV3ToV4/fixtures/ollama-output-v4.json +0 -86
  505. package/src/migrations/FromV3ToV4/fixtures/openai-input-v3.json +0 -77
  506. package/src/migrations/FromV3ToV4/fixtures/openai-output-v4.json +0 -77
  507. package/src/migrations/FromV3ToV4/fixtures/openrouter-input-v3.json +0 -82
  508. package/src/migrations/FromV3ToV4/fixtures/openrouter-output-v4.json +0 -85
  509. package/src/migrations/FromV3ToV4/fixtures/output-v4-from-v1.json +0 -203
  510. package/src/migrations/FromV3ToV4/index.ts +0 -102
  511. package/src/migrations/FromV3ToV4/migrations.test.ts +0 -195
  512. package/src/migrations/FromV3ToV4/types/v3.ts +0 -52
  513. package/src/migrations/FromV3ToV4/types/v4.ts +0 -37
  514. package/src/migrations/FromV4ToV5/fixtures/from-v1-to-v5-output.json +0 -245
  515. package/src/migrations/FromV4ToV5/fixtures/function-input-v4.json +0 -96
  516. package/src/migrations/FromV4ToV5/fixtures/function-output-v5.json +0 -120
  517. package/src/migrations/FromV4ToV5/index.ts +0 -58
  518. package/src/migrations/FromV4ToV5/migrations.test.ts +0 -49
  519. package/src/migrations/FromV4ToV5/types/v4.ts +0 -21
  520. package/src/migrations/FromV4ToV5/types/v5.ts +0 -27
  521. package/src/migrations/FromV5ToV6/fixtures/from-v1-to-v6-output.json +0 -247
  522. package/src/migrations/FromV5ToV6/fixtures/session-input-v5.json +0 -81
  523. package/src/migrations/FromV5ToV6/fixtures/session-output-v6.json +0 -85
  524. package/src/migrations/FromV5ToV6/index.ts +0 -61
  525. package/src/migrations/FromV5ToV6/migrations.test.ts +0 -50
  526. package/src/migrations/FromV5ToV6/types/v5.ts +0 -48
  527. package/src/migrations/FromV5ToV6/types/v6.ts +0 -63
  528. package/src/migrations/FromV6ToV7/fixtures/output-v7-from-v1.json +0 -203
  529. package/src/migrations/FromV6ToV7/fixtures/provider-input-v6.json +0 -103
  530. package/src/migrations/FromV6ToV7/fixtures/provider-output-v7.json +0 -118
  531. package/src/migrations/FromV6ToV7/index.ts +0 -101
  532. package/src/migrations/FromV6ToV7/migrations.test.ts +0 -64
  533. package/src/migrations/FromV6ToV7/types/v6.ts +0 -61
  534. package/src/migrations/FromV6ToV7/types/v7.ts +0 -69
  535. package/src/migrations/VersionController.test.ts +0 -88
  536. package/src/migrations/VersionController.ts +0 -67
  537. package/src/migrations/index.ts +0 -61
  538. package/src/server/globalConfig/_deprecated.test.ts +0 -92
  539. package/src/server/globalConfig/_deprecated.ts +0 -41
  540. package/src/server/routers/edge/appStatus.ts +0 -3
  541. package/src/server/routers/edge/index.ts +0 -14
  542. package/src/server/routers/edge/upload.ts +0 -16
  543. package/src/services/aiModel/client.ts +0 -70
  544. package/src/services/aiProvider/client.ts +0 -58
  545. package/src/services/baseClientService/index.ts +0 -9
  546. package/src/services/chat/__snapshots__/chat.test.ts.snap +0 -110
  547. package/src/services/chatGroup/client.ts +0 -63
  548. package/src/services/export/_deprecated.ts +0 -155
  549. package/src/services/export/client.ts +0 -15
  550. package/src/services/file/_deprecated.test.ts +0 -119
  551. package/src/services/file/_deprecated.ts +0 -80
  552. package/src/services/file/client.test.ts +0 -199
  553. package/src/services/file/client.ts +0 -85
  554. package/src/services/import/_deprecated.ts +0 -115
  555. package/src/services/import/client.test.ts +0 -1015
  556. package/src/services/import/client.ts +0 -64
  557. package/src/services/message/_deprecated.test.ts +0 -398
  558. package/src/services/message/_deprecated.ts +0 -168
  559. package/src/services/message/client.test.ts +0 -410
  560. package/src/services/message/client.ts +0 -186
  561. package/src/services/plugin/_deprecated.test.ts +0 -162
  562. package/src/services/plugin/_deprecated.ts +0 -42
  563. package/src/services/plugin/client.test.ts +0 -177
  564. package/src/services/plugin/client.ts +0 -46
  565. package/src/services/session/_deprecated.test.ts +0 -440
  566. package/src/services/session/_deprecated.ts +0 -190
  567. package/src/services/session/client.test.ts +0 -413
  568. package/src/services/session/client.ts +0 -193
  569. package/src/services/thread/client.ts +0 -51
  570. package/src/services/topic/_deprecated.test.ts +0 -245
  571. package/src/services/topic/_deprecated.ts +0 -75
  572. package/src/services/topic/client.ts +0 -89
  573. package/src/services/topic/pglite.test.ts +0 -212
  574. package/src/services/user/_deprecated.test.ts +0 -101
  575. package/src/services/user/_deprecated.ts +0 -70
  576. package/src/services/user/client.test.ts +0 -108
  577. package/src/services/user/client.ts +0 -104
  578. package/src/store/chat/slices/builtinTool/actions/__tests__/dalle.test.ts +0 -121
  579. package/src/store/chat/slices/builtinTool/actions/dalle.ts +0 -124
  580. package/src/store/global/actions/clientDb.ts +0 -67
  581. package/src/store/user/slices/modelList/__snapshots__/action.test.ts.snap +0 -12
  582. package/src/store/user/slices/modelList/action.test.ts +0 -359
  583. package/src/store/user/slices/modelList/action.ts +0 -223
  584. package/src/store/user/slices/modelList/initialState.ts +0 -15
  585. package/src/store/user/slices/modelList/reducers/customModelCard.test.ts +0 -204
  586. package/src/store/user/slices/modelList/reducers/customModelCard.ts +0 -64
  587. package/src/store/user/slices/modelList/selectors/index.ts +0 -3
  588. package/src/store/user/slices/modelList/selectors/keyVaults.test.ts +0 -201
  589. package/src/store/user/slices/modelList/selectors/keyVaults.ts +0 -50
  590. package/src/store/user/slices/modelList/selectors/modelConfig.test.ts +0 -219
  591. package/src/store/user/slices/modelList/selectors/modelConfig.ts +0 -95
  592. package/src/store/user/slices/modelList/selectors/modelProvider.test.ts +0 -138
  593. package/src/store/user/slices/modelList/selectors/modelProvider.ts +0 -170
  594. package/src/tools/dalle/Render/GalleyGrid.tsx +0 -60
  595. package/src/tools/dalle/Render/Item/EditMode.tsx +0 -66
  596. package/src/tools/dalle/Render/Item/Error.tsx +0 -49
  597. package/src/tools/dalle/Render/Item/Image.tsx +0 -44
  598. package/src/tools/dalle/Render/Item/ImageFileItem.tsx +0 -57
  599. package/src/tools/dalle/Render/Item/index.tsx +0 -88
  600. package/src/tools/dalle/Render/ToolBar.tsx +0 -56
  601. package/src/tools/dalle/Render/index.tsx +0 -52
  602. package/src/tools/dalle/index.ts +0 -92
  603. /package/src/{middleware.ts → proxy.ts} +0 -0
@@ -1,440 +0,0 @@
1
- import { Mock, beforeEach, describe, expect, it, vi } from 'vitest';
2
-
3
- import { SessionModel } from '@/database/_deprecated/models/session';
4
- import { SessionGroupModel } from '@/database/_deprecated/models/sessionGroup';
5
- import { LobeAgentConfig } from '@/types/agent';
6
- import { LobeAgentSession, LobeSessionType, SessionGroups } from '@/types/session';
7
-
8
- import { ClientService } from './_deprecated';
9
-
10
- const sessionService = new ClientService();
11
-
12
- // Mock the SessionModel
13
- vi.mock('@/database/_deprecated/models/session', () => {
14
- return {
15
- SessionModel: {
16
- create: vi.fn(),
17
- query: vi.fn(),
18
- delete: vi.fn(),
19
- clearTable: vi.fn(),
20
- update: vi.fn(),
21
- count: vi.fn(),
22
- batchCreate: vi.fn(),
23
- findById: vi.fn(),
24
- isEmpty: vi.fn(),
25
- queryByKeyword: vi.fn(),
26
- updateConfig: vi.fn(),
27
- queryByGroupIds: vi.fn(),
28
- updatePinned: vi.fn(),
29
- duplicate: vi.fn(),
30
- queryWithGroups: vi.fn(),
31
- },
32
- };
33
- });
34
-
35
- // Mock the SessionGroupModel
36
- vi.mock('@/database/_deprecated/models/sessionGroup', () => {
37
- return {
38
- SessionGroupModel: {
39
- create: vi.fn(),
40
- query: vi.fn(),
41
- delete: vi.fn(),
42
- clear: vi.fn(),
43
- update: vi.fn(),
44
- batchCreate: vi.fn(),
45
- isEmpty: vi.fn(),
46
- updateOrder: vi.fn(),
47
- queryByKeyword: vi.fn(),
48
- updateConfig: vi.fn(),
49
- queryByGroupIds: vi.fn(),
50
- },
51
- };
52
- });
53
-
54
- describe('SessionService', () => {
55
- const mockSessionId = 'mock-session-id';
56
- const mockSession = {
57
- id: mockSessionId,
58
- type: 'agent',
59
- meta: { title: 'Mock Session' },
60
- } as LobeAgentSession;
61
- const mockSessions = [mockSession];
62
-
63
- beforeEach(() => {
64
- // Reset all mocks before running each test case
65
- vi.resetAllMocks();
66
- });
67
-
68
- describe('createSession', () => {
69
- it('should create a new session and return its id', async () => {
70
- // Setup
71
- const sessionType = LobeSessionType.Agent;
72
- const defaultValue = { meta: { title: 'New Session' } } as Partial<LobeAgentSession>;
73
- (SessionModel.create as Mock).mockResolvedValue(mockSession);
74
-
75
- // Execute
76
- const sessionId = await sessionService.createSession(sessionType, defaultValue);
77
-
78
- // Assert
79
- expect(SessionModel.create).toHaveBeenCalledWith(sessionType, defaultValue);
80
- expect(sessionId).toBe(mockSessionId);
81
- });
82
-
83
- it('should throw an error if session creation fails', async () => {
84
- // Setup
85
- const sessionType = LobeSessionType.Agent;
86
- const defaultValue = { meta: { title: 'New Session' } } as Partial<LobeAgentSession>;
87
- (SessionModel.create as Mock).mockResolvedValue(null);
88
-
89
- // Execute & Assert
90
- await expect(sessionService.createSession(sessionType, defaultValue)).rejects.toThrow(
91
- 'session create Error',
92
- );
93
- });
94
- });
95
-
96
- describe('batchCreateSessions', () => {
97
- it('should batch create sessions', async () => {
98
- // Setup
99
- (SessionModel.batchCreate as Mock).mockResolvedValue(mockSessions);
100
-
101
- // Execute
102
- const result = await sessionService.batchCreateSessions(mockSessions);
103
-
104
- // Assert
105
- expect(SessionModel.batchCreate).toHaveBeenCalledWith(mockSessions);
106
- expect(result).toBe(mockSessions);
107
- });
108
- });
109
-
110
- describe('getSessionsByType', () => {
111
- it('should retrieve sessions with their group ids', async () => {
112
- // Setup
113
- (SessionModel.query as Mock).mockResolvedValue(mockSessions);
114
-
115
- // Execute
116
- const sessions = await sessionService.getSessionsByType();
117
-
118
- // Assert
119
- expect(SessionModel.query).toHaveBeenCalled();
120
- expect(sessions).toBe(mockSessions);
121
- });
122
-
123
- it('should retrieve all agent sessions', async () => {
124
- // Setup
125
- // Assuming that SessionModel.query has been modified to accept filters
126
- const agentSessions = mockSessions.filter((session) => session.type === 'agent');
127
- (SessionModel.query as Mock).mockResolvedValue(agentSessions);
128
-
129
- // Execute
130
- const result = await sessionService.getSessionsByType('agent');
131
-
132
- // Assert
133
- // Assuming that SessionModel.query would be called with a filter for agents
134
- expect(SessionModel.query).toHaveBeenCalled(); // Add filter argument if applicable
135
- expect(result).toBe(agentSessions);
136
- });
137
- });
138
-
139
- describe('removeSession', () => {
140
- it('should remove a session by its id', async () => {
141
- // Setup
142
- (SessionModel.delete as Mock).mockResolvedValue(true);
143
-
144
- // Execute
145
- const result = await sessionService.removeSession(mockSessionId);
146
-
147
- // Assert
148
- expect(SessionModel.delete).toHaveBeenCalledWith(mockSessionId);
149
- expect(result).toBe(true);
150
- });
151
- });
152
-
153
- describe('removeAllSessions', () => {
154
- it('should clear all sessions from the table', async () => {
155
- // Setup
156
- (SessionModel.clearTable as Mock).mockResolvedValue(true);
157
-
158
- // Execute
159
- const result = await sessionService.removeAllSessions();
160
-
161
- // Assert
162
- expect(SessionModel.clearTable).toHaveBeenCalled();
163
- expect(result).toBe(true);
164
- });
165
- });
166
-
167
- describe('updateSession', () => {
168
- it('should update the group of a session', async () => {
169
- // Setup
170
- const groupId = 'new-group';
171
- (SessionModel.update as Mock).mockResolvedValue({ ...mockSession, group: groupId });
172
-
173
- // Execute
174
- const result = await sessionService.updateSession(mockSessionId, { group: groupId });
175
-
176
- // Assert
177
- expect(SessionModel.update).toHaveBeenCalledWith(mockSessionId, { group: groupId });
178
- expect(result).toEqual({ ...mockSession, group: groupId });
179
- });
180
-
181
- it('should update the meta of a session', async () => {
182
- // Setup
183
- const newMeta = { description: 'Updated description' };
184
- (SessionModel.update as Mock).mockResolvedValue({ ...mockSession, meta: newMeta });
185
-
186
- // Execute
187
- const result = await sessionService.updateSession(mockSessionId, { meta: newMeta });
188
-
189
- // Assert
190
- expect(SessionModel.update).toHaveBeenCalledWith(mockSessionId, { meta: newMeta });
191
- expect(result).toEqual({ ...mockSession, meta: newMeta });
192
- });
193
-
194
- it('should update the pinned status of a session', async () => {
195
- // Setup
196
- const pinned = true;
197
-
198
- // Execute
199
- await sessionService.updateSession(mockSessionId, { pinned });
200
-
201
- // Assert
202
- expect(SessionModel.update).toHaveBeenCalledWith(mockSessionId, { pinned: 1 });
203
- });
204
- });
205
-
206
- describe('updateSessionConfig', () => {
207
- it('should update the config of a session', async () => {
208
- // Setup
209
- const newConfig = { model: 'abc' } as LobeAgentConfig;
210
- (SessionModel.updateConfig as Mock).mockResolvedValue({ ...mockSession, config: newConfig });
211
-
212
- // Execute
213
- const result = await sessionService.updateSessionConfig(mockSessionId, newConfig);
214
-
215
- // Assert
216
- expect(SessionModel.updateConfig).toHaveBeenCalledWith(mockSessionId, newConfig);
217
- expect(result).toEqual({ ...mockSession, config: newConfig });
218
- });
219
- });
220
-
221
- describe('countSessions', () => {
222
- it('should return false if no sessions exist', async () => {
223
- // Setup
224
- (SessionModel.count as Mock).mockResolvedValue(0);
225
-
226
- // Execute
227
- const result = await sessionService.countSessions();
228
-
229
- // Assert
230
- expect(SessionModel.count).toHaveBeenCalled();
231
- expect(result).toBe(0);
232
- });
233
-
234
- it('should return true if sessions exist', async () => {
235
- // Setup
236
- (SessionModel.count as Mock).mockResolvedValue(1);
237
-
238
- // Execute
239
- const result = await sessionService.countSessions();
240
-
241
- // Assert
242
- expect(SessionModel.count).toHaveBeenCalled();
243
- expect(result).toBe(1);
244
- });
245
- });
246
-
247
- describe('hasSessions', () => {
248
- it('should return false if no sessions exist', async () => {
249
- // Setup
250
- (SessionModel.count as Mock).mockResolvedValue(0);
251
-
252
- // Execute
253
- const result = await sessionService.hasSessions();
254
-
255
- // Assert
256
- expect(SessionModel.count).toHaveBeenCalled();
257
- expect(result).toBe(false);
258
- });
259
-
260
- it('should return true if sessions exist', async () => {
261
- // Setup
262
- (SessionModel.count as Mock).mockResolvedValue(1);
263
-
264
- // Execute
265
- const result = await sessionService.hasSessions();
266
-
267
- // Assert
268
- expect(SessionModel.count).toHaveBeenCalled();
269
- expect(result).toBe(true);
270
- });
271
- });
272
-
273
- describe('searchSessions', () => {
274
- it('should return sessions that match the keyword', async () => {
275
- // Setup
276
- const keyword = 'search';
277
- (SessionModel.queryByKeyword as Mock).mockResolvedValue(mockSessions);
278
-
279
- // Execute
280
- const result = await sessionService.searchSessions(keyword);
281
-
282
- // Assert
283
- expect(SessionModel.queryByKeyword).toHaveBeenCalledWith(keyword);
284
- expect(result).toBe(mockSessions);
285
- });
286
- });
287
-
288
- describe('cloneSession', () => {
289
- it('should duplicate a session and return its id', async () => {
290
- // Setup
291
- const newTitle = 'Duplicated Session';
292
- (SessionModel.duplicate as Mock).mockResolvedValue({
293
- ...mockSession,
294
- id: 'duplicated-session-id',
295
- });
296
-
297
- // Execute
298
- const duplicatedSessionId = await sessionService.cloneSession(mockSessionId, newTitle);
299
-
300
- // Assert
301
- expect(SessionModel.duplicate).toHaveBeenCalledWith(mockSessionId, newTitle);
302
- expect(duplicatedSessionId).toBe('duplicated-session-id');
303
- });
304
- });
305
-
306
- describe('getGroupedSessions', () => {
307
- it('should retrieve sessions with their group', async () => {
308
- // Setup
309
- (SessionModel.queryWithGroups as Mock).mockResolvedValue(mockSessions);
310
-
311
- // Execute
312
- const sessionsWithGroup = await sessionService.getGroupedSessions();
313
-
314
- // Assert
315
- expect(SessionModel.queryWithGroups).toHaveBeenCalled();
316
- expect(sessionsWithGroup).toBe(mockSessions);
317
- });
318
- });
319
-
320
- // SessionGroup related tests
321
- describe('createSessionGroup', () => {
322
- it('should create a new session group and return its id', async () => {
323
- // Setup
324
- const groupName = 'New Group';
325
- const sort = 1;
326
- (SessionGroupModel.create as Mock).mockResolvedValue({
327
- id: 'new-group-id',
328
- name: groupName,
329
- sort,
330
- });
331
-
332
- // Execute
333
- const groupId = await sessionService.createSessionGroup(groupName, sort);
334
-
335
- // Assert
336
- expect(SessionGroupModel.create).toHaveBeenCalledWith(groupName, sort);
337
- expect(groupId).toBe('new-group-id');
338
- });
339
- });
340
-
341
- describe('batchCreateSessionGroups', () => {
342
- it('should batch create session groups', async () => {
343
- // Setup
344
- const groups = [
345
- { id: 'group-1', name: 'Group 1', sort: 1 },
346
- { id: 'group-2', name: 'Group 2', sort: 2 },
347
- ] as SessionGroups;
348
-
349
- (SessionGroupModel.batchCreate as Mock).mockResolvedValue(groups);
350
-
351
- // Execute
352
- const result = await sessionService.batchCreateSessionGroups(groups);
353
-
354
- // Assert
355
- expect(SessionGroupModel.batchCreate).toHaveBeenCalledWith(groups);
356
- expect(result).toBe(groups);
357
- });
358
- });
359
-
360
- describe('removeSessionGroup', () => {
361
- it('should remove a session group by its id', async () => {
362
- // Setup
363
- const removeChildren = true;
364
- (SessionGroupModel.delete as Mock).mockResolvedValue(true);
365
-
366
- // Execute
367
- const result = await sessionService.removeSessionGroup('group-id', removeChildren);
368
-
369
- // Assert
370
- expect(SessionGroupModel.delete).toHaveBeenCalledWith('group-id', removeChildren);
371
- expect(result).toBe(true);
372
- });
373
- });
374
-
375
- describe('clearSessionGroups', () => {
376
- it('should clear all session groups', async () => {
377
- // Setup
378
- (SessionGroupModel.clear as Mock).mockResolvedValue(true);
379
-
380
- // Execute
381
- const result = await sessionService.removeSessionGroups();
382
-
383
- // Assert
384
- expect(SessionGroupModel.clear).toHaveBeenCalled();
385
- expect(result).toBe(true);
386
- });
387
- });
388
-
389
- describe('getSessionGroups', () => {
390
- it('should retrieve all session groups', async () => {
391
- // Setup
392
- const groups = [
393
- { id: 'group-1', name: 'Group 1', sort: 1 },
394
- { id: 'group-2', name: 'Group 2', sort: 2 },
395
- ];
396
- (SessionGroupModel.query as Mock).mockResolvedValue(groups);
397
-
398
- // Execute
399
- const result = await sessionService.getSessionGroups();
400
-
401
- // Assert
402
- expect(SessionGroupModel.query).toHaveBeenCalled();
403
- expect(result).toBe(groups);
404
- });
405
- });
406
-
407
- describe('updateSessionGroup', () => {
408
- it('should update a session group', async () => {
409
- // Setup
410
- const groupId = 'group-1';
411
- const data = { name: 'Updated Group', sort: 2 };
412
- (SessionGroupModel.update as Mock).mockResolvedValue({ id: groupId, ...data });
413
-
414
- // Execute
415
- const result = await sessionService.updateSessionGroup(groupId, data);
416
-
417
- // Assert
418
- expect(SessionGroupModel.update).toHaveBeenCalledWith(groupId, data);
419
- expect(result).toEqual({ id: groupId, ...data });
420
- });
421
- });
422
-
423
- describe('updateSessionGroupOrder', () => {
424
- it('should update the order of session groups', async () => {
425
- // Setup
426
- const sortMap = [
427
- { id: 'group-1', sort: 2 },
428
- { id: 'group-2', sort: 1 },
429
- ];
430
- (SessionGroupModel.updateOrder as Mock).mockResolvedValue(true);
431
-
432
- // Execute
433
- const result = await sessionService.updateSessionGroupOrder(sortMap);
434
-
435
- // Assert
436
- expect(SessionGroupModel.updateOrder).toHaveBeenCalledWith(sortMap);
437
- expect(result).toBe(true);
438
- });
439
- });
440
- });
@@ -1,190 +0,0 @@
1
- import type { PartialDeep } from 'type-fest';
2
-
3
- import { INBOX_SESSION_ID } from '@/const/session';
4
- import { DEFAULT_AGENT_CONFIG } from '@/const/settings';
5
- import { SessionModel } from '@/database/_deprecated/models/session';
6
- import { SessionGroupModel } from '@/database/_deprecated/models/sessionGroup';
7
- import { UserModel } from '@/database/_deprecated/models/user';
8
- import { useUserStore } from '@/store/user';
9
- import { LobeAgentChatConfig, LobeAgentConfig } from '@/types/agent';
10
- import { MetaData } from '@/types/meta';
11
- import {
12
- ChatSessionList,
13
- LobeAgentSession,
14
- LobeSessionType,
15
- LobeSessions,
16
- SessionGroupItem,
17
- SessionGroups,
18
- } from '@/types/session';
19
- import { merge } from '@/utils/merge';
20
-
21
- import { ISessionService } from './type';
22
-
23
- export class ClientService implements ISessionService {
24
- async createSession(
25
- type: LobeSessionType,
26
- defaultValue: Partial<LobeAgentSession>,
27
- ): Promise<string> {
28
- const item = await SessionModel.create(type, defaultValue);
29
- if (!item) {
30
- throw new Error('session create Error');
31
- }
32
- return item.id;
33
- }
34
-
35
- async batchCreateSessions(importSessions: LobeSessions) {
36
- // @ts-ignore
37
- return SessionModel.batchCreate(importSessions);
38
- }
39
-
40
- async cloneSession(id: string, newTitle: string): Promise<string | undefined> {
41
- const res = await SessionModel.duplicate(id, newTitle);
42
-
43
- if (res) return res?.id;
44
- }
45
-
46
- async getGroupedSessions(): Promise<ChatSessionList> {
47
- return SessionModel.queryWithGroups();
48
- }
49
-
50
- async getSessionConfig(id: string): Promise<LobeAgentConfig> {
51
- if (!id || id === INBOX_SESSION_ID) {
52
- return (await UserModel.getAgentConfig()) || DEFAULT_AGENT_CONFIG;
53
- }
54
-
55
- const res = await SessionModel.findById(id);
56
-
57
- if (!res) throw new Error('Session not found');
58
-
59
- return res.config as LobeAgentConfig;
60
- }
61
-
62
- async getSessionsByType(type: 'agent' | 'group' | 'all' = 'all'): Promise<LobeSessions> {
63
- switch (type) {
64
- // TODO: add a filter to get only agents or agents
65
- case 'group': {
66
- return SessionModel.query();
67
- }
68
- case 'agent': {
69
- return SessionModel.query();
70
- }
71
-
72
- case 'all': {
73
- return SessionModel.query();
74
- }
75
- }
76
- }
77
-
78
- async getAllAgents(): Promise<LobeSessions> {
79
- // TODO: add a filter to get only agents
80
- return SessionModel.query();
81
- }
82
-
83
- async countSessions() {
84
- return SessionModel.count();
85
- }
86
-
87
- // @ts-ignore
88
- async rankSessions() {
89
- throw new Error('Method not implemented.');
90
- }
91
-
92
- async hasSessions() {
93
- return (await this.countSessions()) !== 0;
94
- }
95
-
96
- async searchSessions(keyword: string) {
97
- return SessionModel.queryByKeyword(keyword);
98
- }
99
-
100
- async updateSession(
101
- id: string,
102
- data: Partial<Pick<LobeAgentSession, 'group' | 'meta' | 'pinned'>>,
103
- ) {
104
- const pinned = typeof data.pinned === 'boolean' ? (data.pinned ? 1 : 0) : undefined;
105
- const prev = await SessionModel.findById(id);
106
-
107
- return SessionModel.update(id, merge(prev, { ...data, pinned }));
108
- }
109
-
110
- async updateSessionConfig(
111
- activeId: string,
112
- config: PartialDeep<LobeAgentConfig>,
113
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
114
- _?: AbortSignal,
115
- ) {
116
- // TODO: 需要删除这部分处理逻辑
117
- // 后续直接给用户创建一个 inbox 的 session
118
- if (activeId === INBOX_SESSION_ID) {
119
- return useUserStore.getState().updateDefaultAgent({ config });
120
- }
121
-
122
- return SessionModel.updateConfig(activeId, config);
123
- }
124
-
125
- async updateSessionMeta(
126
- activeId: string,
127
- meta: Partial<MetaData>,
128
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
129
- _?: AbortSignal,
130
- ) {
131
- // inbox 不允许修改 meta
132
- if (activeId === INBOX_SESSION_ID) return;
133
-
134
- return SessionModel.update(activeId, { meta });
135
- }
136
-
137
- async updateSessionChatConfig(
138
- activeId: string,
139
- config: PartialDeep<LobeAgentChatConfig>,
140
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
141
- _?: AbortSignal,
142
- ) {
143
- return this.updateSessionConfig(activeId, { chatConfig: config });
144
- }
145
-
146
- async removeSession(id: string) {
147
- return SessionModel.delete(id);
148
- }
149
-
150
- async removeAllSessions() {
151
- return SessionModel.clearTable();
152
- }
153
-
154
- // ************************************** //
155
- // *********** SessionGroup *********** //
156
- // ************************************** //
157
-
158
- async createSessionGroup(name: string, sort?: number) {
159
- const item = await SessionGroupModel.create(name, sort);
160
- if (!item) {
161
- throw new Error('session group create Error');
162
- }
163
-
164
- return item.id;
165
- }
166
-
167
- async batchCreateSessionGroups(groups: SessionGroups) {
168
- return SessionGroupModel.batchCreate(groups);
169
- }
170
-
171
- async removeSessionGroup(id: string, removeChildren?: boolean) {
172
- return SessionGroupModel.delete(id, removeChildren);
173
- }
174
-
175
- async updateSessionGroup(id: string, data: Partial<SessionGroupItem>) {
176
- return SessionGroupModel.update(id, data as any);
177
- }
178
-
179
- async updateSessionGroupOrder(sortMap: { id: string; sort: number }[]) {
180
- return SessionGroupModel.updateOrder(sortMap);
181
- }
182
-
183
- async getSessionGroups(): Promise<SessionGroupItem[]> {
184
- return SessionGroupModel.query();
185
- }
186
-
187
- async removeSessionGroups() {
188
- return SessionGroupModel.clear();
189
- }
190
- }