3.50.1 • Published 8 months ago

@eggjs/tegg-ajv-plugin v3.50.1

Weekly downloads
-
License
-
Repository
github
Last release
8 months ago

@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