feat: add packages for edit
This commit is contained in:
parent
e032c092d9
commit
6021aca4ba
@ -19,3 +19,5 @@ import './github/index.ts';
|
|||||||
import './app-manager/index.ts';
|
import './app-manager/index.ts';
|
||||||
|
|
||||||
import './file/index.ts';
|
import './file/index.ts';
|
||||||
|
|
||||||
|
import './packages/index.ts';
|
||||||
|
1
src/routes/packages/index.ts
Normal file
1
src/routes/packages/index.ts
Normal file
@ -0,0 +1 @@
|
|||||||
|
import './list.ts'
|
120
src/routes/packages/list.ts
Normal file
120
src/routes/packages/list.ts
Normal file
@ -0,0 +1,120 @@
|
|||||||
|
import { app } from '@/app.ts';
|
||||||
|
import { PackagesModel } from './models/index.ts';
|
||||||
|
import { Op } from 'sequelize';
|
||||||
|
import { CustomError } from '@kevisual/router';
|
||||||
|
|
||||||
|
app
|
||||||
|
.route({
|
||||||
|
path: 'packages',
|
||||||
|
key: 'list',
|
||||||
|
middleware: ['auth'],
|
||||||
|
})
|
||||||
|
.define(async (ctx) => {
|
||||||
|
const tokenUser = ctx.state.tokenUser;
|
||||||
|
const { uid } = tokenUser;
|
||||||
|
const { page = 1, pageSize = 999, search } = ctx.query;
|
||||||
|
const searchWhere = search ? { title: { [Op.like]: `%${search}%` } } : {};
|
||||||
|
const { rows: packages, count } = await PackagesModel.findAndCountAll({
|
||||||
|
where: {
|
||||||
|
uid,
|
||||||
|
...searchWhere,
|
||||||
|
},
|
||||||
|
limit: pageSize,
|
||||||
|
offset: page * pageSize,
|
||||||
|
});
|
||||||
|
ctx.body = {
|
||||||
|
pagination: {
|
||||||
|
current: page,
|
||||||
|
pageSize,
|
||||||
|
total: count,
|
||||||
|
},
|
||||||
|
list: packages,
|
||||||
|
};
|
||||||
|
})
|
||||||
|
.addTo(app);
|
||||||
|
|
||||||
|
app
|
||||||
|
.route({
|
||||||
|
path: 'packages',
|
||||||
|
key: 'get',
|
||||||
|
middleware: ['auth'],
|
||||||
|
})
|
||||||
|
.define(async (ctx) => {
|
||||||
|
const tokenUser = ctx.state.tokenUser;
|
||||||
|
const { uid } = tokenUser;
|
||||||
|
const { id } = ctx.query;
|
||||||
|
if (!id) {
|
||||||
|
throw new CustomError('id is required');
|
||||||
|
}
|
||||||
|
const packages = await PackagesModel.findOne({
|
||||||
|
where: {
|
||||||
|
uid,
|
||||||
|
id,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
if (!packages) {
|
||||||
|
throw new CustomError('not found data');
|
||||||
|
}
|
||||||
|
ctx.body = packages;
|
||||||
|
})
|
||||||
|
.addTo(app);
|
||||||
|
|
||||||
|
app
|
||||||
|
.route({
|
||||||
|
path: 'packages',
|
||||||
|
key: 'update',
|
||||||
|
})
|
||||||
|
.define(async (ctx) => {
|
||||||
|
const tokenUser = ctx.state.tokenUser;
|
||||||
|
const { uid } = tokenUser;
|
||||||
|
const { id, ...rest } = ctx.request.body;
|
||||||
|
let packages: PackagesModel;
|
||||||
|
if (!id) {
|
||||||
|
packages = await PackagesModel.create({
|
||||||
|
...rest,
|
||||||
|
uid,
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
packages = await PackagesModel.findOne({
|
||||||
|
where: {
|
||||||
|
uid,
|
||||||
|
id,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
if (!packages) {
|
||||||
|
throw new CustomError('not found data');
|
||||||
|
}
|
||||||
|
await packages.update({
|
||||||
|
...rest,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
ctx.body = packages;
|
||||||
|
})
|
||||||
|
.addTo(app);
|
||||||
|
|
||||||
|
app
|
||||||
|
.route({
|
||||||
|
path: 'packages',
|
||||||
|
key: 'delete',
|
||||||
|
middleware: ['auth'],
|
||||||
|
})
|
||||||
|
.define(async (ctx) => {
|
||||||
|
const tokenUser = ctx.state.tokenUser;
|
||||||
|
const { uid } = tokenUser;
|
||||||
|
const { id } = ctx.request.body;
|
||||||
|
if (!id) {
|
||||||
|
throw new CustomError('id is required');
|
||||||
|
}
|
||||||
|
const packages = await PackagesModel.findOne({
|
||||||
|
where: {
|
||||||
|
uid,
|
||||||
|
id,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
if (!packages) {
|
||||||
|
throw new CustomError('not found data');
|
||||||
|
}
|
||||||
|
await packages.destroy();
|
||||||
|
ctx.body = packages;
|
||||||
|
})
|
||||||
|
.addTo(app);
|
73
src/routes/packages/models/index.ts
Normal file
73
src/routes/packages/models/index.ts
Normal file
@ -0,0 +1,73 @@
|
|||||||
|
import { sequelize } from '../../../modules/sequelize.ts';
|
||||||
|
import { DataTypes, Model } from 'sequelize';
|
||||||
|
|
||||||
|
export interface PackagesData {}
|
||||||
|
export type PackagesPublish = {
|
||||||
|
key: string;
|
||||||
|
title?: string;
|
||||||
|
description?: string;
|
||||||
|
version?: string;
|
||||||
|
filesName?: any[];
|
||||||
|
};
|
||||||
|
export type Packages = Partial<InstanceType<typeof PackagesModel>>;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 用户代码容器
|
||||||
|
*/
|
||||||
|
export class PackagesModel extends Model {
|
||||||
|
declare id: string;
|
||||||
|
declare title: string;
|
||||||
|
declare description: string;
|
||||||
|
declare tags: string[];
|
||||||
|
declare data: PackagesData; // files
|
||||||
|
declare publish: PackagesPublish;
|
||||||
|
declare uid: string;
|
||||||
|
declare expand: any;
|
||||||
|
}
|
||||||
|
PackagesModel.init(
|
||||||
|
{
|
||||||
|
id: {
|
||||||
|
type: DataTypes.UUID,
|
||||||
|
primaryKey: true,
|
||||||
|
defaultValue: DataTypes.UUIDV4,
|
||||||
|
comment: 'id',
|
||||||
|
},
|
||||||
|
title: {
|
||||||
|
type: DataTypes.TEXT,
|
||||||
|
defaultValue: '',
|
||||||
|
},
|
||||||
|
description: {
|
||||||
|
type: DataTypes.TEXT,
|
||||||
|
defaultValue: '',
|
||||||
|
},
|
||||||
|
tags: {
|
||||||
|
type: DataTypes.JSONB,
|
||||||
|
defaultValue: [],
|
||||||
|
},
|
||||||
|
data: {
|
||||||
|
type: DataTypes.JSONB,
|
||||||
|
defaultValue: {},
|
||||||
|
},
|
||||||
|
publish: {
|
||||||
|
type: DataTypes.JSONB,
|
||||||
|
defaultValue: {},
|
||||||
|
},
|
||||||
|
expand: {
|
||||||
|
type: DataTypes.JSONB,
|
||||||
|
defaultValue: {},
|
||||||
|
},
|
||||||
|
uid: {
|
||||||
|
type: DataTypes.UUID,
|
||||||
|
allowNull: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
sequelize,
|
||||||
|
tableName: 'kv_packages',
|
||||||
|
paranoid: true,
|
||||||
|
},
|
||||||
|
);
|
||||||
|
|
||||||
|
PackagesModel.sync({ alter: true, logging: false }).catch((e) => {
|
||||||
|
console.error('PackagesModel sync', e);
|
||||||
|
});
|
Loading…
x
Reference in New Issue
Block a user