@decaf-ts/core 0.2.1 → 0.3.0
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/dist/core.bundle.min.js +1 -1
- package/dist/esm/core.bundle.min.esm.js +1 -1
- package/lib/esm/identity/decorators.d.ts +2 -1
- package/lib/esm/identity/decorators.js +2 -2
- package/lib/esm/identity/index.d.ts +1 -0
- package/lib/esm/identity/index.js +2 -1
- package/lib/esm/identity/utils.d.ts +2 -2
- package/lib/esm/identity/utils.js +1 -1
- package/lib/esm/index.d.ts +1 -1
- package/lib/esm/index.js +2 -2
- package/lib/esm/interfaces/index.d.ts +0 -1
- package/lib/esm/interfaces/index.js +1 -2
- package/lib/esm/model/BaseModel.d.ts +2 -2
- package/lib/esm/model/BaseModel.js +1 -3
- package/lib/esm/model/construction.d.ts +15 -0
- package/lib/esm/model/construction.js +201 -0
- package/lib/esm/model/decorators.d.ts +45 -1
- package/lib/esm/model/decorators.js +79 -3
- package/lib/esm/model/types.d.ts +6 -0
- package/lib/esm/model/types.js +3 -0
- package/lib/esm/persistence/Adapter.d.ts +2 -1
- package/lib/esm/persistence/Adapter.js +4 -1
- package/lib/esm/persistence/Sequence.d.ts +22 -0
- package/lib/esm/persistence/Sequence.js +11 -0
- package/lib/esm/persistence/constants.d.ts +5 -1
- package/lib/esm/persistence/constants.js +6 -1
- package/lib/esm/persistence/index.d.ts +1 -0
- package/lib/esm/persistence/index.js +2 -1
- package/lib/esm/repository/Repository.d.ts +2 -3
- package/lib/esm/repository/Repository.js +51 -45
- package/lib/esm/repository/decorators.js +2 -2
- package/lib/esm/repository/injectables.js +3 -1
- package/lib/identity/decorators.cjs +2 -2
- package/lib/identity/decorators.d.ts +2 -1
- package/lib/identity/index.cjs +2 -1
- package/lib/identity/index.d.ts +1 -0
- package/lib/identity/utils.cjs +1 -1
- package/lib/identity/utils.d.ts +2 -2
- package/lib/index.cjs +2 -2
- package/lib/index.d.ts +1 -1
- package/lib/interfaces/index.cjs +1 -2
- package/lib/interfaces/index.d.ts +0 -1
- package/lib/model/BaseModel.cjs +1 -3
- package/lib/model/BaseModel.d.ts +2 -2
- package/lib/model/construction.cjs +214 -0
- package/lib/model/construction.d.ts +15 -0
- package/lib/model/decorators.cjs +80 -1
- package/lib/model/decorators.d.ts +45 -1
- package/lib/model/types.cjs +4 -0
- package/lib/model/types.d.ts +6 -0
- package/lib/persistence/Adapter.cjs +4 -1
- package/lib/persistence/Adapter.d.ts +2 -1
- package/lib/persistence/Sequence.cjs +15 -0
- package/lib/persistence/Sequence.d.ts +22 -0
- package/lib/persistence/constants.cjs +6 -1
- package/lib/persistence/constants.d.ts +5 -1
- package/lib/persistence/index.cjs +2 -1
- package/lib/persistence/index.d.ts +1 -0
- package/lib/repository/Repository.cjs +50 -44
- package/lib/repository/Repository.d.ts +2 -3
- package/lib/repository/decorators.cjs +2 -2
- package/lib/repository/injectables.cjs +3 -1
- package/package.json +1 -1
- package/lib/esm/interfaces/Sequence.d.ts +0 -17
- package/lib/esm/interfaces/Sequence.js +0 -10
- package/lib/interfaces/Sequence.cjs +0 -11
- package/lib/interfaces/Sequence.d.ts +0 -17
@@ -16,6 +16,8 @@ export class InjectablesRegistry extends InjectableRegistryImp {
|
|
16
16
|
if (m)
|
17
17
|
injectable = Repository.forModel(m);
|
18
18
|
if (injectable) {
|
19
|
+
if (injectable instanceof Repository)
|
20
|
+
return injectable;
|
19
21
|
const flavour = Reflect.getMetadata(Adapter.key(PersistenceKeys.ADAPTER), injectable.constructor) ||
|
20
22
|
Reflect.getMetadata(Adapter.key(PersistenceKeys.ADAPTER), m);
|
21
23
|
Injectables.register(injectable, generateInjectableNameForRepository(m, flavour));
|
@@ -29,4 +31,4 @@ export class InjectablesRegistry extends InjectableRegistryImp {
|
|
29
31
|
}
|
30
32
|
}
|
31
33
|
|
32
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,
|
34
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9yZXBvc2l0b3J5L2luamVjdGFibGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxxQkFBcUIsRUFDckIsV0FBVyxHQUNaLE1BQU0saUNBQWlDLENBQUM7QUFDekMsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUMxQyxPQUFPLEVBQUUsS0FBSyxFQUFvQixNQUFNLGdDQUFnQyxDQUFDO0FBQ3pFLE9BQU8sRUFBRSxtQ0FBbUMsRUFBRSxNQUFNLFNBQVMsQ0FBQztBQUM5RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBRWpELE1BQU0sT0FBTyxtQkFBb0IsU0FBUSxxQkFBcUI7SUFDNUQ7UUFDRSxLQUFLLEVBQUUsQ0FBQztJQUNWLENBQUM7SUFFRCxHQUFHLENBQUksSUFBWTtRQUNqQixJQUFJLFVBQVUsR0FBRyxLQUFLLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ2pDLElBQUksQ0FBQyxVQUFVO1lBQ2IsSUFBSSxDQUFDO2dCQUNILE1BQU0sQ0FBQyxHQUFHLEtBQUssQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7Z0JBQzFCLElBQUksQ0FBQztvQkFBRSxVQUFVLEdBQUcsVUFBVSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFDM0MsSUFBSSxVQUFVLEVBQUUsQ0FBQztvQkFDZixJQUFJLFVBQVUsWUFBWSxVQUFVO3dCQUFFLE9BQU8sVUFBZSxDQUFDO29CQUM3RCxNQUFNLE9BQU8sR0FDWCxPQUFPLENBQUMsV0FBVyxDQUNqQixPQUFPLENBQUMsR0FBRyxDQUFDLGVBQWUsQ0FBQyxPQUFPLENBQUMsRUFDcEMsVUFBVSxDQUFDLFdBQVcsQ0FDdkI7d0JBQ0QsT0FBTyxDQUFDLFdBQVcsQ0FDakIsT0FBTyxDQUFDLEdBQUcsQ0FBQyxlQUFlLENBQUMsT0FBTyxDQUFDLEVBQ3BDLENBQTBCLENBQzNCLENBQUM7b0JBQ0osV0FBVyxDQUFDLFFBQVEsQ0FDbEIsVUFBVSxFQUNWLG1DQUFtQyxDQUNqQyxDQUEwQixFQUMxQixPQUFPLENBQ1IsQ0FDRixDQUFDO2dCQUNKLENBQUM7Z0JBQ0QsNkRBQTZEO1lBQy9ELENBQUM7WUFBQyxPQUFPLENBQU0sRUFBRSxDQUFDO2dCQUNoQixPQUFPLFNBQVMsQ0FBQztZQUNuQixDQUFDO1FBQ0gsT0FBTyxVQUEyQixDQUFDO0lBQ3JDLENBQUM7Q0FDRiIsImZpbGUiOiJyZXBvc2l0b3J5L2luamVjdGFibGVzLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgSW5qZWN0YWJsZVJlZ2lzdHJ5SW1wLFxuICBJbmplY3RhYmxlcyxcbn0gZnJvbSBcIkBkZWNhZi10cy9pbmplY3RhYmxlLWRlY29yYXRvcnNcIjtcbmltcG9ydCB7IFJlcG9zaXRvcnkgfSBmcm9tIFwiLi9SZXBvc2l0b3J5XCI7XG5pbXBvcnQgeyBNb2RlbCwgTW9kZWxDb25zdHJ1Y3RvciB9IGZyb20gXCJAZGVjYWYtdHMvZGVjb3JhdG9yLXZhbGlkYXRpb25cIjtcbmltcG9ydCB7IGdlbmVyYXRlSW5qZWN0YWJsZU5hbWVGb3JSZXBvc2l0b3J5IH0gZnJvbSBcIi4vdXRpbHNcIjtcbmltcG9ydCB7IFBlcnNpc3RlbmNlS2V5cyB9IGZyb20gXCIuLi9wZXJzaXN0ZW5jZS9jb25zdGFudHNcIjtcbmltcG9ydCB7IEFkYXB0ZXIgfSBmcm9tIFwiLi4vcGVyc2lzdGVuY2UvQWRhcHRlclwiO1xuXG5leHBvcnQgY2xhc3MgSW5qZWN0YWJsZXNSZWdpc3RyeSBleHRlbmRzIEluamVjdGFibGVSZWdpc3RyeUltcCB7XG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIHN1cGVyKCk7XG4gIH1cblxuICBnZXQ8VD4obmFtZTogc3RyaW5nKTogVCB8IHVuZGVmaW5lZCB7XG4gICAgbGV0IGluamVjdGFibGUgPSBzdXBlci5nZXQobmFtZSk7XG4gICAgaWYgKCFpbmplY3RhYmxlKVxuICAgICAgdHJ5IHtcbiAgICAgICAgY29uc3QgbSA9IE1vZGVsLmdldChuYW1lKTtcbiAgICAgICAgaWYgKG0pIGluamVjdGFibGUgPSBSZXBvc2l0b3J5LmZvck1vZGVsKG0pO1xuICAgICAgICBpZiAoaW5qZWN0YWJsZSkge1xuICAgICAgICAgIGlmIChpbmplY3RhYmxlIGluc3RhbmNlb2YgUmVwb3NpdG9yeSkgcmV0dXJuIGluamVjdGFibGUgYXMgVDtcbiAgICAgICAgICBjb25zdCBmbGF2b3VyID1cbiAgICAgICAgICAgIFJlZmxlY3QuZ2V0TWV0YWRhdGEoXG4gICAgICAgICAgICAgIEFkYXB0ZXIua2V5KFBlcnNpc3RlbmNlS2V5cy5BREFQVEVSKSxcbiAgICAgICAgICAgICAgaW5qZWN0YWJsZS5jb25zdHJ1Y3RvclxuICAgICAgICAgICAgKSB8fFxuICAgICAgICAgICAgUmVmbGVjdC5nZXRNZXRhZGF0YShcbiAgICAgICAgICAgICAgQWRhcHRlci5rZXkoUGVyc2lzdGVuY2VLZXlzLkFEQVBURVIpLFxuICAgICAgICAgICAgICBtIGFzIE1vZGVsQ29uc3RydWN0b3I8YW55PlxuICAgICAgICAgICAgKTtcbiAgICAgICAgICBJbmplY3RhYmxlcy5yZWdpc3RlcihcbiAgICAgICAgICAgIGluamVjdGFibGUsXG4gICAgICAgICAgICBnZW5lcmF0ZUluamVjdGFibGVOYW1lRm9yUmVwb3NpdG9yeShcbiAgICAgICAgICAgICAgbSBhcyBNb2RlbENvbnN0cnVjdG9yPGFueT4sXG4gICAgICAgICAgICAgIGZsYXZvdXJcbiAgICAgICAgICAgIClcbiAgICAgICAgICApO1xuICAgICAgICB9XG4gICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW51c2VkLXZhcnNcbiAgICAgIH0gY2F0Y2ggKGU6IGFueSkge1xuICAgICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgICAgfVxuICAgIHJldHVybiBpbmplY3RhYmxlIGFzIFQgfCB1bmRlZmluZWQ7XG4gIH1cbn1cbiJdfQ==
|
@@ -27,7 +27,7 @@ const utils_1 = require("./utils.cjs");
|
|
27
27
|
* @param key
|
28
28
|
* @param model
|
29
29
|
*/
|
30
|
-
async function pkOnCreate(data, key, model) {
|
30
|
+
async function pkOnCreate(context, data, key, model) {
|
31
31
|
if (!data.type || model[key]) {
|
32
32
|
return;
|
33
33
|
}
|
@@ -58,4 +58,4 @@ function pk(opts = SequenceOptions_1.DefaultSequenceOptions) {
|
|
58
58
|
(0, decorator_validation_1.propMetadata)(Repository_1.Repository.key(db_decorators_1.DBKeys.ID), opts), (0, db_decorators_1.onCreate)(pkOnCreate, opts));
|
59
59
|
}
|
60
60
|
|
61
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,
|
61
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9pZGVudGl0eS9kZWNvcmF0b3JzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBb0NBLGdDQW1DQztBQUVELGdCQWVDO0FBeEZELHlFQUErRTtBQUMvRSxtRUFHdUM7QUFDdkMsMkRBS2lDO0FBQ2pDLHFEQUE2QztBQUM3Qyx5REFBc0Q7QUFDdEQsb0RBQTRDO0FBQzVDLG1DQUErQztBQUkvQzs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FpQkc7QUFDSSxLQUFLLFVBQVUsVUFBVSxDQUU5QixPQUFnQixFQUNoQixJQUFxQixFQUNyQixHQUFXLEVBQ1gsS0FBUTtJQUVSLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxJQUFLLEtBQTZCLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQztRQUN0RCxPQUFPO0lBQ1QsQ0FBQztJQUVELE1BQU0sa0JBQWtCLEdBQUcsVUFDekIsTUFBUyxFQUNULFdBQW1CLEVBQ25CLEtBQStCO1FBRS9CLE1BQU0sQ0FBQyxjQUFjLENBQUMsTUFBTSxFQUFFLFdBQVcsRUFBRTtZQUN6QyxVQUFVLEVBQUUsSUFBSTtZQUNoQixRQUFRLEVBQUUsS0FBSztZQUNmLFlBQVksRUFBRSxJQUFJO1lBQ2xCLEtBQUssRUFBRSxLQUFLO1NBQ2IsQ0FBQyxDQUFDO0lBQ0wsQ0FBQyxDQUFDO0lBQ0YsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJO1FBQUUsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFBLDRCQUFvQixFQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsQ0FBQztJQUM5RCxJQUFJLFFBQWtCLENBQUM7SUFDdkIsSUFBSSxDQUFDO1FBQ0gsUUFBUSxHQUFHLE1BQU0sSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDL0MsQ0FBQztJQUFDLE9BQU8sQ0FBTSxFQUFFLENBQUM7UUFDaEIsTUFBTSxJQUFJLDZCQUFhLENBQ3JCLGtDQUFrQyxJQUFJLENBQUMsSUFBSSxLQUFLLENBQUMsRUFBRSxDQUNwRCxDQUFDO0lBQ0osQ0FBQztJQUVELE1BQU0sSUFBSSxHQUFHLE1BQU0sUUFBUSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ25DLGtCQUFrQixDQUFDLEtBQUssRUFBRSxHQUFHLEVBQUUsSUFBSSxDQUFDLENBQUM7QUFDdkMsQ0FBQztBQUVELFNBQWdCLEVBQUUsQ0FDaEIsT0FHSSx3Q0FBc0I7SUFFMUIsSUFBSSxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsRUFBRSxFQUFFLHdDQUFzQixFQUFFLElBQUksQ0FBb0IsQ0FBQztJQUMxRSxPQUFPLElBQUEsa0JBQUssRUFDVixJQUFBLGtCQUFLLEdBQUUsRUFDUCxJQUFBLCtCQUFRLEdBQUUsRUFDVixJQUFBLHdCQUFRLEdBQUU7SUFDVixpREFBaUQ7SUFDakQsSUFBQSxtQ0FBWSxFQUFDLHVCQUFVLENBQUMsR0FBRyxDQUFDLHNCQUFNLENBQUMsRUFBRSxDQUFDLEVBQUUsSUFBdUIsQ0FBQyxFQUNoRSxJQUFBLHdCQUFRLEVBQUMsVUFBVSxFQUFFLElBQXVCLENBQUMsQ0FDOUMsQ0FBQztBQUNKLENBQUMiLCJmaWxlIjoiaWRlbnRpdHkvZGVjb3JhdG9ycy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHByb3BNZXRhZGF0YSwgcmVxdWlyZWQsIE1vZGVsIH0gZnJvbSBcIkBkZWNhZi10cy9kZWNvcmF0b3ItdmFsaWRhdGlvblwiO1xuaW1wb3J0IHtcbiAgRGVmYXVsdFNlcXVlbmNlT3B0aW9ucyxcbiAgU2VxdWVuY2VPcHRpb25zLFxufSBmcm9tIFwiLi4vaW50ZXJmYWNlcy9TZXF1ZW5jZU9wdGlvbnNcIjtcbmltcG9ydCB7XG4gIERCS2V5cyxcbiAgSW50ZXJuYWxFcnJvcixcbiAgb25DcmVhdGUsXG4gIHJlYWRvbmx5LFxufSBmcm9tIFwiQGRlY2FmLXRzL2RiLWRlY29yYXRvcnNcIjtcbmltcG9ydCB7IGFwcGx5IH0gZnJvbSBcIkBkZWNhZi10cy9yZWZsZWN0aW9uXCI7XG5pbXBvcnQgeyBSZXBvc2l0b3J5IH0gZnJvbSBcIi4uL3JlcG9zaXRvcnkvUmVwb3NpdG9yeVwiO1xuaW1wb3J0IHsgaW5kZXggfSBmcm9tIFwiLi4vbW9kZWwvZGVjb3JhdG9yc1wiO1xuaW1wb3J0IHsgc2VxdWVuY2VOYW1lRm9yTW9kZWwgfSBmcm9tIFwiLi91dGlsc1wiO1xuaW1wb3J0IHsgU2VxdWVuY2UgfSBmcm9tIFwiLi4vcGVyc2lzdGVuY2UvU2VxdWVuY2VcIjtcbmltcG9ydCB7IENvbnRleHQgfSBmcm9tIFwiQGRlY2FmLXRzL2RiLWRlY29yYXRvcnMvbGliL3JlcG9zaXRvcnkvQ29udGV4dFwiO1xuXG4vKipcbiAqIEBzdW1tYXJ5IFByaW1hcnkgS2V5IERlY29yYXRvclxuICogQGRlc2NyaXB0aW9uIE1hcmtzIHRoZSBwcm9wZXJ0eSBhcyB0aGUge0BsaW5rIE1vZGVsfXMgcHJpbWFyeSBrZXkuXG4gKiAgQWxzbyBtYXJrcyB0aGUgcHJvcGVydHkgYXMge0BsaW5rIHVuaXF1ZX0gYXMge0ByZXF1aXJlZH0gYW5kIGVuc3VyZXMgdGhlIGluZGV4IGlzIGNyZWF0ZWQgcHJvcGVybHkgYWNjb3JkaW5nIHRvIHRoZSBwcm92aWRlZCB7QGxpbmsgU2VxdWVuY2V9XG4gKlxuICpcbiAqXG4gKiBAZnVuY3Rpb24gcGtcbiAqXG4gKiBAbWVtYmVyT2YgbW9kdWxlOndhbGxldC1kYi5EZWNvcmF0b3JzXG4gKlxuICogQHNlZSB1bmlxdWVcbiAqIEBzZWUgcmVxdWlyZWRcbiAqIEBzZWUgb25cbiAqIEBwYXJhbSBkYXRhXG4gKiBAcGFyYW0ga2V5XG4gKiBAcGFyYW0gbW9kZWxcbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHBrT25DcmVhdGU8TSBleHRlbmRzIE1vZGVsLCBWIGV4dGVuZHMgUmVwb3NpdG9yeTxNLCBhbnk+PihcbiAgdGhpczogVixcbiAgY29udGV4dDogQ29udGV4dCxcbiAgZGF0YTogU2VxdWVuY2VPcHRpb25zLFxuICBrZXk6IHN0cmluZyxcbiAgbW9kZWw6IE1cbik6IFByb21pc2U8dm9pZD4ge1xuICBpZiAoIWRhdGEudHlwZSB8fCAobW9kZWwgYXMgUmVjb3JkPHN0cmluZywgYW55Pilba2V5XSkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IHNldFByaW1hcnlLZXlWYWx1ZSA9IGZ1bmN0aW9uIDxNIGV4dGVuZHMgTW9kZWw+KFxuICAgIHRhcmdldDogTSxcbiAgICBwcm9wZXJ0eUtleTogc3RyaW5nLFxuICAgIHZhbHVlOiBzdHJpbmcgfCBudW1iZXIgfCBiaWdpbnRcbiAgKSB7XG4gICAgT2JqZWN0LmRlZmluZVByb3BlcnR5KHRhcmdldCwgcHJvcGVydHlLZXksIHtcbiAgICAgIGVudW1lcmFibGU6IHRydWUsXG4gICAgICB3cml0YWJsZTogZmFsc2UsXG4gICAgICBjb25maWd1cmFibGU6IHRydWUsXG4gICAgICB2YWx1ZTogdmFsdWUsXG4gICAgfSk7XG4gIH07XG4gIGlmICghZGF0YS5uYW1lKSBkYXRhLm5hbWUgPSBzZXF1ZW5jZU5hbWVGb3JNb2RlbChtb2RlbCwgXCJwa1wiKTtcbiAgbGV0IHNlcXVlbmNlOiBTZXF1ZW5jZTtcbiAgdHJ5IHtcbiAgICBzZXF1ZW5jZSA9IGF3YWl0IHRoaXMuYWRhcHRlci5TZXF1ZW5jZShkYXRhKTtcbiAgfSBjYXRjaCAoZTogYW55KSB7XG4gICAgdGhyb3cgbmV3IEludGVybmFsRXJyb3IoXG4gICAgICBgRmFpbGVkIHRvIGluc3RhbnRpYXRlIFNlcXVlbmNlICR7ZGF0YS5uYW1lfTogJHtlfWBcbiAgICApO1xuICB9XG5cbiAgY29uc3QgbmV4dCA9IGF3YWl0IHNlcXVlbmNlLm5leHQoKTtcbiAgc2V0UHJpbWFyeUtleVZhbHVlKG1vZGVsLCBrZXksIG5leHQpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gcGsoXG4gIG9wdHM6IE9taXQ8XG4gICAgU2VxdWVuY2VPcHRpb25zLFxuICAgIFwiY3ljbGVcIiB8IFwic3RhcnRXaXRoXCIgfCBcImluY3JlbWVudEJ5XCJcbiAgPiA9IERlZmF1bHRTZXF1ZW5jZU9wdGlvbnNcbikge1xuICBvcHRzID0gT2JqZWN0LmFzc2lnbih7fSwgRGVmYXVsdFNlcXVlbmNlT3B0aW9ucywgb3B0cykgYXMgU2VxdWVuY2VPcHRpb25zO1xuICByZXR1cm4gYXBwbHkoXG4gICAgaW5kZXgoKSxcbiAgICByZXF1aXJlZCgpLFxuICAgIHJlYWRvbmx5KCksXG4gICAgLy8gdHlwZShbU3RyaW5nLm5hbWUsIE51bWJlci5uYW1lLCBCaWdJbnQubmFtZV0pLFxuICAgIHByb3BNZXRhZGF0YShSZXBvc2l0b3J5LmtleShEQktleXMuSUQpLCBvcHRzIGFzIFNlcXVlbmNlT3B0aW9ucyksXG4gICAgb25DcmVhdGUocGtPbkNyZWF0ZSwgb3B0cyBhcyBTZXF1ZW5jZU9wdGlvbnMpXG4gICk7XG59XG4iXX0=
|
@@ -1,6 +1,7 @@
|
|
1
1
|
import { Model } from "@decaf-ts/decorator-validation";
|
2
2
|
import { SequenceOptions } from "../interfaces/SequenceOptions";
|
3
3
|
import { Repository } from "../repository/Repository";
|
4
|
+
import { Context } from "@decaf-ts/db-decorators/lib/repository/Context";
|
4
5
|
/**
|
5
6
|
* @summary Primary Key Decorator
|
6
7
|
* @description Marks the property as the {@link Model}s primary key.
|
@@ -19,5 +20,5 @@ import { Repository } from "../repository/Repository";
|
|
19
20
|
* @param key
|
20
21
|
* @param model
|
21
22
|
*/
|
22
|
-
export declare function pkOnCreate<M extends Model, V extends Repository<M, any>>(this: V, data: SequenceOptions, key: string, model: M): Promise<void>;
|
23
|
+
export declare function pkOnCreate<M extends Model, V extends Repository<M, any>>(this: V, context: Context, data: SequenceOptions, key: string, model: M): Promise<void>;
|
23
24
|
export declare function pk(opts?: Omit<SequenceOptions, "cycle" | "startWith" | "incrementBy">): (target: object, propertyKey?: any, descriptor?: any) => void;
|
package/lib/identity/index.cjs
CHANGED
@@ -15,5 +15,6 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
15
15
|
};
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
17
17
|
__exportStar(require("./decorators.cjs"), exports);
|
18
|
+
__exportStar(require("./utils.cjs"), exports);
|
18
19
|
|
19
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,
|
20
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9pZGVudGl0eS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsK0NBQTZCO0FBQzdCLDBDQUF3QiIsImZpbGUiOiJpZGVudGl0eS9pbmRleC5qcyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL2RlY29yYXRvcnNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3V0aWxzXCI7XG4iXX0=
|
package/lib/identity/index.d.ts
CHANGED
package/lib/identity/utils.cjs
CHANGED
@@ -6,4 +6,4 @@ function sequenceNameForModel(model, ...args) {
|
|
6
6
|
return [Repository_1.Repository.table(model), ...args].join("_");
|
7
7
|
}
|
8
8
|
|
9
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,
|
9
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9pZGVudGl0eS91dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUdBLG9EQUtDO0FBUEQseURBQXNEO0FBRXRELFNBQWdCLG9CQUFvQixDQUNsQyxLQUF5QixFQUN6QixHQUFHLElBQWM7SUFFakIsT0FBTyxDQUFDLHVCQUFVLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxFQUFFLEdBQUcsSUFBSSxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0FBQ3RELENBQUMiLCJmaWxlIjoiaWRlbnRpdHkvdXRpbHMuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb25zdHJ1Y3RvciwgTW9kZWwgfSBmcm9tIFwiQGRlY2FmLXRzL2RlY29yYXRvci12YWxpZGF0aW9uXCI7XG5pbXBvcnQgeyBSZXBvc2l0b3J5IH0gZnJvbSBcIi4uL3JlcG9zaXRvcnkvUmVwb3NpdG9yeVwiO1xuXG5leHBvcnQgZnVuY3Rpb24gc2VxdWVuY2VOYW1lRm9yTW9kZWw8TSBleHRlbmRzIE1vZGVsPihcbiAgbW9kZWw6IE0gfCBDb25zdHJ1Y3RvcjxNPixcbiAgLi4uYXJnczogc3RyaW5nW11cbikge1xuICByZXR1cm4gW1JlcG9zaXRvcnkudGFibGUobW9kZWwpLCAuLi5hcmdzXS5qb2luKFwiX1wiKTtcbn1cbiJdfQ==
|
package/lib/identity/utils.d.ts
CHANGED
@@ -1,2 +1,2 @@
|
|
1
|
-
import { Model } from "@decaf-ts/decorator-validation";
|
2
|
-
export declare function sequenceNameForModel<M extends Model>(model: M
|
1
|
+
import { Constructor, Model } from "@decaf-ts/decorator-validation";
|
2
|
+
export declare function sequenceNameForModel<M extends Model>(model: M | Constructor<M>, ...args: string[]): string;
|
package/lib/index.cjs
CHANGED
@@ -42,6 +42,6 @@ injectable_decorators_1.Injectables.setRegistry(new repository_1.InjectablesRegi
|
|
42
42
|
* @const VERSION
|
43
43
|
* @memberOf module:ts-workspace
|
44
44
|
*/
|
45
|
-
exports.VERSION = "0.2.
|
45
|
+
exports.VERSION = "0.2.1";
|
46
46
|
|
47
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,
|
47
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDZDQUFtRDtBQUNuRCwyRUFBOEQ7QUFFOUQ7Ozs7R0FJRztBQUVIOzs7OztHQUtHO0FBRUgsNkNBQTJCO0FBQzNCLCtDQUE2QjtBQUM3QiwwQ0FBd0I7QUFDeEIsZ0RBQThCO0FBQzlCLDBDQUF3QjtBQUN4QiwrQ0FBNkI7QUFDN0IsK0NBQTZCO0FBRTdCLG1DQUFXLENBQUMsV0FBVyxDQUFDLElBQUksZ0NBQW1CLEVBQUUsQ0FBQyxDQUFDO0FBRW5EOzs7OztHQUtHO0FBQ1UsUUFBQSxPQUFPLEdBQUcsT0FBTyxDQUFDIiwiZmlsZSI6ImluZGV4LmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZXNSZWdpc3RyeSB9IGZyb20gXCIuL3JlcG9zaXRvcnlcIjtcbmltcG9ydCB7IEluamVjdGFibGVzIH0gZnJvbSBcIkBkZWNhZi10cy9pbmplY3RhYmxlLWRlY29yYXRvcnNcIjtcblxuLyoqXG4gKiBAc3VtbWFyeSBNb2R1bGUgc3VtbWFyeVxuICogQGRlc2NyaXB0aW9uIE1vZHVsZSBkZXNjcmlwdGlvblxuICogQG1vZHVsZSB0cy13b3Jrc3BhY2VcbiAqL1xuXG4vKipcbiAqIEBzdW1tYXJ5IE5hbWVzcGFjZSBzdW1tYXJ5XG4gKiBAZGVzY3JpcHRpb24gTmFtZXNwYWNlIGRlc2NyaXB0aW9uXG4gKiBAbmFtZXNwYWNlIE5hbWVzcGFjZVxuICogQG1lbWJlck9mIG1vZHVsZTp0cy13b3Jrc3BhY2VcbiAqL1xuXG5leHBvcnQgKiBmcm9tIFwiLi9pZGVudGl0eVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vaW50ZXJmYWNlc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vbW9kZWxcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3BlcnNpc3RlbmNlXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9xdWVyeVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vcmVwb3NpdG9yeVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vdmFsaWRhdG9yc1wiO1xuXG5JbmplY3RhYmxlcy5zZXRSZWdpc3RyeShuZXcgSW5qZWN0YWJsZXNSZWdpc3RyeSgpKTtcblxuLyoqXG4gKiBAc3VtbWFyeSBzdG9yZXMgdGhlIGN1cnJlbnQgcGFja2FnZSB2ZXJzaW9uXG4gKiBAZGVzY3JpcHRpb24gdGhpcyBpcyBob3cgeW91IHNob3VsZCBkb2N1bWVudCBhIGNvbnN0YW50XG4gKiBAY29uc3QgVkVSU0lPTlxuICogQG1lbWJlck9mIG1vZHVsZTp0cy13b3Jrc3BhY2VcbiAqL1xuZXhwb3J0IGNvbnN0IFZFUlNJT04gPSBcIjAuMi4xXCI7XG4iXX0=
|
package/lib/index.d.ts
CHANGED
package/lib/interfaces/index.cjs
CHANGED
@@ -20,7 +20,6 @@ __exportStar(require("./Observable.cjs"), exports);
|
|
20
20
|
__exportStar(require("./Observer.cjs"), exports);
|
21
21
|
__exportStar(require("./Queriable.cjs"), exports);
|
22
22
|
__exportStar(require("./RawExecutor.cjs"), exports);
|
23
|
-
__exportStar(require("./Sequence.cjs"), exports);
|
24
23
|
__exportStar(require("./SequenceOptions.cjs"), exports);
|
25
24
|
|
26
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,
|
25
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9pbnRlcmZhY2VzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSw0Q0FBMEI7QUFDMUIsNkNBQTJCO0FBQzNCLCtDQUE2QjtBQUM3Qiw2Q0FBMkI7QUFDM0IsOENBQTRCO0FBQzVCLGdEQUE4QjtBQUM5QixvREFBa0MiLCJmaWxlIjoiaW50ZXJmYWNlcy9pbmRleC5qcyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL0J1aWxkZXJcIjtcbmV4cG9ydCAqIGZyb20gXCIuL0V4ZWN1dG9yXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9PYnNlcnZhYmxlXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9PYnNlcnZlclwiO1xuZXhwb3J0ICogZnJvbSBcIi4vUXVlcmlhYmxlXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9SYXdFeGVjdXRvclwiO1xuZXhwb3J0ICogZnJvbSBcIi4vU2VxdWVuY2VPcHRpb25zXCI7XG4iXX0=
|
package/lib/model/BaseModel.cjs
CHANGED
@@ -15,8 +15,6 @@ const decorator_validation_1 = require("@decaf-ts/decorator-validation");
|
|
15
15
|
class BaseModel extends decorator_validation_1.Model {
|
16
16
|
constructor(arg) {
|
17
17
|
super(arg);
|
18
|
-
this.createdOn = undefined;
|
19
|
-
this.updatedOn = undefined;
|
20
18
|
}
|
21
19
|
}
|
22
20
|
exports.BaseModel = BaseModel;
|
@@ -29,4 +27,4 @@ __decorate([
|
|
29
27
|
__metadata("design:type", Date)
|
30
28
|
], BaseModel.prototype, "updatedOn", void 0);
|
31
29
|
|
32
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,
|
30
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9tb2RlbC9CYXNlTW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEsMkRBQWtFO0FBQ2xFLHlFQUFpRTtBQUVqRSxNQUFzQixTQUFVLFNBQVEsNEJBQUs7SUFNM0MsWUFBc0IsR0FBeUI7UUFDN0MsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ2IsQ0FBQztDQUNGO0FBVEQsOEJBU0M7QUFQQztJQURDLElBQUEseUJBQVMsRUFBQyw0QkFBWSxDQUFDLE1BQU0sQ0FBQzs4QkFDbkIsSUFBSTs0Q0FBQztBQUVqQjtJQURDLElBQUEseUJBQVMsR0FBRTs4QkFDQSxJQUFJOzRDQUFDIiwiZmlsZSI6Im1vZGVsL0Jhc2VNb2RlbC5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERCT3BlcmF0aW9ucywgdGltZXN0YW1wIH0gZnJvbSBcIkBkZWNhZi10cy9kYi1kZWNvcmF0b3JzXCI7XG5pbXBvcnQgeyBNb2RlbEFyZywgTW9kZWwgfSBmcm9tIFwiQGRlY2FmLXRzL2RlY29yYXRvci12YWxpZGF0aW9uXCI7XG5cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBCYXNlTW9kZWwgZXh0ZW5kcyBNb2RlbCB7XG4gIEB0aW1lc3RhbXAoREJPcGVyYXRpb25zLkNSRUFURSlcbiAgY3JlYXRlZE9uITogRGF0ZTtcbiAgQHRpbWVzdGFtcCgpXG4gIHVwZGF0ZWRPbiE6IERhdGU7XG5cbiAgcHJvdGVjdGVkIGNvbnN0cnVjdG9yKGFyZz86IE1vZGVsQXJnPEJhc2VNb2RlbD4pIHtcbiAgICBzdXBlcihhcmcpO1xuICB9XG59XG4iXX0=
|
package/lib/model/BaseModel.d.ts
CHANGED
@@ -0,0 +1,214 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.createOrUpdate = createOrUpdate;
|
4
|
+
exports.oneToOneOnCreate = oneToOneOnCreate;
|
5
|
+
exports.oneToOneOnUpdate = oneToOneOnUpdate;
|
6
|
+
exports.oneToOneOnDelete = oneToOneOnDelete;
|
7
|
+
exports.oneToManyOnCreate = oneToManyOnCreate;
|
8
|
+
exports.oneToManyOnUpdate = oneToManyOnUpdate;
|
9
|
+
exports.oneToManyOnDelete = oneToManyOnDelete;
|
10
|
+
exports.getPopulateKey = getPopulateKey;
|
11
|
+
exports.cacheModelForPopulate = cacheModelForPopulate;
|
12
|
+
exports.populate = populate;
|
13
|
+
exports.repositoryFromTypeMetadata = repositoryFromTypeMetadata;
|
14
|
+
const decorator_validation_1 = require("@decaf-ts/decorator-validation");
|
15
|
+
const Repository_1 = require("../repository/Repository.cjs");
|
16
|
+
const db_decorators_1 = require("@decaf-ts/db-decorators");
|
17
|
+
const constants_1 = require("../persistence/constants.cjs");
|
18
|
+
const constants_2 = require("../repository/constants.cjs");
|
19
|
+
async function createOrUpdate(model, context, repository = undefined, pk) {
|
20
|
+
if (!repository) {
|
21
|
+
const constructor = decorator_validation_1.Model.get(model.constructor.name);
|
22
|
+
if (!constructor)
|
23
|
+
throw new db_decorators_1.InternalError(`Could not find model ${model.constructor.name}`);
|
24
|
+
repository = Repository_1.Repository.forModel(constructor);
|
25
|
+
}
|
26
|
+
if (!pk)
|
27
|
+
pk = (0, db_decorators_1.findPrimaryKey)(model).id;
|
28
|
+
if (typeof model[pk] === "undefined")
|
29
|
+
return repository.create(model, context);
|
30
|
+
else {
|
31
|
+
try {
|
32
|
+
return repository.update(model, context);
|
33
|
+
}
|
34
|
+
catch (e) {
|
35
|
+
if (!(e instanceof db_decorators_1.NotFoundError))
|
36
|
+
throw e;
|
37
|
+
return repository.create(model, context);
|
38
|
+
}
|
39
|
+
}
|
40
|
+
}
|
41
|
+
async function oneToOneOnCreate(context, data, key, model) {
|
42
|
+
const propertyValue = model[key];
|
43
|
+
if (!propertyValue)
|
44
|
+
return;
|
45
|
+
if (typeof propertyValue !== "object") {
|
46
|
+
const innerRepo = repositoryFromTypeMetadata(model, key);
|
47
|
+
const read = await innerRepo.read(propertyValue);
|
48
|
+
await cacheModelForPopulate(context, model, key, propertyValue, read);
|
49
|
+
model[key] = propertyValue;
|
50
|
+
return;
|
51
|
+
}
|
52
|
+
const constructor = decorator_validation_1.Model.get(data.class);
|
53
|
+
if (!constructor)
|
54
|
+
throw new db_decorators_1.InternalError(`Could not find model ${data.class}`);
|
55
|
+
const repo = Repository_1.Repository.forModel(constructor);
|
56
|
+
const created = await repo.create(propertyValue);
|
57
|
+
const pk = (0, db_decorators_1.findPrimaryKey)(created).id;
|
58
|
+
await cacheModelForPopulate(context, model, key, created[pk], created);
|
59
|
+
model[key] = created[pk];
|
60
|
+
}
|
61
|
+
async function oneToOneOnUpdate(context, data, key, model) {
|
62
|
+
const propertyValue = model[key];
|
63
|
+
if (!propertyValue)
|
64
|
+
return;
|
65
|
+
if (data.cascade.update !== constants_2.Cascade.CASCADE)
|
66
|
+
return;
|
67
|
+
if (typeof propertyValue !== "object") {
|
68
|
+
const innerRepo = repositoryFromTypeMetadata(model, key);
|
69
|
+
const read = await innerRepo.read(propertyValue);
|
70
|
+
await cacheModelForPopulate(context, model, key, propertyValue, read);
|
71
|
+
model[key] = propertyValue;
|
72
|
+
return;
|
73
|
+
}
|
74
|
+
const updated = await createOrUpdate(model[key], context);
|
75
|
+
const pk = (0, db_decorators_1.findPrimaryKey)(updated).id;
|
76
|
+
await cacheModelForPopulate(context, model, key, updated[pk], updated);
|
77
|
+
model[key] = updated[pk];
|
78
|
+
}
|
79
|
+
async function oneToOneOnDelete(context, data, key, model) {
|
80
|
+
const propertyValue = model[key];
|
81
|
+
if (!propertyValue)
|
82
|
+
return;
|
83
|
+
if (data.cascade.update !== constants_2.Cascade.CASCADE)
|
84
|
+
return;
|
85
|
+
const innerRepo = repositoryFromTypeMetadata(model, key);
|
86
|
+
if (!(propertyValue instanceof decorator_validation_1.Model))
|
87
|
+
await innerRepo.delete(model[key], context);
|
88
|
+
else
|
89
|
+
await innerRepo.delete((0, db_decorators_1.findModelId)(model[key]), context);
|
90
|
+
}
|
91
|
+
async function oneToManyOnCreate(context, data, key, model) {
|
92
|
+
const propertyValues = model[key];
|
93
|
+
if (!propertyValues || !propertyValues.length)
|
94
|
+
return;
|
95
|
+
const arrayType = typeof propertyValues[0];
|
96
|
+
if (!propertyValues.every((item) => typeof item === arrayType))
|
97
|
+
throw new db_decorators_1.InternalError(`Invalid operation. All elements of property ${key} must match the same type.`);
|
98
|
+
const uniqueValues = new Set([...propertyValues]);
|
99
|
+
if (arrayType !== "object") {
|
100
|
+
const repo = repositoryFromTypeMetadata(model, key);
|
101
|
+
for (const id of uniqueValues) {
|
102
|
+
const read = await repo.read(id);
|
103
|
+
await cacheModelForPopulate(context, model, key, id, read);
|
104
|
+
}
|
105
|
+
model[key] = uniqueValues;
|
106
|
+
return;
|
107
|
+
}
|
108
|
+
const pkName = (0, db_decorators_1.findPrimaryKey)(propertyValues[0]).id;
|
109
|
+
const result = new Set();
|
110
|
+
for (const m of propertyValues) {
|
111
|
+
const record = await createOrUpdate(m, context);
|
112
|
+
await cacheModelForPopulate(context, model, key, record[pkName], record);
|
113
|
+
result.add(record[pkName]);
|
114
|
+
}
|
115
|
+
model[key] = [...result];
|
116
|
+
}
|
117
|
+
async function oneToManyOnUpdate(context, data, key, model) {
|
118
|
+
const { cascade } = data;
|
119
|
+
if (cascade.update !== constants_2.Cascade.CASCADE)
|
120
|
+
return;
|
121
|
+
return oneToManyOnCreate.call(this, context, data, key, model);
|
122
|
+
}
|
123
|
+
async function oneToManyOnDelete(context, data, key, id) {
|
124
|
+
if (data.cascade.delete !== constants_2.Cascade.CASCADE)
|
125
|
+
return;
|
126
|
+
const model = await this.read(id);
|
127
|
+
const values = model[key];
|
128
|
+
if (!values || !values.length)
|
129
|
+
return;
|
130
|
+
const arrayType = typeof values[0];
|
131
|
+
const areAllSameType = values.every((item) => typeof item === arrayType);
|
132
|
+
if (!areAllSameType)
|
133
|
+
throw new db_decorators_1.InternalError(`Invalid operation. All elements of property ${key} must match the same type.`);
|
134
|
+
const isInstantiated = arrayType === Object.name;
|
135
|
+
const repo = isInstantiated
|
136
|
+
? Repository_1.Repository.forModel(values[0])
|
137
|
+
: repositoryFromTypeMetadata(model, key);
|
138
|
+
let pk;
|
139
|
+
if (isInstantiated)
|
140
|
+
pk = (0, db_decorators_1.findPrimaryKey)(values[0]).id;
|
141
|
+
const uniqueValues = new Set([
|
142
|
+
...(isInstantiated
|
143
|
+
? values
|
144
|
+
: values.map((v) => v[pk])),
|
145
|
+
]);
|
146
|
+
for (const id of uniqueValues) {
|
147
|
+
const deleted = await repo.delete(id, context);
|
148
|
+
await cacheModelForPopulate(context, model, key, id, deleted);
|
149
|
+
}
|
150
|
+
model[key] = [...uniqueValues];
|
151
|
+
}
|
152
|
+
function getPopulateKey(tableName, fieldName, id) {
|
153
|
+
return [constants_1.PersistenceKeys.POPULATE, tableName, fieldName, id].join(".");
|
154
|
+
}
|
155
|
+
async function cacheModelForPopulate(context, parentModel, propertyKey, pkValue, cacheValue) {
|
156
|
+
const cacheKey = getPopulateKey(parentModel.constructor.name, propertyKey, pkValue);
|
157
|
+
return context.put(cacheKey, cacheValue);
|
158
|
+
}
|
159
|
+
async function populate(context, data, key, model) {
|
160
|
+
if (!data.populate)
|
161
|
+
return;
|
162
|
+
const nested = model[key];
|
163
|
+
if (typeof nested === "undefined" ||
|
164
|
+
(Array.isArray(nested) && nested.length === 0))
|
165
|
+
return;
|
166
|
+
async function fetchPopulateValue(c, model, propName, propKeyValue) {
|
167
|
+
const cacheKey = getPopulateKey(model.constructor.name, propName, propKeyValue);
|
168
|
+
return c.get(cacheKey);
|
169
|
+
}
|
170
|
+
if (!Array.isArray(nested)) {
|
171
|
+
model[key] = await fetchPopulateValue(context, model, key, model[key]);
|
172
|
+
return;
|
173
|
+
}
|
174
|
+
const result = [];
|
175
|
+
for (const v of nested) {
|
176
|
+
const record = await fetchPopulateValue(context, model, key, v);
|
177
|
+
result.concat([record]);
|
178
|
+
}
|
179
|
+
model[key] = result;
|
180
|
+
}
|
181
|
+
const commomTypes = [
|
182
|
+
"array",
|
183
|
+
"string",
|
184
|
+
"number",
|
185
|
+
"boolean",
|
186
|
+
"symbol",
|
187
|
+
"function",
|
188
|
+
"object",
|
189
|
+
"undefined",
|
190
|
+
"null",
|
191
|
+
"bigint",
|
192
|
+
];
|
193
|
+
function repositoryFromTypeMetadata(model, propertyKey) {
|
194
|
+
const types = Reflect.getMetadata(decorator_validation_1.Validation.key(Array.isArray(model[propertyKey])
|
195
|
+
? decorator_validation_1.ValidationKeys.LIST
|
196
|
+
: decorator_validation_1.ValidationKeys.TYPE), model, propertyKey);
|
197
|
+
const customTypes = Array.isArray(model[propertyKey])
|
198
|
+
? types.class
|
199
|
+
: types.customTypes;
|
200
|
+
if (!types || !customTypes)
|
201
|
+
throw new db_decorators_1.InternalError(`Failed to find types decorators for property ${propertyKey}`);
|
202
|
+
const allowedTypes = Array.isArray(customTypes)
|
203
|
+
? [...customTypes]
|
204
|
+
: [customTypes];
|
205
|
+
const constructorName = allowedTypes.find((t) => !commomTypes.includes(`${t}`.toLowerCase()));
|
206
|
+
if (!constructorName)
|
207
|
+
throw new db_decorators_1.InternalError(`Property key ${propertyKey} does not have a valid constructor type`);
|
208
|
+
const constructor = decorator_validation_1.Model.get(constructorName);
|
209
|
+
if (!constructor)
|
210
|
+
throw new db_decorators_1.InternalError(`No registered model found for ${constructorName}`);
|
211
|
+
return Repository_1.Repository.forModel(constructor);
|
212
|
+
}
|
213
|
+
|
214
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["src/model/construction.ts"],"names":[],"mappings":"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","file":"model/construction.js","sourcesContent":["import {\n  Constructor,\n  Model,\n  Validation,\n  ValidationKeys,\n} from \"@decaf-ts/decorator-validation\";\nimport { Repository } from \"../repository/Repository\";\nimport { RelationsMetadata } from \"./types\";\nimport {\n  findModelId,\n  findPrimaryKey,\n  InternalError,\n  NotFoundError,\n} from \"@decaf-ts/db-decorators\";\nimport { PersistenceKeys } from \"../persistence/constants\";\nimport { Cascade } from \"../repository/constants\";\nimport { Context } from \"@decaf-ts/db-decorators/lib/repository/Context\";\n\nexport async function createOrUpdate<M extends Model>(\n  model: M,\n  context: Context,\n  repository: Repository<M> | undefined = undefined,\n  pk?: string\n): Promise<M> {\n  if (!repository) {\n    const constructor = Model.get(model.constructor.name);\n    if (!constructor)\n      throw new InternalError(`Could not find model ${model.constructor.name}`);\n    repository = Repository.forModel(constructor) as Repository<M>;\n  }\n  if (!pk) pk = findPrimaryKey(model).id;\n  if (typeof (model as Record<string, any>)[pk] === \"undefined\")\n    return repository.create(model, context);\n  else {\n    try {\n      return repository.update(model, context);\n    } catch (e: any) {\n      if (!(e instanceof NotFoundError)) throw e;\n      return repository.create(model, context);\n    }\n  }\n}\n\nexport async function oneToOneOnCreate<\n  M extends Model,\n  R extends Repository<M>,\n  Y extends RelationsMetadata,\n>(this: R, context: Context, data: Y, key: string, model: M): Promise<void> {\n  const propertyValue: any = (model as Record<string, any>)[key];\n  if (!propertyValue) return;\n\n  if (typeof propertyValue !== \"object\") {\n    const innerRepo = repositoryFromTypeMetadata(model, key);\n    const read = await innerRepo.read(propertyValue);\n    await cacheModelForPopulate(context, model, key, propertyValue, read);\n    (model as Record<string, any>)[key] = propertyValue;\n    return;\n  }\n\n  const constructor = Model.get(data.class);\n  if (!constructor)\n    throw new InternalError(`Could not find model ${data.class}`);\n  const repo: Repository<any> = Repository.forModel(constructor);\n  const created = await repo.create(propertyValue);\n  const pk = findPrimaryKey(created).id;\n  await cacheModelForPopulate(context, model, key, created[pk], created);\n  (model as any)[key] = created[pk];\n}\n\nexport async function oneToOneOnUpdate<\n  M extends Model,\n  R extends Repository<M>,\n  Y extends RelationsMetadata,\n>(this: R, context: Context, data: Y, key: string, model: M): Promise<void> {\n  const propertyValue: any = (model as Record<string, any>)[key];\n  if (!propertyValue) return;\n  if (data.cascade.update !== Cascade.CASCADE) return;\n\n  if (typeof propertyValue !== \"object\") {\n    const innerRepo = repositoryFromTypeMetadata(model, key);\n    const read = await innerRepo.read(propertyValue);\n    await cacheModelForPopulate(context, model, key, propertyValue, read);\n    (model as Record<string, any>)[key] = propertyValue;\n    return;\n  }\n\n  const updated = await createOrUpdate(\n    (model as Record<string, any>)[key],\n    context\n  );\n  const pk = findPrimaryKey(updated).id;\n  await cacheModelForPopulate(\n    context,\n    model,\n    key,\n    (updated as Record<string, any>)[pk],\n    updated\n  );\n  (model as any)[key] = (updated as Record<string, any>)[pk];\n}\n\nexport async function oneToOneOnDelete<\n  M extends Model,\n  R extends Repository<M>,\n  Y extends RelationsMetadata,\n>(this: R, context: Context, data: Y, key: string, model: M): Promise<void> {\n  const propertyValue: any = (model as Record<string, any>)[key];\n  if (!propertyValue) return;\n  if (data.cascade.update !== Cascade.CASCADE) return;\n  const innerRepo = repositoryFromTypeMetadata(model, key);\n  if (!(propertyValue instanceof Model))\n    await innerRepo.delete((model as Record<string, any>)[key], context);\n  else\n    await innerRepo.delete(\n      findModelId((model as Record<string, any>)[key]),\n      context\n    );\n}\n\nexport async function oneToManyOnCreate<\n  M extends Model,\n  R extends Repository<M>,\n  Y extends RelationsMetadata,\n>(this: R, context: Context, data: Y, key: string, model: M): Promise<void> {\n  const propertyValues: any = (model as Record<string, any>)[key];\n  if (!propertyValues || !propertyValues.length) return;\n  const arrayType = typeof propertyValues[0];\n  if (!propertyValues.every((item: any) => typeof item === arrayType))\n    throw new InternalError(\n      `Invalid operation. All elements of property ${key} must match the same type.`\n    );\n  const uniqueValues = new Set([...propertyValues]);\n  if (arrayType !== \"object\") {\n    const repo = repositoryFromTypeMetadata(model, key);\n    for (const id of uniqueValues) {\n      const read = await repo.read(id);\n      await cacheModelForPopulate(context, model, key, id, read);\n    }\n    (model as any)[key] = uniqueValues;\n    return;\n  }\n\n  const pkName = findPrimaryKey(propertyValues[0]).id;\n\n  const result: Set<string> = new Set();\n\n  for (const m of propertyValues) {\n    const record = await createOrUpdate(m, context);\n    await cacheModelForPopulate(context, model, key, record[pkName], record);\n    result.add(record[pkName]);\n  }\n\n  (model as any)[key] = [...result];\n}\n\nexport async function oneToManyOnUpdate<\n  M extends Model,\n  R extends Repository<M>,\n  Y extends RelationsMetadata,\n>(this: R, context: Context, data: Y, key: string, model: M): Promise<void> {\n  const { cascade } = data;\n  if (cascade.update !== Cascade.CASCADE) return;\n  return oneToManyOnCreate.call(this, context, data, key, model);\n}\n\nexport async function oneToManyOnDelete<\n  M extends Model,\n  R extends Repository<M>,\n  Y extends RelationsMetadata,\n>(this: R, context: Context, data: Y, key: string, id: string): Promise<void> {\n  if (data.cascade.delete !== Cascade.CASCADE) return;\n  const model = await this.read(id);\n  const values = (model as Record<string, any>)[key];\n  if (!values || !values.length) return;\n  const arrayType = typeof values[0];\n  const areAllSameType = values.every((item: any) => typeof item === arrayType);\n  if (!areAllSameType)\n    throw new InternalError(\n      `Invalid operation. All elements of property ${key} must match the same type.`\n    );\n  const isInstantiated = arrayType === Object.name;\n  const repo = isInstantiated\n    ? Repository.forModel(values[0])\n    : repositoryFromTypeMetadata(model, key);\n  let pk: string;\n  if (isInstantiated) pk = findPrimaryKey(values[0]).id;\n  const uniqueValues = new Set([\n    ...(isInstantiated\n      ? values\n      : values.map((v: Record<string, any>) => v[pk])),\n  ]);\n\n  for (const id of uniqueValues) {\n    const deleted = await repo.delete(id, context);\n    await cacheModelForPopulate(context, model, key, id, deleted);\n  }\n  (model as any)[key] = [...uniqueValues];\n}\n\nexport function getPopulateKey(\n  tableName: string,\n  fieldName: string,\n  id: string | number\n) {\n  return [PersistenceKeys.POPULATE, tableName, fieldName, id].join(\".\");\n}\n\nexport async function cacheModelForPopulate(\n  context: Context,\n  parentModel: any,\n  propertyKey: string,\n  pkValue: string | number,\n  cacheValue: any\n) {\n  const cacheKey = getPopulateKey(\n    parentModel.constructor.name,\n    propertyKey,\n    pkValue\n  );\n  return context.put(cacheKey, cacheValue);\n}\n\nexport async function populate<\n  M extends Model,\n  R extends Repository<M>,\n  Y extends RelationsMetadata,\n>(this: R, context: Context, data: Y, key: string, model: M): Promise<void> {\n  if (!data.populate) return;\n  const nested: any = (model as Record<string, any>)[key];\n  if (\n    typeof nested === \"undefined\" ||\n    (Array.isArray(nested) && nested.length === 0)\n  )\n    return;\n\n  async function fetchPopulateValue(\n    c: Context,\n    model: Model,\n    propName: string,\n    propKeyValue: any\n  ) {\n    const cacheKey = getPopulateKey(\n      model.constructor.name,\n      propName,\n      propKeyValue\n    );\n    return c.get(cacheKey);\n  }\n  if (!Array.isArray(nested)) {\n    (model as any)[key] = await fetchPopulateValue(\n      context,\n      model,\n      key,\n      (model as Record<string, any>)[key]\n    );\n    return;\n  }\n\n  const result: M[] = [];\n\n  for (const v of nested) {\n    const record = await fetchPopulateValue(context, model, key, v);\n    result.concat([record]);\n  }\n  (model as Record<string, any>)[key] = result;\n}\n\nconst commomTypes = [\n  \"array\",\n  \"string\",\n  \"number\",\n  \"boolean\",\n  \"symbol\",\n  \"function\",\n  \"object\",\n  \"undefined\",\n  \"null\",\n  \"bigint\",\n];\n\nexport function repositoryFromTypeMetadata<M extends Model>(\n  model: any,\n  propertyKey: string\n): Repository<M> {\n  const types = Reflect.getMetadata(\n    Validation.key(\n      Array.isArray(model[propertyKey])\n        ? ValidationKeys.LIST\n        : ValidationKeys.TYPE\n    ),\n    model,\n    propertyKey\n  );\n  const customTypes: any = Array.isArray(model[propertyKey])\n    ? types.class\n    : types.customTypes;\n  if (!types || !customTypes)\n    throw new InternalError(\n      `Failed to find types decorators for property ${propertyKey}`\n    );\n\n  const allowedTypes: string[] = Array.isArray(customTypes)\n    ? [...customTypes]\n    : [customTypes];\n  const constructorName = allowedTypes.find(\n    (t) => !commomTypes.includes(`${t}`.toLowerCase())\n  );\n  if (!constructorName)\n    throw new InternalError(\n      `Property key ${propertyKey} does not have a valid constructor type`\n    );\n  const constructor: Constructor<M> | undefined = Model.get(constructorName);\n  if (!constructor)\n    throw new InternalError(`No registered model found for ${constructorName}`);\n\n  return Repository.forModel(constructor);\n}\n"]}
|
@@ -0,0 +1,15 @@
|
|
1
|
+
import { Model } from "@decaf-ts/decorator-validation";
|
2
|
+
import { Repository } from "../repository/Repository";
|
3
|
+
import { RelationsMetadata } from "./types";
|
4
|
+
import { Context } from "@decaf-ts/db-decorators/lib/repository/Context";
|
5
|
+
export declare function createOrUpdate<M extends Model>(model: M, context: Context, repository?: Repository<M> | undefined, pk?: string): Promise<M>;
|
6
|
+
export declare function oneToOneOnCreate<M extends Model, R extends Repository<M>, Y extends RelationsMetadata>(this: R, context: Context, data: Y, key: string, model: M): Promise<void>;
|
7
|
+
export declare function oneToOneOnUpdate<M extends Model, R extends Repository<M>, Y extends RelationsMetadata>(this: R, context: Context, data: Y, key: string, model: M): Promise<void>;
|
8
|
+
export declare function oneToOneOnDelete<M extends Model, R extends Repository<M>, Y extends RelationsMetadata>(this: R, context: Context, data: Y, key: string, model: M): Promise<void>;
|
9
|
+
export declare function oneToManyOnCreate<M extends Model, R extends Repository<M>, Y extends RelationsMetadata>(this: R, context: Context, data: Y, key: string, model: M): Promise<void>;
|
10
|
+
export declare function oneToManyOnUpdate<M extends Model, R extends Repository<M>, Y extends RelationsMetadata>(this: R, context: Context, data: Y, key: string, model: M): Promise<void>;
|
11
|
+
export declare function oneToManyOnDelete<M extends Model, R extends Repository<M>, Y extends RelationsMetadata>(this: R, context: Context, data: Y, key: string, id: string): Promise<void>;
|
12
|
+
export declare function getPopulateKey(tableName: string, fieldName: string, id: string | number): string;
|
13
|
+
export declare function cacheModelForPopulate(context: Context, parentModel: any, propertyKey: string, pkValue: string | number, cacheValue: any): Promise<void>;
|
14
|
+
export declare function populate<M extends Model, R extends Repository<M>, Y extends RelationsMetadata>(this: R, context: Context, data: Y, key: string, model: M): Promise<void>;
|
15
|
+
export declare function repositoryFromTypeMetadata<M extends Model>(model: any, propertyKey: string): Repository<M>;
|
package/lib/model/decorators.cjs
CHANGED
@@ -5,13 +5,18 @@ exports.column = column;
|
|
5
5
|
exports.index = index;
|
6
6
|
exports.uniqueOnCreateUpdate = uniqueOnCreateUpdate;
|
7
7
|
exports.unique = unique;
|
8
|
+
exports.oneToOne = oneToOne;
|
9
|
+
exports.oneToMany = oneToMany;
|
10
|
+
exports.manyToOne = manyToOne;
|
8
11
|
const db_decorators_1 = require("@decaf-ts/db-decorators");
|
9
12
|
const reflection_1 = require("@decaf-ts/reflection");
|
10
13
|
const constants_1 = require("../persistence/constants.cjs");
|
14
|
+
const constants_2 = require("../repository/constants.cjs");
|
11
15
|
const decorator_validation_1 = require("@decaf-ts/decorator-validation");
|
12
16
|
const Adapter_1 = require("../persistence/Adapter.cjs");
|
13
17
|
const Repository_1 = require("../repository/Repository.cjs");
|
14
18
|
const Condition_1 = require("../query/Condition.cjs");
|
19
|
+
const construction_1 = require("./construction.cjs");
|
15
20
|
function table(tableName) {
|
16
21
|
return (0, reflection_1.metadata)(Adapter_1.Adapter.key(constants_1.PersistenceKeys.TABLE), tableName);
|
17
22
|
}
|
@@ -55,5 +60,79 @@ async function uniqueOnCreateUpdate(data, key, model) {
|
|
55
60
|
function unique() {
|
56
61
|
return (0, reflection_1.apply)((0, db_decorators_1.onCreateUpdate)(uniqueOnCreateUpdate), (0, decorator_validation_1.propMetadata)(Repository_1.Repository.key(constants_1.PersistenceKeys.UNIQUE), {}));
|
57
62
|
}
|
63
|
+
/**
|
64
|
+
* @summary One To One relation Decorators
|
65
|
+
*
|
66
|
+
* @param {Constructor<any>} clazz the {@link Sequence} to use. Defaults to {@link NoneSequence}
|
67
|
+
* @param {CascadeMetadata} [cascadeOptions]
|
68
|
+
* @param {boolean} populate If true, replaces the specified key in the document with the corresponding record from the database
|
69
|
+
*
|
70
|
+
* @function onToOne
|
71
|
+
*
|
72
|
+
* @memberOf module:wallet-db.Decorators
|
73
|
+
*
|
74
|
+
* @see oneToMany
|
75
|
+
* @see manyToOne
|
76
|
+
*/
|
77
|
+
function oneToOne(clazz, cascadeOptions = constants_2.DefaultCascade, populate = true) {
|
78
|
+
decorator_validation_1.Model.register(clazz);
|
79
|
+
const metadata = {
|
80
|
+
class: clazz.name,
|
81
|
+
cascade: cascadeOptions,
|
82
|
+
populate: populate,
|
83
|
+
};
|
84
|
+
return (0, reflection_1.apply)((0, decorator_validation_1.type)([clazz.name, String.name, Number.name, BigInt.name]), (0, db_decorators_1.onCreate)(construction_1.oneToOneOnCreate, metadata), (0, db_decorators_1.onUpdate)(construction_1.oneToOneOnUpdate, metadata), (0, db_decorators_1.onDelete)(construction_1.oneToOneOnDelete, metadata), (0, db_decorators_1.afterAny)(construction_1.populate, metadata), (0, decorator_validation_1.propMetadata)(Repository_1.Repository.key(constants_1.PersistenceKeys.ONE_TO_ONE), metadata));
|
85
|
+
}
|
86
|
+
/**
|
87
|
+
* @summary One To Many relation Decorators
|
88
|
+
*
|
89
|
+
* @param {Constructor<any>} clazz the {@link Sequence} to use. Defaults to {@link NoneSequence}
|
90
|
+
* @param {CascadeMetadata} [cascadeOptions]
|
91
|
+
*
|
92
|
+
* @function oneToMany
|
93
|
+
*
|
94
|
+
* @memberOf module:wallet-db.Decorators
|
95
|
+
*
|
96
|
+
* @see oneToOne
|
97
|
+
* @see manyToOne
|
98
|
+
*/
|
99
|
+
function oneToMany(clazz, cascadeOptions = constants_2.DefaultCascade, populate = true) {
|
100
|
+
decorator_validation_1.Model.register(clazz);
|
101
|
+
const metadata = {
|
102
|
+
class: clazz.name,
|
103
|
+
cascade: cascadeOptions,
|
104
|
+
populate: populate,
|
105
|
+
};
|
106
|
+
return (0, reflection_1.apply)(
|
107
|
+
// @ts-expect-error forced override of previous decorator
|
108
|
+
(0, decorator_validation_1.list)([clazz, String, Number, BigInt]), (0, db_decorators_1.onCreate)(construction_1.oneToManyOnCreate, metadata), (0, db_decorators_1.onUpdate)(construction_1.oneToManyOnUpdate, metadata), (0, db_decorators_1.onDelete)(construction_1.oneToManyOnDelete, metadata), (0, db_decorators_1.afterAny)(construction_1.populate, metadata), (0, decorator_validation_1.propMetadata)(Repository_1.Repository.key(constants_1.PersistenceKeys.ONE_TO_MANY), metadata));
|
109
|
+
}
|
110
|
+
/**
|
111
|
+
* @summary Many To One relation Decorators
|
112
|
+
*
|
113
|
+
* @param {Constructor<any>} clazz the {@link Sequence} to use. Defaults to {@link NoneSequence}
|
114
|
+
* @param {CascadeMetadata} [cascadeOptions]
|
115
|
+
*
|
116
|
+
* @function manyToOne
|
117
|
+
*
|
118
|
+
* @memberOf module:wallet-db.Decorators
|
119
|
+
*
|
120
|
+
* @see oneToMany
|
121
|
+
* @see oneToOne
|
122
|
+
*/
|
123
|
+
function manyToOne(clazz, cascadeOptions = constants_2.DefaultCascade, populate = true) {
|
124
|
+
decorator_validation_1.Model.register(clazz);
|
125
|
+
const metadata = {
|
126
|
+
class: clazz.name,
|
127
|
+
cascade: cascadeOptions,
|
128
|
+
populate: populate,
|
129
|
+
};
|
130
|
+
return (0, reflection_1.apply)((0, decorator_validation_1.type)([clazz.name, String.name, Number.name, BigInt.name]),
|
131
|
+
// onCreate(oneToManyOnCreate, metadata),
|
132
|
+
// onUpdate(oneToManyOnUpdate, metadata),
|
133
|
+
// onDelete(oneToManyOnDelete, metadata),
|
134
|
+
// afterAll(populate, metadata),
|
135
|
+
(0, decorator_validation_1.propMetadata)(Repository_1.Repository.key(constants_1.PersistenceKeys.MANY_TO_ONE), metadata));
|
136
|
+
}
|
58
137
|
|
59
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9tb2RlbC9kZWNvcmF0b3JzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBVUEsc0JBRUM7QUFFRCx3QkFFQztBQVlELHNCQVVDO0FBRUQsb0RBYUM7QUFXRCx3QkFLQztBQXJFRCwyREFBd0U7QUFDeEUscURBQXVEO0FBQ3ZELHdEQUEyRDtBQUczRCx5RUFBcUU7QUFDckUsb0RBQWlEO0FBQ2pELHlEQUFzRDtBQUN0RCxrREFBK0M7QUFFL0MsU0FBZ0IsS0FBSyxDQUFDLFNBQWlCO0lBQ3JDLE9BQU8sSUFBQSxxQkFBUSxFQUFDLGlCQUFPLENBQUMsR0FBRyxDQUFDLDJCQUFlLENBQUMsS0FBSyxDQUFDLEVBQUUsU0FBUyxDQUFDLENBQUM7QUFDakUsQ0FBQztBQUVELFNBQWdCLE1BQU0sQ0FBQyxVQUFrQjtJQUN2QyxPQUFPLElBQUEsbUNBQVksRUFBQyxpQkFBTyxDQUFDLEdBQUcsQ0FBQywyQkFBZSxDQUFDLE1BQU0sQ0FBQyxFQUFFLFVBQVUsQ0FBQyxDQUFDO0FBQ3ZFLENBQUM7QUFFRDs7Ozs7Ozs7O0dBU0c7QUFDSCxTQUFnQixLQUFLLENBQUMsWUFBdUIsRUFBRSxVQUE2QjtJQUMxRSxPQUFPLElBQUEsbUNBQVksRUFDakIsdUJBQVUsQ0FBQyxHQUFHLENBQ1osR0FBRywyQkFBZSxDQUFDLEtBQUssR0FBRyxZQUFZLElBQUksWUFBWSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsSUFBSSxZQUFZLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUNyRyxFQUNEO1FBQ0UsVUFBVSxFQUFFLFVBQVU7UUFDdEIsWUFBWSxFQUFFLFlBQVk7S0FDVixDQUNuQixDQUFDO0FBQ0osQ0FBQztBQUVNLEtBQUssVUFBVSxvQkFBb0IsQ0FJL0IsSUFBTyxFQUFFLEdBQVcsRUFBRSxLQUFRO0lBQ3ZDLElBQUksQ0FBRSxLQUFhLENBQUMsR0FBRyxDQUFDO1FBQUUsT0FBTztJQUNqQyxNQUFNLFFBQVEsR0FBRyxNQUFNLElBQUksQ0FBQyxNQUFNLEVBQUU7U0FDakMsS0FBSyxDQUFDLHFCQUFTLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUUsQ0FBRSxLQUFhLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztTQUN2RCxPQUFPLEVBQU8sQ0FBQztJQUNsQixJQUFJLFFBQVEsQ0FBQyxNQUFNO1FBQ2pCLE1BQU0sSUFBSSw2QkFBYSxDQUNyQixzQ0FBc0MsR0FBRyxhQUFhLElBQUksQ0FBQyxTQUFTLENBQUUsS0FBYSxDQUFDLEdBQUcsQ0FBQyxFQUFFLFNBQVMsRUFBRSxDQUFDLENBQUMsRUFBRSxDQUMxRyxDQUFDO0FBQ04sQ0FBQztBQUVEOzs7Ozs7OztHQVFHO0FBQ0gsU0FBZ0IsTUFBTTtJQUNwQixPQUFPLElBQUEsa0JBQUssRUFDVixJQUFBLDhCQUFjLEVBQUMsb0JBQW9CLENBQUMsRUFDcEMsSUFBQSxtQ0FBWSxFQUFDLHVCQUFVLENBQUMsR0FBRyxDQUFDLDJCQUFlLENBQUMsTUFBTSxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQ3pELENBQUM7QUFDSixDQUFDIiwiZmlsZSI6Im1vZGVsL2RlY29yYXRvcnMuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb25mbGljdEVycm9yLCBvbkNyZWF0ZVVwZGF0ZSB9IGZyb20gXCJAZGVjYWYtdHMvZGItZGVjb3JhdG9yc1wiO1xuaW1wb3J0IHsgYXBwbHksIG1ldGFkYXRhIH0gZnJvbSBcIkBkZWNhZi10cy9yZWZsZWN0aW9uXCI7XG5pbXBvcnQgeyBQZXJzaXN0ZW5jZUtleXMgfSBmcm9tIFwiLi4vcGVyc2lzdGVuY2UvY29uc3RhbnRzXCI7XG5pbXBvcnQgeyBJbmRleE1ldGFkYXRhIH0gZnJvbSBcIi4uL3JlcG9zaXRvcnkvdHlwZXNcIjtcbmltcG9ydCB7IE9yZGVyRGlyZWN0aW9uIH0gZnJvbSBcIi4uL3JlcG9zaXRvcnkvY29uc3RhbnRzXCI7XG5pbXBvcnQgeyBNb2RlbCwgcHJvcE1ldGFkYXRhIH0gZnJvbSBcIkBkZWNhZi10cy9kZWNvcmF0b3ItdmFsaWRhdGlvblwiO1xuaW1wb3J0IHsgQWRhcHRlciB9IGZyb20gXCIuLi9wZXJzaXN0ZW5jZS9BZGFwdGVyXCI7XG5pbXBvcnQgeyBSZXBvc2l0b3J5IH0gZnJvbSBcIi4uL3JlcG9zaXRvcnkvUmVwb3NpdG9yeVwiO1xuaW1wb3J0IHsgQ29uZGl0aW9uIH0gZnJvbSBcIi4uL3F1ZXJ5L0NvbmRpdGlvblwiO1xuXG5leHBvcnQgZnVuY3Rpb24gdGFibGUodGFibGVOYW1lOiBzdHJpbmcpIHtcbiAgcmV0dXJuIG1ldGFkYXRhKEFkYXB0ZXIua2V5KFBlcnNpc3RlbmNlS2V5cy5UQUJMRSksIHRhYmxlTmFtZSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjb2x1bW4oY29sdW1uTmFtZTogc3RyaW5nKSB7XG4gIHJldHVybiBwcm9wTWV0YWRhdGEoQWRhcHRlci5rZXkoUGVyc2lzdGVuY2VLZXlzLkNPTFVNTiksIGNvbHVtbk5hbWUpO1xufVxuXG4vKipcbiAqIEBzdW1tYXJ5IEluZGV4IERlY29yYXRvclxuICogQGRlc2NyaXB0aW9uIHByb3BlcnRpZXMgZGVjb3JhdGVkIHdpbGwgdGhlIGluZGV4IGluIHRoZVxuICogREIgZm9yIHBlcmZvcm1hbmNlIGluIHF1ZXJpZXNcbiAqXG4gKiBAcGFyYW0ge09yZGVyRGlyZWN0aW9uW119IFtkaXJlY3Rpb25zXVxuICogQHBhcmFtIHtzdHJpbmdbXX0gW2NvbXBvc2l0aW9uc11cbiAqXG4gKiBAZnVuY3Rpb24gaW5kZXhcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGluZGV4KGNvbXBvc2l0aW9ucz86IHN0cmluZ1tdLCBkaXJlY3Rpb25zPzogT3JkZXJEaXJlY3Rpb25bXSkge1xuICByZXR1cm4gcHJvcE1ldGFkYXRhKFxuICAgIFJlcG9zaXRvcnkua2V5KFxuICAgICAgYCR7UGVyc2lzdGVuY2VLZXlzLklOREVYfSR7Y29tcG9zaXRpb25zICYmIGNvbXBvc2l0aW9ucy5sZW5ndGggPyBgLiR7Y29tcG9zaXRpb25zLmpvaW4oXCIuXCIpfWAgOiBcIlwifWBcbiAgICApLFxuICAgIHtcbiAgICAgIGRpcmVjdGlvbnM6IGRpcmVjdGlvbnMsXG4gICAgICBjb21wb3NpdGlvbnM6IGNvbXBvc2l0aW9ucyxcbiAgICB9IGFzIEluZGV4TWV0YWRhdGFcbiAgKTtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHVuaXF1ZU9uQ3JlYXRlVXBkYXRlPFxuICBNIGV4dGVuZHMgTW9kZWwsXG4gIFIgZXh0ZW5kcyBSZXBvc2l0b3J5PE0+LFxuICBZID0gYW55LFxuPih0aGlzOiBSLCBkYXRhOiBZLCBrZXk6IHN0cmluZywgbW9kZWw6IE0pOiBQcm9taXNlPHZvaWQ+IHtcbiAgaWYgKCEobW9kZWwgYXMgYW55KVtrZXldKSByZXR1cm47XG4gIGNvbnN0IGV4aXN0aW5nID0gYXdhaXQgdGhpcy5zZWxlY3QoKVxuICAgIC53aGVyZShDb25kaXRpb24uYXR0cmlidXRlKGtleSkuZXEoKG1vZGVsIGFzIGFueSlba2V5XSkpXG4gICAgLmV4ZWN1dGU8TVtdPigpO1xuICBpZiAoZXhpc3RpbmcubGVuZ3RoKVxuICAgIHRocm93IG5ldyBDb25mbGljdEVycm9yKFxuICAgICAgYG1vZGVsIGFscmVhZHkgZXhpc3RzIHdpdGggcHJvcGVydHkgJHtrZXl9IGVxdWFsIHRvICR7SlNPTi5zdHJpbmdpZnkoKG1vZGVsIGFzIGFueSlba2V5XSwgdW5kZWZpbmVkLCAyKX1gXG4gICAgKTtcbn1cblxuLyoqXG4gKiBAc3VtbWFyeSBVbmlxdWUgRGVjb3JhdG9yXG4gKiBAZGVzY3JpcHRpb24gVGFncyBhIHByb3BlcnR5IGFzIHVuaXF1ZS5cbiAqICBObyBvdGhlciBlbGVtZW50cyBpbiB0aGF0IHRhYmxlIGNhbiBoYXZlIHRoZSBzYW1lIHByb3BlcnR5IHZhbHVlXG4gKlxuICogQGZ1bmN0aW9uIHVuaXF1ZVxuICpcbiAqIEBtZW1iZXJPZiBtb2R1bGU6d2FsbGV0LWRiLkRlY29yYXRvcnNcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVuaXF1ZSgpIHtcbiAgcmV0dXJuIGFwcGx5KFxuICAgIG9uQ3JlYXRlVXBkYXRlKHVuaXF1ZU9uQ3JlYXRlVXBkYXRlKSxcbiAgICBwcm9wTWV0YWRhdGEoUmVwb3NpdG9yeS5rZXkoUGVyc2lzdGVuY2VLZXlzLlVOSVFVRSksIHt9KVxuICApO1xufVxuIl19
|
138
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["src/model/decorators.ts"],"names":[],"mappings":";;AAiCA,sBAEC;AAED,wBAEC;AAYD,sBAUC;AAED,oDAaC;AAWD,wBAKC;AAgBD,4BAmBC;AAeD,8BAoBC;AAeD,8BAmBC;AApMD,2DAOiC;AACjC,qDAAuD;AACvD,wDAA2D;AAE3D,uDAAyE;AACzE,yEAMwC;AACxC,oDAAiD;AACjD,yDAAsD;AACtD,kDAA+C;AAE/C,iDAQwB;AAExB,SAAgB,KAAK,CAAC,SAAiB;IACrC,OAAO,IAAA,qBAAQ,EAAC,iBAAO,CAAC,GAAG,CAAC,2BAAe,CAAC,KAAK,CAAC,EAAE,SAAS,CAAC,CAAC;AACjE,CAAC;AAED,SAAgB,MAAM,CAAC,UAAkB;IACvC,OAAO,IAAA,mCAAY,EAAC,iBAAO,CAAC,GAAG,CAAC,2BAAe,CAAC,MAAM,CAAC,EAAE,UAAU,CAAC,CAAC;AACvE,CAAC;AAED;;;;;;;;;GASG;AACH,SAAgB,KAAK,CAAC,YAAuB,EAAE,UAA6B;IAC1E,OAAO,IAAA,mCAAY,EACjB,uBAAU,CAAC,GAAG,CACZ,GAAG,2BAAe,CAAC,KAAK,GAAG,YAAY,IAAI,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CACrG,EACD;QACE,UAAU,EAAE,UAAU;QACtB,YAAY,EAAE,YAAY;KACV,CACnB,CAAC;AACJ,CAAC;AAEM,KAAK,UAAU,oBAAoB,CAI/B,IAAO,EAAE,GAAW,EAAE,KAAQ;IACvC,IAAI,CAAE,KAAa,CAAC,GAAG,CAAC;QAAE,OAAO;IACjC,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,MAAM,EAAE;SACjC,KAAK,CAAC,qBAAS,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,EAAE,CAAE,KAAa,CAAC,GAAG,CAAC,CAAC,CAAC;SACvD,OAAO,EAAO,CAAC;IAClB,IAAI,QAAQ,CAAC,MAAM;QACjB,MAAM,IAAI,6BAAa,CACrB,sCAAsC,GAAG,aAAa,IAAI,CAAC,SAAS,CAAE,KAAa,CAAC,GAAG,CAAC,EAAE,SAAS,EAAE,CAAC,CAAC,EAAE,CAC1G,CAAC;AACN,CAAC;AAED;;;;;;;;GAQG;AACH,SAAgB,MAAM;IACpB,OAAO,IAAA,kBAAK,EACV,IAAA,8BAAc,EAAC,oBAAoB,CAAC,EACpC,IAAA,mCAAY,EAAC,uBAAU,CAAC,GAAG,CAAC,2BAAe,CAAC,MAAM,CAAC,EAAE,EAAE,CAAC,CACzD,CAAC;AACJ,CAAC;AAED;;;;;;;;;;;;;GAaG;AACH,SAAgB,QAAQ,CACtB,KAAqB,EACrB,iBAAkC,0BAAc,EAChD,WAAoB,IAAI;IAExB,4BAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACtB,MAAM,QAAQ,GAAsB;QAClC,KAAK,EAAE,KAAK,CAAC,IAAI;QACjB,OAAO,EAAE,cAAc;QACvB,QAAQ,EAAE,QAAQ;KACnB,CAAC;IACF,OAAO,IAAA,kBAAK,EACV,IAAA,2BAAI,EAAC,CAAC,KAAK,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC,EACzD,IAAA,wBAAQ,EAAC,+BAAgB,EAAE,QAAQ,CAAC,EACpC,IAAA,wBAAQ,EAAC,+BAAgB,EAAE,QAAQ,CAAC,EACpC,IAAA,wBAAQ,EAAC,+BAAgB,EAAE,QAAQ,CAAC,EACpC,IAAA,wBAAQ,EAAC,uBAAG,EAAE,QAAQ,CAAC,EACvB,IAAA,mCAAY,EAAC,uBAAU,CAAC,GAAG,CAAC,2BAAe,CAAC,UAAU,CAAC,EAAE,QAAQ,CAAC,CACnE,CAAC;AACJ,CAAC;AAED;;;;;;;;;;;;GAYG;AACH,SAAgB,SAAS,CACvB,KAAqB,EACrB,iBAAkC,0BAAc,EAChD,WAAoB,IAAI;IAExB,4BAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACtB,MAAM,QAAQ,GAAsB;QAClC,KAAK,EAAE,KAAK,CAAC,IAAI;QACjB,OAAO,EAAE,cAAc;QACvB,QAAQ,EAAE,QAAQ;KACnB,CAAC;IACF,OAAO,IAAA,kBAAK;IACV,yDAAyD;IACzD,IAAA,2BAAI,EAAC,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC,EACrC,IAAA,wBAAQ,EAAC,gCAAiB,EAAE,QAAQ,CAAC,EACrC,IAAA,wBAAQ,EAAC,gCAAiB,EAAE,QAAQ,CAAC,EACrC,IAAA,wBAAQ,EAAC,gCAAiB,EAAE,QAAQ,CAAC,EACrC,IAAA,wBAAQ,EAAC,uBAAG,EAAE,QAAQ,CAAC,EACvB,IAAA,mCAAY,EAAC,uBAAU,CAAC,GAAG,CAAC,2BAAe,CAAC,WAAW,CAAC,EAAE,QAAQ,CAAC,CACpE,CAAC;AACJ,CAAC;AAED;;;;;;;;;;;;GAYG;AACH,SAAgB,SAAS,CACvB,KAAuB,EACvB,iBAAkC,0BAAc,EAChD,QAAQ,GAAG,IAAI;IAEf,4BAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACtB,MAAM,QAAQ,GAAsB;QAClC,KAAK,EAAE,KAAK,CAAC,IAAI;QACjB,OAAO,EAAE,cAAc;QACvB,QAAQ,EAAE,QAAQ;KACnB,CAAC;IACF,OAAO,IAAA,kBAAK,EACV,IAAA,2BAAI,EAAC,CAAC,KAAK,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC;IACzD,yCAAyC;IACzC,yCAAyC;IACzC,yCAAyC;IACzC,gCAAgC;IAChC,IAAA,mCAAY,EAAC,uBAAU,CAAC,GAAG,CAAC,2BAAe,CAAC,WAAW,CAAC,EAAE,QAAQ,CAAC,CACpE,CAAC;AACJ,CAAC","file":"model/decorators.js","sourcesContent":["import {\n  ConflictError,\n  onCreate,\n  onCreateUpdate,\n  onDelete,\n  onUpdate,\n  afterAny,\n} from \"@decaf-ts/db-decorators\";\nimport { apply, metadata } from \"@decaf-ts/reflection\";\nimport { PersistenceKeys } from \"../persistence/constants\";\nimport { CascadeMetadata, IndexMetadata } from \"../repository/types\";\nimport { DefaultCascade, OrderDirection } from \"../repository/constants\";\nimport {\n  Constructor,\n  list,\n  Model,\n  propMetadata,\n  type,\n} from \"@decaf-ts/decorator-validation\";\nimport { Adapter } from \"../persistence/Adapter\";\nimport { Repository } from \"../repository/Repository\";\nimport { Condition } from \"../query/Condition\";\nimport { RelationsMetadata } from \"./types\";\nimport {\n  oneToManyOnCreate,\n  oneToManyOnDelete,\n  oneToManyOnUpdate,\n  oneToOneOnCreate,\n  oneToOneOnDelete,\n  oneToOneOnUpdate,\n  populate as pop,\n} from \"./construction\";\n\nexport function table(tableName: string) {\n  return metadata(Adapter.key(PersistenceKeys.TABLE), tableName);\n}\n\nexport function column(columnName: string) {\n  return propMetadata(Adapter.key(PersistenceKeys.COLUMN), columnName);\n}\n\n/**\n * @summary Index Decorator\n * @description properties decorated will the index in the\n * DB for performance in queries\n *\n * @param {OrderDirection[]} [directions]\n * @param {string[]} [compositions]\n *\n * @function index\n */\nexport function index(compositions?: string[], directions?: OrderDirection[]) {\n  return propMetadata(\n    Repository.key(\n      `${PersistenceKeys.INDEX}${compositions && compositions.length ? `.${compositions.join(\".\")}` : \"\"}`\n    ),\n    {\n      directions: directions,\n      compositions: compositions,\n    } as IndexMetadata\n  );\n}\n\nexport async function uniqueOnCreateUpdate<\n  M extends Model,\n  R extends Repository<M>,\n  Y = any,\n>(this: R, data: Y, key: string, model: M): Promise<void> {\n  if (!(model as any)[key]) return;\n  const existing = await this.select()\n    .where(Condition.attribute(key).eq((model as any)[key]))\n    .execute<M[]>();\n  if (existing.length)\n    throw new ConflictError(\n      `model already exists with property ${key} equal to ${JSON.stringify((model as any)[key], undefined, 2)}`\n    );\n}\n\n/**\n * @summary Unique Decorator\n * @description Tags a property as unique.\n *  No other elements in that table can have the same property value\n *\n * @function unique\n *\n * @memberOf module:wallet-db.Decorators\n */\nexport function unique() {\n  return apply(\n    onCreateUpdate(uniqueOnCreateUpdate),\n    propMetadata(Repository.key(PersistenceKeys.UNIQUE), {})\n  );\n}\n\n/**\n * @summary One To One relation Decorators\n *\n * @param {Constructor<any>} clazz the {@link Sequence} to use. Defaults to {@link NoneSequence}\n * @param {CascadeMetadata} [cascadeOptions]\n * @param {boolean} populate If true, replaces the specified key in the document with the corresponding record from the database\n *\n * @function onToOne\n *\n * @memberOf module:wallet-db.Decorators\n *\n * @see oneToMany\n * @see manyToOne\n */\nexport function oneToOne<M extends Model>(\n  clazz: Constructor<M>,\n  cascadeOptions: CascadeMetadata = DefaultCascade,\n  populate: boolean = true\n) {\n  Model.register(clazz);\n  const metadata: RelationsMetadata = {\n    class: clazz.name,\n    cascade: cascadeOptions,\n    populate: populate,\n  };\n  return apply(\n    type([clazz.name, String.name, Number.name, BigInt.name]),\n    onCreate(oneToOneOnCreate, metadata),\n    onUpdate(oneToOneOnUpdate, metadata),\n    onDelete(oneToOneOnDelete, metadata),\n    afterAny(pop, metadata),\n    propMetadata(Repository.key(PersistenceKeys.ONE_TO_ONE), metadata)\n  );\n}\n\n/**\n * @summary One To Many relation Decorators\n *\n * @param {Constructor<any>} clazz the {@link Sequence} to use. Defaults to {@link NoneSequence}\n * @param {CascadeMetadata} [cascadeOptions]\n *\n * @function oneToMany\n *\n * @memberOf module:wallet-db.Decorators\n *\n * @see oneToOne\n * @see manyToOne\n */\nexport function oneToMany<M extends Model>(\n  clazz: Constructor<M>,\n  cascadeOptions: CascadeMetadata = DefaultCascade,\n  populate: boolean = true\n) {\n  Model.register(clazz);\n  const metadata: RelationsMetadata = {\n    class: clazz.name,\n    cascade: cascadeOptions,\n    populate: populate,\n  };\n  return apply(\n    // @ts-expect-error forced override of previous decorator\n    list([clazz, String, Number, BigInt]),\n    onCreate(oneToManyOnCreate, metadata),\n    onUpdate(oneToManyOnUpdate, metadata),\n    onDelete(oneToManyOnDelete, metadata),\n    afterAny(pop, metadata),\n    propMetadata(Repository.key(PersistenceKeys.ONE_TO_MANY), metadata)\n  );\n}\n\n/**\n * @summary Many To One relation Decorators\n *\n * @param {Constructor<any>} clazz the {@link Sequence} to use. Defaults to {@link NoneSequence}\n * @param {CascadeMetadata} [cascadeOptions]\n *\n * @function manyToOne\n *\n * @memberOf module:wallet-db.Decorators\n *\n * @see oneToMany\n * @see oneToOne\n */\nexport function manyToOne(\n  clazz: Constructor<any>,\n  cascadeOptions: CascadeMetadata = DefaultCascade,\n  populate = true\n) {\n  Model.register(clazz);\n  const metadata: RelationsMetadata = {\n    class: clazz.name,\n    cascade: cascadeOptions,\n    populate: populate,\n  };\n  return apply(\n    type([clazz.name, String.name, Number.name, BigInt.name]),\n    // onCreate(oneToManyOnCreate, metadata),\n    // onUpdate(oneToManyOnUpdate, metadata),\n    // onDelete(oneToManyOnDelete, metadata),\n    // afterAll(populate, metadata),\n    propMetadata(Repository.key(PersistenceKeys.MANY_TO_ONE), metadata)\n  );\n}\n"]}
|