"feat: 新增 kevisual 同步配置,升级相关依赖"
This commit is contained in:
35
assistant/src/routes/ai/index.ts
Normal file
35
assistant/src/routes/ai/index.ts
Normal file
@@ -0,0 +1,35 @@
|
||||
import { useContextKey } from '@kevisual/use-config/context';
|
||||
// import { appDefine } from '@/query/query-ai/defines/ai.ts';
|
||||
import { ProviderManager } from '@kevisual/ai';
|
||||
import { App } from '@kevisual/router';
|
||||
import { assistantConfig } from '@/app.ts';
|
||||
const app = useContextKey<App>('app');
|
||||
|
||||
app
|
||||
.route({
|
||||
path: 'ai',
|
||||
key: 'chat',
|
||||
middleware: ['auth'],
|
||||
})
|
||||
.define(async (ctx) => {
|
||||
const { messages = [], username, group, question, chatOpts = {} } = ctx.query;
|
||||
// if (!username || !model || !group) {
|
||||
// return ctx.throw(4001, 'username, model, group is required');
|
||||
// }
|
||||
if (messages.length === 0 && question) {
|
||||
messages.push({
|
||||
role: 'user',
|
||||
content: question,
|
||||
});
|
||||
}
|
||||
const as = assistantConfig.getCacheAssistantConfig();
|
||||
const { provider, apiKey, model } = as.ai || {};
|
||||
const pm = new ProviderManager({
|
||||
provider: provider,
|
||||
apiKey: apiKey,
|
||||
model: model,
|
||||
});
|
||||
const result = await pm.provider.chat(messages, chatOpts);
|
||||
ctx.body = result;
|
||||
})
|
||||
.addTo(app);
|
||||
@@ -2,6 +2,8 @@ import { Query } from '@kevisual/query';
|
||||
import { app, assistantConfig } from '../app.ts';
|
||||
import './config/index.ts';
|
||||
import './shop-install/index.ts';
|
||||
import './ai/index.ts';
|
||||
|
||||
import os from 'node:os';
|
||||
|
||||
app
|
||||
|
||||
Reference in New Issue
Block a user