如何使用 Nestjs 验证枚举值数组
How can I validate an array of enum values with Nestjs
我觉得 and 的组合是我需要实现的,我无法将它们组合在一起。
我有一个包含 enum
.
的 DTO
使用 Postman,我正在发送一个 PurchasableType
的 FOO
并期望得到某种错误。通读上面的链接,似乎过程很复杂;这让我觉得我完全忽略了重点。
如何使用验证管道来确保只允许 purchasable-type.enum.ts
中的值?
感谢您的任何建议!
// create-order.dto.ts
import { IsEmail, IsNotEmpty, IsEnum } from 'class-validator';
import { PurchasableType } from '../enum/purchaseable-type.enum';
export class CreateOrderDto {
@IsNotEmpty()
readonly userId: string;
@IsNotEmpty()
readonly locationId: string;
@IsNotEmpty()
@IsEnum(PurchasableType)
readonly purchasableType: PurchasableType;
@IsNotEmpty()
@IsEmail()
readonly email: string;
}
// purchasable-type.enum.ts
export enum PurchasableType {
CLINIC = 'CLINIC',
EVENT = 'EVENT',
LESSON = 'LESSON',
RESERVATION = 'RESERVATION',
TEAM = 'TEAM',
}
编辑
看来我也没有正确定义实体,这可能是主要问题。我仍然很好奇我的实现是否 good/bad.
// order.entity.ts
...
import { PurchasableType } from '../enum/purchaseable-type.enum';
@Entity()
export class Order extends BaseEntity {
@PrimaryGeneratedColumn()
id: number;
@Column({
type: 'enum',
enum: PurchasableType,
})
现在,当我发送 foo
的 purchasableType
时,我收到了 500 错误。如果我发送 enum
范围内的任何有效值,我将收到 200/201.
编辑 2
当然 - 这是我所拥有的更广泛的观点。 似乎一切正常,我只是想更好地了解真正发生的事情。
// event.controller.ts
@Post('/:id/orders')
async purchaseEventTickets(@Body() createOrderDto: CreateOrderDto):
Promise<Order> {
return await this.eventService.purchaseEventTickets(createOrderDto);
}
// create-order.dto.ts
export class CreateOrderDto {
@IsNotEmpty()
@IsEnum(PurchasableType)
readonly purchasableType: PurchasableType;
}
// event.service.ts
async purchaseEventTickets(createOrderDto: CreateOrderDto): Promise<Order> {
...
return await this.orderRepository.createOrder(createOrderDto);
}
// order.repository.ts
async createOrder(createOrderDto: CreateOrderDto): Promise<Order> {
const { purchasableType } = createOrderDto;
const order = this.create();
order.purchasableType = purchasableType;
try {
await order.save();
} catch (error) {
this.logger.error(`Failed to create the order: ${error.stack}`);
throw new InternalServerErrorException();
}
return order;
}
使用 Postman,如果我将“Foo”的无效值作为 PurchasableType
发送,我会收到预期的错误。
这是您的 create-dto
包含 enum
.
的样子
// create-order.dto.ts
import { IsEmail, IsNotEmpty, IsEnum } from 'class-validator';
import { PurchasableType } from '../enum/purchaseable-type.enum';
export class CreateOrderDto {
...
@IsNotEmpty()
@IsEnum(PurchasableType)
readonly purchasableType: PurchasableType;
}
枚举文件如下所示:
// purchasable-type.enum.ts
export enum PurchasableType {
CLINIC = 'CLINIC',
EVENT = 'EVENT',
LESSON = 'LESSON',
RESERVATION = 'RESERVATION',
TEAM = 'TEAM',
}
从那里我可以自信地期望枚举的值是上述值之一。如果有其他值通过,nest 将抛出验证错误。
此外,如果您尝试使用嵌套对象(或具有多个属性或数组的对象),您可以在 DTO 中执行类似的操作:
import { PurchasableType } from '../interface/purchasable-type.interface';
...
@ApiProperty()
@IsArray()
@ArrayMinSize(7)
@ArrayMaxSize(7)
@ValidateNested({ each: true })
@Type(() => PurchasableType)
@IsNotEmpty()
readonly PurchasableType: PurchasableType[];
...
我花了一段时间才找到好的解决方案。
@ApiProperty({
description: 'List of enums',
isArray: true,
enum: MyEnum
})
@IsEnum(MyEnum, { each: true })
prop: MyEnum[];
@IsArray()
@IsEnum(enum, { each: true })
prop: enum[]
我觉得
我有一个包含 enum
.
使用 Postman,我正在发送一个 PurchasableType
的 FOO
并期望得到某种错误。通读上面的链接,似乎过程很复杂;这让我觉得我完全忽略了重点。
如何使用验证管道来确保只允许 purchasable-type.enum.ts
中的值?
感谢您的任何建议!
// create-order.dto.ts
import { IsEmail, IsNotEmpty, IsEnum } from 'class-validator';
import { PurchasableType } from '../enum/purchaseable-type.enum';
export class CreateOrderDto {
@IsNotEmpty()
readonly userId: string;
@IsNotEmpty()
readonly locationId: string;
@IsNotEmpty()
@IsEnum(PurchasableType)
readonly purchasableType: PurchasableType;
@IsNotEmpty()
@IsEmail()
readonly email: string;
}
// purchasable-type.enum.ts
export enum PurchasableType {
CLINIC = 'CLINIC',
EVENT = 'EVENT',
LESSON = 'LESSON',
RESERVATION = 'RESERVATION',
TEAM = 'TEAM',
}
编辑
看来我也没有正确定义实体,这可能是主要问题。我仍然很好奇我的实现是否 good/bad.
// order.entity.ts
...
import { PurchasableType } from '../enum/purchaseable-type.enum';
@Entity()
export class Order extends BaseEntity {
@PrimaryGeneratedColumn()
id: number;
@Column({
type: 'enum',
enum: PurchasableType,
})
现在,当我发送 foo
的 purchasableType
时,我收到了 500 错误。如果我发送 enum
范围内的任何有效值,我将收到 200/201.
编辑 2
当然 - 这是我所拥有的更广泛的观点。 似乎一切正常,我只是想更好地了解真正发生的事情。
// event.controller.ts
@Post('/:id/orders')
async purchaseEventTickets(@Body() createOrderDto: CreateOrderDto):
Promise<Order> {
return await this.eventService.purchaseEventTickets(createOrderDto);
}
// create-order.dto.ts
export class CreateOrderDto {
@IsNotEmpty()
@IsEnum(PurchasableType)
readonly purchasableType: PurchasableType;
}
// event.service.ts
async purchaseEventTickets(createOrderDto: CreateOrderDto): Promise<Order> {
...
return await this.orderRepository.createOrder(createOrderDto);
}
// order.repository.ts
async createOrder(createOrderDto: CreateOrderDto): Promise<Order> {
const { purchasableType } = createOrderDto;
const order = this.create();
order.purchasableType = purchasableType;
try {
await order.save();
} catch (error) {
this.logger.error(`Failed to create the order: ${error.stack}`);
throw new InternalServerErrorException();
}
return order;
}
使用 Postman,如果我将“Foo”的无效值作为 PurchasableType
发送,我会收到预期的错误。
这是您的 create-dto
包含 enum
.
// create-order.dto.ts
import { IsEmail, IsNotEmpty, IsEnum } from 'class-validator';
import { PurchasableType } from '../enum/purchaseable-type.enum';
export class CreateOrderDto {
...
@IsNotEmpty()
@IsEnum(PurchasableType)
readonly purchasableType: PurchasableType;
}
枚举文件如下所示:
// purchasable-type.enum.ts
export enum PurchasableType {
CLINIC = 'CLINIC',
EVENT = 'EVENT',
LESSON = 'LESSON',
RESERVATION = 'RESERVATION',
TEAM = 'TEAM',
}
从那里我可以自信地期望枚举的值是上述值之一。如果有其他值通过,nest 将抛出验证错误。
此外,如果您尝试使用嵌套对象(或具有多个属性或数组的对象),您可以在 DTO 中执行类似的操作:
import { PurchasableType } from '../interface/purchasable-type.interface';
...
@ApiProperty()
@IsArray()
@ArrayMinSize(7)
@ArrayMaxSize(7)
@ValidateNested({ each: true })
@Type(() => PurchasableType)
@IsNotEmpty()
readonly PurchasableType: PurchasableType[];
...
我花了一段时间才找到好的解决方案。
@ApiProperty({
description: 'List of enums',
isArray: true,
enum: MyEnum
})
@IsEnum(MyEnum, { each: true })
prop: MyEnum[];
@IsArray()
@IsEnum(enum, { each: true })
prop: enum[]