mirror of
https://github.com/misskey-dev/misskey.git
synced 2024-12-11 23:40:52 +01:00
Refactor
This commit is contained in:
parent
6e181ee0f1
commit
2e4e599c01
1 changed files with 22 additions and 15 deletions
|
@ -5,22 +5,22 @@
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Usage Examples
|
* Usage Examples
|
||||||
*
|
*
|
||||||
* const [val, err] = it(x).must.be.a.string().or('asc desc').default('desc').qed();
|
* const [val, err] = it(x).must.be.a.string().or('asc desc').default('desc').qed();
|
||||||
* → xは文字列でなければならず、'asc'または'desc'でなければならない。省略された場合のデフォルトは'desc'とする。
|
* → xは文字列でなければならず、'asc'または'desc'でなければならない。省略された場合のデフォルトは'desc'とする。
|
||||||
*
|
*
|
||||||
* const [val, err] = it(x).must.be.a.number().required().range(0, 100).qed();
|
* const [val, err] = it(x).must.be.a.number().required().range(0, 100).qed();
|
||||||
* → xは数値でなければならず、かつ0~100の範囲内でなければならない。この値は省略することはできない。
|
* → xは数値でなければならず、かつ0~100の範囲内でなければならない。この値は省略することはできない。
|
||||||
*
|
*
|
||||||
* const [val, err] = it(x).must.be.an.array().unique().required().validate(x => x[0] != 'strawberry pasta').qed();
|
* const [val, err] = it(x).must.be.an.array().unique().required().validate(x => x[0] != 'strawberry pasta').qed();
|
||||||
* → xは配列でなければならず、かつ中身が重複していてはならない。この値を省略することはできない。そして配列の最初の要素が'strawberry pasta'という文字列であってはならない。
|
* → xは配列でなければならず、かつ中身が重複していてはならない。この値を省略することはできない。そして配列の最初の要素が'strawberry pasta'という文字列であってはならない。
|
||||||
*
|
*
|
||||||
* ~糖衣構文~
|
* ~糖衣構文~
|
||||||
* const [val, err] = it(x).must.be.a.string().required().qed();
|
* const [val, err] = it(x).must.be.a.string().required().qed();
|
||||||
* は
|
* は
|
||||||
* const [val, err] = it(x, 'string', true);
|
* const [val, err] = it(x, 'string', true);
|
||||||
* と書けます
|
* と書けます
|
||||||
*
|
*
|
||||||
* ~BDD風記法~
|
* ~BDD風記法~
|
||||||
* must.be.a(n) の代わりに expect とも書けます:
|
* must.be.a(n) の代わりに expect とも書けます:
|
||||||
* const [val, err] = it(x).expect.string().required().qed();
|
* const [val, err] = it(x).expect.string().required().qed();
|
||||||
|
@ -53,6 +53,13 @@ class QueryCore implements Query {
|
||||||
this.error = null;
|
this.error = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* このインスタンスの値が null、またはエラーが存在しているなどして、処理をスキップするべきか否か
|
||||||
|
*/
|
||||||
|
get shouldSkip() {
|
||||||
|
return this.error !== null || this.value === null;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* このインスタンスの値が undefined または null の場合エラーにします
|
* このインスタンスの値が undefined または null の場合エラーにします
|
||||||
*/
|
*/
|
||||||
|
@ -86,7 +93,7 @@ class QueryCore implements Query {
|
||||||
* @param validator バリデータ
|
* @param validator バリデータ
|
||||||
*/
|
*/
|
||||||
validate(validator: Validator<any>) {
|
validate(validator: Validator<any>) {
|
||||||
if (this.error || this.value === null) return this;
|
if (this.shouldSkip) return this;
|
||||||
const result = validator(this.value);
|
const result = validator(this.value);
|
||||||
if (result === false) {
|
if (result === false) {
|
||||||
this.error = new Error('invalid-format');
|
this.error = new Error('invalid-format');
|
||||||
|
@ -164,7 +171,7 @@ class NumberQuery extends QueryCore {
|
||||||
* @param max 上限
|
* @param max 上限
|
||||||
*/
|
*/
|
||||||
range(min: number, max: number) {
|
range(min: number, max: number) {
|
||||||
if (this.error || this.value === null) return this;
|
if (this.shouldSkip) return this;
|
||||||
if (this.value < min || this.value > max) {
|
if (this.value < min || this.value > max) {
|
||||||
this.error = new Error('invalid-range');
|
this.error = new Error('invalid-range');
|
||||||
}
|
}
|
||||||
|
@ -176,7 +183,7 @@ class NumberQuery extends QueryCore {
|
||||||
* @param value 下限
|
* @param value 下限
|
||||||
*/
|
*/
|
||||||
min(value: number) {
|
min(value: number) {
|
||||||
if (this.error || this.value === null) return this;
|
if (this.shouldSkip) return this;
|
||||||
if (this.value < value) {
|
if (this.value < value) {
|
||||||
this.error = new Error('invalid-range');
|
this.error = new Error('invalid-range');
|
||||||
}
|
}
|
||||||
|
@ -188,7 +195,7 @@ class NumberQuery extends QueryCore {
|
||||||
* @param value 上限
|
* @param value 上限
|
||||||
*/
|
*/
|
||||||
max(value: number) {
|
max(value: number) {
|
||||||
if (this.error || this.value === null) return this;
|
if (this.shouldSkip) return this;
|
||||||
if (this.value > value) {
|
if (this.value > value) {
|
||||||
this.error = new Error('invalid-range');
|
this.error = new Error('invalid-range');
|
||||||
}
|
}
|
||||||
|
@ -247,7 +254,7 @@ class StringQuery extends QueryCore {
|
||||||
* @param max 上限
|
* @param max 上限
|
||||||
*/
|
*/
|
||||||
range(min: number, max: number) {
|
range(min: number, max: number) {
|
||||||
if (this.error || this.value === null) return this;
|
if (this.shouldSkip) return this;
|
||||||
if (this.value.length < min || this.value.length > max) {
|
if (this.value.length < min || this.value.length > max) {
|
||||||
this.error = new Error('invalid-range');
|
this.error = new Error('invalid-range');
|
||||||
}
|
}
|
||||||
|
@ -255,7 +262,7 @@ class StringQuery extends QueryCore {
|
||||||
}
|
}
|
||||||
|
|
||||||
trim() {
|
trim() {
|
||||||
if (this.error || this.value === null) return this;
|
if (this.shouldSkip) return this;
|
||||||
this.value = this.value.trim();
|
this.value = this.value.trim();
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
@ -296,7 +303,7 @@ class StringQuery extends QueryCore {
|
||||||
* @param pattern 文字列の配列またはスペースで区切られた文字列
|
* @param pattern 文字列の配列またはスペースで区切られた文字列
|
||||||
*/
|
*/
|
||||||
or(pattern: string | string[]) {
|
or(pattern: string | string[]) {
|
||||||
if (this.error || this.value === null) return this;
|
if (this.shouldSkip) return this;
|
||||||
if (typeof pattern == 'string') pattern = pattern.split(' ');
|
if (typeof pattern == 'string') pattern = pattern.split(' ');
|
||||||
const match = pattern.some(x => x === this.value);
|
const match = pattern.some(x => x === this.value);
|
||||||
if (!match) this.error = new Error('not-match-pattern');
|
if (!match) this.error = new Error('not-match-pattern');
|
||||||
|
@ -309,7 +316,7 @@ class StringQuery extends QueryCore {
|
||||||
* @param pattern 正規表現
|
* @param pattern 正規表現
|
||||||
*/
|
*/
|
||||||
match(pattern: RegExp) {
|
match(pattern: RegExp) {
|
||||||
if (this.error || this.value === null) return this;
|
if (this.shouldSkip) return this;
|
||||||
if (!pattern.test(this.value)) this.error = new Error('not-match-pattern');
|
if (!pattern.test(this.value)) this.error = new Error('not-match-pattern');
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
@ -334,7 +341,7 @@ class ArrayQuery extends QueryCore {
|
||||||
* 配列の値がユニークでない場合(=重複した項目がある場合)エラーにします
|
* 配列の値がユニークでない場合(=重複した項目がある場合)エラーにします
|
||||||
*/
|
*/
|
||||||
unique() {
|
unique() {
|
||||||
if (this.error || this.value === null) return this;
|
if (this.shouldSkip) return this;
|
||||||
if (hasDuplicates(this.value)) {
|
if (hasDuplicates(this.value)) {
|
||||||
this.error = new Error('must-be-unique');
|
this.error = new Error('must-be-unique');
|
||||||
}
|
}
|
||||||
|
@ -347,7 +354,7 @@ class ArrayQuery extends QueryCore {
|
||||||
* @param max 上限
|
* @param max 上限
|
||||||
*/
|
*/
|
||||||
range(min: number, max: number) {
|
range(min: number, max: number) {
|
||||||
if (this.error || this.value === null) return this;
|
if (this.shouldSkip) return this;
|
||||||
if (this.value.length < min || this.value.length > max) {
|
if (this.value.length < min || this.value.length > max) {
|
||||||
this.error = new Error('invalid-range');
|
this.error = new Error('invalid-range');
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue