3.50.1 • Published 8 months ago
@eggjs/tegg-ajv-plugin v3.50.1
@eggjs/tegg-ajv-plugin
参考 egg-typebox-validate 的最佳实践,结合 ajv + typebox,只需要定义一次参数类型和规则,就能同时拥有参数校验和类型定义(完整的 ts 类型提示)。
egg 模式
Install
# tegg 注解
npm i --save @eggjs/tegg
# tegg 插件
npm i --save @eggjs/tegg-plugin
# tegg ajv 插件
npm i --save @eggjs/tegg-ajv-plugin
Prepare
// tsconfig.json
{
"extends": "@eggjs/tsconfig"
}
Config
// config/plugin.js
exports.tegg = {
package: '@eggjs/tegg-plugin',
enable: true,
};
exports.teggAjv = {
package: '@eggjs/tegg-ajv-plugin',
enable: true,
};
standalone 模式
Install
# tegg 注解
npm i --save @eggjs/tegg
# tegg ajv 插件
npm i --save @eggjs/tegg-ajv-plugin
Prepare
// tsconfig.json
{
"extends": "@eggjs/tsconfig"
}
Usage
1、定义入参校验 Schema
使用 typebox 定义,会内置到 tegg 导出
import { Type, TransformEnum } from '@eggjs/tegg/ajv';
const SyncPackageTaskSchema = Type.Object({
fullname: Type.String({
transform: [ TransformEnum.trim ],
maxLength: 100,
}),
tips: Type.String({
transform: [ TransformEnum.trim ],
maxLength: 1024,
}),
skipDependencies: Type.Boolean(),
syncDownloadData: Type.Boolean(),
// force sync immediately, only allow by admin
force: Type.Boolean(),
// sync history version
forceSyncHistory: Type.Boolean(),
// source registry
registryName: Type.Optional(Type.String()),
});
2、从校验 Schema 生成静态的入参类型
import { Static } from '@eggjs/tegg/ajv';
type SyncPackageTaskType = Static<typeof SyncPackageTaskSchema>;
3、在 Controller 中使用入参类型和校验 Schema
注入全局单例 ajv,调用 ajv.validate(XxxSchema, params)
进行参数校验,参数校验失败会直接抛出 AjvInvalidParamError
异常,
tegg 会自动返回相应的错误响应给客户端。
import { Inject, HTTPController, HTTPMethod, HTTPMethodEnum, HTTPBody } from '@eggjs/tegg';
import { Ajv, Type, Static, TransformEnum } from '@eggjs/tegg/ajv';
const SyncPackageTaskSchema = Type.Object({
fullname: Type.String({
transform: [ TransformEnum.trim ],
maxLength: 100,
}),
tips: Type.String({
transform: [ TransformEnum.trim ],
maxLength: 1024,
}),
skipDependencies: Type.Boolean(),
syncDownloadData: Type.Boolean(),
// force sync immediately, only allow by admin
force: Type.Boolean(),
// sync history version
forceSyncHistory: Type.Boolean(),
// source registry
registryName: Type.Optional(Type.String()),
});
type SyncPackageTaskType = Static<typeof SyncPackageTaskSchema>;
@HTTPController()
export class HelloController {
private readonly ajv: Ajv;
@HTTPMethod({
method: HTTPMethodEnum.POST,
path: '/sync',
})
async sync(@HTTPBody() task: SyncPackageTaskType) {
this.ajv.validate(SyncPackageTaskSchema, task);
return {
task,
};
}
}
3.51.0
8 months ago
3.50.1
8 months ago
3.50.0
8 months ago
3.49.0
8 months ago
3.40.0
10 months ago
3.41.0
10 months ago
3.40.1
10 months ago
3.42.0
10 months ago
3.43.0
9 months ago
3.44.0
9 months ago
3.43.1
9 months ago
3.45.0
9 months ago
3.44.1
9 months ago
3.43.2
9 months ago
3.46.0
9 months ago
3.39.5
11 months ago
3.39.4
12 months ago
3.47.0
9 months ago
3.46.1
9 months ago
3.48.0
9 months ago
3.46.2
9 months ago
3.48.1
8 months ago
3.47.2
9 months ago
3.46.3
9 months ago
3.46.4
9 months ago
3.39.1
1 year ago
3.39.2
1 year ago
3.39.3
1 year ago
3.38.0
1 year ago
3.39.0
1 year ago
3.37.3
1 year ago
3.37.0
1 year ago
3.37.1
1 year ago
3.36.3
1 year ago
3.36.2
1 year ago
3.36.1
1 year ago
3.36.0
1 year ago