not-node 6.3.22 → 6.3.23
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +1 -1
- package/src/form/form.js +36 -2
- package/src/generic/form.authorizedAction.js +2 -2
- package/src/generic/form.getByID.js +2 -2
- package/src/generic/form.getById.js +2 -2
- package/src/generic/form.list.js +8 -2
- package/src/generic/form.listAndCount.js +8 -2
- package/src/init/lib/rateLimiter.js +0 -1
package/package.json
CHANGED
package/src/form/form.js
CHANGED
|
@@ -1,7 +1,5 @@
|
|
|
1
1
|
const validator = require("validator");
|
|
2
|
-
|
|
3
2
|
const FormFabric = require("./fabric");
|
|
4
|
-
|
|
5
3
|
const { createSchemaFromFields } = require("../fields");
|
|
6
4
|
|
|
7
5
|
const { objHas, isFunc, firstLetterToUpper } = require("../common");
|
|
@@ -10,6 +8,8 @@ const ValidationBuilder = require("not-validation").Builder;
|
|
|
10
8
|
const ValidationSession = require("not-validation").Session;
|
|
11
9
|
|
|
12
10
|
const notValidationError = require("not-error/src/validation.error.node.cjs");
|
|
11
|
+
const InitRateLimiter = require("../init/lib/rateLimiter");
|
|
12
|
+
|
|
13
13
|
const notError = require("not-error/src/error.node.cjs");
|
|
14
14
|
|
|
15
15
|
const {
|
|
@@ -53,6 +53,10 @@ class Form {
|
|
|
53
53
|
...DEFAULT_TRANSFORMERS,
|
|
54
54
|
};
|
|
55
55
|
|
|
56
|
+
#rateLimiter = null;
|
|
57
|
+
#rateLimiterIdGetter = null;
|
|
58
|
+
#rateLimiterException = null;
|
|
59
|
+
|
|
56
60
|
constructor({
|
|
57
61
|
FIELDS,
|
|
58
62
|
FORM_NAME,
|
|
@@ -62,6 +66,7 @@ class Form {
|
|
|
62
66
|
EXTRACTORS = {},
|
|
63
67
|
ENV_EXTRACTORS = {},
|
|
64
68
|
TRANSFORMERS = {},
|
|
69
|
+
rate = null,
|
|
65
70
|
}) {
|
|
66
71
|
this.#FORM_NAME = FORM_NAME;
|
|
67
72
|
this.#MODEL_NAME = MODEL_NAME;
|
|
@@ -72,6 +77,7 @@ class Form {
|
|
|
72
77
|
this.#addExtractors(EXTRACTORS);
|
|
73
78
|
this.#addEnvExtractors(ENV_EXTRACTORS);
|
|
74
79
|
this.#addTransformers(TRANSFORMERS);
|
|
80
|
+
this.#createRateLimiter(rate);
|
|
75
81
|
}
|
|
76
82
|
|
|
77
83
|
/**
|
|
@@ -109,6 +115,7 @@ class Form {
|
|
|
109
115
|
**/
|
|
110
116
|
async run(req) {
|
|
111
117
|
let data = await this.extract(req);
|
|
118
|
+
this.#checkRate(data);
|
|
112
119
|
await this.#_validate(data);
|
|
113
120
|
return data;
|
|
114
121
|
}
|
|
@@ -460,6 +467,33 @@ class Form {
|
|
|
460
467
|
this.#TRANSFORMERS = { ...this.#TRANSFORMERS, ...transformers };
|
|
461
468
|
}
|
|
462
469
|
}
|
|
470
|
+
|
|
471
|
+
#createRateLimiter(rate) {
|
|
472
|
+
if (rate) {
|
|
473
|
+
this.#rateLimiterIdGetter = rate.idGetter;
|
|
474
|
+
this.#rateLimiterException = rate.exception;
|
|
475
|
+
this.#rateLimiter = InitRateLimiter.initCustom(
|
|
476
|
+
rate.options,
|
|
477
|
+
rate.client
|
|
478
|
+
);
|
|
479
|
+
}
|
|
480
|
+
}
|
|
481
|
+
|
|
482
|
+
async #checkRate(envs) {
|
|
483
|
+
try {
|
|
484
|
+
this.#rateLimiter &&
|
|
485
|
+
typeof this.#rateLimiterIdGetter === "function" &&
|
|
486
|
+
(await this.#rateLimiter.consume(
|
|
487
|
+
this.#rateLimiterIdGetter(envs)
|
|
488
|
+
));
|
|
489
|
+
} catch (e) {
|
|
490
|
+
if (this.#rateLimiterException) {
|
|
491
|
+
throw new this.#rateLimiterException(envs);
|
|
492
|
+
} else {
|
|
493
|
+
throw e;
|
|
494
|
+
}
|
|
495
|
+
}
|
|
496
|
+
}
|
|
463
497
|
}
|
|
464
498
|
|
|
465
499
|
module.exports = Form;
|
|
@@ -9,8 +9,8 @@ module.exports = ({ MODULE_NAME, MODEL_NAME, actionName }) => {
|
|
|
9
9
|
actionName
|
|
10
10
|
)}Form`;
|
|
11
11
|
return class extends Form {
|
|
12
|
-
constructor(
|
|
13
|
-
super({ MODULE_NAME, MODEL_NAME, FIELDS, FORM_NAME
|
|
12
|
+
constructor(params) {
|
|
13
|
+
super({ ...params, MODULE_NAME, MODEL_NAME, FIELDS, FORM_NAME });
|
|
14
14
|
}
|
|
15
15
|
|
|
16
16
|
async extract(req) {
|
|
@@ -13,8 +13,8 @@ module.exports = ({ MODULE_NAME, MODEL_NAME, actionName }) => {
|
|
|
13
13
|
actionName
|
|
14
14
|
)}Form`;
|
|
15
15
|
return class extends Form {
|
|
16
|
-
constructor(
|
|
17
|
-
super({ MODULE_NAME, MODEL_NAME, FIELDS, FORM_NAME
|
|
16
|
+
constructor(params) {
|
|
17
|
+
super({ ...params, MODULE_NAME, MODEL_NAME, FIELDS, FORM_NAME });
|
|
18
18
|
}
|
|
19
19
|
|
|
20
20
|
async extract(req) {
|
|
@@ -13,8 +13,8 @@ module.exports = ({ MODULE_NAME, MODEL_NAME, actionName }) => {
|
|
|
13
13
|
actionName
|
|
14
14
|
)}Form`;
|
|
15
15
|
return class extends Form {
|
|
16
|
-
constructor(
|
|
17
|
-
super({ MODULE_NAME, MODEL_NAME, FIELDS, FORM_NAME
|
|
16
|
+
constructor(params) {
|
|
17
|
+
super({ ...params, MODULE_NAME, MODEL_NAME, FIELDS, FORM_NAME });
|
|
18
18
|
}
|
|
19
19
|
|
|
20
20
|
async extract(req) {
|
package/src/generic/form.list.js
CHANGED
|
@@ -23,8 +23,14 @@ const FactoryFormList = ({ MODULE_NAME, MODEL_NAME, actionName }) => {
|
|
|
23
23
|
)}Form`;
|
|
24
24
|
|
|
25
25
|
return class extends Form {
|
|
26
|
-
constructor(
|
|
27
|
-
super({
|
|
26
|
+
constructor(params) {
|
|
27
|
+
super({
|
|
28
|
+
...params,
|
|
29
|
+
FIELDS,
|
|
30
|
+
FORM_NAME,
|
|
31
|
+
MODULE_NAME,
|
|
32
|
+
MODEL_NAME,
|
|
33
|
+
});
|
|
28
34
|
}
|
|
29
35
|
|
|
30
36
|
/**
|
|
@@ -23,8 +23,14 @@ const FactoryFormListAndCount = ({ MODULE_NAME, MODEL_NAME, actionName }) => {
|
|
|
23
23
|
)}Form`;
|
|
24
24
|
|
|
25
25
|
return class extends Form {
|
|
26
|
-
constructor(
|
|
27
|
-
super({
|
|
26
|
+
constructor(params) {
|
|
27
|
+
super({
|
|
28
|
+
...params,
|
|
29
|
+
FIELDS,
|
|
30
|
+
FORM_NAME,
|
|
31
|
+
MODULE_NAME,
|
|
32
|
+
MODEL_NAME,
|
|
33
|
+
});
|
|
28
34
|
}
|
|
29
35
|
|
|
30
36
|
/**
|
|
@@ -28,7 +28,6 @@ module.exports = class InitRateLimiter {
|
|
|
28
28
|
await emit("rateLimiter.pre", { config, master });
|
|
29
29
|
const rateLimiter = InitRateLimiter.createRateLimiter({
|
|
30
30
|
config,
|
|
31
|
-
master,
|
|
32
31
|
});
|
|
33
32
|
const middleware = InitRateLimiter.createMiddleware({ rateLimiter });
|
|
34
33
|
master.getServer().use(middleware);
|