web-dev-qa-db-ja.com

クラスバリデーターのメタデータが見つかりません

ValidationPipeを使用しようとしていますが、コードをどのように記述しても、リクエストを送信すると次の警告が表示されます:No metadata found. There is more than once class-validator version installed probably. You need to flatten your dependencies

私のルートは次のようになります。

@Get()
@UsePipes(new ValidationPipe({ transform: true }))
async findAll(@Query() queryDto: QueryDto) {
    return await this.myService.findAll(queryDto);
}

そして、私のDTOは次のようになります。

export class queryDto
{
    @ApiModelProperty({
        description: 'Maximum number of results',
        type: Number,
        example: 50,
        default: 50,
        required: false
    })
    readonly limit: number = 50;
}

doc に従って、ValidationPipeをいくつかの方法で使用してみましたが、何も機能しません。リクエストは応答を受け取りますが、クエリが空の場合、プロパティlimitのDTOに書き込んだデフォルト値である50は使用されないため、機能しないことはわかっています。したがって、クエリでlimitが指定されていない場合、limitの値は未定義ですが、50である必要があります(つまり、ValidationPipeは使用されません)。

私のpackage.jsonは正しいようです:

npm ls class-validator
[email protected] /home/pierre_t/Bureau/dev/ApiSport
└── [email protected]

フルpackage.json

{
  "name": "api-sport",
  "version": "0.0.1",
  "description": "",
  "author": "",
  "license": "MIT",
  "scripts": {
    "build": "tsc -p tsconfig.build.json",
    "format": "prettier --write \"src/**/*.ts\"",
    "start": "ts-node -r tsconfig-paths/register src/main.ts",
    "start:dev": "nodemon",
    "start:debug": "nodemon --config nodemon-debug.json",
    "start:prod": "pm2 start ./src/main.js --no-daemon",
    "lint": "tslint -p tsconfig.json -c tslint.json",
    "test": "jest",
    "test:watch": "jest --watch",
    "test:cov": "jest --coverage",
    "test:debug": "node --inspect-brk -r tsconfig-paths/register -r ts-node/register node_modules/.bin/jest --runInBand",
    "test:e2e": "jest --config ./test/jest-e2e.json"
  },
  "dependencies": {
    "@nestjs/common": "^6.0.5",
    "@nestjs/core": "^6.0.5",
    "@nestjs/platform-express": "^6.0.5",
    "@nestjs/swagger": "^3.0.1",
    "@nestjs/typeorm": "^6.0.0",
    "@types/lodash": "^4.14.123",
    "class-transformer": "^0.2.0",
    "class-validator": "^0.9.1",
    "dotenv": "^7.0.0",
    "hbs": "^4.0.3",
    "mysql": "^2.16.0",
    "pm2": "^3.4.1",
    "reflect-metadata": "^0.1.12",
    "rimraf": "^2.6.2",
    "rxjs": "^6.3.3",
    "swagger-ui-express": "^4.0.2",
    "typeorm": "^0.2.16"
  },
  "devDependencies": {
    "@nestjs/testing": "^6.0.5",
    "@types/express": "^4.16.0",
    "@types/jest": "^23.3.13",
    "@types/node": "^10.14.4",
    "@types/supertest": "^2.0.7",
    "jest": "^23.6.0",
    "nodemon": "^1.18.9",
    "prettier": "^1.15.3",
    "supertest": "^3.4.1",
    "ts-jest": "^23.10.5",
    "ts-node": "^7.0.1",
    "tsconfig-paths": "^3.7.0",
    "tslint": "5.12.1",
    "TypeScript": "^3.4.1"
  },
  "jest": {
    "moduleFileExtensions": [
      "js",
      "json",
      "ts"
    ],
    "rootDir": "src",
    "testRegex": ".spec.ts$",
    "transform": {
      "^.+\\.(t|j)s$": "ts-jest"
    },
    "coverageDirectory": "../coverage",
    "testEnvironment": "node"
  }
}

このメッセージが表示されるのはなぜですか。また、ValidationPipeを使用するにはどうすればよいですか?

5
papillon

質問はすでに回答済みですが、同じ問題を抱えている人々の将来の参考のために...

class-validator を使用すると、特定のプロパティの検証をバイパスできます( whitelisting )特別なフラグプロパティを検証します。

docs として:

これにより、デコレータがないすべてのプロパティが削除されます。プロパティに適したデコレータが他にない場合は、@ Allowデコレータを使用できます。

例えば:

import {validate, Allow, Min} from "class-validator";

export class Post {

    @Allow()
    title: string;

    @Min(0)
    views: number;

    nonWhitelistedProperty: number;
}
0
Mathias Falci