feat: refactor route definitions and enhance metadata for app domain manager

- Updated route definitions in `src/route.ts` to utilize `toJSONSchema` and `pick` for cleaner route listing.
- Enhanced the `app.domain.manager` routes in `src/routes/app-manager/domain/manager.ts`:
  - Changed path format to snake_case.
  - Added descriptions for each route.
  - Introduced Zod schema validation for request arguments in metadata.
This commit is contained in:
2026-02-18 03:17:45 +08:00
parent 8c6d57d228
commit 6c611dcf78
4 changed files with 430 additions and 270 deletions

View File

@@ -49,11 +49,11 @@
"@kevisual/ai": "^0.0.24",
"@kevisual/auth": "^2.0.3",
"@kevisual/js-filter": "^0.0.5",
"@kevisual/query": "^0.0.40",
"@kevisual/query": "^0.0.43",
"@types/busboy": "^1.5.4",
"@types/send": "^1.2.1",
"@types/ws": "^8.18.1",
"bullmq": "^5.67.3",
"bullmq": "^5.69.3",
"busboy": "^1.6.0",
"drizzle-kit": "^0.31.9",
"drizzle-orm": "^0.45.1",
@@ -66,18 +66,18 @@
"xml2js": "^0.6.2"
},
"devDependencies": {
"@aws-sdk/client-s3": "^3.986.0",
"@kevisual/api": "^0.0.47",
"@kevisual/context": "^0.0.4",
"@aws-sdk/client-s3": "^3.991.0",
"@kevisual/api": "^0.0.51",
"@kevisual/context": "^0.0.6",
"@kevisual/local-app-manager": "0.1.32",
"@kevisual/logger": "^0.0.4",
"@kevisual/oss": "0.0.19",
"@kevisual/permission": "^0.0.4",
"@kevisual/router": "0.0.70",
"@kevisual/router": "0.0.73",
"@kevisual/types": "^0.0.12",
"@kevisual/use-config": "^1.0.30",
"@types/archiver": "^7.0.0",
"@types/bun": "^1.3.8",
"@types/bun": "^1.3.9",
"@types/crypto-js": "^4.2.2",
"@types/jsonwebtoken": "^9.0.10",
"@types/node": "^25.2.3",
@@ -87,9 +87,9 @@
"archiver": "^7.0.1",
"crypto-js": "^4.2.0",
"dayjs": "^1.11.19",
"dotenv": "^17.2.4",
"dotenv": "^17.3.1",
"es-toolkit": "^1.44.0",
"ioredis": "^5.9.2",
"ioredis": "^5.9.3",
"jsonwebtoken": "^9.0.3",
"nanoid": "^5.1.6",
"p-queue": "^9.1.0",
@@ -102,5 +102,5 @@
"inflight": "latest",
"picomatch": "^4.0.2"
},
"packageManager": "pnpm@10.29.2"
"packageManager": "pnpm@10.30.0"
}

601
pnpm-lock.yaml generated

File diff suppressed because it is too large Load Diff

View File

@@ -4,6 +4,8 @@ import { app } from './app.ts';
import type { App } from '@kevisual/router';
import { User } from './models/user.ts';
import { createCookie, getSomeInfoFromReq } from './routes/user/me.ts';
import { toJSONSchema } from '@kevisual/router';
import { pick } from 'es-toolkit';
/**
* 添加auth中间件, 用于验证token
@@ -169,22 +171,17 @@ app
.define(async (ctx) => {
const tokenUser = ctx.state.tokenUser;
let isUser = !!tokenUser;
const routesList = app.router.routes.filter(item => {
if (item.id === 'auth' || item.id === 'auth-can' || item.id === 'check-auth-admin' || item.id === 'auth-admin') {
return false;
}
return true;
}).map((item) => {
const route = pick(item, ['id', 'path', 'key', 'description', 'middleware'] as const);
return toJSONSchema(route);
})
ctx.body = {
list: app.router.routes.filter(item => {
if (item.id === 'auth' || item.id === 'auth-can' || item.id === 'check-auth-admin' || item.id === 'auth-admin') {
return false;
}
return true;
}).map((item) => {
return {
id: item.id,
path: item.path,
key: item.key,
description: item.description,
middeleware: item.middleware,
metadata: item.metadata,
};
}),
list: routesList,
isUser
}
})

View File

@@ -1,15 +1,23 @@
import { app, db, schema } from '@/app.ts';
import { AppDomain, AppDomainHelper } from '../module/app-domain-drizzle.ts';
import { App } from '../module/app-drizzle.ts';
import { CustomError } from '@kevisual/router';
import { eq, or } from 'drizzle-orm';
import { eq } from 'drizzle-orm';
import { randomUUID } from 'crypto';
import z from 'zod';
app
.route({
path: 'app.domain.manager',
path: 'app_domain_manager',
key: 'list',
description: '获取域名列表,支持分页',
middleware: ['auth-admin'],
metadata: {
args: {
data: z.object({
page: z.number().optional(),
pageSize: z.number().optional(),
}).optional()
}
}
})
.define(async (ctx) => {
const { page = 1, pageSize = 999 } = ctx.query.data || {};
@@ -26,9 +34,21 @@ app
app
.route({
path: 'app.domain.manager',
path: 'app_domain_manager',
key: 'update',
description: '更新一个域名的信息',
middleware: ['auth-admin'],
metadata: {
args: {
data: z.object({
id: z.string().optional(),
domain: z.string(),
appId: z.string().optional(),
status: z.enum(['active', 'inactive']).optional(),
data: z.record(z.string(), z.any()).optional(),
})
}
}
})
.define(async (ctx) => {
const { domain, data, id, ...rest } = ctx.query.data || {};
@@ -95,9 +115,18 @@ app
app
.route({
path: 'app.domain.manager',
path: 'app_domain_manager',
key: 'delete',
description: '删除一个域名',
middleware: ['auth-admin'],
metadata: {
args: {
data: z.object({
id: z.string().optional(),
domain: z.string().optional(),
})
}
}
})
.define(async (ctx) => {
const { id, domain } = ctx.query.data || {};
@@ -117,9 +146,18 @@ app
app
.route({
path: 'app.domain.manager',
path: 'app_domain_manager',
key: 'get',
description: '获取域名信息可以通过id或者domain进行查询',
middleware: ['auth-admin'],
metadata: {
args: {
data: z.object({
id: z.string().optional(),
domain: z.string().optional(),
})
}
}
})
.define(async (ctx) => {
const { id, domain } = ctx.query.data || {};