私はこれでかなり長い間問題を抱えています。私のデコレータは、フィールドを一意の値でチェックするための情報を提供するはずでした。次のようになります。
export const IsUnique = (
metadata: {
entity: any,
field: string,
},
): PropertyDecorator => {
return createPropertyDecorator(constants.custom_decorators.is_unique, metadata);
};
そして私の検証は次のようになります:
import { HttpException } from '@nestjs/common';
import { PipeTransform, Pipe, ArgumentMetadata, HttpStatus } from '@nestjs/common';
import {validate, ValidationError} from 'class-validator';
import { plainToClass } from 'class-transformer';
import constants from '../../../constants';
@Pipe()
export class ValidationPipe implements PipeTransform<any> {
async transform(value, metadata: ArgumentMetadata) {
console.log(arguments);
const { metatype } = metadata;
if (!metatype || !this.toValidate(metatype)) {
return value;
}
const object = plainToClass(metatype, value);
const errors = await validate(object);
const myErrors = await this.uniqueValidation(object);
if (errors.length > 0) {
throw new HttpException(errors, HttpStatus.BAD_REQUEST);
}
return value;
}
private toValidate(metatype): boolean {
const types = [String, Boolean, Number, Array, Object];
return !types.find((type) => metatype === type);
}
private async uniqueValidation(object): Promise<ValidationError[]|null>{
const md = Reflect.getMetadata('swagger/apiModelPropertiesArray', object);
console.log(md);
return null;
}
}
コードを実行すると、md=undefined のようになります。どうすればメタデータを取得できますか? たぶん、間違った方法で createPropertyDecorator を使用していますか?
編集: 数時間後、nestjs に「createPropertyDecorator」がないことに気付き、swagger モジュールからインポートしました (大きな間違い)。したがって、独自の関数を作成する必要があります。今、私はそれを次のようにやっています:
export const IsUnique = (
metadata: {
entity: any,
field: string,
},
): PropertyDecorator => {
return (target: object, propertyKey: string) => {
const args = Reflect.getMetadata(constants.custom_decorators.is_unique, target, propertyKey) || {};
const modifiedArgs = Object.assign(args, { IsUnique: metadata.field });
Reflect.defineMetadata(constants.custom_decorators.is_unique, modifiedArgs, target);
};
};
だから、私の質問は同じです-メタデータを適切に定義して、他のものと干渉しないようにする方法は?