如何在Next.js中验证可选参数?

问题描述 投票:0回答:1

我正在尝试验证我的PUT用户/端点的参数,但我希望所有参数都是可选的,但是一旦api使用者填写这些参数,我想验证它们。

我试图将@ApiModelProperty所需的false与验证管道装饰器合并,但验证管道接管了ApiModelProperty(发送400错误请求HttpException非常正常)

这是我的DTO:usersUpdate.dto.ts

import { IsEmail, IsEnum, IsPhoneNumber, IsEmpty } from 'class-validator';
import { ApiModelProperty } from '@nestjs/swagger';
import { RoleType } from './role-type.enum';

class UserInfo {
    @ApiModelProperty({ description: 'User firstname', required: false  })
    readonly firstname: string;

    @ApiModelProperty({ description: 'User lastname', required: false  })
    readonly lastname: string;

    @ApiModelProperty({description: 'User postal address', required: false })
    readonly address: string;

    @ApiModelProperty({ description: 'User phone number', required: false  })
    @IsPhoneNumber('FR')
    readonly phone: string;

    @ApiModelProperty({ description: 'User siret number', required: false  })
    readonly siret: string;
}

export class UpdateUserDTO {
    @ApiModelProperty({ description: 'User email address', required: false })
    readonly email: string;

    @ApiModelProperty({ description: 'User password', required: false })
    readonly password: string;

    @ApiModelProperty({ description: 'User informations', required: false })
    readonly user_info: UserInfo;

    @ApiModelProperty({ enum: ['Admin', 'Runner', 'Dispatcher'], description:'User role',  required: false })
    readonly role: RoleType;

    @ApiModelProperty({ description: 'User activation token', required: false })
    readonly activationToken: string;
}

我想在电子邮件参数和角色的@IsEmail()装饰器上使用和@Enum()装饰器,但是一旦我使用这些装饰器,参数是必需的。

如果参数为空,有人知道如何跳过此验证器吗?

validation nestjs
1个回答
1
投票

是的,您可以通过应用class-validator中的@IsOptional装饰器让验证器在字段上是可选的。

您可以使用的另一件事而不是@ApiModelProperty({ description: 'User activation token', required: false })@ApiModelPropertyOptional,因此删除声明的必需:false部分。

最后你甚至可以使用@IsEmail()装饰器验证电子邮件字段是一封电子邮件,你可以做的最后一件事是组合@IsNotEmpty()@IsOptional(),这样当提供一个字段时它不应该是空的。

提供的代码如下所示:

    import { IsEmail, IsEnum, IsPhoneNumber, IsEmpty, IsOptional } from 'class-validator';
    import { ApiModelPropertyOptional } from '@nestjs/swagger';
    import { RoleType } from './role-type.enum';

    class UserInfo {
        @ApiModelPropertyOptional({ description: 'User firstname' })
        @IsOptional()
        readonly firstname: string;

        @ApiModelPropertyOptional({ description: 'User lastname' })
        @IsOptional()
        readonly lastname: string;

        @ApiModelPropertyOptional({description: 'User postal address' })
        @IsOptional()
        readonly address: string;

        @ApiModelPropertyOptional({ description: 'User phone number'  })
        @IsOptional()
        @IsPhoneNumber('FR')
        readonly phone: string;

        @ApiModelPropertyOptional({ description: 'User siret number'  })
        @IsOptional()
        readonly siret: string;
    }

    export class UpdateUserDTO {
        @ApiModelPropertyOptional({ description: 'User email address' })
        @IsEmail()
        @IsOptional()
        readonly email: string;

        @ApiModelPropertyOptional({ description: 'User password' })
        @IsOptional()
        readonly password: string;

        @ApiModelPropertyOptional({ description: 'User informations' })
        @IsOptional()
        readonly user_info: UserInfo;

        @ApiModelPropertyOptional({ enum: ['Admin', 'Runner', 'Dispatcher'], description:'User role' })
        @IsEnum(RoleType)
        @IsOptional()
        readonly role: RoleType;

        @ApiModelPropertyOptional({ description: 'User activation token' })
        @IsOptional()
        readonly activationToken: string;
    }

让我知道它是否有帮助;)

© www.soinside.com 2019 - 2024. All rights reserved.