Skip to content

Commit

Permalink
🐛 fix: refactor and fix dalle (#3572)
Browse files Browse the repository at this point in the history
* fix dalle

* revert change

* fix lint and test

* fix test

* 🚨 ci: fix lint

* 🐛 fix: fix image url in server mode

* 🐛 fix: fix file can't download if cors
  • Loading branch information
arvinxx authored Aug 23, 2024
1 parent 320df5b commit 8b39b61
Show file tree
Hide file tree
Showing 23 changed files with 152 additions and 259 deletions.
112 changes: 56 additions & 56 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -99,66 +99,66 @@
]
},
"dependencies": {
"@ant-design/icons": "^5.3.7",
"@ant-design/icons": "^5.4.0",
"@anthropic-ai/sdk": "^0.24.3",
"@auth/core": "0.28.0",
"@aws-sdk/client-bedrock-runtime": "^3.609.0",
"@aws-sdk/client-s3": "^3.609.0",
"@aws-sdk/s3-request-presigner": "^3.609.0",
"@aws-sdk/client-bedrock-runtime": "^3.637.0",
"@aws-sdk/client-s3": "^3.637.0",
"@aws-sdk/s3-request-presigner": "^3.637.0",
"@azure/core-rest-pipeline": "1.16.0",
"@azure/openai": "1.0.0-beta.12",
"@cfworker/json-schema": "^1.12.8",
"@clerk/localizations": "2.0.0",
"@clerk/nextjs": "^5.2.14",
"@clerk/themes": "^2.1.10",
"@clerk/nextjs": "^5.3.3",
"@clerk/themes": "^2.1.21",
"@cyntler/react-doc-viewer": "^1.16.6",
"@google/generative-ai": "^0.16.0",
"@icons-pack/react-simple-icons": "9.6.0",
"@khmyznikov/pwa-install": "^0.3.9",
"@langchain/community": "^0.2.27",
"@langchain/community": "^0.2.31",
"@lobehub/chat-plugin-sdk": "^1.32.4",
"@lobehub/chat-plugins-gateway": "^1.9.0",
"@lobehub/icons": "^1.28.0",
"@lobehub/tts": "^1.24.3",
"@lobehub/ui": "^1.149.2",
"@neondatabase/serverless": "^0.9.4",
"@next/third-parties": "^14.2.4",
"@sentry/nextjs": "^7.118.0",
"@next/third-parties": "^14.2.6",
"@sentry/nextjs": "^7.119.0",
"@t3-oss/env-nextjs": "^0.10.1",
"@tanstack/react-query": "^5.51.11",
"@tanstack/react-query": "^5.52.1",
"@trpc/client": "next",
"@trpc/next": "next",
"@trpc/react-query": "next",
"@trpc/server": "next",
"@vercel/analytics": "^1.3.1",
"@vercel/edge-config": "^1.2.1",
"@vercel/speed-insights": "^1.0.12",
"ahooks": "^3.8.0",
"ai": "^3.2.16",
"ahooks": "^3.8.1",
"ai": "^3.3.16",
"antd": "^5.20.2",
"antd-style": "^3.6.2",
"brotli-wasm": "^3.0.1",
"chroma-js": "^2.4.2",
"dayjs": "^1.11.11",
"debug": "^4.3.5",
"chroma-js": "^2.6.0",
"dayjs": "^1.11.13",
"debug": "^4.3.6",
"dexie": "^3.2.7",
"diff": "^5.2.0",
"drizzle-orm": "^0.32.0",
"drizzle-orm": "^0.32.2",
"drizzle-zod": "^0.5.1",
"fast-deep-equal": "^3.1.3",
"file-type": "^19.4.1",
"gpt-tokenizer": "^2.1.2",
"i18next": "^23.11.5",
"gpt-tokenizer": "^2.2.1",
"i18next": "^23.14.0",
"i18next-browser-languagedetector": "^7.2.1",
"i18next-resources-to-backend": "^1.2.1",
"idb-keyval": "^6.2.1",
"immer": "^10.1.1",
"ip": "^2.0.1",
"jose": "^5.6.3",
"jose": "^5.7.0",
"js-sha256": "^0.11.0",
"langchain": "^0.2.16",
"langfuse": "^3.14.0",
"langfuse-core": "^3.14.0",
"langchain": "^0.2.17",
"langfuse": "^3.19.0",
"langfuse-core": "^3.19.0",
"lodash-es": "^4.17.21",
"lucide-react": "latest",
"mammoth": "^1.8.0",
Expand All @@ -168,19 +168,19 @@
"next-auth": "5.0.0-beta.15",
"next-sitemap": "^4.2.3",
"numeral": "^2.0.6",
"nuqs": "^1.17.4",
"nuqs": "^1.17.8",
"officeparser": "^4.1.1",
"ollama": "^0.5.8",
"openai": "~4.54.0",
"partial-json": "^0.1.7",
"pdf-parse": "^1.1.1",
"pdfjs-dist": "4.4.168",
"pg": "^8.12.0",
"pino": "^9.2.0",
"pino": "^9.3.2",
"polished": "^4.3.1",
"posthog-js": "^1.144.2",
"posthog-js": "^1.157.2",
"pwa-install-handler": "^2.6.0",
"query-string": "^9.0.0",
"query-string": "^9.1.0",
"random-words": "^2.0.1",
"react": "^18.3.1",
"react-dom": "^18.3.1",
Expand All @@ -190,97 +190,97 @@
"react-layout-kit": "^1.9.0",
"react-lazy-load": "^4.0.1",
"react-pdf": "^9.1.0",
"react-virtuoso": "^4.7.11",
"react-virtuoso": "^4.10.1",
"react-wrap-balancer": "^1.1.1",
"remark": "^14.0.3",
"remark-gfm": "^3.0.1",
"remark-html": "^15.0.2",
"resolve-accept-language": "^3.1.4",
"resolve-accept-language": "^3.1.5",
"rtl-detect": "^1.1.2",
"semver": "^7.6.2",
"sharp": "^0.33.4",
"semver": "^7.6.3",
"sharp": "^0.33.5",
"superjson": "^2.2.1",
"svix": "^1.24.0",
"svix": "^1.30.0",
"swr": "^2.2.5",
"systemjs": "^6.15.1",
"ts-md5": "^1.3.1",
"ua-parser-js": "^1.0.38",
"unstructured-client": "^0.15.0",
"unstructured-client": "^0.15.1",
"url-join": "^5.0.0",
"use-merge-value": "^1.2.0",
"utility-types": "^3.11.0",
"uuid": "^10.0.0",
"ws": "^8.18.0",
"y-protocols": "^1.0.6",
"y-webrtc": "^10.3.0",
"yaml": "^2.4.5",
"yaml": "^2.5.0",
"yjs": "^13.6.18",
"zod": "^3.23.8",
"zustand": "^4.5.4",
"zustand": "^4.5.5",
"zustand-utils": "^1.3.2"
},
"devDependencies": {
"@commitlint/cli": "^19.3.0",
"@ducanh2912/next-pwa": "^10.2.7",
"@edge-runtime/vm": "^4.0.0",
"@commitlint/cli": "^19.4.0",
"@ducanh2912/next-pwa": "^10.2.8",
"@edge-runtime/vm": "^4.0.2",
"@lobehub/i18n-cli": "^1.19.1",
"@lobehub/lint": "^1.24.3",
"@lobehub/seo-cli": "^1.4.1",
"@next/bundle-analyzer": "^14.2.4",
"@next/eslint-plugin-next": "^14.2.4",
"@lobehub/lint": "^1.24.4",
"@lobehub/seo-cli": "^1.4.2",
"@next/bundle-analyzer": "^14.2.6",
"@next/eslint-plugin-next": "^14.2.6",
"@peculiar/webcrypto": "^1.5.0",
"@testing-library/jest-dom": "^6.4.6",
"@testing-library/jest-dom": "^6.4.8",
"@testing-library/react": "^16.0.0",
"@types/chroma-js": "^2.4.4",
"@types/debug": "^4.1.12",
"@types/diff": "^5.2.1",
"@types/ip": "^1.1.3",
"@types/json-schema": "^7.0.15",
"@types/lodash": "^4.17.6",
"@types/lodash": "^4.17.7",
"@types/lodash-es": "^4.17.12",
"@types/node": "^20.14.10",
"@types/node": "^20.16.1",
"@types/numeral": "^2.0.5",
"@types/pg": "^8.11.6",
"@types/react": "^18.3.3",
"@types/react": "^18.3.4",
"@types/react-dom": "^18.3.0",
"@types/rtl-detect": "^1.0.3",
"@types/semver": "^7.5.8",
"@types/systemjs": "^6.13.5",
"@types/ua-parser-js": "^0.7.39",
"@types/uuid": "^10.0.0",
"@types/ws": "^8.5.10",
"@types/ws": "^8.5.12",
"@vitest/coverage-v8": "~1.2.2",
"ajv-keywords": "^5.1.0",
"commitlint": "^19.3.0",
"commitlint": "^19.4.0",
"consola": "^3.2.3",
"dotenv": "^16.4.5",
"dpdm": "^3.14.0",
"drizzle-kit": "^0.23.0",
"drizzle-kit": "^0.23.2",
"eslint": "^8.57.0",
"eslint-plugin-mdx": "^2.3.4",
"eslint-plugin-unused-imports": "4.0.1",
"fake-indexeddb": "^6.0.0",
"glob": "^10.4.3",
"glob": "^10.4.5",
"gray-matter": "^4.0.3",
"happy-dom": "^14.12.3",
"husky": "^9.0.11",
"husky": "^9.1.5",
"just-diff": "^6.0.2",
"lint-staged": "^15.2.7",
"lint-staged": "^15.2.9",
"lodash": "^4.17.21",
"markdown-table": "^3.0.3",
"node-fetch": "^3.3.2",
"node-gyp": "^10.1.0",
"node-gyp": "^10.2.0",
"p-map": "^7.0.2",
"prettier": "^3.3.2",
"prettier": "^3.3.3",
"remark-cli": "^11.0.0",
"remark-parse": "^10.0.2",
"semantic-release": "^21.1.2",
"stylelint": "^15.11.0",
"tsx": "^4.16.2",
"typescript": "^5.5.3",
"tsx": "^4.17.0",
"typescript": "^5.5.4",
"unified": "^11.0.5",
"unist-util-visit": "^5.0.0",
"vite": "^5.3.3",
"vite": "^5.4.2",
"vitest": "~1.2.2",
"vitest-canvas-mock": "^0.3.3"
},
Expand Down
2 changes: 1 addition & 1 deletion src/app/(main)/files/[id]/Header.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ import { memo } from 'react';
import { useTranslation } from 'react-i18next';
import { Flexbox } from 'react-layout-kit';

