@decaf-ts/db-decorators 0.2.0 → 0.3.1
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/README.md +4 -4
- package/dist/db-decorators.bundle.min.js +1 -1
- package/dist/esm/db-decorators.bundle.min.esm.js +1 -1
- package/lib/esm/identity/decorators.d.ts +1 -1
- package/lib/esm/identity/decorators.js +10 -1
- package/lib/esm/identity/index.js +4 -1
- package/lib/esm/identity/utils.d.ts +6 -9
- package/lib/esm/identity/utils.js +63 -1
- package/lib/esm/index.js +35 -1
- package/lib/esm/interfaces/BulkCrudOperator.js +3 -0
- package/lib/esm/interfaces/CrudOperator.js +3 -0
- package/lib/esm/interfaces/IRepository.d.ts +2 -3
- package/lib/esm/interfaces/IRepository.js +3 -0
- package/lib/esm/interfaces/index.js +5 -1
- package/lib/esm/model/constants.d.ts +1 -1
- package/lib/esm/model/constants.js +39 -1
- package/lib/esm/model/decorators.d.ts +5 -7
- package/lib/esm/model/decorators.js +69 -1
- package/lib/esm/model/index.d.ts +2 -1
- package/lib/esm/model/index.js +6 -1
- package/lib/esm/model/model.d.ts +8 -0
- package/lib/esm/model/model.js +14 -0
- package/lib/esm/model/validation.d.ts +1 -2
- package/lib/esm/model/validation.js +122 -1
- package/lib/esm/operations/Operations.d.ts +3 -4
- package/lib/esm/operations/Operations.js +35 -1
- package/lib/esm/operations/OperationsRegistry.d.ts +2 -3
- package/lib/esm/operations/OperationsRegistry.js +65 -1
- package/lib/esm/operations/constants.d.ts +1 -1
- package/lib/esm/operations/constants.js +39 -1
- package/lib/esm/operations/decorators.js +226 -1
- package/lib/esm/operations/index.js +7 -1
- package/lib/esm/operations/types.d.ts +4 -5
- package/lib/esm/operations/types.js +3 -0
- package/lib/esm/repository/BaseRepository.d.ts +2 -3
- package/lib/esm/repository/BaseRepository.js +158 -1
- package/lib/esm/repository/DataCache.js +32 -1
- package/lib/esm/repository/Repository.d.ts +3 -2
- package/lib/esm/repository/Repository.js +89 -2
- package/lib/esm/repository/errors.js +88 -1
- package/lib/esm/repository/index.js +8 -1
- package/lib/esm/repository/utils.d.ts +3 -4
- package/lib/esm/repository/utils.js +167 -1
- package/lib/esm/repository/wrappers.js +90 -1
- package/lib/esm/validation/constants.js +33 -1
- package/lib/esm/validation/decorators.d.ts +6 -8
- package/lib/esm/validation/decorators.js +223 -1
- package/lib/esm/validation/index.js +5 -1
- package/lib/esm/validation/validators/ReadOnlyValidator.js +52 -1
- package/lib/esm/validation/validators/TimestampValidator.js +49 -1
- package/lib/esm/validation/validators/UpdateValidator.js +20 -1
- package/lib/esm/validation/validators/index.js +5 -1
- package/lib/identity/decorators.cjs +13 -1
- package/lib/identity/decorators.d.ts +1 -1
- package/lib/identity/index.cjs +20 -1
- package/lib/identity/utils.cjs +67 -1
- package/lib/identity/utils.d.ts +6 -9
- package/lib/index.cjs +51 -1
- package/lib/interfaces/BulkCrudOperator.cjs +4 -1
- package/lib/interfaces/CrudOperator.cjs +4 -1
- package/lib/interfaces/IRepository.cjs +4 -1
- package/lib/interfaces/IRepository.d.ts +2 -3
- package/lib/interfaces/index.cjs +21 -1
- package/lib/model/constants.cjs +42 -1
- package/lib/model/constants.d.ts +1 -1
- package/lib/model/decorators.cjs +76 -1
- package/lib/model/decorators.d.ts +5 -7
- package/lib/model/index.cjs +22 -1
- package/lib/model/index.d.ts +2 -1
- package/lib/model/model.cjs +16 -0
- package/lib/model/model.d.ts +8 -0
- package/lib/model/validation.cjs +125 -1
- package/lib/model/validation.d.ts +1 -2
- package/lib/operations/Operations.cjs +39 -1
- package/lib/operations/Operations.d.ts +3 -4
- package/lib/operations/OperationsRegistry.cjs +69 -1
- package/lib/operations/OperationsRegistry.d.ts +2 -3
- package/lib/operations/constants.cjs +42 -1
- package/lib/operations/constants.d.ts +1 -1
- package/lib/operations/decorators.cjs +241 -1
- package/lib/operations/index.cjs +23 -1
- package/lib/operations/types.cjs +4 -1
- package/lib/operations/types.d.ts +4 -5
- package/lib/repository/BaseRepository.cjs +162 -1
- package/lib/repository/BaseRepository.d.ts +2 -3
- package/lib/repository/DataCache.cjs +36 -1
- package/lib/repository/Repository.cjs +93 -2
- package/lib/repository/Repository.d.ts +3 -2
- package/lib/repository/errors.cjs +97 -1
- package/lib/repository/index.cjs +24 -1
- package/lib/repository/utils.cjs +174 -1
- package/lib/repository/utils.d.ts +3 -4
- package/lib/repository/wrappers.cjs +95 -1
- package/lib/validation/constants.cjs +36 -1
- package/lib/validation/decorators.cjs +232 -1
- package/lib/validation/decorators.d.ts +6 -8
- package/lib/validation/index.cjs +21 -1
- package/lib/validation/validators/ReadOnlyValidator.cjs +55 -1
- package/lib/validation/validators/TimestampValidator.cjs +52 -1
- package/lib/validation/validators/UpdateValidator.cjs +24 -1
- package/lib/validation/validators/index.cjs +21 -1
- package/package.json +22 -18
- package/lib/esm/model/DBModel.d.ts +0 -25
- package/lib/esm/model/DBModel.js +0 -1
- package/lib/esm/validation/comparison.d.ts +0 -1
- package/lib/esm/validation/comparison.js +0 -1
- package/lib/model/DBModel.cjs +0 -1
- package/lib/model/DBModel.d.ts +0 -25
- package/lib/validation/comparison.cjs +0 -1
- package/lib/validation/comparison.d.ts +0 -1
|
@@ -1,2 +1,93 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Repository = void 0;
|
|
4
|
+
const utils_1 = require("./utils.cjs");
|
|
5
|
+
const constants_1 = require("../operations/constants.cjs");
|
|
6
|
+
const errors_1 = require("./errors.cjs");
|
|
7
|
+
const BaseRepository_1 = require("./BaseRepository.cjs");
|
|
8
|
+
const utils_2 = require("../identity/utils.cjs");
|
|
9
|
+
const constants_2 = require("../model/constants.cjs");
|
|
10
|
+
class Repository extends BaseRepository_1.BaseRepository {
|
|
11
|
+
constructor(clazz) {
|
|
12
|
+
super(clazz);
|
|
13
|
+
}
|
|
14
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
15
|
+
async create(model) {
|
|
16
|
+
throw new Error("Child classes must implement this.");
|
|
17
|
+
}
|
|
18
|
+
async createPrefix(model, ...args) {
|
|
19
|
+
model = new this.class(model);
|
|
20
|
+
await (0, utils_1.enforceDBDecorators)(this, model, constants_1.OperationKeys.CREATE, constants_1.OperationKeys.ON);
|
|
21
|
+
const errors = model.hasErrors();
|
|
22
|
+
if (errors)
|
|
23
|
+
throw new errors_1.ValidationError(errors.toString());
|
|
24
|
+
return [model, ...args];
|
|
25
|
+
}
|
|
26
|
+
async createAllPrefix(models, ...args) {
|
|
27
|
+
await Promise.all(models.map(async (m) => {
|
|
28
|
+
m = new this.class(m);
|
|
29
|
+
await (0, utils_1.enforceDBDecorators)(this, m, constants_1.OperationKeys.CREATE, constants_1.OperationKeys.ON);
|
|
30
|
+
return m;
|
|
31
|
+
}));
|
|
32
|
+
const errors = models
|
|
33
|
+
.map((m) => m.hasErrors())
|
|
34
|
+
.reduce((accum, e, i) => {
|
|
35
|
+
if (e)
|
|
36
|
+
accum =
|
|
37
|
+
typeof accum === "string"
|
|
38
|
+
? accum + `\n - ${i}: ${e.toString()}`
|
|
39
|
+
: ` - ${i}: ${e.toString()}`;
|
|
40
|
+
return accum;
|
|
41
|
+
}, undefined);
|
|
42
|
+
if (errors)
|
|
43
|
+
throw new errors_1.ValidationError(errors);
|
|
44
|
+
return [models, ...args];
|
|
45
|
+
}
|
|
46
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
47
|
+
async delete(key) {
|
|
48
|
+
throw new Error("Child classes must implement this.");
|
|
49
|
+
}
|
|
50
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
51
|
+
async read(key) {
|
|
52
|
+
throw new Error("Child classes must implement this.");
|
|
53
|
+
}
|
|
54
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
55
|
+
async update(model) {
|
|
56
|
+
throw new Error("Child classes must implement this.");
|
|
57
|
+
}
|
|
58
|
+
async updatePrefix(model, ...args) {
|
|
59
|
+
const pk = (0, utils_2.findModelId)(model);
|
|
60
|
+
const oldModel = await this.read(pk);
|
|
61
|
+
model = this.merge(oldModel, model);
|
|
62
|
+
await (0, utils_1.enforceDBDecorators)(this, model, constants_1.OperationKeys.UPDATE, constants_1.OperationKeys.ON, oldModel);
|
|
63
|
+
const errors = model.hasErrors(oldModel);
|
|
64
|
+
if (errors)
|
|
65
|
+
throw new errors_1.ValidationError(errors.toString());
|
|
66
|
+
return [model, ...args];
|
|
67
|
+
}
|
|
68
|
+
async updateAllPrefix(models, ...args) {
|
|
69
|
+
const ids = models.map((m) => (0, utils_2.findModelId)(m));
|
|
70
|
+
const oldModels = await this.readAll(ids);
|
|
71
|
+
models = models.map((m, i) => this.merge(oldModels[i], m));
|
|
72
|
+
await Promise.all(models.map((m, i) => (0, utils_1.enforceDBDecorators)(this, m, constants_1.OperationKeys.UPDATE, constants_1.OperationKeys.ON, oldModels[i])));
|
|
73
|
+
const errors = models
|
|
74
|
+
.map((m, i) => m.hasErrors(oldModels[i], m))
|
|
75
|
+
.reduce((accum, e, i) => {
|
|
76
|
+
if (e)
|
|
77
|
+
accum =
|
|
78
|
+
typeof accum === "string"
|
|
79
|
+
? accum + `\n - ${i}: ${e.toString()}`
|
|
80
|
+
: ` - ${i}: ${e.toString()}`;
|
|
81
|
+
return accum;
|
|
82
|
+
}, undefined);
|
|
83
|
+
if (errors)
|
|
84
|
+
throw new errors_1.ValidationError(errors);
|
|
85
|
+
return [models, ...args];
|
|
86
|
+
}
|
|
87
|
+
static key(key) {
|
|
88
|
+
return constants_2.DBKeys.REFLECT + key;
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
exports.Repository = Repository;
|
|
92
|
+
|
|
93
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["src/repository/Repository.ts"],"names":[],"mappings":"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","file":"repository/Repository.js","sourcesContent":["import { enforceDBDecorators } from \"./utils\";\nimport { OperationKeys } from \"../operations/constants\";\nimport { ValidationError } from \"./errors\";\nimport { BaseRepository } from \"./BaseRepository\";\nimport { findModelId } from \"../identity/utils\";\nimport { Constructor } from \"@decaf-ts/decorator-validation\";\nimport { DBKeys } from \"../model/constants\";\n\nexport abstract class Repository<M extends Model> extends BaseRepository<M> {\n  protected constructor(clazz?: Constructor<M>) {\n    super(clazz);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  async create(model: M): Promise<M> {\n    throw new Error(\"Child classes must implement this.\");\n  }\n\n  protected override async createPrefix(\n    model: M,\n    ...args: any[]\n  ): Promise<[M, ...any[]]> {\n    model = new this.class(model);\n    await enforceDBDecorators(\n      this,\n      model,\n      OperationKeys.CREATE,\n      OperationKeys.ON\n    );\n\n    const errors = model.hasErrors();\n    if (errors) throw new ValidationError(errors.toString());\n\n    return [model, ...args];\n  }\n\n  protected async createAllPrefix(models: M[], ...args: any[]): Promise<any[]> {\n    await Promise.all(\n      models.map(async (m) => {\n        m = new this.class(m);\n        await enforceDBDecorators(\n          this,\n          m,\n          OperationKeys.CREATE,\n          OperationKeys.ON\n        );\n        return m;\n      })\n    );\n    const errors = models\n      .map((m) => m.hasErrors())\n      .reduce((accum: string | undefined, e, i) => {\n        if (e)\n          accum =\n            typeof accum === \"string\"\n              ? accum + `\\n - ${i}: ${e.toString()}`\n              : ` - ${i}: ${e.toString()}`;\n        return accum;\n      }, undefined);\n    if (errors) throw new ValidationError(errors);\n    return [models, ...args];\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  async delete(key: string | number): Promise<M> {\n    throw new Error(\"Child classes must implement this.\");\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  async read(key: string | number): Promise<M> {\n    throw new Error(\"Child classes must implement this.\");\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  async update(model: M): Promise<M> {\n    throw new Error(\"Child classes must implement this.\");\n  }\n\n  protected async updatePrefix(\n    model: M,\n    ...args: any[]\n  ): Promise<[M, ...args: any[]]> {\n    const pk = findModelId(model);\n\n    const oldModel = await this.read(pk);\n\n    model = this.merge(oldModel, model);\n\n    await enforceDBDecorators(\n      this,\n      model,\n      OperationKeys.UPDATE,\n      OperationKeys.ON,\n      oldModel\n    );\n\n    const errors = model.hasErrors(oldModel);\n    if (errors) throw new ValidationError(errors.toString());\n    return [model, ...args];\n  }\n\n  protected async updateAllPrefix(models: M[], ...args: any[]) {\n    const ids = models.map((m) => findModelId(m));\n    const oldModels = await this.readAll(ids);\n    models = models.map((m, i) => this.merge(oldModels[i], m));\n    await Promise.all(\n      models.map((m, i) =>\n        enforceDBDecorators(\n          this,\n          m,\n          OperationKeys.UPDATE,\n          OperationKeys.ON,\n          oldModels[i]\n        )\n      )\n    );\n\n    const errors = models\n      .map((m, i) => m.hasErrors(oldModels[i], m))\n      .reduce((accum: string | undefined, e, i) => {\n        if (e)\n          accum =\n            typeof accum === \"string\"\n              ? accum + `\\n - ${i}: ${e.toString()}`\n              : ` - ${i}: ${e.toString()}`;\n        return accum;\n      }, undefined);\n    if (errors) throw new ValidationError(errors);\n    return [models, ...args];\n  }\n\n  static key(key: string) {\n    return DBKeys.REFLECT + key;\n  }\n}\n"]}
|
|
@@ -1,13 +1,14 @@
|
|
|
1
|
-
import { DBModel } from "../model/DBModel";
|
|
2
1
|
import { BaseRepository } from "./BaseRepository";
|
|
3
2
|
import { Constructor } from "@decaf-ts/decorator-validation";
|
|
4
|
-
export declare abstract class Repository<M extends
|
|
3
|
+
export declare abstract class Repository<M extends Model> extends BaseRepository<M> {
|
|
5
4
|
protected constructor(clazz?: Constructor<M>);
|
|
6
5
|
create(model: M): Promise<M>;
|
|
7
6
|
protected createPrefix(model: M, ...args: any[]): Promise<[M, ...any[]]>;
|
|
7
|
+
protected createAllPrefix(models: M[], ...args: any[]): Promise<any[]>;
|
|
8
8
|
delete(key: string | number): Promise<M>;
|
|
9
9
|
read(key: string | number): Promise<M>;
|
|
10
10
|
update(model: M): Promise<M>;
|
|
11
11
|
protected updatePrefix(model: M, ...args: any[]): Promise<[M, ...args: any[]]>;
|
|
12
12
|
protected updateAllPrefix(models: M[], ...args: any[]): Promise<any[]>;
|
|
13
|
+
static key(key: string): string;
|
|
13
14
|
}
|
|
@@ -1 +1,97 @@
|
|
|
1
|
-
"use strict";
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ConflictError = exports.NotFoundError = exports.SerializationError = exports.InternalError = exports.ValidationError = exports.BaseError = void 0;
|
|
4
|
+
/**
|
|
5
|
+
* @summary Base Error
|
|
6
|
+
*
|
|
7
|
+
* @param {string} msg the error message
|
|
8
|
+
*
|
|
9
|
+
* @class BaseDLTError
|
|
10
|
+
* @extends Error
|
|
11
|
+
*/
|
|
12
|
+
class BaseError extends Error {
|
|
13
|
+
constructor(name, msg) {
|
|
14
|
+
if (msg instanceof BaseError)
|
|
15
|
+
return msg;
|
|
16
|
+
const message = `[${name}] ${msg instanceof Error ? msg.message : msg}`;
|
|
17
|
+
super(message);
|
|
18
|
+
if (msg instanceof Error)
|
|
19
|
+
this.stack = msg.stack;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
exports.BaseError = BaseError;
|
|
23
|
+
/**
|
|
24
|
+
* @summary Represents a failure in the Model details
|
|
25
|
+
*
|
|
26
|
+
* @param {string} msg the error message
|
|
27
|
+
*
|
|
28
|
+
* @class ValidationError
|
|
29
|
+
* @extends BaseError
|
|
30
|
+
*/
|
|
31
|
+
class ValidationError extends BaseError {
|
|
32
|
+
constructor(msg) {
|
|
33
|
+
super(ValidationError.name, msg);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
exports.ValidationError = ValidationError;
|
|
37
|
+
/**
|
|
38
|
+
* @summary Represents an internal failure (should mean an error in code)
|
|
39
|
+
*
|
|
40
|
+
* @param {string} msg the error message
|
|
41
|
+
*
|
|
42
|
+
* @class InternalError
|
|
43
|
+
* @extends BaseError
|
|
44
|
+
*/
|
|
45
|
+
class InternalError extends BaseError {
|
|
46
|
+
constructor(msg) {
|
|
47
|
+
super(InternalError.name, msg);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
exports.InternalError = InternalError;
|
|
51
|
+
/**
|
|
52
|
+
* @summary Represents a failure in the Model de/serialization
|
|
53
|
+
*
|
|
54
|
+
* @param {string} msg the error message
|
|
55
|
+
*
|
|
56
|
+
* @class SerializationError
|
|
57
|
+
* @extends BaseError
|
|
58
|
+
*
|
|
59
|
+
*/
|
|
60
|
+
class SerializationError extends BaseError {
|
|
61
|
+
constructor(msg) {
|
|
62
|
+
super(SerializationError.name, msg);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
exports.SerializationError = SerializationError;
|
|
66
|
+
/**
|
|
67
|
+
* @summary Represents a failure in finding a model
|
|
68
|
+
*
|
|
69
|
+
* @param {string} msg the error message
|
|
70
|
+
*
|
|
71
|
+
* @class NotFoundError
|
|
72
|
+
* @extends BaseError
|
|
73
|
+
*
|
|
74
|
+
*/
|
|
75
|
+
class NotFoundError extends BaseError {
|
|
76
|
+
constructor(msg) {
|
|
77
|
+
super(NotFoundError.name, msg);
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
exports.NotFoundError = NotFoundError;
|
|
81
|
+
/**
|
|
82
|
+
* @summary Represents a conflict in the storage
|
|
83
|
+
*
|
|
84
|
+
* @param {string} msg the error message
|
|
85
|
+
*
|
|
86
|
+
* @class ConflictError
|
|
87
|
+
* @extends BaseError
|
|
88
|
+
*
|
|
89
|
+
*/
|
|
90
|
+
class ConflictError extends BaseError {
|
|
91
|
+
constructor(msg) {
|
|
92
|
+
super(ConflictError.name, msg);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
exports.ConflictError = ConflictError;
|
|
96
|
+
|
|
97
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9yZXBvc2l0b3J5L2Vycm9ycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQTs7Ozs7OztHQU9HO0FBQ0gsTUFBc0IsU0FBVSxTQUFRLEtBQUs7SUFDM0MsWUFBc0IsSUFBWSxFQUFFLEdBQW1CO1FBQ3JELElBQUksR0FBRyxZQUFZLFNBQVM7WUFBRSxPQUFPLEdBQUcsQ0FBQztRQUN6QyxNQUFNLE9BQU8sR0FBRyxJQUFJLElBQUksS0FBSyxHQUFHLFlBQVksS0FBSyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxHQUFHLEVBQUUsQ0FBQztRQUN4RSxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDZixJQUFJLEdBQUcsWUFBWSxLQUFLO1lBQUUsSUFBSSxDQUFDLEtBQUssR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDO0lBQ25ELENBQUM7Q0FDRjtBQVBELDhCQU9DO0FBRUQ7Ozs7Ozs7R0FPRztBQUNILE1BQWEsZUFBZ0IsU0FBUSxTQUFTO0lBQzVDLFlBQVksR0FBbUI7UUFDN0IsS0FBSyxDQUFDLGVBQWUsQ0FBQyxJQUFJLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFDbkMsQ0FBQztDQUNGO0FBSkQsMENBSUM7QUFDRDs7Ozs7OztHQU9HO0FBQ0gsTUFBYSxhQUFjLFNBQVEsU0FBUztJQUMxQyxZQUFZLEdBQW1CO1FBQzdCLEtBQUssQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBQ2pDLENBQUM7Q0FDRjtBQUpELHNDQUlDO0FBQ0Q7Ozs7Ozs7O0dBUUc7QUFDSCxNQUFhLGtCQUFtQixTQUFRLFNBQVM7SUFDL0MsWUFBWSxHQUFtQjtRQUM3QixLQUFLLENBQUMsa0JBQWtCLENBQUMsSUFBSSxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBQ3RDLENBQUM7Q0FDRjtBQUpELGdEQUlDO0FBRUQ7Ozs7Ozs7O0dBUUc7QUFDSCxNQUFhLGFBQWMsU0FBUSxTQUFTO0lBQzFDLFlBQVksR0FBbUI7UUFDN0IsS0FBSyxDQUFDLGFBQWEsQ0FBQyxJQUFJLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFDakMsQ0FBQztDQUNGO0FBSkQsc0NBSUM7QUFDRDs7Ozs7Ozs7R0FRRztBQUNILE1BQWEsYUFBYyxTQUFRLFNBQVM7SUFDMUMsWUFBWSxHQUFtQjtRQUM3QixLQUFLLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxHQUFHLENBQUMsQ0FBQztJQUNqQyxDQUFDO0NBQ0Y7QUFKRCxzQ0FJQyIsImZpbGUiOiJyZXBvc2l0b3J5L2Vycm9ycy5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQHN1bW1hcnkgQmFzZSBFcnJvclxuICpcbiAqIEBwYXJhbSB7c3RyaW5nfSBtc2cgdGhlIGVycm9yIG1lc3NhZ2VcbiAqXG4gKiBAY2xhc3MgQmFzZURMVEVycm9yXG4gKiBAZXh0ZW5kcyBFcnJvclxuICovXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQmFzZUVycm9yIGV4dGVuZHMgRXJyb3Ige1xuICBwcm90ZWN0ZWQgY29uc3RydWN0b3IobmFtZTogc3RyaW5nLCBtc2c6IHN0cmluZyB8IEVycm9yKSB7XG4gICAgaWYgKG1zZyBpbnN0YW5jZW9mIEJhc2VFcnJvcikgcmV0dXJuIG1zZztcbiAgICBjb25zdCBtZXNzYWdlID0gYFske25hbWV9XSAke21zZyBpbnN0YW5jZW9mIEVycm9yID8gbXNnLm1lc3NhZ2UgOiBtc2d9YDtcbiAgICBzdXBlcihtZXNzYWdlKTtcbiAgICBpZiAobXNnIGluc3RhbmNlb2YgRXJyb3IpIHRoaXMuc3RhY2sgPSBtc2cuc3RhY2s7XG4gIH1cbn1cblxuLyoqXG4gKiBAc3VtbWFyeSBSZXByZXNlbnRzIGEgZmFpbHVyZSBpbiB0aGUgTW9kZWwgZGV0YWlsc1xuICpcbiAqIEBwYXJhbSB7c3RyaW5nfSBtc2cgdGhlIGVycm9yIG1lc3NhZ2VcbiAqXG4gKiBAY2xhc3MgVmFsaWRhdGlvbkVycm9yXG4gKiBAZXh0ZW5kcyBCYXNlRXJyb3JcbiAqL1xuZXhwb3J0IGNsYXNzIFZhbGlkYXRpb25FcnJvciBleHRlbmRzIEJhc2VFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1zZzogc3RyaW5nIHwgRXJyb3IpIHtcbiAgICBzdXBlcihWYWxpZGF0aW9uRXJyb3IubmFtZSwgbXNnKTtcbiAgfVxufVxuLyoqXG4gKiBAc3VtbWFyeSBSZXByZXNlbnRzIGFuIGludGVybmFsIGZhaWx1cmUgKHNob3VsZCBtZWFuIGFuIGVycm9yIGluIGNvZGUpXG4gKlxuICogQHBhcmFtIHtzdHJpbmd9IG1zZyB0aGUgZXJyb3IgbWVzc2FnZVxuICpcbiAqIEBjbGFzcyBJbnRlcm5hbEVycm9yXG4gKiBAZXh0ZW5kcyBCYXNlRXJyb3JcbiAqL1xuZXhwb3J0IGNsYXNzIEludGVybmFsRXJyb3IgZXh0ZW5kcyBCYXNlRXJyb3Ige1xuICBjb25zdHJ1Y3Rvcihtc2c6IHN0cmluZyB8IEVycm9yKSB7XG4gICAgc3VwZXIoSW50ZXJuYWxFcnJvci5uYW1lLCBtc2cpO1xuICB9XG59XG4vKipcbiAqIEBzdW1tYXJ5IFJlcHJlc2VudHMgYSBmYWlsdXJlIGluIHRoZSBNb2RlbCBkZS9zZXJpYWxpemF0aW9uXG4gKlxuICogQHBhcmFtIHtzdHJpbmd9IG1zZyB0aGUgZXJyb3IgbWVzc2FnZVxuICpcbiAqIEBjbGFzcyBTZXJpYWxpemF0aW9uRXJyb3JcbiAqIEBleHRlbmRzIEJhc2VFcnJvclxuICpcbiAqL1xuZXhwb3J0IGNsYXNzIFNlcmlhbGl6YXRpb25FcnJvciBleHRlbmRzIEJhc2VFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1zZzogc3RyaW5nIHwgRXJyb3IpIHtcbiAgICBzdXBlcihTZXJpYWxpemF0aW9uRXJyb3IubmFtZSwgbXNnKTtcbiAgfVxufVxuXG4vKipcbiAqIEBzdW1tYXJ5IFJlcHJlc2VudHMgYSBmYWlsdXJlIGluIGZpbmRpbmcgYSBtb2RlbFxuICpcbiAqIEBwYXJhbSB7c3RyaW5nfSBtc2cgdGhlIGVycm9yIG1lc3NhZ2VcbiAqXG4gKiBAY2xhc3MgTm90Rm91bmRFcnJvclxuICogQGV4dGVuZHMgQmFzZUVycm9yXG4gKlxuICovXG5leHBvcnQgY2xhc3MgTm90Rm91bmRFcnJvciBleHRlbmRzIEJhc2VFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1zZzogc3RyaW5nIHwgRXJyb3IpIHtcbiAgICBzdXBlcihOb3RGb3VuZEVycm9yLm5hbWUsIG1zZyk7XG4gIH1cbn1cbi8qKlxuICogQHN1bW1hcnkgUmVwcmVzZW50cyBhIGNvbmZsaWN0IGluIHRoZSBzdG9yYWdlXG4gKlxuICogQHBhcmFtIHtzdHJpbmd9IG1zZyB0aGUgZXJyb3IgbWVzc2FnZVxuICpcbiAqIEBjbGFzcyBDb25mbGljdEVycm9yXG4gKiBAZXh0ZW5kcyBCYXNlRXJyb3JcbiAqXG4gKi9cbmV4cG9ydCBjbGFzcyBDb25mbGljdEVycm9yIGV4dGVuZHMgQmFzZUVycm9yIHtcbiAgY29uc3RydWN0b3IobXNnOiBzdHJpbmcgfCBFcnJvcikge1xuICAgIHN1cGVyKENvbmZsaWN0RXJyb3IubmFtZSwgbXNnKTtcbiAgfVxufVxuIl19
|
package/lib/repository/index.cjs
CHANGED
|
@@ -1 +1,24 @@
|
|
|
1
|
-
"use strict";
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./BaseRepository.cjs"), exports);
|
|
18
|
+
__exportStar(require("./DataCache.cjs"), exports);
|
|
19
|
+
__exportStar(require("./errors.cjs"), exports);
|
|
20
|
+
__exportStar(require("./Repository.cjs"), exports);
|
|
21
|
+
__exportStar(require("./utils.cjs"), exports);
|
|
22
|
+
__exportStar(require("./wrappers.cjs"), exports);
|
|
23
|
+
|
|
24
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9yZXBvc2l0b3J5L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxtREFBaUM7QUFDakMsOENBQTRCO0FBQzVCLDJDQUF5QjtBQUN6QiwrQ0FBNkI7QUFDN0IsMENBQXdCO0FBQ3hCLDZDQUEyQiIsImZpbGUiOiJyZXBvc2l0b3J5L2luZGV4LmpzIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vQmFzZVJlcG9zaXRvcnlcIjtcbmV4cG9ydCAqIGZyb20gXCIuL0RhdGFDYWNoZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vZXJyb3JzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9SZXBvc2l0b3J5XCI7XG5leHBvcnQgKiBmcm9tIFwiLi91dGlsc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vd3JhcHBlcnNcIjtcbiJdfQ==
|
package/lib/repository/utils.cjs
CHANGED
|
@@ -1 +1,174 @@
|
|
|
1
|
-
"use strict";
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getAllPropertyDecoratorsRecursive = exports.getHandlerArgs = void 0;
|
|
4
|
+
exports.enforceDBDecorators = enforceDBDecorators;
|
|
5
|
+
exports.getDbDecorators = getDbDecorators;
|
|
6
|
+
const Operations_1 = require("../operations/Operations.cjs");
|
|
7
|
+
const constants_1 = require("../operations/constants.cjs");
|
|
8
|
+
const reflection_1 = require("@decaf-ts/reflection");
|
|
9
|
+
const errors_1 = require("./errors.cjs");
|
|
10
|
+
const decorator_validation_1 = require("@decaf-ts/decorator-validation");
|
|
11
|
+
/**
|
|
12
|
+
* @summary retrieves the arguments for the handler
|
|
13
|
+
* @param {any} dec the decorator
|
|
14
|
+
* @param {string} prop the property name
|
|
15
|
+
* @param {{}} m the model
|
|
16
|
+
* @param {{}} [accum] accumulator used for internal recursiveness
|
|
17
|
+
*
|
|
18
|
+
* @function getHandlerArgs
|
|
19
|
+
* @memberOf module:db-decorators.Repository
|
|
20
|
+
*/
|
|
21
|
+
const getHandlerArgs = function (dec, prop, m, accum) {
|
|
22
|
+
const name = m.constructor.name;
|
|
23
|
+
if (!name)
|
|
24
|
+
throw new errors_1.InternalError("Could not determine model class");
|
|
25
|
+
accum = accum || {};
|
|
26
|
+
if (dec.props.handlers[name] && dec.props.handlers[name][prop])
|
|
27
|
+
accum = { ...dec.props.handlers[name][prop], ...accum };
|
|
28
|
+
let proto = Object.getPrototypeOf(m);
|
|
29
|
+
if (proto === Object.prototype)
|
|
30
|
+
return accum;
|
|
31
|
+
if (proto.constructor.name === name)
|
|
32
|
+
proto = Object.getPrototypeOf(proto);
|
|
33
|
+
return (0, exports.getHandlerArgs)(dec, prop, proto, accum);
|
|
34
|
+
};
|
|
35
|
+
exports.getHandlerArgs = getHandlerArgs;
|
|
36
|
+
/**
|
|
37
|
+
*
|
|
38
|
+
* @param {IRepository<T>} repo
|
|
39
|
+
* @param {T} model
|
|
40
|
+
* @param operation
|
|
41
|
+
* @param prefix
|
|
42
|
+
*
|
|
43
|
+
* @param oldModel
|
|
44
|
+
* @function enforceDBPropertyDecoratorsAsync
|
|
45
|
+
*
|
|
46
|
+
* @memberOf db-decorators.utils
|
|
47
|
+
*/
|
|
48
|
+
async function enforceDBDecorators(repo, model, operation, prefix, oldModel) {
|
|
49
|
+
const decorators = getDbDecorators(model, operation, prefix);
|
|
50
|
+
if (!decorators)
|
|
51
|
+
return;
|
|
52
|
+
for (const prop in decorators) {
|
|
53
|
+
const decs = decorators[prop];
|
|
54
|
+
for (const dec of decs) {
|
|
55
|
+
const { key } = dec;
|
|
56
|
+
const handlers = Operations_1.Operations.get(model, prop, prefix + key);
|
|
57
|
+
if (!handlers || !handlers.length)
|
|
58
|
+
throw new errors_1.InternalError(`Could not find registered handler for the operation ${prefix + key} under property ${prop}`);
|
|
59
|
+
const handlerArgs = (0, exports.getHandlerArgs)(dec, prop, model);
|
|
60
|
+
if (!handlerArgs || Object.values(handlerArgs).length !== handlers.length)
|
|
61
|
+
throw new errors_1.InternalError((0, decorator_validation_1.sf)("Args and handlers length do not match"));
|
|
62
|
+
let handler;
|
|
63
|
+
let data;
|
|
64
|
+
for (let i = 0; i < handlers.length; i++) {
|
|
65
|
+
handler = handlers[i];
|
|
66
|
+
data = Object.values(handlerArgs)[i];
|
|
67
|
+
const args = [data.data, prop, model];
|
|
68
|
+
if (operation === constants_1.OperationKeys.UPDATE) {
|
|
69
|
+
if (!oldModel)
|
|
70
|
+
throw new errors_1.InternalError("Missing old model for update operation");
|
|
71
|
+
args.push(oldModel);
|
|
72
|
+
}
|
|
73
|
+
await handler.apply(repo, args);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* Specific for DB Decorators
|
|
80
|
+
* @param {T} model
|
|
81
|
+
* @param {string} operation CRUD {@link OperationKeys}
|
|
82
|
+
* @param {string} [extraPrefix]
|
|
83
|
+
*
|
|
84
|
+
* @function getDbPropertyDecorators
|
|
85
|
+
*
|
|
86
|
+
* @memberOf db-decorators.utils
|
|
87
|
+
*/
|
|
88
|
+
function getDbDecorators(model, operation, extraPrefix) {
|
|
89
|
+
const decorators = (0, reflection_1.getAllPropertyDecorators)(model,
|
|
90
|
+
// undefined,
|
|
91
|
+
constants_1.OperationKeys.REFLECT + (extraPrefix ? extraPrefix : ""));
|
|
92
|
+
if (!decorators)
|
|
93
|
+
return;
|
|
94
|
+
return Object.keys(decorators).reduce((accum, decorator) => {
|
|
95
|
+
const dec = decorators[decorator].filter((d) => d.key === operation);
|
|
96
|
+
if (dec && dec.length) {
|
|
97
|
+
if (!accum)
|
|
98
|
+
accum = {};
|
|
99
|
+
accum[decorator] = dec;
|
|
100
|
+
}
|
|
101
|
+
return accum;
|
|
102
|
+
}, undefined);
|
|
103
|
+
}
|
|
104
|
+
/**
|
|
105
|
+
* @summary Retrieves the decorators for an object's properties prefixed by {@param prefixes} recursively
|
|
106
|
+
* @param model
|
|
107
|
+
* @param accum
|
|
108
|
+
* @param prefixes
|
|
109
|
+
*
|
|
110
|
+
* @function getAllPropertyDecoratorsRecursive
|
|
111
|
+
* @memberOf module:db-decorators.Repository
|
|
112
|
+
*/
|
|
113
|
+
const getAllPropertyDecoratorsRecursive = function (model, accum, ...prefixes) {
|
|
114
|
+
const accumulator = accum || {};
|
|
115
|
+
const mergeDecorators = function (decs) {
|
|
116
|
+
const pushOrSquash = (key, ...values) => {
|
|
117
|
+
values.forEach((val) => {
|
|
118
|
+
let match;
|
|
119
|
+
if (!(match = accumulator[key].find((e) => e.key === val.key)) ||
|
|
120
|
+
match.props.operation !== val.props.operation) {
|
|
121
|
+
accumulator[key].push(val);
|
|
122
|
+
return;
|
|
123
|
+
}
|
|
124
|
+
if (val.key === decorator_validation_1.ModelKeys.TYPE)
|
|
125
|
+
return;
|
|
126
|
+
const { handlers, operation } = val.props;
|
|
127
|
+
if (!operation ||
|
|
128
|
+
!operation.match(new RegExp(`^(:?${constants_1.OperationKeys.ON}|${constants_1.OperationKeys.AFTER})(:?${constants_1.OperationKeys.CREATE}|${constants_1.OperationKeys.READ}|${constants_1.OperationKeys.UPDATE}|${constants_1.OperationKeys.DELETE})$`))) {
|
|
129
|
+
accumulator[key].push(val);
|
|
130
|
+
return;
|
|
131
|
+
}
|
|
132
|
+
const accumHandlers = match.props.handlers;
|
|
133
|
+
Object.entries(handlers).forEach(([clazz, handlerDef]) => {
|
|
134
|
+
if (!(clazz in accumHandlers)) {
|
|
135
|
+
accumHandlers[clazz] = handlerDef;
|
|
136
|
+
return;
|
|
137
|
+
}
|
|
138
|
+
Object.entries(handlerDef).forEach(([handlerProp, handler]) => {
|
|
139
|
+
if (!(handlerProp in accumHandlers[clazz])) {
|
|
140
|
+
accumHandlers[clazz][handlerProp] = handler;
|
|
141
|
+
return;
|
|
142
|
+
}
|
|
143
|
+
Object.entries(handler).forEach(([handlerKey, argsObj]) => {
|
|
144
|
+
if (!(handlerKey in accumHandlers[clazz][handlerProp])) {
|
|
145
|
+
accumHandlers[clazz][handlerProp][handlerKey] = argsObj;
|
|
146
|
+
return;
|
|
147
|
+
}
|
|
148
|
+
console.warn((0, decorator_validation_1.sf)("Skipping handler registration for {0} under prop {0} because handler is the same", clazz, handlerProp));
|
|
149
|
+
});
|
|
150
|
+
});
|
|
151
|
+
});
|
|
152
|
+
});
|
|
153
|
+
};
|
|
154
|
+
Object.entries(decs).forEach(([key, value]) => {
|
|
155
|
+
accumulator[key] = accumulator[key] || [];
|
|
156
|
+
pushOrSquash(key, ...value);
|
|
157
|
+
});
|
|
158
|
+
};
|
|
159
|
+
const decs = (0, reflection_1.getAllPropertyDecorators)(model, ...prefixes);
|
|
160
|
+
if (decs)
|
|
161
|
+
mergeDecorators(decs);
|
|
162
|
+
if (Object.getPrototypeOf(model) === Object.prototype)
|
|
163
|
+
return accumulator;
|
|
164
|
+
// const name = model.constructor.name;
|
|
165
|
+
const proto = Object.getPrototypeOf(model);
|
|
166
|
+
if (!proto)
|
|
167
|
+
return accumulator;
|
|
168
|
+
// if (proto.constructor && proto.constructor.name === name)
|
|
169
|
+
// proto = Object.getPrototypeOf(proto)
|
|
170
|
+
return (0, exports.getAllPropertyDecoratorsRecursive)(proto, accumulator, ...prefixes);
|
|
171
|
+
};
|
|
172
|
+
exports.getAllPropertyDecoratorsRecursive = getAllPropertyDecoratorsRecursive;
|
|
173
|
+
|
|
174
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["src/repository/utils.ts"],"names":[],"mappings":"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","file":"repository/utils.js","sourcesContent":["import { Operations } from \"../operations/Operations\";\nimport { OperationHandler, UpdateOperationHandler } from \"../operations/types\";\nimport { IRepository } from \"../interfaces/IRepository\";\nimport { OperationKeys } from \"../operations/constants\";\nimport {\n  DecoratorMetadata,\n  getAllPropertyDecorators,\n} from \"@decaf-ts/reflection\";\nimport { InternalError } from \"./errors\";\nimport { Constructor, ModelKeys, sf } from \"@decaf-ts/decorator-validation\";\n\n/**\n * @summary retrieves the arguments for the handler\n * @param {any} dec the decorator\n * @param {string} prop the property name\n * @param {{}} m the model\n * @param {{}} [accum] accumulator used for internal recursiveness\n *\n * @function getHandlerArgs\n * @memberOf module:db-decorators.Repository\n */\nexport const getHandlerArgs = function (\n  dec: any,\n  prop: string,\n  m: Constructor<any>,\n  accum?: Record<string, { args: string[] }>\n): Record<string, { args: string[] }> | void {\n  const name = m.constructor.name;\n  if (!name) throw new InternalError(\"Could not determine model class\");\n  accum = accum || {};\n\n  if (dec.props.handlers[name] && dec.props.handlers[name][prop])\n    accum = { ...dec.props.handlers[name][prop], ...accum };\n\n  let proto = Object.getPrototypeOf(m);\n  if (proto === Object.prototype) return accum;\n  if (proto.constructor.name === name) proto = Object.getPrototypeOf(proto);\n\n  return getHandlerArgs(dec, prop, proto, accum);\n};\n\n/**\n *\n * @param {IRepository<T>} repo\n * @param {T} model\n * @param operation\n * @param prefix\n *\n * @param oldModel\n * @function enforceDBPropertyDecoratorsAsync\n *\n * @memberOf db-decorators.utils\n */\nexport async function enforceDBDecorators<\n  T extends Model,\n  Y extends IRepository<T>,\n  V,\n>(\n  repo: Y,\n  model: T,\n  operation: string,\n  prefix: string,\n  oldModel?: T\n): Promise<void> {\n  const decorators: Record<string, DecoratorMetadata[]> | undefined =\n    getDbDecorators(model, operation, prefix);\n\n  if (!decorators) return;\n\n  for (const prop in decorators) {\n    const decs: DecoratorMetadata[] = decorators[prop];\n    for (const dec of decs) {\n      const { key } = dec;\n      const handlers: OperationHandler<T, Y, V>[] | undefined = Operations.get(\n        model,\n        prop,\n        prefix + key\n      );\n      if (!handlers || !handlers.length)\n        throw new InternalError(\n          `Could not find registered handler for the operation ${prefix + key} under property ${prop}`\n        );\n\n      const handlerArgs = getHandlerArgs(dec, prop, model as any);\n\n      if (!handlerArgs || Object.values(handlerArgs).length !== handlers.length)\n        throw new InternalError(sf(\"Args and handlers length do not match\"));\n\n      let handler: OperationHandler<any, any, any>;\n      let data: any;\n      for (let i = 0; i < handlers.length; i++) {\n        handler = handlers[i];\n        data = Object.values(handlerArgs)[i];\n\n        const args: any[] = [data.data, prop, model];\n\n        if (operation === OperationKeys.UPDATE) {\n          if (!oldModel)\n            throw new InternalError(\"Missing old model for update operation\");\n          args.push(oldModel);\n        }\n        await (handler as UpdateOperationHandler<T, Y, V>).apply(\n          repo,\n          args as [V, any, T, T]\n        );\n      }\n    }\n  }\n}\n\n/**\n * Specific for DB Decorators\n * @param {T} model\n * @param {string} operation CRUD {@link OperationKeys}\n * @param {string} [extraPrefix]\n *\n * @function getDbPropertyDecorators\n *\n * @memberOf db-decorators.utils\n */\nexport function getDbDecorators<T extends Model>(\n  model: T,\n  operation: string,\n  extraPrefix?: string\n): Record<string, DecoratorMetadata[]> | undefined {\n  const decorators: Record<string, DecoratorMetadata[]> | undefined =\n    getAllPropertyDecorators(\n      model,\n      // undefined,\n      OperationKeys.REFLECT + (extraPrefix ? extraPrefix : \"\")\n    );\n  if (!decorators) return;\n  return Object.keys(decorators).reduce(\n    (accum: Record<string, DecoratorMetadata[]> | undefined, decorator) => {\n      const dec = decorators[decorator].filter((d) => d.key === operation);\n      if (dec && dec.length) {\n        if (!accum) accum = {};\n        accum[decorator] = dec;\n      }\n      return accum;\n    },\n    undefined\n  );\n}\n\n/**\n * @summary Retrieves the decorators for an object's properties prefixed by {@param prefixes} recursively\n * @param model\n * @param accum\n * @param prefixes\n *\n * @function getAllPropertyDecoratorsRecursive\n * @memberOf module:db-decorators.Repository\n */\nexport const getAllPropertyDecoratorsRecursive = function <T extends Model>(\n  model: T,\n  accum: { [indexer: string]: any[] } | undefined,\n  ...prefixes: string[]\n): { [indexer: string]: any[] } | undefined {\n  const accumulator = accum || {};\n  const mergeDecorators = function (decs: { [indexer: string]: any[] }) {\n    const pushOrSquash = (key: string, ...values: any[]) => {\n      values.forEach((val) => {\n        let match: any;\n        if (\n          !(match = accumulator[key].find((e) => e.key === val.key)) ||\n          match.props.operation !== val.props.operation\n        ) {\n          accumulator[key].push(val);\n          return;\n        }\n\n        if (val.key === ModelKeys.TYPE) return;\n\n        const { handlers, operation } = val.props;\n\n        if (\n          !operation ||\n          !operation.match(\n            new RegExp(\n              `^(:?${OperationKeys.ON}|${OperationKeys.AFTER})(:?${OperationKeys.CREATE}|${OperationKeys.READ}|${OperationKeys.UPDATE}|${OperationKeys.DELETE})$`\n            )\n          )\n        ) {\n          accumulator[key].push(val);\n          return;\n        }\n\n        const accumHandlers = match.props.handlers;\n\n        Object.entries(handlers).forEach(([clazz, handlerDef]) => {\n          if (!(clazz in accumHandlers)) {\n            accumHandlers[clazz] = handlerDef;\n            return;\n          }\n\n          Object.entries(handlerDef as object).forEach(\n            ([handlerProp, handler]) => {\n              if (!(handlerProp in accumHandlers[clazz])) {\n                accumHandlers[clazz][handlerProp] = handler;\n                return;\n              }\n\n              Object.entries(handler as object).forEach(\n                ([handlerKey, argsObj]) => {\n                  if (!(handlerKey in accumHandlers[clazz][handlerProp])) {\n                    accumHandlers[clazz][handlerProp][handlerKey] = argsObj;\n                    return;\n                  }\n                  console.warn(\n                    sf(\n                      \"Skipping handler registration for {0} under prop {0} because handler is the same\",\n                      clazz,\n                      handlerProp\n                    )\n                  );\n                }\n              );\n            }\n          );\n        });\n      });\n    };\n\n    Object.entries(decs).forEach(([key, value]) => {\n      accumulator[key] = accumulator[key] || [];\n      pushOrSquash(key, ...value);\n    });\n  };\n\n  const decs: { [indexer: string]: any[] } | undefined =\n    getAllPropertyDecorators(model, ...prefixes);\n  if (decs) mergeDecorators(decs);\n\n  if (Object.getPrototypeOf(model) === Object.prototype) return accumulator;\n\n  // const name = model.constructor.name;\n  const proto = Object.getPrototypeOf(model);\n  if (!proto) return accumulator;\n  // if (proto.constructor && proto.constructor.name === name)\n  //     proto = Object.getPrototypeOf(proto)\n  return getAllPropertyDecoratorsRecursive(proto, accumulator, ...prefixes);\n};\n"]}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { DBModel } from "../model/DBModel";
|
|
2
1
|
import { IRepository } from "../interfaces/IRepository";
|
|
3
2
|
import { DecoratorMetadata } from "@decaf-ts/reflection";
|
|
4
3
|
import { Constructor } from "@decaf-ts/decorator-validation";
|
|
@@ -29,7 +28,7 @@ export declare const getHandlerArgs: (dec: any, prop: string, m: Constructor<any
|
|
|
29
28
|
*
|
|
30
29
|
* @memberOf db-decorators.utils
|
|
31
30
|
*/
|
|
32
|
-
export declare function enforceDBDecorators<T extends
|
|
31
|
+
export declare function enforceDBDecorators<T extends Model, Y extends IRepository<T>, V>(repo: Y, model: T, operation: string, prefix: string, oldModel?: T): Promise<void>;
|
|
33
32
|
/**
|
|
34
33
|
* Specific for DB Decorators
|
|
35
34
|
* @param {T} model
|
|
@@ -40,7 +39,7 @@ export declare function enforceDBDecorators<T extends DBModel, Y extends IReposi
|
|
|
40
39
|
*
|
|
41
40
|
* @memberOf db-decorators.utils
|
|
42
41
|
*/
|
|
43
|
-
export declare function getDbDecorators<T extends
|
|
42
|
+
export declare function getDbDecorators<T extends Model>(model: T, operation: string, extraPrefix?: string): Record<string, DecoratorMetadata[]> | undefined;
|
|
44
43
|
/**
|
|
45
44
|
* @summary Retrieves the decorators for an object's properties prefixed by {@param prefixes} recursively
|
|
46
45
|
* @param model
|
|
@@ -50,7 +49,7 @@ export declare function getDbDecorators<T extends DBModel>(model: T, operation:
|
|
|
50
49
|
* @function getAllPropertyDecoratorsRecursive
|
|
51
50
|
* @memberOf module:db-decorators.Repository
|
|
52
51
|
*/
|
|
53
|
-
export declare const getAllPropertyDecoratorsRecursive: <T extends
|
|
52
|
+
export declare const getAllPropertyDecoratorsRecursive: <T extends Model>(model: T, accum: {
|
|
54
53
|
[indexer: string]: any[];
|
|
55
54
|
} | undefined, ...prefixes: string[]) => {
|
|
56
55
|
[indexer: string]: any[];
|
|
@@ -1 +1,95 @@
|
|
|
1
|
-
"use strict";
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.prefixMethod = prefixMethod;
|
|
4
|
+
exports.suffixMethod = suffixMethod;
|
|
5
|
+
exports.wrapMethod = wrapMethod;
|
|
6
|
+
/**
|
|
7
|
+
* @summary Util method to change a method of an object prefixing it with another
|
|
8
|
+
* @param {any} obj The Base Object
|
|
9
|
+
* @param {Function} after The original method
|
|
10
|
+
* @param {Function} prefix The Prefix method. The output will be used as arguments in the original method
|
|
11
|
+
* @param {string} [afterName] When the after function anme cannot be extracted, pass it here
|
|
12
|
+
*
|
|
13
|
+
* @function prefixMethod
|
|
14
|
+
*
|
|
15
|
+
* @memberOf module:db-decorators.Repository
|
|
16
|
+
*/
|
|
17
|
+
function prefixMethod(obj, after, prefix, afterName) {
|
|
18
|
+
async function wrapper(...args) {
|
|
19
|
+
const results = await Promise.resolve(prefix.call(this, ...args));
|
|
20
|
+
return Promise.resolve(after.apply(this, results));
|
|
21
|
+
}
|
|
22
|
+
const wrapped = wrapper.bind(obj);
|
|
23
|
+
const name = afterName ? afterName : after.name;
|
|
24
|
+
Object.defineProperty(wrapped, "name", {
|
|
25
|
+
enumerable: true,
|
|
26
|
+
configurable: true,
|
|
27
|
+
writable: false,
|
|
28
|
+
value: name,
|
|
29
|
+
});
|
|
30
|
+
obj[name] = wrapped;
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* @summary Util method to change a method of an object suffixing it with another
|
|
34
|
+
* @param {any} obj The Base Object
|
|
35
|
+
* @param {Function} before The original method
|
|
36
|
+
* @param {Function} suffix The Prefix method. The output will be used as arguments in the original method
|
|
37
|
+
* @param {string} [beforeName] When the after function anme cannot be extracted, pass it here
|
|
38
|
+
*
|
|
39
|
+
* @function suffixMethod
|
|
40
|
+
*
|
|
41
|
+
* @memberOf module:db-decorators.Repository
|
|
42
|
+
*/
|
|
43
|
+
function suffixMethod(obj, before, suffix, beforeName) {
|
|
44
|
+
async function wrapper(...args) {
|
|
45
|
+
const results = await Promise.resolve(before.call(this, ...args));
|
|
46
|
+
return suffix.call(this, ...results);
|
|
47
|
+
}
|
|
48
|
+
const wrapped = wrapper.bind(obj);
|
|
49
|
+
const name = beforeName ? beforeName : before.name;
|
|
50
|
+
Object.defineProperty(wrapped, "name", {
|
|
51
|
+
enumerable: true,
|
|
52
|
+
configurable: true,
|
|
53
|
+
writable: false,
|
|
54
|
+
value: name,
|
|
55
|
+
});
|
|
56
|
+
obj[name] = wrapped;
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* @summary Util method to wrap a method of an object with additional logic
|
|
60
|
+
*
|
|
61
|
+
* @param {any} obj The Base Object
|
|
62
|
+
* @param {Function} before the method to be prefixed
|
|
63
|
+
* @param {Function} method the method to be wrapped
|
|
64
|
+
* @param {Function} after The method to be suffixed
|
|
65
|
+
* @param {string} [methodName] When the after function anme cannot be extracted, pass it here
|
|
66
|
+
*
|
|
67
|
+
* @function wrapMethod
|
|
68
|
+
*
|
|
69
|
+
* @memberOf module:db-decorators.Repository
|
|
70
|
+
*/
|
|
71
|
+
function wrapMethod(obj, before, method, after, methodName) {
|
|
72
|
+
async function wrapper(...args) {
|
|
73
|
+
let transformedArgs = before.call(obj, ...args);
|
|
74
|
+
if (transformedArgs instanceof Promise)
|
|
75
|
+
transformedArgs = await transformedArgs;
|
|
76
|
+
let results = await method.call(obj, ...transformedArgs);
|
|
77
|
+
if (results instanceof Promise)
|
|
78
|
+
results = await results;
|
|
79
|
+
results = after.call(this, results);
|
|
80
|
+
if (results instanceof Promise)
|
|
81
|
+
results = await results;
|
|
82
|
+
return results;
|
|
83
|
+
}
|
|
84
|
+
const wrapped = wrapper.bind(obj);
|
|
85
|
+
const name = methodName ? methodName : method.name;
|
|
86
|
+
Object.defineProperty(wrapped, "name", {
|
|
87
|
+
enumerable: true,
|
|
88
|
+
configurable: true,
|
|
89
|
+
writable: false,
|
|
90
|
+
value: name,
|
|
91
|
+
});
|
|
92
|
+
obj[name] = wrapped;
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9yZXBvc2l0b3J5L3dyYXBwZXJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBV0Esb0NBbUJDO0FBYUQsb0NBbUJDO0FBZUQsZ0NBMEJDO0FBdkdEOzs7Ozs7Ozs7O0dBVUc7QUFDSCxTQUFnQixZQUFZLENBQzFCLEdBQVEsRUFDUixLQUE4QixFQUM5QixNQUErQixFQUMvQixTQUFrQjtJQUVsQixLQUFLLFVBQVUsT0FBTyxDQUFZLEdBQUcsSUFBVztRQUM5QyxNQUFNLE9BQU8sR0FBRyxNQUFNLE9BQU8sQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsR0FBRyxJQUFJLENBQUMsQ0FBQyxDQUFDO1FBQ2xFLE9BQU8sT0FBTyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxPQUFPLENBQUMsQ0FBQyxDQUFDO0lBQ3JELENBQUM7SUFDRCxNQUFNLE9BQU8sR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ2xDLE1BQU0sSUFBSSxHQUFHLFNBQVMsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDO0lBQ2hELE1BQU0sQ0FBQyxjQUFjLENBQUMsT0FBTyxFQUFFLE1BQU0sRUFBRTtRQUNyQyxVQUFVLEVBQUUsSUFBSTtRQUNoQixZQUFZLEVBQUUsSUFBSTtRQUNsQixRQUFRLEVBQUUsS0FBSztRQUNmLEtBQUssRUFBRSxJQUFJO0tBQ1osQ0FBQyxDQUFDO0lBQ0gsR0FBRyxDQUFDLElBQUksQ0FBQyxHQUFHLE9BQU8sQ0FBQztBQUN0QixDQUFDO0FBRUQ7Ozs7Ozs7Ozs7R0FVRztBQUNILFNBQWdCLFlBQVksQ0FDMUIsR0FBUSxFQUNSLE1BQStCLEVBQy9CLE1BQStCLEVBQy9CLFVBQW1CO0lBRW5CLEtBQUssVUFBVSxPQUFPLENBQVksR0FBRyxJQUFXO1FBQzlDLE1BQU0sT0FBTyxHQUFHLE1BQU0sT0FBTyxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxHQUFHLElBQUksQ0FBQyxDQUFDLENBQUM7UUFDbEUsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxHQUFHLE9BQU8sQ0FBQyxDQUFDO0lBQ3ZDLENBQUM7SUFDRCxNQUFNLE9BQU8sR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ2xDLE1BQU0sSUFBSSxHQUFHLFVBQVUsQ0FBQyxDQUFDLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDO0lBQ25ELE1BQU0sQ0FBQyxjQUFjLENBQUMsT0FBTyxFQUFFLE1BQU0sRUFBRTtRQUNyQyxVQUFVLEVBQUUsSUFBSTtRQUNoQixZQUFZLEVBQUUsSUFBSTtRQUNsQixRQUFRLEVBQUUsS0FBSztRQUNmLEtBQUssRUFBRSxJQUFJO0tBQ1osQ0FBQyxDQUFDO0lBQ0gsR0FBRyxDQUFDLElBQUksQ0FBQyxHQUFHLE9BQU8sQ0FBQztBQUN0QixDQUFDO0FBRUQ7Ozs7Ozs7Ozs7OztHQVlHO0FBQ0gsU0FBZ0IsVUFBVSxDQUN4QixHQUFRLEVBQ1IsTUFBK0IsRUFDL0IsTUFBK0IsRUFDL0IsS0FBOEIsRUFDOUIsVUFBbUI7SUFFbkIsS0FBSyxVQUFVLE9BQU8sQ0FBWSxHQUFHLElBQVc7UUFDOUMsSUFBSSxlQUFlLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsR0FBRyxJQUFJLENBQUMsQ0FBQztRQUNoRCxJQUFJLGVBQWUsWUFBWSxPQUFPO1lBQ3BDLGVBQWUsR0FBRyxNQUFNLGVBQWUsQ0FBQztRQUMxQyxJQUFJLE9BQU8sR0FBRyxNQUFNLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFLEdBQUcsZUFBZSxDQUFDLENBQUM7UUFDekQsSUFBSSxPQUFPLFlBQVksT0FBTztZQUFFLE9BQU8sR0FBRyxNQUFNLE9BQU8sQ0FBQztRQUN4RCxPQUFPLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDcEMsSUFBSSxPQUFPLFlBQVksT0FBTztZQUFFLE9BQU8sR0FBRyxNQUFNLE9BQU8sQ0FBQztRQUN4RCxPQUFPLE9BQU8sQ0FBQztJQUNqQixDQUFDO0lBQ0QsTUFBTSxPQUFPLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNsQyxNQUFNLElBQUksR0FBRyxVQUFVLENBQUMsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQztJQUNuRCxNQUFNLENBQUMsY0FBYyxDQUFDLE9BQU8sRUFBRSxNQUFNLEVBQUU7UUFDckMsVUFBVSxFQUFFLElBQUk7UUFDaEIsWUFBWSxFQUFFLElBQUk7UUFDbEIsUUFBUSxFQUFFLEtBQUs7UUFDZixLQUFLLEVBQUUsSUFBSTtLQUNaLENBQUMsQ0FBQztJQUNILEdBQUcsQ0FBQyxJQUFJLENBQUMsR0FBRyxPQUFPLENBQUM7QUFDdEIsQ0FBQyIsImZpbGUiOiJyZXBvc2l0b3J5L3dyYXBwZXJzLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAc3VtbWFyeSBVdGlsIG1ldGhvZCB0byBjaGFuZ2UgYSBtZXRob2Qgb2YgYW4gb2JqZWN0IHByZWZpeGluZyBpdCB3aXRoIGFub3RoZXJcbiAqIEBwYXJhbSB7YW55fSBvYmogVGhlIEJhc2UgT2JqZWN0XG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBhZnRlciBUaGUgb3JpZ2luYWwgbWV0aG9kXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBwcmVmaXggVGhlIFByZWZpeCBtZXRob2QuIFRoZSBvdXRwdXQgd2lsbCBiZSB1c2VkIGFzIGFyZ3VtZW50cyBpbiB0aGUgb3JpZ2luYWwgbWV0aG9kXG4gKiBAcGFyYW0ge3N0cmluZ30gW2FmdGVyTmFtZV0gV2hlbiB0aGUgYWZ0ZXIgZnVuY3Rpb24gYW5tZSBjYW5ub3QgYmUgZXh0cmFjdGVkLCBwYXNzIGl0IGhlcmVcbiAqXG4gKiBAZnVuY3Rpb24gcHJlZml4TWV0aG9kXG4gKlxuICogQG1lbWJlck9mIG1vZHVsZTpkYi1kZWNvcmF0b3JzLlJlcG9zaXRvcnlcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHByZWZpeE1ldGhvZChcbiAgb2JqOiBhbnksXG4gIGFmdGVyOiAoLi4uYXJnczogYW55W10pID0+IGFueSxcbiAgcHJlZml4OiAoLi4uYXJnczogYW55W10pID0+IGFueSxcbiAgYWZ0ZXJOYW1lPzogc3RyaW5nLFxuKSB7XG4gIGFzeW5jIGZ1bmN0aW9uIHdyYXBwZXIodGhpczogYW55LCAuLi5hcmdzOiBhbnlbXSkge1xuICAgIGNvbnN0IHJlc3VsdHMgPSBhd2FpdCBQcm9taXNlLnJlc29sdmUocHJlZml4LmNhbGwodGhpcywgLi4uYXJncykpO1xuICAgIHJldHVybiBQcm9taXNlLnJlc29sdmUoYWZ0ZXIuYXBwbHkodGhpcywgcmVzdWx0cykpO1xuICB9XG4gIGNvbnN0IHdyYXBwZWQgPSB3cmFwcGVyLmJpbmQob2JqKTtcbiAgY29uc3QgbmFtZSA9IGFmdGVyTmFtZSA/IGFmdGVyTmFtZSA6IGFmdGVyLm5hbWU7XG4gIE9iamVjdC5kZWZpbmVQcm9wZXJ0eSh3cmFwcGVkLCBcIm5hbWVcIiwge1xuICAgIGVudW1lcmFibGU6IHRydWUsXG4gICAgY29uZmlndXJhYmxlOiB0cnVlLFxuICAgIHdyaXRhYmxlOiBmYWxzZSxcbiAgICB2YWx1ZTogbmFtZSxcbiAgfSk7XG4gIG9ialtuYW1lXSA9IHdyYXBwZWQ7XG59XG5cbi8qKlxuICogQHN1bW1hcnkgVXRpbCBtZXRob2QgdG8gY2hhbmdlIGEgbWV0aG9kIG9mIGFuIG9iamVjdCBzdWZmaXhpbmcgaXQgd2l0aCBhbm90aGVyXG4gKiBAcGFyYW0ge2FueX0gb2JqIFRoZSBCYXNlIE9iamVjdFxuICogQHBhcmFtIHtGdW5jdGlvbn0gYmVmb3JlIFRoZSBvcmlnaW5hbCBtZXRob2RcbiAqIEBwYXJhbSB7RnVuY3Rpb259IHN1ZmZpeCBUaGUgUHJlZml4IG1ldGhvZC4gVGhlIG91dHB1dCB3aWxsIGJlIHVzZWQgYXMgYXJndW1lbnRzIGluIHRoZSBvcmlnaW5hbCBtZXRob2RcbiAqIEBwYXJhbSB7c3RyaW5nfSBbYmVmb3JlTmFtZV0gV2hlbiB0aGUgYWZ0ZXIgZnVuY3Rpb24gYW5tZSBjYW5ub3QgYmUgZXh0cmFjdGVkLCBwYXNzIGl0IGhlcmVcbiAqXG4gKiBAZnVuY3Rpb24gc3VmZml4TWV0aG9kXG4gKlxuICogQG1lbWJlck9mIG1vZHVsZTpkYi1kZWNvcmF0b3JzLlJlcG9zaXRvcnlcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHN1ZmZpeE1ldGhvZChcbiAgb2JqOiBhbnksXG4gIGJlZm9yZTogKC4uLmFyZ3M6IGFueVtdKSA9PiBhbnksXG4gIHN1ZmZpeDogKC4uLmFyZ3M6IGFueVtdKSA9PiBhbnksXG4gIGJlZm9yZU5hbWU/OiBzdHJpbmcsXG4pIHtcbiAgYXN5bmMgZnVuY3Rpb24gd3JhcHBlcih0aGlzOiBhbnksIC4uLmFyZ3M6IGFueVtdKSB7XG4gICAgY29uc3QgcmVzdWx0cyA9IGF3YWl0IFByb21pc2UucmVzb2x2ZShiZWZvcmUuY2FsbCh0aGlzLCAuLi5hcmdzKSk7XG4gICAgcmV0dXJuIHN1ZmZpeC5jYWxsKHRoaXMsIC4uLnJlc3VsdHMpO1xuICB9XG4gIGNvbnN0IHdyYXBwZWQgPSB3cmFwcGVyLmJpbmQob2JqKTtcbiAgY29uc3QgbmFtZSA9IGJlZm9yZU5hbWUgPyBiZWZvcmVOYW1lIDogYmVmb3JlLm5hbWU7XG4gIE9iamVjdC5kZWZpbmVQcm9wZXJ0eSh3cmFwcGVkLCBcIm5hbWVcIiwge1xuICAgIGVudW1lcmFibGU6IHRydWUsXG4gICAgY29uZmlndXJhYmxlOiB0cnVlLFxuICAgIHdyaXRhYmxlOiBmYWxzZSxcbiAgICB2YWx1ZTogbmFtZSxcbiAgfSk7XG4gIG9ialtuYW1lXSA9IHdyYXBwZWQ7XG59XG5cbi8qKlxuICogQHN1bW1hcnkgVXRpbCBtZXRob2QgdG8gd3JhcCBhIG1ldGhvZCBvZiBhbiBvYmplY3Qgd2l0aCBhZGRpdGlvbmFsIGxvZ2ljXG4gKlxuICogQHBhcmFtIHthbnl9IG9iaiBUaGUgQmFzZSBPYmplY3RcbiAqIEBwYXJhbSB7RnVuY3Rpb259IGJlZm9yZSB0aGUgbWV0aG9kIHRvIGJlIHByZWZpeGVkXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBtZXRob2QgdGhlIG1ldGhvZCB0byBiZSB3cmFwcGVkXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBhZnRlciBUaGUgbWV0aG9kIHRvIGJlIHN1ZmZpeGVkXG4gKiBAcGFyYW0ge3N0cmluZ30gW21ldGhvZE5hbWVdIFdoZW4gdGhlIGFmdGVyIGZ1bmN0aW9uIGFubWUgY2Fubm90IGJlIGV4dHJhY3RlZCwgcGFzcyBpdCBoZXJlXG4gKlxuICogQGZ1bmN0aW9uIHdyYXBNZXRob2RcbiAqXG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRiLWRlY29yYXRvcnMuUmVwb3NpdG9yeVxuICovXG5leHBvcnQgZnVuY3Rpb24gd3JhcE1ldGhvZChcbiAgb2JqOiBhbnksXG4gIGJlZm9yZTogKC4uLmFyZ3M6IGFueVtdKSA9PiBhbnksXG4gIG1ldGhvZDogKC4uLmFyZ3M6IGFueVtdKSA9PiBhbnksXG4gIGFmdGVyOiAoLi4uYXJnczogYW55W10pID0+IGFueSxcbiAgbWV0aG9kTmFtZT86IHN0cmluZyxcbikge1xuICBhc3luYyBmdW5jdGlvbiB3cmFwcGVyKHRoaXM6IGFueSwgLi4uYXJnczogYW55W10pIHtcbiAgICBsZXQgdHJhbnNmb3JtZWRBcmdzID0gYmVmb3JlLmNhbGwob2JqLCAuLi5hcmdzKTtcbiAgICBpZiAodHJhbnNmb3JtZWRBcmdzIGluc3RhbmNlb2YgUHJvbWlzZSlcbiAgICAgIHRyYW5zZm9ybWVkQXJncyA9IGF3YWl0IHRyYW5zZm9ybWVkQXJncztcbiAgICBsZXQgcmVzdWx0cyA9IGF3YWl0IG1ldGhvZC5jYWxsKG9iaiwgLi4udHJhbnNmb3JtZWRBcmdzKTtcbiAgICBpZiAocmVzdWx0cyBpbnN0YW5jZW9mIFByb21pc2UpIHJlc3VsdHMgPSBhd2FpdCByZXN1bHRzO1xuICAgIHJlc3VsdHMgPSBhZnRlci5jYWxsKHRoaXMsIHJlc3VsdHMpO1xuICAgIGlmIChyZXN1bHRzIGluc3RhbmNlb2YgUHJvbWlzZSkgcmVzdWx0cyA9IGF3YWl0IHJlc3VsdHM7XG4gICAgcmV0dXJuIHJlc3VsdHM7XG4gIH1cbiAgY29uc3Qgd3JhcHBlZCA9IHdyYXBwZXIuYmluZChvYmopO1xuICBjb25zdCBuYW1lID0gbWV0aG9kTmFtZSA/IG1ldGhvZE5hbWUgOiBtZXRob2QubmFtZTtcbiAgT2JqZWN0LmRlZmluZVByb3BlcnR5KHdyYXBwZWQsIFwibmFtZVwiLCB7XG4gICAgZW51bWVyYWJsZTogdHJ1ZSxcbiAgICBjb25maWd1cmFibGU6IHRydWUsXG4gICAgd3JpdGFibGU6IGZhbHNlLFxuICAgIHZhbHVlOiBuYW1lLFxuICB9KTtcbiAgb2JqW25hbWVdID0gd3JhcHBlZDtcbn1cbiJdfQ==
|