diff options
| author | syuilo <syuilotan@yahoo.co.jp> | 2017-03-02 03:16:39 +0900 |
|---|---|---|
| committer | syuilo <syuilotan@yahoo.co.jp> | 2017-03-02 03:16:39 +0900 |
| commit | a53edc96bec3503517daa24837def5d3ecd82624 (patch) | |
| tree | e0a1b5081c137664d87d8ffa1f49160793edabb3 /src/api/validator.ts | |
| parent | Custom validator support (diff) | |
| download | misskey-a53edc96bec3503517daa24837def5d3ecd82624.tar.gz misskey-a53edc96bec3503517daa24837def5d3ecd82624.tar.bz2 misskey-a53edc96bec3503517daa24837def5d3ecd82624.zip | |
wip
Diffstat (limited to 'src/api/validator.ts')
| -rw-r--r-- | src/api/validator.ts | 26 |
1 files changed, 22 insertions, 4 deletions
diff --git a/src/api/validator.ts b/src/api/validator.ts index 2562535c02..830786a18d 100644 --- a/src/api/validator.ts +++ b/src/api/validator.ts @@ -2,7 +2,15 @@ import * as mongo from 'mongodb'; type Type = 'id' | 'string' | 'number' | 'boolean' | 'array' | 'object'; -export default <T>(value: any, isRequired: boolean, type: Type, validator?: (any) => boolean): [T, string] => { +type Validator<T> = ((x: T) => boolean | string) | ((x: T) => boolean | string)[]; + +function validate(value: any, type: 'id', isRequired?: boolean): [mongo.ObjectID, string]; +function validate(value: any, type: 'string', isRequired?: boolean, validator?: Validator<string>): [string, string]; +function validate(value: any, type: 'number', isRequired?: boolean, validator?: Validator<number>): [number, string]; +function validate(value: any, type: 'boolean', isRequired?: boolean): [boolean, string]; +function validate(value: any, type: 'array', isRequired?: boolean, validator?: Validator<any[]>): [any[], string]; +function validate(value: any, type: 'object', isRequired?: boolean, validator?: Validator<Object>): [Object, string]; +function validate<T>(value: any, type: Type, isRequired?: boolean, validator?: Validator<T>): [T, string] { if (value === undefined || value === null) { if (isRequired) { return [null, 'is-required'] @@ -49,11 +57,21 @@ export default <T>(value: any, isRequired: boolean, type: Type, validator?: (any break; } + if (type == 'id') value = new mongo.ObjectID(value); + if (validator) { - if (!validator(value)) { - return [null, 'invalid-format']; + const validators = Array.isArray(validator) ? validator : [validator]; + for (let i = 0; i < validators.length; i++) { + const result = validators[i](value); + if (result === false) { + return [null, 'invalid-format']; + } else if (typeof result == 'string') { + return [null, result]; + } } } return [value, null]; -}; +} + +export default validate; |