summaryrefslogtreecommitdiff
path: root/src/api/validator.ts
diff options
context:
space:
mode:
authorsyuilo <syuilotan@yahoo.co.jp>2017-03-02 03:16:39 +0900
committersyuilo <syuilotan@yahoo.co.jp>2017-03-02 03:16:39 +0900
commita53edc96bec3503517daa24837def5d3ecd82624 (patch)
treee0a1b5081c137664d87d8ffa1f49160793edabb3 /src/api/validator.ts
parentCustom validator support (diff)
downloadmisskey-a53edc96bec3503517daa24837def5d3ecd82624.tar.gz
misskey-a53edc96bec3503517daa24837def5d3ecd82624.tar.bz2
misskey-a53edc96bec3503517daa24837def5d3ecd82624.zip
wip
Diffstat (limited to 'src/api/validator.ts')
-rw-r--r--src/api/validator.ts26
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;