This commit is contained in:
xion 2024-09-30 01:39:07 +08:00
parent 962d89ff29
commit e05c042827
8 changed files with 152 additions and 9 deletions

View File

@ -31,7 +31,7 @@
],
"license": "ISC",
"dependencies": {
"@abearxiong/auth": "1.0.0-alpha.5",
"@abearxiong/auth": "1.0.1",
"@abearxiong/router": "0.0.1-alpha.38",
"@abearxiong/use-config": "^0.0.2",
"@babel/core": "^7.25.2",

10
pnpm-lock.yaml generated
View File

@ -14,8 +14,8 @@ importers:
.:
dependencies:
'@abearxiong/auth':
specifier: 1.0.0-alpha.5
version: 1.0.0-alpha.5(@abearxiong/router@0.0.1-alpha.38)
specifier: 1.0.1
version: 1.0.1(@abearxiong/router@0.0.1-alpha.38)
'@abearxiong/router':
specifier: 0.0.1-alpha.38
version: 0.0.1-alpha.38
@ -222,8 +222,8 @@ importers:
packages:
'@abearxiong/auth@1.0.0-alpha.5':
resolution: {integrity: sha512-/DPlwvWN0zLQ7X3D/zAhtHRTVWP/Odn3lZeyllUzjn8PFV9E5pCVXbLV9fBqmP400icZkG9a3fplSbUrVIIpOA==, tarball: https://npm.pkg.github.com/download/@abearxiong/auth/1.0.0-alpha.5/9d149a4e10bde7fd51b102b00849d75da85dd282}
'@abearxiong/auth@1.0.1':
resolution: {integrity: sha512-KWolCGZorF/h+IyBToQyom/7iNUYN1V4ZsVSb8saAhnkQZ52CVT0P/8zBBq6WvbU8ZlJGCFk5mm7Jtaq9AE5kw==, tarball: https://npm.pkg.github.com/download/@abearxiong/auth/1.0.1/41c1a8845ad5fe34168bfbc209c8cb6e242de590}
peerDependencies:
'@abearxiong/router': ^0.0.1-alpha.38
@ -3371,7 +3371,7 @@ packages:
snapshots:
'@abearxiong/auth@1.0.0-alpha.5(@abearxiong/router@0.0.1-alpha.38)':
'@abearxiong/auth@1.0.1(@abearxiong/router@0.0.1-alpha.38)':
dependencies:
'@abearxiong/router': 0.0.1-alpha.38

View File

@ -22,6 +22,15 @@ export const app = new App<{ import: any; emit: typeof emit }>({
import: dynamicImport,
emit,
},
// routerHandle(res) {
// console.log('routerHandle', res.query);
// const { code, data, message } = res;
// return {
// code,
// data,
// message,
// };
// },
});
const clients = [];

View File

@ -0,0 +1,58 @@
import { chat } from '@/modules/ollama.ts';
import { sequelize } from '../modules/sequelize.ts';
import { DataTypes, Model } from 'sequelize';
/**
* chat
*
*/
export class ChatHistory extends Model {
declare id: string;
declare data: string;
declare root: boolean;
declare show: boolean;
declare uid: string;
}
ChatHistory.init(
{
id: {
type: DataTypes.UUID,
primaryKey: true,
defaultValue: DataTypes.UUIDV4,
},
data: {
type: DataTypes.JSON,
allowNull: true,
},
chatId: {
type: DataTypes.UUID, // 历史属于哪一条会话
allowNull: true,
},
chatPromptId: {
type: DataTypes.UUID, // 属于哪一个prompt
allowNull: true,
},
root: {
type: DataTypes.BOOLEAN, // 是否是根节点
defaultValue: false,
},
show: {
type: DataTypes.BOOLEAN, // 当创建返回的时候,配置是否显示
defaultValue: true,
},
uid: {
type: DataTypes.STRING,
allowNull: true,
},
},
{
sequelize, // 传入 Sequelize 实例
modelName: 'chat_history', // 模型名称
},
);
// force 只能run一次否则会删除表
ChatHistory.sync({ alter: true, force: true, logging: false }).catch((e) => {
console.error('History sync error', e);
});

61
src/models/chat-prompt.ts Normal file
View File

@ -0,0 +1,61 @@
import { sequelize } from '../modules/sequelize.ts';
import { DataTypes, Model } from 'sequelize';
import { Variable } from '@kevisual/ai-graph';
export type ChatPromptData = {
// 使用那个agent, 必须要有
aiAgentId: string;
// 使用那个初始化的prompt如果不存在则纯粹的白对话。
promptId?: string;
};
/**
* chat绑定就的agent和prompt
*
*/
export class ChatPrompt extends Model {
declare id: string;
declare title: string;
declare description: string;
declare uid: string;
declare key: string;
declare data: string;
}
ChatPrompt.init(
{
id: {
type: DataTypes.UUID,
primaryKey: true,
defaultValue: DataTypes.UUIDV4,
},
title: {
type: DataTypes.STRING,
allowNull: false,
},
description: {
type: DataTypes.TEXT,
allowNull: true,
},
data: {
type: DataTypes.JSON,
allowNull: true,
},
key: {
type: DataTypes.STRING, // 页面属于 /container/edit/list
allowNull: false,
},
uid: {
type: DataTypes.STRING,
allowNull: true,
},
},
{
sequelize, // 传入 Sequelize 实例
modelName: 'chat_prompt', // 模型名称
},
);
// force 只能run一次否则会删除表
ChatPrompt.sync({ alter: true, force: true, logging: false }).catch((e) => {
console.error('Prompt sync error', e);
});

View File

@ -5,10 +5,16 @@ import semver from 'semver';
const list = app.route({
path: 'container',
key: 'list',
middleware: ['auth']
});
list.run = async (ctx) => {
const tokenUser = ctx.state.tokenUser;
const list = await ContainerModel.findAll({
order: [['updatedAt', 'DESC']],
where: {
uid: tokenUser.id,
},
});
ctx.body = list;
return ctx;
@ -42,10 +48,7 @@ add.run = async (ctx) => {
title: '',
description: '',
code: '',
source: '',
type: '',
sourceType: '',
data: {},
};
const container = {
..._data,
@ -67,6 +70,8 @@ add.run = async (ctx) => {
try {
containerModel = await ContainerModel.create({
...container,
source: '',
sourceType: '',
});
} catch (e) {
console.log('error', e);

View File

@ -29,10 +29,15 @@ app
.route({
path: 'page',
key: 'list',
middleware: ['auth'],
})
.define(async (ctx) => {
const tokenUser = ctx.state.tokenUser;
ctx.body = await PageModel.findAll({
order: [['updatedAt', 'DESC']],
where: {
uid: tokenUser.id,
},
});
return ctx;
})

View File

@ -6,10 +6,15 @@ app
.route({
path: 'resource',
key: 'list',
middleware: ['auth'],
})
.define(async (ctx) => {
const tokenUser = ctx.state.tokenUser;
const list = await ResourceModel.findAll({
order: [['updatedAt', 'DESC']],
where: {
uid: tokenUser.id,
},
});
ctx.body = list;
return ctx;