@decaf-ts/db-decorators 0.6.7 → 0.6.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -2
- package/dist/db-decorators.cjs +418 -377
- package/dist/db-decorators.esm.cjs +417 -379
- package/lib/esm/index.d.ts +1 -1
- package/lib/esm/index.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 +125 -1
- package/lib/esm/operations/types.js +1 -1
- package/lib/esm/repository/Context.d.ts +3 -65
- package/lib/esm/repository/Context.js +4 -71
- package/lib/esm/repository/utils.js +25 -33
- package/lib/index.cjs +1 -1
- package/lib/index.d.ts +1 -1
- 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 +125 -1
- package/lib/repository/Context.cjs +4 -71
- package/lib/repository/Context.d.ts +3 -65
- package/lib/repository/utils.cjs +25 -33
- package/package.json +1 -1
|
@@ -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
|
|
@@ -1,5 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getHandlersDecorators = getHandlersDecorators;
|
|
4
|
+
exports.groupDecorators = groupDecorators;
|
|
5
|
+
exports.sortDecorators = sortDecorators;
|
|
3
6
|
exports.onCreateUpdate = onCreateUpdate;
|
|
4
7
|
exports.onUpdate = onUpdate;
|
|
5
8
|
exports.onCreate = onCreate;
|
|
@@ -19,6 +22,10 @@ const constants_1 = require("./constants.cjs");
|
|
|
19
22
|
const Operations_1 = require("./Operations.cjs");
|
|
20
23
|
const reflection_1 = require("@decaf-ts/reflection");
|
|
21
24
|
const decorator_validation_1 = require("@decaf-ts/decorator-validation");
|
|
25
|
+
const errors_1 = require("./../repository/errors.cjs");
|
|
26
|
+
const utils_1 = require("./../repository/utils.cjs");
|
|
27
|
+
const defaultPriority = 50;
|
|
28
|
+
const DefaultGroupSort = { priority: defaultPriority };
|
|
22
29
|
/**
|
|
23
30
|
* @description Internal function to register operation handlers
|
|
24
31
|
* @summary Registers an operation handler for a specific operation key on a target property
|
|
@@ -33,18 +40,120 @@ function handle(op, handler) {
|
|
|
33
40
|
Operations_1.Operations.register(handler, op, target, propertyKey);
|
|
34
41
|
};
|
|
35
42
|
}
|
|
43
|
+
/**
|
|
44
|
+
* @description Retrieves decorator objects for handling database operations
|
|
45
|
+
* @summary Retrieves a list of decorator objects representing operation handlers for a given model and decorators
|
|
46
|
+
* @template M - Type for the model, defaults to Model<true | false>
|
|
47
|
+
* @template R - Type for the repository, defaults to IRepository<M, F, C>
|
|
48
|
+
* @template V - Type for metadata, defaults to object
|
|
49
|
+
* @template F - Type for repository flags, defaults to RepositoryFlags
|
|
50
|
+
* @template C - Type for context, defaults to Context<F>
|
|
51
|
+
* @param {Model} model - The model for which to retrieve decorator objects
|
|
52
|
+
* @param {Record<string, DecoratorMetadata[]>} decorators - The decorators associated with the model properties
|
|
53
|
+
* @param {string} prefix - The operation prefix (e.g., 'on', 'after')
|
|
54
|
+
* @return {DecoratorObject[]} An array of decorator objects representing operation handlers
|
|
55
|
+
* @function getHandlersDecorators
|
|
56
|
+
* @category Function
|
|
57
|
+
*/
|
|
58
|
+
function getHandlersDecorators(model, decorators, prefix) {
|
|
59
|
+
const accum = [];
|
|
60
|
+
for (const prop in decorators) {
|
|
61
|
+
const decs = decorators[prop];
|
|
62
|
+
for (const dec of decs) {
|
|
63
|
+
const { key } = dec;
|
|
64
|
+
const handlers = Operations_1.Operations.get(model, prop, prefix + key);
|
|
65
|
+
if (!handlers || !handlers.length)
|
|
66
|
+
throw new errors_1.InternalError(`Could not find registered handler for the operation ${prefix + key} under property ${prop}`);
|
|
67
|
+
const handlerArgs = (0, utils_1.getHandlerArgs)(dec, prop, model);
|
|
68
|
+
if (!handlerArgs || Object.values(handlerArgs).length !== handlers.length)
|
|
69
|
+
throw new errors_1.InternalError("Args and handlers length do not match");
|
|
70
|
+
for (let i = 0; i < handlers.length; i++) {
|
|
71
|
+
const data = handlerArgs[handlers[i].name]
|
|
72
|
+
.data;
|
|
73
|
+
accum.push({
|
|
74
|
+
handler: handlers[i],
|
|
75
|
+
data: [data],
|
|
76
|
+
prop: [prop],
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
return accum;
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* @description Groups decorators based on their group property
|
|
85
|
+
* @summary Groups decorator objects by their group property, combining data and properties within each group
|
|
86
|
+
* @param {DecoratorObject[]} decorators - The array of decorator objects to group
|
|
87
|
+
* @return {DecoratorObject[]} An array of grouped decorator objects
|
|
88
|
+
* @function groupDecorators
|
|
89
|
+
* @category Function
|
|
90
|
+
*/
|
|
91
|
+
function groupDecorators(decorators) {
|
|
92
|
+
const grouped = decorators.reduce((acc, dec) => {
|
|
93
|
+
if (!dec || !dec.data || !dec.prop)
|
|
94
|
+
throw new errors_1.InternalError("Missing decorator properties or data");
|
|
95
|
+
// If decorator have no group
|
|
96
|
+
if (!dec.data[0].group) {
|
|
97
|
+
acc.set(Symbol(), dec);
|
|
98
|
+
return acc;
|
|
99
|
+
}
|
|
100
|
+
const groupKey = dec.data[0].group;
|
|
101
|
+
if (!acc.has(groupKey)) {
|
|
102
|
+
// first handler is saved in the group
|
|
103
|
+
acc.set(groupKey, { ...dec });
|
|
104
|
+
}
|
|
105
|
+
else {
|
|
106
|
+
const existing = acc.get(groupKey);
|
|
107
|
+
acc.set(groupKey, {
|
|
108
|
+
handler: existing.handler,
|
|
109
|
+
data: [...existing.data, ...dec.data],
|
|
110
|
+
prop: [...existing.prop, ...dec.prop],
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
return acc;
|
|
114
|
+
}, new Map());
|
|
115
|
+
const groups = Array.from(grouped.values());
|
|
116
|
+
// Sort inside each group by priority
|
|
117
|
+
groups.forEach((group) => {
|
|
118
|
+
const combined = group.data.map((d, i) => ({
|
|
119
|
+
data: d,
|
|
120
|
+
prop: group.prop[i],
|
|
121
|
+
}));
|
|
122
|
+
combined.sort((a, b) => (a.data.groupPriority ?? 50) - (b.data.groupPriority ?? 50));
|
|
123
|
+
group.data = combined.map((c) => c.data);
|
|
124
|
+
group.prop = combined.map((c) => c.prop);
|
|
125
|
+
});
|
|
126
|
+
return groups;
|
|
127
|
+
}
|
|
128
|
+
/**
|
|
129
|
+
* @description Sorts decorator objects based on their priority
|
|
130
|
+
* @summary Sorts an array of decorator objects by the priority of their first data element
|
|
131
|
+
* @param {DecoratorObject[]} decorators - The array of decorator objects to sort
|
|
132
|
+
* @return {DecoratorObject[]} The sorted array of decorator objects
|
|
133
|
+
* @function sortDecorators
|
|
134
|
+
* @category Function
|
|
135
|
+
*/
|
|
136
|
+
function sortDecorators(decorators) {
|
|
137
|
+
// Sort by groupPriority
|
|
138
|
+
decorators.sort((a, b) => {
|
|
139
|
+
const priorityA = a.data[0].priority ?? defaultPriority;
|
|
140
|
+
const priorityB = b.data[0].priority ?? defaultPriority;
|
|
141
|
+
return priorityA - priorityB; // lower number = higher priority
|
|
142
|
+
});
|
|
143
|
+
return decorators;
|
|
144
|
+
}
|
|
36
145
|
/**
|
|
37
146
|
* @description Decorator for handling create and update operations
|
|
38
147
|
* @summary Defines a behavior to execute during both create and update operations
|
|
39
148
|
* @template V - Type for metadata, defaults to object
|
|
40
|
-
* @param {
|
|
149
|
+
* @param {GeneralOperationHandler<any, any, V, any, any> | GeneralUpdateOperationHandler<any, any, V, any, any>} handler - The method called upon the operation
|
|
41
150
|
* @param {V} [data] - Optional metadata to pass to the handler
|
|
42
151
|
* @return {PropertyDecorator} A decorator that can be applied to class properties
|
|
43
152
|
* @function onCreateUpdate
|
|
44
153
|
* @category Property Decorators
|
|
45
154
|
*/
|
|
46
|
-
function onCreateUpdate(handler, data) {
|
|
47
|
-
return on(constants_1.DBOperations.CREATE_UPDATE, handler, data);
|
|
155
|
+
function onCreateUpdate(handler, data, groupsort) {
|
|
156
|
+
return on(constants_1.DBOperations.CREATE_UPDATE, handler, data, groupsort);
|
|
48
157
|
}
|
|
49
158
|
/**
|
|
50
159
|
* @description Decorator for handling update operations
|
|
@@ -56,21 +165,21 @@ function onCreateUpdate(handler, data) {
|
|
|
56
165
|
* @function onUpdate
|
|
57
166
|
* @category Property Decorators
|
|
58
167
|
*/
|
|
59
|
-
function onUpdate(handler, data) {
|
|
60
|
-
return on(constants_1.DBOperations.UPDATE, handler, data);
|
|
168
|
+
function onUpdate(handler, data, groupsort) {
|
|
169
|
+
return on(constants_1.DBOperations.UPDATE, handler, data, groupsort);
|
|
61
170
|
}
|
|
62
171
|
/**
|
|
63
172
|
* @description Decorator for handling create operations
|
|
64
173
|
* @summary Defines a behavior to execute during create operations
|
|
65
174
|
* @template V - Type for metadata, defaults to object
|
|
66
|
-
* @param {
|
|
175
|
+
* @param {GeneralOperationHandler<any, any, V, any, any>} handler - The method called upon the operation
|
|
67
176
|
* @param {V} [data] - Optional metadata to pass to the handler
|
|
68
177
|
* @return {PropertyDecorator} A decorator that can be applied to class properties
|
|
69
178
|
* @function onCreate
|
|
70
179
|
* @category Property Decorators
|
|
71
180
|
*/
|
|
72
|
-
function onCreate(handler, data) {
|
|
73
|
-
return on(constants_1.DBOperations.CREATE, handler, data);
|
|
181
|
+
function onCreate(handler, data, groupsort) {
|
|
182
|
+
return on(constants_1.DBOperations.CREATE, handler, data, groupsort);
|
|
74
183
|
}
|
|
75
184
|
/**
|
|
76
185
|
* @description Decorator for handling read operations
|
|
@@ -82,8 +191,8 @@ function onCreate(handler, data) {
|
|
|
82
191
|
* @function onRead
|
|
83
192
|
* @category Property Decorators
|
|
84
193
|
*/
|
|
85
|
-
function onRead(handler, data) {
|
|
86
|
-
return on(constants_1.DBOperations.READ, handler, data);
|
|
194
|
+
function onRead(handler, data, groupsort) {
|
|
195
|
+
return on(constants_1.DBOperations.READ, handler, data, groupsort);
|
|
87
196
|
}
|
|
88
197
|
/**
|
|
89
198
|
* @description Decorator for handling delete operations
|
|
@@ -95,8 +204,8 @@ function onRead(handler, data) {
|
|
|
95
204
|
* @function onDelete
|
|
96
205
|
* @category Property Decorators
|
|
97
206
|
*/
|
|
98
|
-
function onDelete(handler, data) {
|
|
99
|
-
return on(constants_1.DBOperations.DELETE, handler, data);
|
|
207
|
+
function onDelete(handler, data, groupsort) {
|
|
208
|
+
return on(constants_1.DBOperations.DELETE, handler, data, groupsort);
|
|
100
209
|
}
|
|
101
210
|
/**
|
|
102
211
|
* @description Decorator for handling all operation types
|
|
@@ -108,8 +217,8 @@ function onDelete(handler, data) {
|
|
|
108
217
|
* @function onAny
|
|
109
218
|
* @category Property Decorators
|
|
110
219
|
*/
|
|
111
|
-
function onAny(handler, data) {
|
|
112
|
-
return on(constants_1.DBOperations.ALL, handler, data);
|
|
220
|
+
function onAny(handler, data, groupsort) {
|
|
221
|
+
return on(constants_1.DBOperations.ALL, handler, data, groupsort);
|
|
113
222
|
}
|
|
114
223
|
/**
|
|
115
224
|
* @description Base decorator for handling database operations
|
|
@@ -128,8 +237,8 @@ function onAny(handler, data) {
|
|
|
128
237
|
* myProperty: string;
|
|
129
238
|
* }
|
|
130
239
|
*/
|
|
131
|
-
function on(op = constants_1.DBOperations.ALL, handler, data) {
|
|
132
|
-
return operation(constants_1.OperationKeys.ON, op, handler, data);
|
|
240
|
+
function on(op = constants_1.DBOperations.ALL, handler, data, groupsort) {
|
|
241
|
+
return operation(constants_1.OperationKeys.ON, op, handler, data, groupsort);
|
|
133
242
|
}
|
|
134
243
|
/**
|
|
135
244
|
* @description Decorator for handling post-create and post-update operations
|
|
@@ -141,8 +250,8 @@ function on(op = constants_1.DBOperations.ALL, handler, data) {
|
|
|
141
250
|
* @function afterCreateUpdate
|
|
142
251
|
* @category Property Decorators
|
|
143
252
|
*/
|
|
144
|
-
function afterCreateUpdate(handler, data) {
|
|
145
|
-
return after(constants_1.DBOperations.CREATE_UPDATE, handler, data);
|
|
253
|
+
function afterCreateUpdate(handler, data, groupsort) {
|
|
254
|
+
return after(constants_1.DBOperations.CREATE_UPDATE, handler, data, groupsort);
|
|
146
255
|
}
|
|
147
256
|
/**
|
|
148
257
|
* @description Decorator for handling post-update operations
|
|
@@ -154,8 +263,8 @@ function afterCreateUpdate(handler, data) {
|
|
|
154
263
|
* @function afterUpdate
|
|
155
264
|
* @category Property Decorators
|
|
156
265
|
*/
|
|
157
|
-
function afterUpdate(handler, data) {
|
|
158
|
-
return after(constants_1.DBOperations.UPDATE, handler, data);
|
|
266
|
+
function afterUpdate(handler, data, groupsort) {
|
|
267
|
+
return after(constants_1.DBOperations.UPDATE, handler, data, groupsort);
|
|
159
268
|
}
|
|
160
269
|
/**
|
|
161
270
|
* @description Decorator for handling post-create operations
|
|
@@ -167,8 +276,8 @@ function afterUpdate(handler, data) {
|
|
|
167
276
|
* @function afterCreate
|
|
168
277
|
* @category Property Decorators
|
|
169
278
|
*/
|
|
170
|
-
function afterCreate(handler, data) {
|
|
171
|
-
return after(constants_1.DBOperations.CREATE, handler, data);
|
|
279
|
+
function afterCreate(handler, data, groupsort) {
|
|
280
|
+
return after(constants_1.DBOperations.CREATE, handler, data, groupsort);
|
|
172
281
|
}
|
|
173
282
|
/**
|
|
174
283
|
* @description Decorator for handling post-read operations
|
|
@@ -180,8 +289,8 @@ function afterCreate(handler, data) {
|
|
|
180
289
|
* @function afterRead
|
|
181
290
|
* @category Property Decorators
|
|
182
291
|
*/
|
|
183
|
-
function afterRead(handler, data) {
|
|
184
|
-
return after(constants_1.DBOperations.READ, handler, data);
|
|
292
|
+
function afterRead(handler, data, groupsort) {
|
|
293
|
+
return after(constants_1.DBOperations.READ, handler, data, groupsort);
|
|
185
294
|
}
|
|
186
295
|
/**
|
|
187
296
|
* @description Decorator for handling post-delete operations
|
|
@@ -193,8 +302,8 @@ function afterRead(handler, data) {
|
|
|
193
302
|
* @function afterDelete
|
|
194
303
|
* @category Property Decorators
|
|
195
304
|
*/
|
|
196
|
-
function afterDelete(handler, data) {
|
|
197
|
-
return after(constants_1.DBOperations.DELETE, handler, data);
|
|
305
|
+
function afterDelete(handler, data, groupsort) {
|
|
306
|
+
return after(constants_1.DBOperations.DELETE, handler, data, groupsort);
|
|
198
307
|
}
|
|
199
308
|
/**
|
|
200
309
|
* @description Decorator for handling post-operation for all operation types
|
|
@@ -206,8 +315,8 @@ function afterDelete(handler, data) {
|
|
|
206
315
|
* @function afterAny
|
|
207
316
|
* @category Property Decorators
|
|
208
317
|
*/
|
|
209
|
-
function afterAny(handler, data) {
|
|
210
|
-
return after(constants_1.DBOperations.ALL, handler, data);
|
|
318
|
+
function afterAny(handler, data, groupsort) {
|
|
319
|
+
return after(constants_1.DBOperations.ALL, handler, data, groupsort);
|
|
211
320
|
}
|
|
212
321
|
/**
|
|
213
322
|
* @description Base decorator for handling post-operation behaviors
|
|
@@ -226,8 +335,8 @@ function afterAny(handler, data) {
|
|
|
226
335
|
* myProperty: string;
|
|
227
336
|
* }
|
|
228
337
|
*/
|
|
229
|
-
function after(op = constants_1.DBOperations.ALL, handler, data) {
|
|
230
|
-
return operation(constants_1.OperationKeys.AFTER, op, handler, data);
|
|
338
|
+
function after(op = constants_1.DBOperations.ALL, handler, data, groupsort) {
|
|
339
|
+
return operation(constants_1.OperationKeys.AFTER, op, handler, data, groupsort);
|
|
231
340
|
}
|
|
232
341
|
/**
|
|
233
342
|
* @description Core decorator factory for operation handlers
|
|
@@ -257,7 +366,7 @@ function after(op = constants_1.DBOperations.ALL, handler, data) {
|
|
|
257
366
|
* Handler-->>Operations: Return result
|
|
258
367
|
* Operations-->>Client: Return final result
|
|
259
368
|
*/
|
|
260
|
-
function operation(baseOp, operation = constants_1.DBOperations.ALL, handler, dataToAdd) {
|
|
369
|
+
function operation(baseOp, operation = constants_1.DBOperations.ALL, handler, dataToAdd, groupsort = DefaultGroupSort) {
|
|
261
370
|
return (target, propertyKey) => {
|
|
262
371
|
const name = target.constructor.name;
|
|
263
372
|
const decorators = operation.reduce((accum, op) => {
|
|
@@ -269,6 +378,12 @@ function operation(baseOp, operation = constants_1.DBOperations.ALL, handler, da
|
|
|
269
378
|
handlers: {},
|
|
270
379
|
};
|
|
271
380
|
const handlerKey = Operations_1.Operations.getHandlerName(handler);
|
|
381
|
+
let mergeData = groupsort;
|
|
382
|
+
if (dataToAdd) {
|
|
383
|
+
if (Object.keys(dataToAdd).filter((key) => key in groupsort).length > 0)
|
|
384
|
+
throw new errors_1.InternalError(`Unable to merge groupSort into dataToAdd due to overlaping keys`);
|
|
385
|
+
mergeData = { ...groupsort, ...dataToAdd };
|
|
386
|
+
}
|
|
272
387
|
if (!data.handlers[name] ||
|
|
273
388
|
!data.handlers[name][propertyKey] ||
|
|
274
389
|
!(handlerKey in data.handlers[name][propertyKey])) {
|
|
@@ -276,7 +391,7 @@ function operation(baseOp, operation = constants_1.DBOperations.ALL, handler, da
|
|
|
276
391
|
data.handlers[name][propertyKey] =
|
|
277
392
|
data.handlers[name][propertyKey] || {};
|
|
278
393
|
data.handlers[name][propertyKey][handlerKey] = {
|
|
279
|
-
data:
|
|
394
|
+
data: mergeData,
|
|
280
395
|
};
|
|
281
396
|
accum.push(handle(compoundKey, handler), (0, decorator_validation_1.propMetadata)(Operations_1.Operations.key(compoundKey), data));
|
|
282
397
|
}
|
|
@@ -285,4 +400,4 @@ function operation(baseOp, operation = constants_1.DBOperations.ALL, handler, da
|
|
|
285
400
|
return (0, reflection_1.apply)(...decorators)(target, propertyKey);
|
|
286
401
|
};
|
|
287
402
|
}
|
|
288
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../src/operations/decorators.ts"],"names":[],"mappings":";;AAuCA,wCAOC;AAWD,4BAKC;AAWD,4BAKC;AAYD,wBAKC;AAYD,4BAKC;AAYD,sBAKC;AAmBD,gBAMC;AAWD,8CAOC;AAYD,kCAKC;AAYD,kCAKC;AAYD,8BAKC;AAWD,kCAKC;AAYD,4BAKC;AAmBD,sBAMC;AA8BD,8BA4CC;AA7VD,+CAA0D;AAC1D,iDAA0C;AAC1C,qDAA6C;AAC7C,yEAA8D;AAE9D;;;;;;;;GAQG;AACH,SAAS,MAAM,CACb,EAAiB,EACjB,OAAkD;IAElD,OAAO,CAAC,MAAW,EAAE,WAAmB,EAAE,EAAE;QAC1C,uBAAU,CAAC,QAAQ,CAAC,OAAO,EAAE,EAAE,EAAE,MAAM,EAAE,WAAW,CAAC,CAAC;IACxD,CAAC,CAAC;AACJ,CAAC;AAED;;;;;;;;;GASG;AACH,SAAgB,cAAc,CAC5B,OAEiD,EACjD,IAAQ;IAER,OAAO,EAAE,CAAC,wBAAY,CAAC,aAAa,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;AACvD,CAAC;AACD;;;;;;;;;GASG;AACH,SAAgB,QAAQ,CACtB,OAAiD,EACjD,IAAQ;IAER,OAAO,EAAE,CAAC,wBAAY,CAAC,MAAM,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;AAChD,CAAC;AACD;;;;;;;;;GASG;AACH,SAAgB,QAAQ,CACtB,OAAwD,EACxD,IAAQ;IAER,OAAO,EAAE,CAAC,wBAAY,CAAC,MAAM,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;AAChD,CAAC;AAED;;;;;;;;;GASG;AACH,SAAgB,MAAM,CACpB,OAAkD,EAClD,IAAO;IAEP,OAAO,EAAE,CAAC,wBAAY,CAAC,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;AAC9C,CAAC;AAED;;;;;;;;;GASG;AACH,SAAgB,QAAQ,CACtB,OAAgD,EAChD,IAAO;IAEP,OAAO,EAAE,CAAC,wBAAY,CAAC,MAAM,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;AAChD,CAAC;AAED;;;;;;;;;GASG;AACH,SAAgB,KAAK,CACnB,OAAgD,EAChD,IAAO;IAEP,OAAO,EAAE,CAAC,wBAAY,CAAC,GAAG,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;AAC7C,CAAC;AAED;;;;;;;;;;;;;;;;GAgBG;AACH,SAAgB,EAAE,CAChB,KAAsB,wBAAY,CAAC,GAAG,EACtC,OAAgD,EAChD,IAAQ;IAER,OAAO,SAAS,CAAC,yBAAa,CAAC,EAAE,EAAE,EAAE,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;AACxD,CAAC;AACD;;;;;;;;;GASG;AACH,SAAgB,iBAAiB,CAC/B,OAEiD,EACjD,IAAO;IAEP,OAAO,KAAK,CAAC,wBAAY,CAAC,aAAa,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;AAC1D,CAAC;AAED;;;;;;;;;GASG;AACH,SAAgB,WAAW,CACzB,OAAsD,EACtD,IAAO;IAEP,OAAO,KAAK,CAAC,wBAAY,CAAC,MAAM,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;AACnD,CAAC;AAED;;;;;;;;;GASG;AACH,SAAgB,WAAW,CACzB,OAAwD,EACxD,IAAO;IAEP,OAAO,KAAK,CAAC,wBAAY,CAAC,MAAM,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;AACnD,CAAC;AAED;;;;;;;;;GASG;AACH,SAAgB,SAAS,CACvB,OAAwD,EACxD,IAAQ;IAER,OAAO,KAAK,CAAC,wBAAY,CAAC,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;AACjD,CAAC;AACD;;;;;;;;;GASG;AACH,SAAgB,WAAW,CACzB,OAAwD,EACxD,IAAQ;IAER,OAAO,KAAK,CAAC,wBAAY,CAAC,MAAM,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;AACnD,CAAC;AAED;;;;;;;;;GASG;AACH,SAAgB,QAAQ,CACtB,OAAwD,EACxD,IAAQ;IAER,OAAO,KAAK,CAAC,wBAAY,CAAC,GAAG,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;AAChD,CAAC;AAED;;;;;;;;;;;;;;;;GAgBG;AACH,SAAgB,KAAK,CACnB,KAAsB,wBAAY,CAAC,GAAG,EACtC,OAAgD,EAChD,IAAQ;IAER,OAAO,SAAS,CAAC,yBAAa,CAAC,KAAK,EAAE,EAAE,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;AAC3D,CAAC;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2BG;AACH,SAAgB,SAAS,CACvB,MAA8C,EAC9C,YAA6B,wBAAY,CAAC,GAAG,EAC7C,OAAgD,EAChD,SAAa;IAEb,OAAO,CAAC,MAAc,EAAE,WAAiB,EAAE,EAAE;QAC3C,MAAM,IAAI,GAAG,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC;QACrC,MAAM,UAAU,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC,KAAY,EAAE,EAAE,EAAE,EAAE;YACvD,MAAM,WAAW,GAAG,MAAM,GAAG,EAAE,CAAC;YAChC,IAAI,IAAI,GAAG,OAAO,CAAC,WAAW,CAC5B,uBAAU,CAAC,GAAG,CAAC,WAAW,CAAC,EAC3B,MAAM,EACN,WAAW,CACZ,CAAC;YACF,IAAI,CAAC,IAAI;gBACP,IAAI,GAAG;oBACL,SAAS,EAAE,EAAE;oBACb,QAAQ,EAAE,EAAE;iBACb,CAAC;YAEJ,MAAM,UAAU,GAAG,uBAAU,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;YAEtD,IACE,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;gBACpB,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;gBACjC,CAAC,CAAC,UAAU,IAAI,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC,CAAC,EACjD,CAAC;gBACD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;gBAChD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;oBAC9B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC;gBACzC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC,CAAC,UAAU,CAAC,GAAG;oBAC7C,IAAI,EAAE,SAAS;iBAChB,CAAC;gBAEF,KAAK,CAAC,IAAI,CACR,MAAM,CAAC,WAA4B,EAAE,OAAO,CAAC,EAC7C,IAAA,mCAAY,EAAC,uBAAU,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE,IAAI,CAAC,CAChD,CAAC;YACJ,CAAC;YACD,OAAO,KAAK,CAAC;QACf,CAAC,EAAE,EAAE,CAAC,CAAC;QACP,OAAO,IAAA,kBAAK,EAAC,GAAG,UAAU,CAAC,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IACnD,CAAC,CAAC;AACJ,CAAC","sourcesContent":["import {\n  IdOperationHandler,\n  OperationHandler,\n  StandardOperationHandler,\n  UpdateOperationHandler,\n} from \"./types\";\nimport { DBOperations, OperationKeys } from \"./constants\";\nimport { Operations } from \"./Operations\";\nimport { apply } from \"@decaf-ts/reflection\";\nimport { propMetadata } from \"@decaf-ts/decorator-validation\";\n\n/**\n * @description Internal function to register operation handlers\n * @summary Registers an operation handler for a specific operation key on a target property\n * @param {OperationKeys} op - The operation key to handle\n * @param {OperationHandler<any, any, any, any, any>} handler - The handler function to register\n * @return {PropertyDecorator} A decorator that registers the handler\n * @function handle\n * @category Property Decorators\n */\nfunction handle(\n  op: OperationKeys,\n  handler: OperationHandler<any, any, any, any, any>\n) {\n  return (target: any, propertyKey: string) => {\n    Operations.register(handler, op, target, propertyKey);\n  };\n}\n\n/**\n * @description Decorator for handling create and update operations\n * @summary Defines a behavior to execute during both create and update operations\n * @template V - Type for metadata, defaults to object\n * @param {StandardOperationHandler<any, any, V, any, any> | UpdateOperationHandler<any, any, V, any, any>} handler - The method called upon the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function onCreateUpdate\n * @category Property Decorators\n */\nexport function onCreateUpdate<V = object>(\n  handler:\n    | StandardOperationHandler<any, any, V, any, any>\n    | UpdateOperationHandler<any, any, V, any, any>,\n  data?: V\n) {\n  return on(DBOperations.CREATE_UPDATE, handler, data);\n}\n/**\n * @description Decorator for handling update operations\n * @summary Defines a behavior to execute during update operations\n * @template V - Type for metadata, defaults to object\n * @param {UpdateOperationHandler<any, any, V, any>} handler - The method called upon the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function onUpdate\n * @category Property Decorators\n */\nexport function onUpdate<V = object>(\n  handler: UpdateOperationHandler<any, any, V, any>,\n  data?: V\n) {\n  return on(DBOperations.UPDATE, handler, data);\n}\n/**\n * @description Decorator for handling create operations\n * @summary Defines a behavior to execute during create operations\n * @template V - Type for metadata, defaults to object\n * @param {StandardOperationHandler<any, any, V, any, any>} handler - The method called upon the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function onCreate\n * @category Property Decorators\n */\nexport function onCreate<V = object>(\n  handler: StandardOperationHandler<any, any, V, any, any>,\n  data?: V\n) {\n  return on(DBOperations.CREATE, handler, data);\n}\n\n/**\n * @description Decorator for handling read operations\n * @summary Defines a behavior to execute during read operations\n * @template V - Type for metadata, defaults to object\n * @param {IdOperationHandler<any, any, V, any, any>} handler - The method called upon the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function onRead\n * @category Property Decorators\n */\nexport function onRead<V = object>(\n  handler: IdOperationHandler<any, any, V, any, any>,\n  data: V\n) {\n  return on(DBOperations.READ, handler, data);\n}\n\n/**\n * @description Decorator for handling delete operations\n * @summary Defines a behavior to execute during delete operations\n * @template V - Type for metadata, defaults to object\n * @param {OperationHandler<any, any, V, any, any>} handler - The method called upon the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function onDelete\n * @category Property Decorators\n */\nexport function onDelete<V = object>(\n  handler: OperationHandler<any, any, V, any, any>,\n  data: V\n) {\n  return on(DBOperations.DELETE, handler, data);\n}\n\n/**\n * @description Decorator for handling all operation types\n * @summary Defines a behavior to execute during any database operation\n * @template V - Type for metadata, defaults to object\n * @param {OperationHandler<any, any, V, any, any>} handler - The method called upon the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function onAny\n * @category Property Decorators\n */\nexport function onAny<V = object>(\n  handler: OperationHandler<any, any, V, any, any>,\n  data: V\n) {\n  return on(DBOperations.ALL, handler, data);\n}\n\n/**\n * @description Base decorator for handling database operations\n * @summary Defines a behavior to execute during specified database operations\n * @template V - Type for metadata, defaults to object\n * @param {OperationKeys[] | DBOperations} [op=DBOperations.ALL] - One or more operation types to handle\n * @param {OperationHandler<any, any, V, any, any>} handler - The method called upon the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function on\n * @category Property Decorators\n * @example\n * // Example usage:\n * class MyModel {\n *   @on(DBOperations.CREATE, myHandler)\n *   myProperty: string;\n * }\n */\nexport function on<V = object>(\n  op: OperationKeys[] = DBOperations.ALL,\n  handler: OperationHandler<any, any, V, any, any>,\n  data?: V\n) {\n  return operation(OperationKeys.ON, op, handler, data);\n}\n/**\n * @description Decorator for handling post-create and post-update operations\n * @summary Defines a behavior to execute after both create and update operations\n * @template V - Type for metadata, defaults to object\n * @param {StandardOperationHandler<any, any, V, any, any> | UpdateOperationHandler<any, any, V, any, any>} handler - The method called after the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function afterCreateUpdate\n * @category Property Decorators\n */\nexport function afterCreateUpdate<V = object>(\n  handler:\n    | StandardOperationHandler<any, any, V, any, any>\n    | UpdateOperationHandler<any, any, V, any, any>,\n  data: V\n) {\n  return after(DBOperations.CREATE_UPDATE, handler, data);\n}\n\n/**\n * @description Decorator for handling post-update operations\n * @summary Defines a behavior to execute after update operations\n * @template V - Type for metadata, defaults to object\n * @param {UpdateOperationHandler<any, any, V, any, any>} handler - The method called after the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function afterUpdate\n * @category Property Decorators\n */\nexport function afterUpdate<V = object>(\n  handler: UpdateOperationHandler<any, any, V, any, any>,\n  data: V\n) {\n  return after(DBOperations.UPDATE, handler, data);\n}\n\n/**\n * @description Decorator for handling post-create operations\n * @summary Defines a behavior to execute after create operations\n * @template V - Type for metadata, defaults to object\n * @param {StandardOperationHandler<any, any, V, any, any>} handler - The method called after the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function afterCreate\n * @category Property Decorators\n */\nexport function afterCreate<V = object>(\n  handler: StandardOperationHandler<any, any, V, any, any>,\n  data: V\n) {\n  return after(DBOperations.CREATE, handler, data);\n}\n\n/**\n * @description Decorator for handling post-read operations\n * @summary Defines a behavior to execute after read operations\n * @template V - Type for metadata, defaults to object\n * @param {StandardOperationHandler<any, any, V, any, any>} handler - The method called after the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function afterRead\n * @category Property Decorators\n */\nexport function afterRead<V = object>(\n  handler: StandardOperationHandler<any, any, V, any, any>,\n  data?: V\n) {\n  return after(DBOperations.READ, handler, data);\n}\n/**\n * @description Decorator for handling post-delete operations\n * @summary Defines a behavior to execute after delete operations\n * @template V - Type for metadata, defaults to object\n * @param {StandardOperationHandler<any, any, V, any, any>} handler - The method called after the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function afterDelete\n * @category Property Decorators\n */\nexport function afterDelete<V = object>(\n  handler: StandardOperationHandler<any, any, V, any, any>,\n  data?: V\n) {\n  return after(DBOperations.DELETE, handler, data);\n}\n\n/**\n * @description Decorator for handling post-operation for all operation types\n * @summary Defines a behavior to execute after any database operation\n * @template V - Type for metadata, defaults to object\n * @param {StandardOperationHandler<any, any, V, any, any>} handler - The method called after the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function afterAny\n * @category Property Decorators\n */\nexport function afterAny<V = object>(\n  handler: StandardOperationHandler<any, any, V, any, any>,\n  data?: V\n) {\n  return after(DBOperations.ALL, handler, data);\n}\n\n/**\n * @description Base decorator for handling post-operation behaviors\n * @summary Defines a behavior to execute after specified database operations\n * @template V - Type for metadata, defaults to object\n * @param {OperationKeys[] | DBOperations} [op=DBOperations.ALL] - One or more operation types to handle\n * @param {OperationHandler<any, any, V, any, any>} handler - The method called after the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function after\n * @category Property Decorators\n * @example\n * // Example usage:\n * class MyModel {\n *   @after(DBOperations.CREATE, myHandler)\n *   myProperty: string;\n * }\n */\nexport function after<V = object>(\n  op: OperationKeys[] = DBOperations.ALL,\n  handler: OperationHandler<any, any, V, any, any>,\n  data?: V\n) {\n  return operation(OperationKeys.AFTER, op, handler, data);\n}\n\n/**\n * @description Core decorator factory for operation handlers\n * @summary Creates decorators that register handlers for database operations\n * @template V - Type for metadata, defaults to object\n * @param {OperationKeys.ON | OperationKeys.AFTER} baseOp - Whether the handler runs during or after the operation\n * @param {OperationKeys[]} [operation=DBOperations.ALL] - The specific operations to handle\n * @param {OperationHandler<any, any, V, any, any>} handler - The handler function to execute\n * @param {V} [dataToAdd] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function operation\n * @category Property Decorators\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant Decorator as @operation\n *   participant Operations as Operations Registry\n *   participant Handler\n *\n *   Client->>Decorator: Apply to property\n *   Decorator->>Operations: Register handler\n *   Decorator->>Decorator: Store metadata\n *\n *   Note over Client,Handler: Later, during operation execution\n *   Client->>Operations: Execute operation\n *   Operations->>Handler: Call registered handler\n *   Handler-->>Operations: Return result\n *   Operations-->>Client: Return final result\n */\nexport function operation<V = object>(\n  baseOp: OperationKeys.ON | OperationKeys.AFTER,\n  operation: OperationKeys[] = DBOperations.ALL,\n  handler: OperationHandler<any, any, V, any, any>,\n  dataToAdd?: V\n) {\n  return (target: object, propertyKey?: any) => {\n    const name = target.constructor.name;\n    const decorators = operation.reduce((accum: any[], op) => {\n      const compoundKey = baseOp + op;\n      let data = Reflect.getMetadata(\n        Operations.key(compoundKey),\n        target,\n        propertyKey\n      );\n      if (!data)\n        data = {\n          operation: op,\n          handlers: {},\n        };\n\n      const handlerKey = Operations.getHandlerName(handler);\n\n      if (\n        !data.handlers[name] ||\n        !data.handlers[name][propertyKey] ||\n        !(handlerKey in data.handlers[name][propertyKey])\n      ) {\n        data.handlers[name] = data.handlers[name] || {};\n        data.handlers[name][propertyKey] =\n          data.handlers[name][propertyKey] || {};\n        data.handlers[name][propertyKey][handlerKey] = {\n          data: dataToAdd,\n        };\n\n        accum.push(\n          handle(compoundKey as OperationKeys, handler),\n          propMetadata(Operations.key(compoundKey), data)\n        );\n      }\n      return accum;\n    }, []);\n    return apply(...decorators)(target, propertyKey);\n  };\n}\n"]}
|
|
403
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../src/operations/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  GeneralOperationHandler,\n  GeneralUpdateOperationHandler,\n  IdOperationHandler,\n  OperationHandler,\n  StandardOperationHandler,\n  UpdateOperationHandler,\n} from \"./types\";\nimport { DBOperations, OperationKeys } from \"./constants\";\nimport { Operations } from \"./Operations\";\nimport { apply } from \"@decaf-ts/reflection\";\nimport { Model, propMetadata } from \"@decaf-ts/decorator-validation\";\nimport { IRepository } from \"../interfaces\";\nimport { RepositoryFlags } from \"../repository/types\";\nimport { Context } from \"../repository/Context\";\nimport { InternalError } from \"../repository/errors\";\nimport { getHandlerArgs } from \"../repository/utils\";\n\n/**\n * @description Represents sorting parameters for grouping decorators\n * @summary Defines the structure for specifying group sorting options\n * @typedef {Object} GroupSort\n * @property {number} priority - The priority of the sorting operation, lower numbers represent higher priority\n * @property {string} [group] - Optional property to group decorators, used for grouping related operations\n * @property {number} [groupPriority] - Optional property to specify the priority within a group, lower numbers represent higher priority within the group\n * @category Type Definitions\n */\nexport type GroupSort = {\n  priority: number;\n  group?: string;\n  groupPriority?: number;\n};\n\nconst defaultPriority = 50;\n\nconst DefaultGroupSort: GroupSort = { priority: defaultPriority };\n\n/**\n * @description DecoratorObject type definition\n * @summary Defines the structure of an object used to represent a decorator in the context of database operations.\n * @typedef {Object} DecoratorObject\n * @property {OperationHandler<any, any, any, any, any>} handler - The handler function to be executed during the operation\n * @property {object} data - Optional metadata to be passed to the handler function\n * @property {string} prop - The property key to which the decorator is applied\n * @category Type Definitions\n */\nexport type DecoratorObject = {\n  handler: OperationHandler<any, any, any, any, any>;\n  data: Record<string, any>[];\n  prop: string[];\n};\n\n/**\n * @description Internal function to register operation handlers\n * @summary Registers an operation handler for a specific operation key on a target property\n * @param {OperationKeys} op - The operation key to handle\n * @param {OperationHandler<any, any, any, any, any>} handler - The handler function to register\n * @return {PropertyDecorator} A decorator that registers the handler\n * @function handle\n * @category Property Decorators\n */\nfunction handle(\n  op: OperationKeys,\n  handler: OperationHandler<any, any, any, any, any>\n) {\n  return (target: any, propertyKey: string) => {\n    Operations.register(handler, op, target, propertyKey);\n  };\n}\n\n/**\n * @description Retrieves decorator objects for handling database operations\n * @summary Retrieves a list of decorator objects representing operation handlers for a given model and decorators\n * @template M - Type for the model, defaults to Model<true | false>\n * @template R - Type for the repository, defaults to IRepository<M, F, C>\n * @template V - Type for metadata, defaults to object\n * @template F - Type for repository flags, defaults to RepositoryFlags\n * @template C - Type for context, defaults to Context<F>\n * @param {Model} model - The model for which to retrieve decorator objects\n * @param {Record<string, DecoratorMetadata[]>} decorators - The decorators associated with the model properties\n * @param {string} prefix - The operation prefix (e.g., 'on', 'after')\n * @return {DecoratorObject[]} An array of decorator objects representing operation handlers\n * @function getHandlersDecorators\n * @category Function\n */\nexport function getHandlersDecorators<\n  M extends Model<true | false>,\n  R extends IRepository<M, F, C>,\n  V extends object = object,\n  F extends RepositoryFlags = RepositoryFlags,\n  C extends Context<F> = Context<F>,\n>(\n  model: Model,\n  decorators: Record<string, DecoratorMetadata[]>,\n  prefix: string\n): DecoratorObject[] {\n  const accum: DecoratorObject[] = [];\n  for (const prop in decorators) {\n    const decs: DecoratorMetadata[] = decorators[prop];\n    for (const dec of decs) {\n      const { key } = dec!;\n      const handlers: OperationHandler<M, R, V, F, C>[] | undefined =\n        Operations.get<M, R, V, F, C>(model, prop, prefix + key);\n      if (!handlers || !handlers.length)\n        throw new InternalError(\n          `Could not find registered handler for the operation ${prefix + key} under property ${prop}`\n        );\n\n      const handlerArgs = getHandlerArgs(dec, prop, model as any);\n\n      if (!handlerArgs || Object.values(handlerArgs).length !== handlers.length)\n        throw new InternalError(\"Args and handlers length do not match\");\n\n      for (let i = 0; i < handlers.length; i++) {\n        const data = (handlerArgs[handlers[i].name] as Record<string, any>)\n          .data;\n        accum.push({\n          handler: handlers[i],\n          data: [data],\n          prop: [prop],\n        });\n      }\n    }\n  }\n  return accum;\n}\n\n/**\n * @description Groups decorators based on their group property\n * @summary Groups decorator objects by their group property, combining data and properties within each group\n * @param {DecoratorObject[]} decorators - The array of decorator objects to group\n * @return {DecoratorObject[]} An array of grouped decorator objects\n * @function groupDecorators\n * @category Function\n */\nexport function groupDecorators(\n  decorators: DecoratorObject[]\n): DecoratorObject[] {\n  const grouped = decorators.reduce<Map<string | symbol, DecoratorObject>>(\n    (acc, dec) => {\n      if (!dec || !dec.data || !dec.prop)\n        throw new InternalError(\"Missing decorator properties or data\");\n\n      // If decorator have no group\n      if (!dec.data[0].group) {\n        acc.set(Symbol(), dec);\n        return acc;\n      }\n\n      const groupKey = dec.data[0].group;\n\n      if (!acc.has(groupKey)) {\n        // first handler is saved in the group\n        acc.set(groupKey, { ...dec });\n      } else {\n        const existing = acc.get(groupKey)!;\n\n        acc.set(groupKey, {\n          handler: existing.handler,\n          data: [...existing.data, ...dec.data],\n          prop: [...existing.prop, ...dec.prop],\n        });\n      }\n\n      return acc;\n    },\n    new Map()\n  );\n\n  const groups = Array.from(grouped.values());\n\n  // Sort inside each group by priority\n  groups.forEach((group) => {\n    const combined = group.data.map((d, i) => ({\n      data: d,\n      prop: group.prop[i],\n    }));\n\n    combined.sort(\n      (a, b) => (a.data.groupPriority ?? 50) - (b.data.groupPriority ?? 50)\n    );\n\n    group.data = combined.map((c) => c.data);\n    group.prop = combined.map((c) => c.prop);\n  });\n\n  return groups;\n}\n\n/**\n * @description Sorts decorator objects based on their priority\n * @summary Sorts an array of decorator objects by the priority of their first data element\n * @param {DecoratorObject[]} decorators - The array of decorator objects to sort\n * @return {DecoratorObject[]} The sorted array of decorator objects\n * @function sortDecorators\n * @category Function\n */\nexport function sortDecorators(\n  decorators: DecoratorObject[]\n): DecoratorObject[] {\n  // Sort by groupPriority\n  decorators.sort((a, b) => {\n    const priorityA = a.data[0].priority ?? defaultPriority;\n    const priorityB = b.data[0].priority ?? defaultPriority;\n    return priorityA - priorityB; // lower number = higher priority\n  });\n\n  return decorators;\n}\n\n/**\n * @description Decorator for handling create and update operations\n * @summary Defines a behavior to execute during both create and update operations\n * @template V - Type for metadata, defaults to object\n * @param {GeneralOperationHandler<any, any, V, any, any> | GeneralUpdateOperationHandler<any, any, V, any, any>} handler - The method called upon the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function onCreateUpdate\n * @category Property Decorators\n */\nexport function onCreateUpdate<V = object>(\n  handler:\n    | GeneralOperationHandler<any, any, V, any, any>\n    | GeneralUpdateOperationHandler<any, any, V, any, any>,\n  data?: V,\n  groupsort?: GroupSort\n) {\n  return on(DBOperations.CREATE_UPDATE, handler, data, groupsort);\n}\n/**\n * @description Decorator for handling update operations\n * @summary Defines a behavior to execute during update operations\n * @template V - Type for metadata, defaults to object\n * @param {UpdateOperationHandler<any, any, V, any>} handler - The method called upon the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function onUpdate\n * @category Property Decorators\n */\nexport function onUpdate<V = object>(\n  handler: UpdateOperationHandler<any, any, V, any>,\n  data?: V,\n  groupsort?: GroupSort\n) {\n  return on(DBOperations.UPDATE, handler, data, groupsort);\n}\n/**\n * @description Decorator for handling create operations\n * @summary Defines a behavior to execute during create operations\n * @template V - Type for metadata, defaults to object\n * @param {GeneralOperationHandler<any, any, V, any, any>} handler - The method called upon the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function onCreate\n * @category Property Decorators\n */\nexport function onCreate<V = object>(\n  handler: GeneralOperationHandler<any, any, V, any, any>,\n  data?: V,\n  groupsort?: GroupSort\n) {\n  return on(DBOperations.CREATE, handler, data, groupsort);\n}\n\n/**\n * @description Decorator for handling read operations\n * @summary Defines a behavior to execute during read operations\n * @template V - Type for metadata, defaults to object\n * @param {IdOperationHandler<any, any, V, any, any>} handler - The method called upon the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function onRead\n * @category Property Decorators\n */\nexport function onRead<V = object>(\n  handler: IdOperationHandler<any, any, V, any, any>,\n  data: V,\n  groupsort?: GroupSort\n) {\n  return on(DBOperations.READ, handler, data, groupsort);\n}\n\n/**\n * @description Decorator for handling delete operations\n * @summary Defines a behavior to execute during delete operations\n * @template V - Type for metadata, defaults to object\n * @param {OperationHandler<any, any, V, any, any>} handler - The method called upon the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function onDelete\n * @category Property Decorators\n */\nexport function onDelete<V = object>(\n  handler: OperationHandler<any, any, V, any, any>,\n  data: V,\n  groupsort?: GroupSort\n) {\n  return on(DBOperations.DELETE, handler, data, groupsort);\n}\n\n/**\n * @description Decorator for handling all operation types\n * @summary Defines a behavior to execute during any database operation\n * @template V - Type for metadata, defaults to object\n * @param {OperationHandler<any, any, V, any, any>} handler - The method called upon the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function onAny\n * @category Property Decorators\n */\nexport function onAny<V = object>(\n  handler: OperationHandler<any, any, V, any, any>,\n  data: V,\n  groupsort?: GroupSort\n) {\n  return on(DBOperations.ALL, handler, data, groupsort);\n}\n\n/**\n * @description Base decorator for handling database operations\n * @summary Defines a behavior to execute during specified database operations\n * @template V - Type for metadata, defaults to object\n * @param {OperationKeys[] | DBOperations} [op=DBOperations.ALL] - One or more operation types to handle\n * @param {OperationHandler<any, any, V, any, any>} handler - The method called upon the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function on\n * @category Property Decorators\n * @example\n * // Example usage:\n * class MyModel {\n *   @on(DBOperations.CREATE, myHandler)\n *   myProperty: string;\n * }\n */\nexport function on<V = object>(\n  op: OperationKeys[] = DBOperations.ALL,\n  handler: OperationHandler<any, any, V, any, any>,\n  data?: V,\n  groupsort?: GroupSort\n) {\n  return operation(OperationKeys.ON, op, handler, data, groupsort);\n}\n/**\n * @description Decorator for handling post-create and post-update operations\n * @summary Defines a behavior to execute after both create and update operations\n * @template V - Type for metadata, defaults to object\n * @param {StandardOperationHandler<any, any, V, any, any> | UpdateOperationHandler<any, any, V, any, any>} handler - The method called after the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function afterCreateUpdate\n * @category Property Decorators\n */\nexport function afterCreateUpdate<V = object>(\n  handler:\n    | StandardOperationHandler<any, any, V, any, any>\n    | UpdateOperationHandler<any, any, V, any, any>,\n  data: V,\n  groupsort?: GroupSort\n) {\n  return after(DBOperations.CREATE_UPDATE, handler, data, groupsort);\n}\n\n/**\n * @description Decorator for handling post-update operations\n * @summary Defines a behavior to execute after update operations\n * @template V - Type for metadata, defaults to object\n * @param {UpdateOperationHandler<any, any, V, any, any>} handler - The method called after the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function afterUpdate\n * @category Property Decorators\n */\nexport function afterUpdate<V = object>(\n  handler: UpdateOperationHandler<any, any, V, any, any>,\n  data: V,\n  groupsort?: GroupSort\n) {\n  return after(DBOperations.UPDATE, handler, data, groupsort);\n}\n\n/**\n * @description Decorator for handling post-create operations\n * @summary Defines a behavior to execute after create operations\n * @template V - Type for metadata, defaults to object\n * @param {StandardOperationHandler<any, any, V, any, any>} handler - The method called after the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function afterCreate\n * @category Property Decorators\n */\nexport function afterCreate<V = object>(\n  handler: StandardOperationHandler<any, any, V, any, any>,\n  data: V,\n  groupsort?: GroupSort\n) {\n  return after(DBOperations.CREATE, handler, data, groupsort);\n}\n\n/**\n * @description Decorator for handling post-read operations\n * @summary Defines a behavior to execute after read operations\n * @template V - Type for metadata, defaults to object\n * @param {StandardOperationHandler<any, any, V, any, any>} handler - The method called after the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function afterRead\n * @category Property Decorators\n */\nexport function afterRead<V = object>(\n  handler: StandardOperationHandler<any, any, V, any, any>,\n  data?: V,\n  groupsort?: GroupSort\n) {\n  return after(DBOperations.READ, handler, data, groupsort);\n}\n/**\n * @description Decorator for handling post-delete operations\n * @summary Defines a behavior to execute after delete operations\n * @template V - Type for metadata, defaults to object\n * @param {StandardOperationHandler<any, any, V, any, any>} handler - The method called after the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function afterDelete\n * @category Property Decorators\n */\nexport function afterDelete<V = object>(\n  handler: StandardOperationHandler<any, any, V, any, any>,\n  data?: V,\n  groupsort?: GroupSort\n) {\n  return after(DBOperations.DELETE, handler, data, groupsort);\n}\n\n/**\n * @description Decorator for handling post-operation for all operation types\n * @summary Defines a behavior to execute after any database operation\n * @template V - Type for metadata, defaults to object\n * @param {StandardOperationHandler<any, any, V, any, any>} handler - The method called after the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function afterAny\n * @category Property Decorators\n */\nexport function afterAny<V = object>(\n  handler: StandardOperationHandler<any, any, V, any, any>,\n  data?: V,\n  groupsort?: GroupSort\n) {\n  return after(DBOperations.ALL, handler, data, groupsort);\n}\n\n/**\n * @description Base decorator for handling post-operation behaviors\n * @summary Defines a behavior to execute after specified database operations\n * @template V - Type for metadata, defaults to object\n * @param {OperationKeys[] | DBOperations} [op=DBOperations.ALL] - One or more operation types to handle\n * @param {OperationHandler<any, any, V, any, any>} handler - The method called after the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function after\n * @category Property Decorators\n * @example\n * // Example usage:\n * class MyModel {\n *   @after(DBOperations.CREATE, myHandler)\n *   myProperty: string;\n * }\n */\nexport function after<V = object>(\n  op: OperationKeys[] = DBOperations.ALL,\n  handler: OperationHandler<any, any, V, any, any>,\n  data?: V,\n  groupsort?: GroupSort\n) {\n  return operation(OperationKeys.AFTER, op, handler, data, groupsort);\n}\n\n/**\n * @description Core decorator factory for operation handlers\n * @summary Creates decorators that register handlers for database operations\n * @template V - Type for metadata, defaults to object\n * @param {OperationKeys.ON | OperationKeys.AFTER} baseOp - Whether the handler runs during or after the operation\n * @param {OperationKeys[]} [operation=DBOperations.ALL] - The specific operations to handle\n * @param {OperationHandler<any, any, V, any, any>} handler - The handler function to execute\n * @param {V} [dataToAdd] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function operation\n * @category Property Decorators\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant Decorator as @operation\n *   participant Operations as Operations Registry\n *   participant Handler\n *\n *   Client->>Decorator: Apply to property\n *   Decorator->>Operations: Register handler\n *   Decorator->>Decorator: Store metadata\n *\n *   Note over Client,Handler: Later, during operation execution\n *   Client->>Operations: Execute operation\n *   Operations->>Handler: Call registered handler\n *   Handler-->>Operations: Return result\n *   Operations-->>Client: Return final result\n */\nexport function operation<V = object>(\n  baseOp: OperationKeys.ON | OperationKeys.AFTER,\n  operation: OperationKeys[] = DBOperations.ALL,\n  handler: OperationHandler<any, any, V, any, any>,\n  dataToAdd?: V,\n  groupsort: GroupSort = DefaultGroupSort\n) {\n  return (target: any, propertyKey?: any) => {\n    const name = target.constructor.name;\n    const decorators = operation.reduce((accum: any[], op) => {\n      const compoundKey = baseOp + op;\n      let data = Reflect.getMetadata(\n        Operations.key(compoundKey),\n        target,\n        propertyKey\n      );\n      if (!data)\n        data = {\n          operation: op,\n          handlers: {},\n        };\n\n      const handlerKey = Operations.getHandlerName(handler);\n\n      let mergeData = groupsort;\n\n      if (dataToAdd) {\n        if (Object.keys(dataToAdd).filter((key) => key in groupsort).length > 0)\n          throw new InternalError(\n            `Unable to merge groupSort into dataToAdd due to overlaping keys`\n          );\n\n        mergeData = { ...groupsort, ...dataToAdd };\n      }\n\n      if (\n        !data.handlers[name] ||\n        !data.handlers[name][propertyKey] ||\n        !(handlerKey in data.handlers[name][propertyKey])\n      ) {\n        data.handlers[name] = data.handlers[name] || {};\n        data.handlers[name][propertyKey] =\n          data.handlers[name][propertyKey] || {};\n        data.handlers[name][propertyKey][handlerKey] = {\n          data: mergeData,\n        };\n\n        accum.push(\n          handle(compoundKey as OperationKeys, handler),\n          propMetadata(Operations.key(compoundKey), data)\n        );\n      }\n      return accum;\n    }, []);\n    return apply(...decorators)(target, propertyKey);\n  };\n}\n"]}
|