класс-валидатор, похоже, ничего не делает в приложении Nest JS - PullRequest
0 голосов
/ 10 марта 2020

Я устанавливаю новое приложение Nest JS, и я только что добавил класс-валидатор для проверки ввода контроллера, но, похоже, он полностью игнорируется. Это DTO:

import {IsString} from 'class-validator';

export class CreateCompanyDto {
    @IsString()
    name: string | undefined;
}

Это контроллер:

import {
    Body,
    Controller,
    InternalServerErrorException,
    Post,
    Request,
    UseGuards, ValidationPipe
} from '@nestjs/common';
import * as admin from 'firebase-admin';
import {User} from 'firebase';
import {AuthGuard} from '../auth/auth.guard';
import {CurrentUser} from '../auth/current-user.decorator';
import {CreateCompanyDto} from './dto/create-company.dto';

@Controller('vendor')
export class VendorController {

    @Post()
    @UseGuards(AuthGuard)
    async create(@CurrentUser() user: User, @Request() req: any, @Body(new ValidationPipe({ transform: true })) company: CreateCompanyDto) {
        console.log(JSON.stringify(company));
        throw new InternalServerErrorException('meh?');

         // irrelevant code
    }

}

Я ожидаю, что код выдаст ошибку проверки и никогда не попадет в сам метод, но вместо этого он сталкивается с исключение, и объект регистрируется в точности так, как он вошел.

пакет. json:

{
    "name": "functions",
    "scripts": {
        "lint": "tslint --project tsconfig.json",
        "prebuild": "(cd src && rm settings.json && ln -s ../configs/prod.json settings.json)",
        "build": "tsc",
        "prebuild:dev": "(cd src && rm settings.json && ln -s ../configs/dev.json settings.json)",
        "build:dev": "tsc",
        "serve": "concurrently \"npm run build:dev -- --watch\" \"firebase emulators:start --only functions\"",
        "shell": "npm run build && firebase functions:shell",
        "start": "npm run shell",
        "deploy": "firebase deploy --only functions",
        "logs": "firebase functions:log"
    },
    "engines": {
        "node": "8"
    },
    "main": "lib/functions/src/index.js",
    "dependencies": {
        "@elastic/elasticsearch": "^7.6.0",
        "@nestjs/common": "^6.11.11",
        "@nestjs/core": "^6.11.11",
        "@nestjs/platform-express": "^6.11.11",
        "@types/airtable": "^0.5.7",
        "@types/nodemailer": "^6.4.0",
        "airtable": "^0.8.1",
        "class-transformer": "^0.2.3",
        "class-validator": "^0.11.0",
        "cors": "^2.8.5",
        "express": "^4.17.1",
        "firebase": "^7.10.0",
        "firebase-admin": "^8.9.2",
        "firebase-functions": "^3.3.0",
        "nodemailer": "^6.4.4",
        "reflect-metadata": "^0.1.13",
        "rxjs": "^6.5.4",
        "slugify": "^1.4.0"
    },
    "devDependencies": {
        "concurrently": "^5.1.0",
        "tslint": "^6.0.0",
        "typescript": "~3.7.5"
    },
    "private": true
}

Что мне здесь не хватает?

Обновление Я выполнил небольшую отладку, и я могу сказать, в чем дело, даже если я до сих пор не знаю, почему.

В методе ValidationPipe.transform он возвращает необработанный ввод, так как метатип не определено:

    async transform(value, metadata) {
        const { metatype } = metadata;
        if (!metatype || !this.toValidate(metadata)) {
            return value;
        }

        // ...
    }

Ответы [ 2 ]

0 голосов
/ 17 марта 2020

in main.ts add app.useGlobalPipes(new ValidationPipe());:

import { ValidationPipe } from '@nestjs/common';
import { NestFactory } from '@nestjs/core';
import { AppModule } from './app.module';

async function bootstrap() {
    const app = await NestFactory.create(AppModule);
    app.enableCors();
    app.useGlobalPipes(new ValidationPipe());
    await app.listen(process.env.PORT || 3000);
}

bootstrap();
0 голосов
/ 10 марта 2020

Хорошо, отладка дала мне достаточно информации, чтобы найти проблему в Google, где я обнаружил эту проблему Github: https://github.com/nestjs/nest/issues/690

Вам необходимо включить "emitDecoratorMetadata": true в вашем tsconfig.json файл, чтобы это работало.

...