@decaf-ts/db-decorators 0.6.8 → 0.6.10
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/LICENSE.md +3 -2
- package/README.md +2 -2
- package/dist/db-decorators.cjs +416 -306
- package/dist/db-decorators.esm.cjs +415 -308
- package/lib/esm/index.d.ts +1 -1
- package/lib/esm/index.js +1 -1
- package/lib/esm/interfaces/IRepository.d.ts +0 -4
- package/lib/esm/interfaces/IRepository.js +1 -1
- package/lib/esm/model/decorators.d.ts +5 -3
- package/lib/esm/model/decorators.js +10 -7
- package/lib/esm/operations/decorators.d.ts +84 -18
- package/lib/esm/operations/decorators.js +145 -33
- package/lib/esm/operations/types.d.ts +38 -1
- package/lib/esm/operations/types.js +1 -1
- package/lib/esm/repository/Context.d.ts +2 -0
- package/lib/esm/repository/Context.js +3 -1
- package/lib/esm/repository/utils.js +25 -33
- package/lib/index.cjs +1 -1
- package/lib/index.d.ts +1 -1
- package/lib/interfaces/IRepository.cjs +1 -1
- package/lib/interfaces/IRepository.d.ts +0 -4
- package/lib/model/decorators.cjs +10 -7
- package/lib/model/decorators.d.ts +5 -3
- package/lib/operations/decorators.cjs +148 -33
- package/lib/operations/decorators.d.ts +84 -18
- package/lib/operations/types.cjs +1 -1
- package/lib/operations/types.d.ts +38 -1
- package/lib/repository/Context.cjs +3 -1
- package/lib/repository/Context.d.ts +2 -0
- package/lib/repository/utils.cjs +25 -33
- package/package.json +11 -4
package/lib/esm/index.d.ts
CHANGED
package/lib/esm/index.js
CHANGED
|
@@ -15,5 +15,5 @@ export * from "./validation/index.js";
|
|
|
15
15
|
* @const VERSION
|
|
16
16
|
* @memberOf module:db-decorators
|
|
17
17
|
*/
|
|
18
|
-
export const VERSION = "0.6.
|
|
18
|
+
export const VERSION = "0.6.9";
|
|
19
19
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsb0NBQTJCO0FBQzNCLHNDQUE2QjtBQUM3QixpQ0FBd0I7QUFDeEIsc0NBQTZCO0FBQzdCLHNDQUE2QjtBQUM3QixzQ0FBNkI7QUFFN0I7Ozs7R0FJRztBQUdIOzs7OztHQUtHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sT0FBTyxHQUFHLGFBQWEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL2lkZW50aXR5XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9pbnRlcmZhY2VzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9tb2RlbFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vb3BlcmF0aW9uc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vcmVwb3NpdG9yeVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vdmFsaWRhdGlvblwiO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBEYXRhYmFzZSBkZWNvcmF0b3JzIGZvciBUeXBlU2NyaXB0IGFwcGxpY2F0aW9uc1xuICogQHN1bW1hcnkgQSBjb21wcmVoZW5zaXZlIGxpYnJhcnkgcHJvdmlkaW5nIGRlY29yYXRvcnMgYW5kIHV0aWxpdGllcyBmb3IgZGF0YWJhc2Ugb3BlcmF0aW9ucywgbW9kZWwgZGVmaW5pdGlvbnMsIHZhbGlkYXRpb24sIGFuZCByZXBvc2l0b3J5IHBhdHRlcm5zIGluIFR5cGVTY3JpcHQgYXBwbGljYXRpb25zXG4gKiBAbW9kdWxlIGRiLWRlY29yYXRvcnNcbiAqL1xuXG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIEN1cnJlbnQgdmVyc2lvbiBvZiB0aGUgcmVmbGVjdGlvbiBwYWNrYWdlXG4gKiBAc3VtbWFyeSBTdG9yZXMgdGhlIHNlbWFudGljIHZlcnNpb24gbnVtYmVyIG9mIHRoZSBwYWNrYWdlXG4gKiBAY29uc3QgVkVSU0lPTlxuICogQG1lbWJlck9mIG1vZHVsZTpkYi1kZWNvcmF0b3JzXG4gKi9cbmV4cG9ydCBjb25zdCBWRVJTSU9OID0gXCIjI1ZFUlNJT04jI1wiO1xuIl19
|
|
@@ -17,9 +17,5 @@ export interface IRepository<M extends Model<true | false>, F extends Repository
|
|
|
17
17
|
* @summary Reference to the model class constructor used to create new instances
|
|
18
18
|
*/
|
|
19
19
|
readonly class: ModelConstructor<M>;
|
|
20
|
-
/**
|
|
21
|
-
* @description Primary key property name
|
|
22
|
-
* @summary The key of the primary identifier property on model M used to uniquely identify records
|
|
23
|
-
*/
|
|
24
20
|
readonly pk: keyof M;
|
|
25
21
|
}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSVJlcG9zaXRvcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvaW50ZXJmYWNlcy9JUmVwb3NpdG9yeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTW9kZWwsIE1vZGVsQ29uc3RydWN0b3IgfSBmcm9tIFwiQGRlY2FmLXRzL2RlY29yYXRvci12YWxpZGF0aW9uXCI7XG5pbXBvcnQgeyBCdWxrQ3J1ZE9wZXJhdG9yIH0gZnJvbSBcIi4vQnVsa0NydWRPcGVyYXRvclwiO1xuaW1wb3J0IHsgUmVwb3NpdG9yeUZsYWdzIH0gZnJvbSBcIi4uL3JlcG9zaXRvcnkvdHlwZXNcIjtcbmltcG9ydCB7IENvbnRleHQgfSBmcm9tIFwiLi4vcmVwb3NpdG9yeVwiO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBSZXBvc2l0b3J5IGludGVyZmFjZSBmb3IgZGF0YWJhc2Ugb3BlcmF0aW9uc1xuICogQHN1bW1hcnkgSW50ZXJmYWNlIGhvbGRpbmcgYmFzaWMgQ1JVRCBBUElzIGZvciBkYXRhYmFzZSBtb2RlbHMsIHByb3ZpZGluZyBzdGFuZGFyZCBvcGVyYXRpb25zIGFuZCBtZXRhZGF0YVxuICogQHRlbXBsYXRlIE0gLSBUeXBlIGV4dGVuZGluZyBNb2RlbFxuICogQHRlbXBsYXRlIEYgLSBUeXBlIGV4dGVuZGluZyBSZXBvc2l0b3J5RmxhZ3MsIGRlZmF1bHRzIHRvIFJlcG9zaXRvcnlGbGFnc1xuICogQHRlbXBsYXRlIEMgLSBUeXBlIGV4dGVuZGluZyBDb250ZXh0PEY+LCBkZWZhdWx0cyB0byBDb250ZXh0PEY+XG4gKiBAaW50ZXJmYWNlIElSZXBvc2l0b3J5XG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRiLWRlY29yYXRvcnNcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBJUmVwb3NpdG9yeTxcbiAgTSBleHRlbmRzIE1vZGVsPHRydWUgfCBmYWxzZT4sXG4gIEYgZXh0ZW5kcyBSZXBvc2l0b3J5RmxhZ3MgPSBSZXBvc2l0b3J5RmxhZ3MsXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW51c2VkLXZhcnNcbiAgQyBleHRlbmRzIENvbnRleHQ8Rj4gPSBDb250ZXh0PEY+
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSVJlcG9zaXRvcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvaW50ZXJmYWNlcy9JUmVwb3NpdG9yeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTW9kZWwsIE1vZGVsQ29uc3RydWN0b3IgfSBmcm9tIFwiQGRlY2FmLXRzL2RlY29yYXRvci12YWxpZGF0aW9uXCI7XG5pbXBvcnQgeyBCdWxrQ3J1ZE9wZXJhdG9yIH0gZnJvbSBcIi4vQnVsa0NydWRPcGVyYXRvclwiO1xuaW1wb3J0IHsgUmVwb3NpdG9yeUZsYWdzIH0gZnJvbSBcIi4uL3JlcG9zaXRvcnkvdHlwZXNcIjtcbmltcG9ydCB7IENvbnRleHQgfSBmcm9tIFwiLi4vcmVwb3NpdG9yeVwiO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBSZXBvc2l0b3J5IGludGVyZmFjZSBmb3IgZGF0YWJhc2Ugb3BlcmF0aW9uc1xuICogQHN1bW1hcnkgSW50ZXJmYWNlIGhvbGRpbmcgYmFzaWMgQ1JVRCBBUElzIGZvciBkYXRhYmFzZSBtb2RlbHMsIHByb3ZpZGluZyBzdGFuZGFyZCBvcGVyYXRpb25zIGFuZCBtZXRhZGF0YVxuICogQHRlbXBsYXRlIE0gLSBUeXBlIGV4dGVuZGluZyBNb2RlbFxuICogQHRlbXBsYXRlIEYgLSBUeXBlIGV4dGVuZGluZyBSZXBvc2l0b3J5RmxhZ3MsIGRlZmF1bHRzIHRvIFJlcG9zaXRvcnlGbGFnc1xuICogQHRlbXBsYXRlIEMgLSBUeXBlIGV4dGVuZGluZyBDb250ZXh0PEY+LCBkZWZhdWx0cyB0byBDb250ZXh0PEY+XG4gKiBAaW50ZXJmYWNlIElSZXBvc2l0b3J5XG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRiLWRlY29yYXRvcnNcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBJUmVwb3NpdG9yeTxcbiAgTSBleHRlbmRzIE1vZGVsPHRydWUgfCBmYWxzZT4sXG4gIEYgZXh0ZW5kcyBSZXBvc2l0b3J5RmxhZ3MgPSBSZXBvc2l0b3J5RmxhZ3MsXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW51c2VkLXZhcnNcbiAgQyBleHRlbmRzIENvbnRleHQ8Rj4gPSBDb250ZXh0PEY+LFxuPiBleHRlbmRzIEJ1bGtDcnVkT3BlcmF0b3I8TT4ge1xuICAvKipcbiAgICogQGRlc2NyaXB0aW9uIFRoZSBjb25zdHJ1Y3RvciBvZiB0aGUgbW9kZWwgY2xhc3NcbiAgICogQHN1bW1hcnkgUmVmZXJlbmNlIHRvIHRoZSBtb2RlbCBjbGFzcyBjb25zdHJ1Y3RvciB1c2VkIHRvIGNyZWF0ZSBuZXcgaW5zdGFuY2VzXG4gICAqL1xuICByZWFkb25seSBjbGFzczogTW9kZWxDb25zdHJ1Y3RvcjxNPjtcblxuICByZWFkb25seSBwazoga2V5b2YgTTtcbn1cbiJdfQ==
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Model } from "@decaf-ts/decorator-validation";
|
|
2
2
|
import { IRepository } from "../interfaces/IRepository";
|
|
3
3
|
import { Context } from "../repository/Context";
|
|
4
|
-
import { CrudOperations } from "../operations";
|
|
4
|
+
import { CrudOperations, GroupSort } from "../operations";
|
|
5
5
|
import { RepositoryFlags } from "../repository/types";
|
|
6
6
|
/**
|
|
7
7
|
* @description Hashes a property value during create or update operations
|
|
@@ -74,11 +74,12 @@ export declare function composedFromCreateUpdate<M extends Model, R extends IRep
|
|
|
74
74
|
* @param {boolean} [hash=false] - Whether to hash the composed result
|
|
75
75
|
* @param {string} [prefix=""] - Optional prefix to add to the composed value
|
|
76
76
|
* @param {string} [suffix=""] - Optional suffix to add to the composed value
|
|
77
|
+
* @param {GroupSort} groupsort - GroupSort configuration
|
|
77
78
|
* @return {PropertyDecorator} A decorator that can be applied to class properties
|
|
78
79
|
* @function composedFromKeys
|
|
79
80
|
* @category PropertyDecorators
|
|
80
81
|
*/
|
|
81
|
-
export declare function composedFromKeys(args: string[], separator?: string, hash?: boolean, prefix?: string, suffix?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
82
|
+
export declare function composedFromKeys(args: string[], separator?: string, hash?: boolean, prefix?: string, suffix?: string, groupsort?: GroupSort): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
82
83
|
/**
|
|
83
84
|
* @description Creates a decorator that composes a property value from property values
|
|
84
85
|
* @summary Decorator that generates a property value by joining the values of other properties
|
|
@@ -87,11 +88,12 @@ export declare function composedFromKeys(args: string[], separator?: string, has
|
|
|
87
88
|
* @param {boolean} [hash=false] - Whether to hash the composed result
|
|
88
89
|
* @param {string} [prefix=""] - Optional prefix to add to the composed value
|
|
89
90
|
* @param {string} [suffix=""] - Optional suffix to add to the composed value
|
|
91
|
+
* @param {GroupSort} groupsort - GroupSort configuration
|
|
90
92
|
* @return {PropertyDecorator} A decorator that can be applied to class properties
|
|
91
93
|
* @function composed
|
|
92
94
|
* @category PropertyDecorators
|
|
93
95
|
*/
|
|
94
|
-
export declare function composed(args: string[], separator?: string, hash?: boolean, prefix?: string, suffix?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
96
|
+
export declare function composed(args: string[], separator?: string, hash?: boolean, prefix?: string, suffix?: string, groupsort?: GroupSort): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
95
97
|
/**
|
|
96
98
|
* @description Creates a function that updates a version property during operations
|
|
97
99
|
* @summary Factory function that generates a callback for incrementing version numbers
|
|
@@ -87,11 +87,12 @@ export function composedFromCreateUpdate(context, data, key, model) {
|
|
|
87
87
|
* @param {"keys"|"values"} [type="values"] - Whether to use property keys or values
|
|
88
88
|
* @param {string} [prefix=""] - Optional prefix to add to the composed value
|
|
89
89
|
* @param {string} [suffix=""] - Optional suffix to add to the composed value
|
|
90
|
+
* @param {GroupSort} groupsort - GroupSort configuration
|
|
90
91
|
* @return {PropertyDecorator} A decorator that can be applied to class properties
|
|
91
92
|
* @function composedFrom
|
|
92
93
|
* @category PropertyDecorators
|
|
93
94
|
*/
|
|
94
|
-
function composedFrom(args, hashResult = false, separator = DefaultSeparator, type = "values", prefix = "", suffix = "") {
|
|
95
|
+
function composedFrom(args, hashResult = false, separator = DefaultSeparator, type = "values", prefix = "", suffix = "", groupsort = { priority: 55 }) {
|
|
95
96
|
const data = {
|
|
96
97
|
args: args,
|
|
97
98
|
hashResult: hashResult,
|
|
@@ -101,7 +102,7 @@ function composedFrom(args, hashResult = false, separator = DefaultSeparator, ty
|
|
|
101
102
|
suffix: suffix,
|
|
102
103
|
};
|
|
103
104
|
const decorators = [
|
|
104
|
-
onCreateUpdate(composedFromCreateUpdate, data),
|
|
105
|
+
onCreateUpdate(composedFromCreateUpdate, data, groupsort),
|
|
105
106
|
propMetadata(Repository.key(DBKeys.COMPOSED), data),
|
|
106
107
|
];
|
|
107
108
|
if (hashResult)
|
|
@@ -116,12 +117,13 @@ function composedFrom(args, hashResult = false, separator = DefaultSeparator, ty
|
|
|
116
117
|
* @param {boolean} [hash=false] - Whether to hash the composed result
|
|
117
118
|
* @param {string} [prefix=""] - Optional prefix to add to the composed value
|
|
118
119
|
* @param {string} [suffix=""] - Optional suffix to add to the composed value
|
|
120
|
+
* @param {GroupSort} groupsort - GroupSort configuration
|
|
119
121
|
* @return {PropertyDecorator} A decorator that can be applied to class properties
|
|
120
122
|
* @function composedFromKeys
|
|
121
123
|
* @category PropertyDecorators
|
|
122
124
|
*/
|
|
123
|
-
export function composedFromKeys(args, separator = DefaultSeparator, hash = false, prefix = "", suffix = "") {
|
|
124
|
-
return composedFrom(args, hash, separator, "keys", prefix, suffix);
|
|
125
|
+
export function composedFromKeys(args, separator = DefaultSeparator, hash = false, prefix = "", suffix = "", groupsort = { priority: 55 }) {
|
|
126
|
+
return composedFrom(args, hash, separator, "keys", prefix, suffix, groupsort);
|
|
125
127
|
}
|
|
126
128
|
/**
|
|
127
129
|
* @description Creates a decorator that composes a property value from property values
|
|
@@ -131,12 +133,13 @@ export function composedFromKeys(args, separator = DefaultSeparator, hash = fals
|
|
|
131
133
|
* @param {boolean} [hash=false] - Whether to hash the composed result
|
|
132
134
|
* @param {string} [prefix=""] - Optional prefix to add to the composed value
|
|
133
135
|
* @param {string} [suffix=""] - Optional suffix to add to the composed value
|
|
136
|
+
* @param {GroupSort} groupsort - GroupSort configuration
|
|
134
137
|
* @return {PropertyDecorator} A decorator that can be applied to class properties
|
|
135
138
|
* @function composed
|
|
136
139
|
* @category PropertyDecorators
|
|
137
140
|
*/
|
|
138
|
-
export function composed(args, separator = DefaultSeparator, hash = false, prefix = "", suffix = "") {
|
|
139
|
-
return composedFrom(args, hash, separator, "values", prefix, suffix);
|
|
141
|
+
export function composed(args, separator = DefaultSeparator, hash = false, prefix = "", suffix = "", groupsort = { priority: 55 }) {
|
|
142
|
+
return composedFrom(args, hash, separator, "values", prefix, suffix, groupsort);
|
|
140
143
|
}
|
|
141
144
|
/**
|
|
142
145
|
* @description Creates a function that updates a version property during operations
|
|
@@ -216,4 +219,4 @@ export function transient() {
|
|
|
216
219
|
})
|
|
217
220
|
.apply();
|
|
218
221
|
}
|
|
219
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../../src/model/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["import { DBKeys, DefaultSeparator } from \"./constants\";\nimport { apply } from \"@decaf-ts/reflection\";\nimport {\n  Decoration,\n  Hashing,\n  Model,\n  propMetadata,\n  type,\n} from \"@decaf-ts/decorator-validation\";\nimport { onCreate, onCreateUpdate, onUpdate } from \"../operations/decorators\";\nimport { IRepository } from \"../interfaces/IRepository\";\nimport { InternalError } from \"../repository/errors\";\nimport { Repository } from \"../repository/Repository\";\nimport { Context } from \"../repository/Context\";\nimport { CrudOperations, OperationKeys } from \"../operations\";\nimport { RepositoryFlags } from \"../repository/types\";\n\n/**\n * @description Hashes a property value during create or update operations\n * @summary Callback function used by the hash decorator to apply hashing to a property value\n * @template M - Type extending Model\n * @template R - Type extending IRepository\n * @template V - Type for metadata\n * @template F - Type extending RepositoryFlags\n * @template C - Type extending Context\n * @param {C} context - The operation context\n * @param {V} data - Metadata for the operation\n * @param key - The property key to hash\n * @param {M} model - The model being processed\n * @param {M} [oldModel] - The previous model state (for updates)\n * @return {void}\n * @function hashOnCreateUpdate\n * @memberOf module:db-decorators\n */\nexport function hashOnCreateUpdate<\n  M extends Model,\n  R extends IRepository<M, F, C>,\n  V extends object,\n  F extends RepositoryFlags = RepositoryFlags,\n  C extends Context<F> = Context<F>,\n>(this: R, context: C, data: V, key: keyof M, model: M, oldModel?: M): void {\n  if (typeof model[key] === \"undefined\") return;\n  const hash = Hashing.hash((model as any)[key]);\n  if (oldModel && (model as any)[key] === hash) return;\n  model[key] = hash;\n}\n\n/**\n * @description Creates a decorator that hashes a property value\n * @summary Decorator that automatically hashes a property value during create and update operations\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function hash\n * @category Property Decorators\n */\nexport function hash() {\n  return apply(\n    onCreateUpdate(hashOnCreateUpdate),\n    propMetadata(Repository.key(DBKeys.HASH), {})\n  );\n}\n\n/**\n * @description Metadata for composed property decorators\n * @summary Configuration options for property composition from other properties\n * @typedef {Object} ComposedFromMetadata\n * @property {string[]} args - Property names to compose from\n * @property {string} separator - Character used to join the composed values\n * @property {boolean} hashResult - Whether to hash the composed result\n * @property {\"keys\"|\"values\"} type - Whether to use property keys or values\n * @property {string} [prefix] - Optional prefix to add to the composed value\n * @property {string} [suffix] - Optional suffix to add to the composed value\n * @memberOf module:db-decorators\n */\nexport type ComposedFromMetadata = {\n  args: string[];\n  separator: string;\n  hashResult: boolean;\n  type: \"keys\" | \"values\";\n  prefix?: string;\n  suffix?: string;\n};\n\n/**\n * @description Composes a property value from other properties during create or update operations\n * @summary Callback function used by composed decorators to generate a property value from other properties\n * @template M - Type extending Model\n * @template R - Type extending IRepository\n * @template V - Type extending ComposedFromMetadata\n * @template F - Type extending RepositoryFlags\n * @template C - Type extending Context\n * @param {C} context - The operation context\n * @param {V} data - Metadata for the composition\n * @param key - The property key to set the composed value on\n * @param {M} model - The model being processed\n * @return {void}\n * @function composedFromCreateUpdate\n * @memberOf module:db-decorators\n */\nexport function composedFromCreateUpdate<\n  M extends Model,\n  R extends IRepository<M, F, C>,\n  V extends ComposedFromMetadata,\n  F extends RepositoryFlags = RepositoryFlags,\n  C extends Context<F> = Context<F>,\n>(this: R, context: C, data: V, key: keyof M, model: M) {\n  try {\n    const { args, type, prefix, suffix, separator } = data;\n    const composed = args.map((arg: string) => {\n      if (!(arg in model))\n        throw new InternalError(`Property ${arg} not found to compose from`);\n      if (type === \"keys\") return arg;\n      if (typeof (model as any)[arg] === \"undefined\")\n        throw new InternalError(\n          `Property ${args} does not contain a value to compose from`\n        );\n      return ((model as any)[arg] as any).toString();\n    });\n\n    if (prefix) composed.unshift(prefix);\n    if (suffix) composed.push(suffix);\n\n    (model as any)[key] = composed.join(separator);\n  } catch (e: any) {\n    throw new InternalError(`Failed to compose value: ${e}`);\n  }\n}\n\n/**\n * @description Creates a decorator that composes a property value from other properties\n * @summary Base function for creating property composition decorators\n * @param {string[]} args - Property names to compose from\n * @param {boolean} [hashResult=false] - Whether to hash the composed result\n * @param {string} [separator=DefaultSeparator] - Character used to join the composed values\n * @param {\"keys\"|\"values\"} [type=\"values\"] - Whether to use property keys or values\n * @param {string} [prefix=\"\"] - Optional prefix to add to the composed value\n * @param {string} [suffix=\"\"] - Optional suffix to add to the composed value\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function composedFrom\n * @category PropertyDecorators\n */\nfunction composedFrom(\n  args: string[],\n  hashResult: boolean = false,\n  separator: string = DefaultSeparator,\n  type: \"keys\" | \"values\" = \"values\",\n  prefix = \"\",\n  suffix = \"\"\n) {\n  const data: ComposedFromMetadata = {\n    args: args,\n    hashResult: hashResult,\n    separator: separator,\n    type: type,\n    prefix: prefix,\n    suffix: suffix,\n  };\n\n  const decorators = [\n    onCreateUpdate(composedFromCreateUpdate, data),\n    propMetadata(Repository.key(DBKeys.COMPOSED), data),\n  ];\n  if (hashResult) decorators.push(hash());\n  return apply(...decorators);\n}\n\n/**\n * @description Creates a decorator that composes a property value from property keys\n * @summary Decorator that generates a property value by joining the names of other properties\n * @param {string[]} args - Property names to compose from\n * @param {string} [separator=DefaultSeparator] - Character used to join the property names\n * @param {boolean} [hash=false] - Whether to hash the composed result\n * @param {string} [prefix=\"\"] - Optional prefix to add to the composed value\n * @param {string} [suffix=\"\"] - Optional suffix to add to the composed value\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function composedFromKeys\n * @category PropertyDecorators\n */\nexport function composedFromKeys(\n  args: string[],\n  separator: string = DefaultSeparator,\n  hash: boolean = false,\n  prefix = \"\",\n  suffix = \"\"\n) {\n  return composedFrom(args, hash, separator, \"keys\", prefix, suffix);\n}\n\n/**\n * @description Creates a decorator that composes a property value from property values\n * @summary Decorator that generates a property value by joining the values of other properties\n * @param {string[]} args - Property names whose values will be composed\n * @param {string} [separator=DefaultSeparator] - Character used to join the property values\n * @param {boolean} [hash=false] - Whether to hash the composed result\n * @param {string} [prefix=\"\"] - Optional prefix to add to the composed value\n * @param {string} [suffix=\"\"] - Optional suffix to add to the composed value\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function composed\n * @category PropertyDecorators\n */\nexport function composed(\n  args: string[],\n  separator: string = DefaultSeparator,\n  hash: boolean = false,\n  prefix = \"\",\n  suffix = \"\"\n) {\n  return composedFrom(args, hash, separator, \"values\", prefix, suffix);\n}\n\n/**\n * @description Creates a function that updates a version property during operations\n * @summary Factory function that generates a callback for incrementing version numbers\n * @param {CrudOperations} operation - The type of operation (CREATE or UPDATE)\n * @return {Function} A callback function that updates the version property\n * @template M - Type extending Model\n * @template R - Type extending IRepository\n * @template V - Type for metadata\n * @template F - Type extending RepositoryFlags\n * @template C - Type extending Context\n * @function versionCreateUpdate\n * @memberOf module:db-decorators\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant versionCreateUpdate\n *\n *   Caller->>versionCreateUpdate: operation\n *   versionCreateUpdate-->>Caller: callback function\n *   Note over Caller,versionCreateUpdate: When callback is executed:\n *   Caller->>versionCreateUpdate: context, data, key, model\n *   alt operation is CREATE\n *     versionCreateUpdate->>versionCreateUpdate: set version to 1\n *   else operation is UPDATE\n *     versionCreateUpdate->>versionCreateUpdate: increment version\n *   else invalid operation\n *     versionCreateUpdate->>versionCreateUpdate: throw error\n *   end\n *   versionCreateUpdate-->>Caller: void\n */\nexport function versionCreateUpdate(operation: CrudOperations) {\n  return function versionCreateUpdate<\n    M extends Model,\n    R extends IRepository<M, F, C>,\n    V extends object,\n    F extends RepositoryFlags = RepositoryFlags,\n    C extends Context<F> = Context<F>,\n  >(this: R, context: C, data: V, key: keyof M, model: M) {\n    try {\n      switch (operation) {\n        case OperationKeys.CREATE:\n          (model as any)[key] = 1;\n          break;\n        case OperationKeys.UPDATE:\n          (model as any)[key]++;\n          break;\n        default:\n          throw new InternalError(`Invalid operation: ${operation}`);\n      }\n    } catch (e: unknown) {\n      throw new InternalError(`Failed to update version: ${e}`);\n    }\n  };\n}\n\n/**\n * @description Creates a decorator for versioning a property in a model\n * @summary This decorator applies multiple sub-decorators to handle version management during create and update operations\n * @return {PropertyDecorator} A composite decorator that sets the type to Number, manages version updates, and adds versioning metadata\n * @function version\n * @category PropertyDecorators\n */\nexport function version() {\n  const key = Repository.key(DBKeys.VERSION);\n  return Decoration.for(key)\n    .define(\n      type(Number.name),\n      onCreate(versionCreateUpdate(OperationKeys.CREATE)),\n      onUpdate(versionCreateUpdate(OperationKeys.UPDATE)),\n      propMetadata(key, true)\n    )\n    .apply();\n}\n\n/**\n * @description Creates a decorator that marks a property as transient\n * @summary Decorator that indicates a property should not be persisted to the database\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function transient\n * @category PropertyDecorators\n */\nexport function transient() {\n  const key = Repository.key(DBKeys.TRANSIENT);\n  return Decoration.for(key)\n    .define(function transient(model: any, attribute: any) {\n      propMetadata(Repository.key(DBKeys.TRANSIENT), true)(model, attribute);\n      propMetadata(Repository.key(DBKeys.TRANSIENT), true)(model.constructor);\n    })\n    .apply();\n}\n"]}
|
|
222
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../../src/model/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["import { DBKeys, DefaultSeparator } from \"./constants\";\nimport { apply } from \"@decaf-ts/reflection\";\nimport {\n  Decoration,\n  Hashing,\n  Model,\n  propMetadata,\n  type,\n} from \"@decaf-ts/decorator-validation\";\nimport { onCreate, onCreateUpdate, onUpdate } from \"../operations/decorators\";\nimport { IRepository } from \"../interfaces/IRepository\";\nimport { InternalError } from \"../repository/errors\";\nimport { Repository } from \"../repository/Repository\";\nimport { Context } from \"../repository/Context\";\nimport { CrudOperations, GroupSort, OperationKeys } from \"../operations\";\nimport { RepositoryFlags } from \"../repository/types\";\n\n/**\n * @description Hashes a property value during create or update operations\n * @summary Callback function used by the hash decorator to apply hashing to a property value\n * @template M - Type extending Model\n * @template R - Type extending IRepository\n * @template V - Type for metadata\n * @template F - Type extending RepositoryFlags\n * @template C - Type extending Context\n * @param {C} context - The operation context\n * @param {V} data - Metadata for the operation\n * @param key - The property key to hash\n * @param {M} model - The model being processed\n * @param {M} [oldModel] - The previous model state (for updates)\n * @return {void}\n * @function hashOnCreateUpdate\n * @memberOf module:db-decorators\n */\nexport function hashOnCreateUpdate<\n  M extends Model,\n  R extends IRepository<M, F, C>,\n  V extends object,\n  F extends RepositoryFlags = RepositoryFlags,\n  C extends Context<F> = Context<F>,\n>(this: R, context: C, data: V, key: keyof M, model: M, oldModel?: M): void {\n  if (typeof model[key] === \"undefined\") return;\n  const hash = Hashing.hash((model as any)[key]);\n  if (oldModel && (model as any)[key] === hash) return;\n  model[key] = hash;\n}\n\n/**\n * @description Creates a decorator that hashes a property value\n * @summary Decorator that automatically hashes a property value during create and update operations\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function hash\n * @category Property Decorators\n */\nexport function hash() {\n  return apply(\n    onCreateUpdate(hashOnCreateUpdate),\n    propMetadata(Repository.key(DBKeys.HASH), {})\n  );\n}\n\n/**\n * @description Metadata for composed property decorators\n * @summary Configuration options for property composition from other properties\n * @typedef {Object} ComposedFromMetadata\n * @property {string[]} args - Property names to compose from\n * @property {string} separator - Character used to join the composed values\n * @property {boolean} hashResult - Whether to hash the composed result\n * @property {\"keys\"|\"values\"} type - Whether to use property keys or values\n * @property {string} [prefix] - Optional prefix to add to the composed value\n * @property {string} [suffix] - Optional suffix to add to the composed value\n * @memberOf module:db-decorators\n */\nexport type ComposedFromMetadata = {\n  args: string[];\n  separator: string;\n  hashResult: boolean;\n  type: \"keys\" | \"values\";\n  prefix?: string;\n  suffix?: string;\n};\n\n/**\n * @description Composes a property value from other properties during create or update operations\n * @summary Callback function used by composed decorators to generate a property value from other properties\n * @template M - Type extending Model\n * @template R - Type extending IRepository\n * @template V - Type extending ComposedFromMetadata\n * @template F - Type extending RepositoryFlags\n * @template C - Type extending Context\n * @param {C} context - The operation context\n * @param {V} data - Metadata for the composition\n * @param key - The property key to set the composed value on\n * @param {M} model - The model being processed\n * @return {void}\n * @function composedFromCreateUpdate\n * @memberOf module:db-decorators\n */\nexport function composedFromCreateUpdate<\n  M extends Model,\n  R extends IRepository<M, F, C>,\n  V extends ComposedFromMetadata,\n  F extends RepositoryFlags = RepositoryFlags,\n  C extends Context<F> = Context<F>,\n>(this: R, context: C, data: V, key: keyof M, model: M) {\n  try {\n    const { args, type, prefix, suffix, separator } = data;\n    const composed = args.map((arg: string) => {\n      if (!(arg in model))\n        throw new InternalError(`Property ${arg} not found to compose from`);\n      if (type === \"keys\") return arg;\n      if (typeof (model as any)[arg] === \"undefined\")\n        throw new InternalError(\n          `Property ${args} does not contain a value to compose from`\n        );\n      return ((model as any)[arg] as any).toString();\n    });\n\n    if (prefix) composed.unshift(prefix);\n    if (suffix) composed.push(suffix);\n\n    (model as any)[key] = composed.join(separator);\n  } catch (e: any) {\n    throw new InternalError(`Failed to compose value: ${e}`);\n  }\n}\n\n/**\n * @description Creates a decorator that composes a property value from other properties\n * @summary Base function for creating property composition decorators\n * @param {string[]} args - Property names to compose from\n * @param {boolean} [hashResult=false] - Whether to hash the composed result\n * @param {string} [separator=DefaultSeparator] - Character used to join the composed values\n * @param {\"keys\"|\"values\"} [type=\"values\"] - Whether to use property keys or values\n * @param {string} [prefix=\"\"] - Optional prefix to add to the composed value\n * @param {string} [suffix=\"\"] - Optional suffix to add to the composed value\n * @param {GroupSort} groupsort - GroupSort configuration\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function composedFrom\n * @category PropertyDecorators\n */\nfunction composedFrom(\n  args: string[],\n  hashResult: boolean = false,\n  separator: string = DefaultSeparator,\n  type: \"keys\" | \"values\" = \"values\",\n  prefix = \"\",\n  suffix = \"\",\n  groupsort: GroupSort = { priority: 55 }\n) {\n  const data: ComposedFromMetadata = {\n    args: args,\n    hashResult: hashResult,\n    separator: separator,\n    type: type,\n    prefix: prefix,\n    suffix: suffix,\n  };\n\n  const decorators = [\n    onCreateUpdate(composedFromCreateUpdate, data, groupsort),\n    propMetadata(Repository.key(DBKeys.COMPOSED), data),\n  ];\n  if (hashResult) decorators.push(hash());\n  return apply(...decorators);\n}\n\n/**\n * @description Creates a decorator that composes a property value from property keys\n * @summary Decorator that generates a property value by joining the names of other properties\n * @param {string[]} args - Property names to compose from\n * @param {string} [separator=DefaultSeparator] - Character used to join the property names\n * @param {boolean} [hash=false] - Whether to hash the composed result\n * @param {string} [prefix=\"\"] - Optional prefix to add to the composed value\n * @param {string} [suffix=\"\"] - Optional suffix to add to the composed value\n * @param {GroupSort} groupsort - GroupSort configuration\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function composedFromKeys\n * @category PropertyDecorators\n */\nexport function composedFromKeys(\n  args: string[],\n  separator: string = DefaultSeparator,\n  hash: boolean = false,\n  prefix = \"\",\n  suffix = \"\",\n  groupsort: GroupSort = { priority: 55 }\n) {\n  return composedFrom(args, hash, separator, \"keys\", prefix, suffix, groupsort);\n}\n\n/**\n * @description Creates a decorator that composes a property value from property values\n * @summary Decorator that generates a property value by joining the values of other properties\n * @param {string[]} args - Property names whose values will be composed\n * @param {string} [separator=DefaultSeparator] - Character used to join the property values\n * @param {boolean} [hash=false] - Whether to hash the composed result\n * @param {string} [prefix=\"\"] - Optional prefix to add to the composed value\n * @param {string} [suffix=\"\"] - Optional suffix to add to the composed value\n * @param {GroupSort} groupsort - GroupSort configuration\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function composed\n * @category PropertyDecorators\n */\nexport function composed(\n  args: string[],\n  separator: string = DefaultSeparator,\n  hash: boolean = false,\n  prefix = \"\",\n  suffix = \"\",\n  groupsort: GroupSort = { priority: 55 }\n) {\n  return composedFrom(\n    args,\n    hash,\n    separator,\n    \"values\",\n    prefix,\n    suffix,\n    groupsort\n  );\n}\n\n/**\n * @description Creates a function that updates a version property during operations\n * @summary Factory function that generates a callback for incrementing version numbers\n * @param {CrudOperations} operation - The type of operation (CREATE or UPDATE)\n * @return {Function} A callback function that updates the version property\n * @template M - Type extending Model\n * @template R - Type extending IRepository\n * @template V - Type for metadata\n * @template F - Type extending RepositoryFlags\n * @template C - Type extending Context\n * @function versionCreateUpdate\n * @memberOf module:db-decorators\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant versionCreateUpdate\n *\n *   Caller->>versionCreateUpdate: operation\n *   versionCreateUpdate-->>Caller: callback function\n *   Note over Caller,versionCreateUpdate: When callback is executed:\n *   Caller->>versionCreateUpdate: context, data, key, model\n *   alt operation is CREATE\n *     versionCreateUpdate->>versionCreateUpdate: set version to 1\n *   else operation is UPDATE\n *     versionCreateUpdate->>versionCreateUpdate: increment version\n *   else invalid operation\n *     versionCreateUpdate->>versionCreateUpdate: throw error\n *   end\n *   versionCreateUpdate-->>Caller: void\n */\nexport function versionCreateUpdate(operation: CrudOperations) {\n  return function versionCreateUpdate<\n    M extends Model,\n    R extends IRepository<M, F, C>,\n    V extends object,\n    F extends RepositoryFlags = RepositoryFlags,\n    C extends Context<F> = Context<F>,\n  >(this: R, context: C, data: V, key: keyof M, model: M) {\n    try {\n      switch (operation) {\n        case OperationKeys.CREATE:\n          (model as any)[key] = 1;\n          break;\n        case OperationKeys.UPDATE:\n          (model as any)[key]++;\n          break;\n        default:\n          throw new InternalError(`Invalid operation: ${operation}`);\n      }\n    } catch (e: unknown) {\n      throw new InternalError(`Failed to update version: ${e}`);\n    }\n  };\n}\n\n/**\n * @description Creates a decorator for versioning a property in a model\n * @summary This decorator applies multiple sub-decorators to handle version management during create and update operations\n * @return {PropertyDecorator} A composite decorator that sets the type to Number, manages version updates, and adds versioning metadata\n * @function version\n * @category PropertyDecorators\n */\nexport function version() {\n  const key = Repository.key(DBKeys.VERSION);\n  return Decoration.for(key)\n    .define(\n      type(Number.name),\n      onCreate(versionCreateUpdate(OperationKeys.CREATE)),\n      onUpdate(versionCreateUpdate(OperationKeys.UPDATE)),\n      propMetadata(key, true)\n    )\n    .apply();\n}\n\n/**\n * @description Creates a decorator that marks a property as transient\n * @summary Decorator that indicates a property should not be persisted to the database\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function transient\n * @category PropertyDecorators\n */\nexport function transient() {\n  const key = Repository.key(DBKeys.TRANSIENT);\n  return Decoration.for(key)\n    .define(function transient(model: any, attribute: any) {\n      propMetadata(Repository.key(DBKeys.TRANSIENT), true)(model, attribute);\n      propMetadata(Repository.key(DBKeys.TRANSIENT), true)(model.constructor);\n    })\n    .apply();\n}\n"]}
|
|
@@ -1,16 +1,82 @@
|
|
|
1
|
-
import { IdOperationHandler, OperationHandler, StandardOperationHandler, UpdateOperationHandler } from "./types";
|
|
1
|
+
import { GeneralOperationHandler, GeneralUpdateOperationHandler, IdOperationHandler, OperationHandler, StandardOperationHandler, UpdateOperationHandler } from "./types";
|
|
2
2
|
import { OperationKeys } from "./constants";
|
|
3
|
+
import { Model } from "@decaf-ts/decorator-validation";
|
|
4
|
+
import { IRepository } from "../interfaces";
|
|
5
|
+
import { RepositoryFlags } from "../repository/types";
|
|
6
|
+
import { Context } from "../repository/Context";
|
|
7
|
+
/**
|
|
8
|
+
* @description Represents sorting parameters for grouping decorators
|
|
9
|
+
* @summary Defines the structure for specifying group sorting options
|
|
10
|
+
* @typedef {Object} GroupSort
|
|
11
|
+
* @property {number} priority - The priority of the sorting operation, lower numbers represent higher priority
|
|
12
|
+
* @property {string} [group] - Optional property to group decorators, used for grouping related operations
|
|
13
|
+
* @property {number} [groupPriority] - Optional property to specify the priority within a group, lower numbers represent higher priority within the group
|
|
14
|
+
* @category Type Definitions
|
|
15
|
+
*/
|
|
16
|
+
export type GroupSort = {
|
|
17
|
+
priority: number;
|
|
18
|
+
group?: string;
|
|
19
|
+
groupPriority?: number;
|
|
20
|
+
};
|
|
21
|
+
/**
|
|
22
|
+
* @description DecoratorObject type definition
|
|
23
|
+
* @summary Defines the structure of an object used to represent a decorator in the context of database operations.
|
|
24
|
+
* @typedef {Object} DecoratorObject
|
|
25
|
+
* @property {OperationHandler<any, any, any, any, any>} handler - The handler function to be executed during the operation
|
|
26
|
+
* @property {object} data - Optional metadata to be passed to the handler function
|
|
27
|
+
* @property {string} prop - The property key to which the decorator is applied
|
|
28
|
+
* @category Type Definitions
|
|
29
|
+
*/
|
|
30
|
+
export type DecoratorObject = {
|
|
31
|
+
handler: OperationHandler<any, any, any, any, any>;
|
|
32
|
+
data: Record<string, any>[];
|
|
33
|
+
prop: string[];
|
|
34
|
+
};
|
|
35
|
+
/**
|
|
36
|
+
* @description Retrieves decorator objects for handling database operations
|
|
37
|
+
* @summary Retrieves a list of decorator objects representing operation handlers for a given model and decorators
|
|
38
|
+
* @template M - Type for the model, defaults to Model<true | false>
|
|
39
|
+
* @template R - Type for the repository, defaults to IRepository<M, F, C>
|
|
40
|
+
* @template V - Type for metadata, defaults to object
|
|
41
|
+
* @template F - Type for repository flags, defaults to RepositoryFlags
|
|
42
|
+
* @template C - Type for context, defaults to Context<F>
|
|
43
|
+
* @param {Model} model - The model for which to retrieve decorator objects
|
|
44
|
+
* @param {Record<string, DecoratorMetadata[]>} decorators - The decorators associated with the model properties
|
|
45
|
+
* @param {string} prefix - The operation prefix (e.g., 'on', 'after')
|
|
46
|
+
* @return {DecoratorObject[]} An array of decorator objects representing operation handlers
|
|
47
|
+
* @function getHandlersDecorators
|
|
48
|
+
* @category Function
|
|
49
|
+
*/
|
|
50
|
+
export declare function getHandlersDecorators<M extends Model<true | false>, R extends IRepository<M, F, C>, V extends object = object, F extends RepositoryFlags = RepositoryFlags, C extends Context<F> = Context<F>>(model: Model, decorators: Record<string, DecoratorMetadata[]>, prefix: string): DecoratorObject[];
|
|
51
|
+
/**
|
|
52
|
+
* @description Groups decorators based on their group property
|
|
53
|
+
* @summary Groups decorator objects by their group property, combining data and properties within each group
|
|
54
|
+
* @param {DecoratorObject[]} decorators - The array of decorator objects to group
|
|
55
|
+
* @return {DecoratorObject[]} An array of grouped decorator objects
|
|
56
|
+
* @function groupDecorators
|
|
57
|
+
* @category Function
|
|
58
|
+
*/
|
|
59
|
+
export declare function groupDecorators(decorators: DecoratorObject[]): DecoratorObject[];
|
|
60
|
+
/**
|
|
61
|
+
* @description Sorts decorator objects based on their priority
|
|
62
|
+
* @summary Sorts an array of decorator objects by the priority of their first data element
|
|
63
|
+
* @param {DecoratorObject[]} decorators - The array of decorator objects to sort
|
|
64
|
+
* @return {DecoratorObject[]} The sorted array of decorator objects
|
|
65
|
+
* @function sortDecorators
|
|
66
|
+
* @category Function
|
|
67
|
+
*/
|
|
68
|
+
export declare function sortDecorators(decorators: DecoratorObject[]): DecoratorObject[];
|
|
3
69
|
/**
|
|
4
70
|
* @description Decorator for handling create and update operations
|
|
5
71
|
* @summary Defines a behavior to execute during both create and update operations
|
|
6
72
|
* @template V - Type for metadata, defaults to object
|
|
7
|
-
* @param {
|
|
73
|
+
* @param {GeneralOperationHandler<any, any, V, any, any> | GeneralUpdateOperationHandler<any, any, V, any, any>} handler - The method called upon the operation
|
|
8
74
|
* @param {V} [data] - Optional metadata to pass to the handler
|
|
9
75
|
* @return {PropertyDecorator} A decorator that can be applied to class properties
|
|
10
76
|
* @function onCreateUpdate
|
|
11
77
|
* @category Property Decorators
|
|
12
78
|
*/
|
|
13
|
-
export declare function onCreateUpdate<V = object>(handler:
|
|
79
|
+
export declare function onCreateUpdate<V = object>(handler: GeneralOperationHandler<any, any, V, any, any> | GeneralUpdateOperationHandler<any, any, V, any, any>, data?: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
|
14
80
|
/**
|
|
15
81
|
* @description Decorator for handling update operations
|
|
16
82
|
* @summary Defines a behavior to execute during update operations
|
|
@@ -21,18 +87,18 @@ export declare function onCreateUpdate<V = object>(handler: StandardOperationHan
|
|
|
21
87
|
* @function onUpdate
|
|
22
88
|
* @category Property Decorators
|
|
23
89
|
*/
|
|
24
|
-
export declare function onUpdate<V = object>(handler: UpdateOperationHandler<any, any, V, any>, data?: V): (target:
|
|
90
|
+
export declare function onUpdate<V = object>(handler: UpdateOperationHandler<any, any, V, any>, data?: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
|
25
91
|
/**
|
|
26
92
|
* @description Decorator for handling create operations
|
|
27
93
|
* @summary Defines a behavior to execute during create operations
|
|
28
94
|
* @template V - Type for metadata, defaults to object
|
|
29
|
-
* @param {
|
|
95
|
+
* @param {GeneralOperationHandler<any, any, V, any, any>} handler - The method called upon the operation
|
|
30
96
|
* @param {V} [data] - Optional metadata to pass to the handler
|
|
31
97
|
* @return {PropertyDecorator} A decorator that can be applied to class properties
|
|
32
98
|
* @function onCreate
|
|
33
99
|
* @category Property Decorators
|
|
34
100
|
*/
|
|
35
|
-
export declare function onCreate<V = object>(handler:
|
|
101
|
+
export declare function onCreate<V = object>(handler: GeneralOperationHandler<any, any, V, any, any>, data?: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
|
36
102
|
/**
|
|
37
103
|
* @description Decorator for handling read operations
|
|
38
104
|
* @summary Defines a behavior to execute during read operations
|
|
@@ -43,7 +109,7 @@ export declare function onCreate<V = object>(handler: StandardOperationHandler<a
|
|
|
43
109
|
* @function onRead
|
|
44
110
|
* @category Property Decorators
|
|
45
111
|
*/
|
|
46
|
-
export declare function onRead<V = object>(handler: IdOperationHandler<any, any, V, any, any>, data: V): (target:
|
|
112
|
+
export declare function onRead<V = object>(handler: IdOperationHandler<any, any, V, any, any>, data: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
|
47
113
|
/**
|
|
48
114
|
* @description Decorator for handling delete operations
|
|
49
115
|
* @summary Defines a behavior to execute during delete operations
|
|
@@ -54,7 +120,7 @@ export declare function onRead<V = object>(handler: IdOperationHandler<any, any,
|
|
|
54
120
|
* @function onDelete
|
|
55
121
|
* @category Property Decorators
|
|
56
122
|
*/
|
|
57
|
-
export declare function onDelete<V = object>(handler: OperationHandler<any, any, V, any, any>, data: V): (target:
|
|
123
|
+
export declare function onDelete<V = object>(handler: OperationHandler<any, any, V, any, any>, data: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
|
58
124
|
/**
|
|
59
125
|
* @description Decorator for handling all operation types
|
|
60
126
|
* @summary Defines a behavior to execute during any database operation
|
|
@@ -65,7 +131,7 @@ export declare function onDelete<V = object>(handler: OperationHandler<any, any,
|
|
|
65
131
|
* @function onAny
|
|
66
132
|
* @category Property Decorators
|
|
67
133
|
*/
|
|
68
|
-
export declare function onAny<V = object>(handler: OperationHandler<any, any, V, any, any>, data: V): (target:
|
|
134
|
+
export declare function onAny<V = object>(handler: OperationHandler<any, any, V, any, any>, data: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
|
69
135
|
/**
|
|
70
136
|
* @description Base decorator for handling database operations
|
|
71
137
|
* @summary Defines a behavior to execute during specified database operations
|
|
@@ -83,7 +149,7 @@ export declare function onAny<V = object>(handler: OperationHandler<any, any, V,
|
|
|
83
149
|
* myProperty: string;
|
|
84
150
|
* }
|
|
85
151
|
*/
|
|
86
|
-
export declare function on<V = object>(op: OperationKeys[] | undefined, handler: OperationHandler<any, any, V, any, any>, data?: V): (target:
|
|
152
|
+
export declare function on<V = object>(op: OperationKeys[] | undefined, handler: OperationHandler<any, any, V, any, any>, data?: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
|
87
153
|
/**
|
|
88
154
|
* @description Decorator for handling post-create and post-update operations
|
|
89
155
|
* @summary Defines a behavior to execute after both create and update operations
|
|
@@ -94,7 +160,7 @@ export declare function on<V = object>(op: OperationKeys[] | undefined, handler:
|
|
|
94
160
|
* @function afterCreateUpdate
|
|
95
161
|
* @category Property Decorators
|
|
96
162
|
*/
|
|
97
|
-
export declare function afterCreateUpdate<V = object>(handler: StandardOperationHandler<any, any, V, any, any> | UpdateOperationHandler<any, any, V, any, any>, data: V): (target:
|
|
163
|
+
export declare function afterCreateUpdate<V = object>(handler: StandardOperationHandler<any, any, V, any, any> | UpdateOperationHandler<any, any, V, any, any>, data: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
|
98
164
|
/**
|
|
99
165
|
* @description Decorator for handling post-update operations
|
|
100
166
|
* @summary Defines a behavior to execute after update operations
|
|
@@ -105,7 +171,7 @@ export declare function afterCreateUpdate<V = object>(handler: StandardOperation
|
|
|
105
171
|
* @function afterUpdate
|
|
106
172
|
* @category Property Decorators
|
|
107
173
|
*/
|
|
108
|
-
export declare function afterUpdate<V = object>(handler: UpdateOperationHandler<any, any, V, any, any>, data: V): (target:
|
|
174
|
+
export declare function afterUpdate<V = object>(handler: UpdateOperationHandler<any, any, V, any, any>, data: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
|
109
175
|
/**
|
|
110
176
|
* @description Decorator for handling post-create operations
|
|
111
177
|
* @summary Defines a behavior to execute after create operations
|
|
@@ -116,7 +182,7 @@ export declare function afterUpdate<V = object>(handler: UpdateOperationHandler<
|
|
|
116
182
|
* @function afterCreate
|
|
117
183
|
* @category Property Decorators
|
|
118
184
|
*/
|
|
119
|
-
export declare function afterCreate<V = object>(handler: StandardOperationHandler<any, any, V, any, any>, data: V): (target:
|
|
185
|
+
export declare function afterCreate<V = object>(handler: StandardOperationHandler<any, any, V, any, any>, data: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
|
120
186
|
/**
|
|
121
187
|
* @description Decorator for handling post-read operations
|
|
122
188
|
* @summary Defines a behavior to execute after read operations
|
|
@@ -127,7 +193,7 @@ export declare function afterCreate<V = object>(handler: StandardOperationHandle
|
|
|
127
193
|
* @function afterRead
|
|
128
194
|
* @category Property Decorators
|
|
129
195
|
*/
|
|
130
|
-
export declare function afterRead<V = object>(handler: StandardOperationHandler<any, any, V, any, any>, data?: V): (target:
|
|
196
|
+
export declare function afterRead<V = object>(handler: StandardOperationHandler<any, any, V, any, any>, data?: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
|
131
197
|
/**
|
|
132
198
|
* @description Decorator for handling post-delete operations
|
|
133
199
|
* @summary Defines a behavior to execute after delete operations
|
|
@@ -138,7 +204,7 @@ export declare function afterRead<V = object>(handler: StandardOperationHandler<
|
|
|
138
204
|
* @function afterDelete
|
|
139
205
|
* @category Property Decorators
|
|
140
206
|
*/
|
|
141
|
-
export declare function afterDelete<V = object>(handler: StandardOperationHandler<any, any, V, any, any>, data?: V): (target:
|
|
207
|
+
export declare function afterDelete<V = object>(handler: StandardOperationHandler<any, any, V, any, any>, data?: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
|
142
208
|
/**
|
|
143
209
|
* @description Decorator for handling post-operation for all operation types
|
|
144
210
|
* @summary Defines a behavior to execute after any database operation
|
|
@@ -149,7 +215,7 @@ export declare function afterDelete<V = object>(handler: StandardOperationHandle
|
|
|
149
215
|
* @function afterAny
|
|
150
216
|
* @category Property Decorators
|
|
151
217
|
*/
|
|
152
|
-
export declare function afterAny<V = object>(handler: StandardOperationHandler<any, any, V, any, any>, data?: V): (target:
|
|
218
|
+
export declare function afterAny<V = object>(handler: StandardOperationHandler<any, any, V, any, any>, data?: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
|
153
219
|
/**
|
|
154
220
|
* @description Base decorator for handling post-operation behaviors
|
|
155
221
|
* @summary Defines a behavior to execute after specified database operations
|
|
@@ -167,7 +233,7 @@ export declare function afterAny<V = object>(handler: StandardOperationHandler<a
|
|
|
167
233
|
* myProperty: string;
|
|
168
234
|
* }
|
|
169
235
|
*/
|
|
170
|
-
export declare function after<V = object>(op: OperationKeys[] | undefined, handler: OperationHandler<any, any, V, any, any>, data?: V): (target:
|
|
236
|
+
export declare function after<V = object>(op: OperationKeys[] | undefined, handler: OperationHandler<any, any, V, any, any>, data?: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
|
171
237
|
/**
|
|
172
238
|
* @description Core decorator factory for operation handlers
|
|
173
239
|
* @summary Creates decorators that register handlers for database operations
|
|
@@ -196,4 +262,4 @@ export declare function after<V = object>(op: OperationKeys[] | undefined, handl
|
|
|
196
262
|
* Handler-->>Operations: Return result
|
|
197
263
|
* Operations-->>Client: Return final result
|
|
198
264
|
*/
|
|
199
|
-
export declare function operation<V = object>(baseOp: OperationKeys.ON | OperationKeys.AFTER, operation: OperationKeys[] | undefined, handler: OperationHandler<any, any, V, any, any>, dataToAdd?: V): (target:
|
|
265
|
+
export declare function operation<V = object>(baseOp: OperationKeys.ON | OperationKeys.AFTER, operation: OperationKeys[] | undefined, handler: OperationHandler<any, any, V, any, any>, dataToAdd?: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|