import { downloadFile } from '@/utils/downloadFile';
import { downloadFile } from '@/utils/client/downloadFile';

interface HeaderProps {
filename: string;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ import { useTranslation } from 'react-i18next';
import { useAddFilesToKnowledgeBaseModal } from '@/features/KnowledgeBaseModal';
import { useFileStore } from '@/store/file';
import { useKnowledgeBaseStore } from '@/store/knowledgeBase';
import { downloadFile } from '@/utils/downloadFile';
import { downloadFile } from '@/utils/client/downloadFile';

interface DropdownMenuProps {
filename: string;
Expand Down
2 changes: 1 addition & 1 deletion src/features/FileViewer/NotSupport/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ import React, { ComponentType, useState } from 'react';
import { useTranslation } from 'react-i18next';
import { Center, Flexbox } from 'react-layout-kit';

import { downloadFile } from '@/utils/downloadFile';
import { downloadFile } from '@/utils/client/downloadFile';

const useStyles = createStyles(({ css, token }) => ({
page: css`
Expand Down
5 changes: 4 additions & 1 deletion src/server/routers/lambda/file.ts
Original file line number Diff line number Diff line change
Expand Up @@ -66,7 +66,10 @@ export const fileRouter = router({
}),
)
.query(async ({ ctx, input }) => {
return ctx.fileModel.findById(input.id);
const item = await ctx.fileModel.findById(input.id);
if (!item) throw new TRPCError({ code: 'BAD_REQUEST', message: 'File not found' });

return { ...item, url: getFullFileUrl(item?.url) };
}),

getFileItemById: fileProcedure
Expand Down
57 changes: 0 additions & 57 deletions src/services/__tests__/chat.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -180,70 +180,13 @@ describe('ChatService', () => {
);
});

it('should not include image content when default model', async () => {
const messages = [
{ content: 'Hello', role: 'user', files: ['file1'] }, // Message with files
{ content: 'Hi', role: 'tool', plugin: { identifier: 'plugin1', apiName: 'api1' } }, // Message with function role
{ content: 'Hey', role: 'assistant' }, // Regular user message
] as ChatMessage[];

// Mock file store state to return a specific image URL or Base64 for the given files
act(() => {
useFileStore.setState({
imagesMap: {
file1: {
id: 'file1',
name: 'abc.png',
saveMode: 'url',
fileType: 'image/png',
url: 'http://example.com/image.jpg',
},
},
});
});

const getChatCompletionSpy = vi.spyOn(chatService, 'getChatCompletion');
await chatService.createAssistantMessage({
messages,
plugins: [],
model: 'gpt-3.5-turbo',
});

expect(getChatCompletionSpy).toHaveBeenCalledWith(
{
messages: [
{ content: 'Hello', role: 'user' },
{ content: 'Hi', name: 'plugin1____api1', role: 'tool' },
{ content: 'Hey', role: 'assistant' },
],
model: 'gpt-3.5-turbo',
},
undefined,
);
});

it('should not include image with vision models when can not find the image', async () => {
const messages = [
{ content: 'Hello', role: 'user', files: ['file2'] }, // Message with files
{ content: 'Hi', role: 'tool', plugin: { identifier: 'plugin1', apiName: 'api1' } }, // Message with function role
{ content: 'Hey', role: 'assistant' }, // Regular user message
] as ChatMessage[];

// Mock file store state to return a specific image URL or Base64 for the given files
act(() => {
useFileStore.setState({
imagesMap: {
file1: {
id: 'file1',
name: 'abc.png',
saveMode: 'url',
fileType: 'image/png',
url: 'http://example.com/image.jpg',
},
},
});
});

const getChatCompletionSpy = vi.spyOn(chatService, 'getChatCompletion');
await chatService.createAssistantMessage({ messages, plugins: [] });

Expand Down
13 changes: 8 additions & 5 deletions src/services/file/client.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -74,13 +74,15 @@ describe('FileService', () => {
describe('getFile', () => {
it('should retrieve and convert local file info to FilePreview', async () => {
const fileId = '1';
const fileData: DB_File = {
const fileData = {
name: 'test',
data: new ArrayBuffer(1),
fileType: 'image/png',
saveMode: 'local',
size: 1,
};
createdAt: 1,
updatedAt: 2,
} as DB_File;

(FileModel.findById as Mock).mockResolvedValue(fileData);
(global.URL.createObjectURL as Mock).mockReturnValue('blob:test');
Expand All @@ -90,12 +92,13 @@ describe('FileService', () => {

expect(FileModel.findById).toHaveBeenCalledWith(fileId);
expect(result).toEqual({
createdAt: new Date(1),
id: '1',
base64Url: '',
fileType: 'image/png',
size: 1,
type: 'image/png',
name: 'test',
saveMode: 'local',
url: 'blob:test',
updatedAt: new Date(2),
});
});

Expand Down
Loading

0 comments on commit 8b39b61

Please sign in to comment.