@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
|
@@ -2,6 +2,10 @@ import { DBOperations, OperationKeys } from "./constants.js";
|
|
|
2
2
|
import { Operations } from "./Operations.js";
|
|
3
3
|
import { apply } from "@decaf-ts/reflection";
|
|
4
4
|
import { propMetadata } from "@decaf-ts/decorator-validation";
|
|
5
|
+
import { InternalError } from "./../repository/errors.js";
|
|
6
|
+
import { getHandlerArgs } from "./../repository/utils.js";
|
|
7
|
+
const defaultPriority = 50;
|
|
8
|
+
const DefaultGroupSort = { priority: defaultPriority };
|
|
5
9
|
/**
|
|
6
10
|
* @description Internal function to register operation handlers
|
|
7
11
|
* @summary Registers an operation handler for a specific operation key on a target property
|
|
@@ -16,18 +20,120 @@ function handle(op, handler) {
|
|
|
16
20
|
Operations.register(handler, op, target, propertyKey);
|
|
17
21
|
};
|
|
18
22
|
}
|
|
23
|
+
/**
|
|
24
|
+
* @description Retrieves decorator objects for handling database operations
|
|
25
|
+
* @summary Retrieves a list of decorator objects representing operation handlers for a given model and decorators
|
|
26
|
+
* @template M - Type for the model, defaults to Model<true | false>
|
|
27
|
+
* @template R - Type for the repository, defaults to IRepository<M, F, C>
|
|
28
|
+
* @template V - Type for metadata, defaults to object
|
|
29
|
+
* @template F - Type for repository flags, defaults to RepositoryFlags
|
|
30
|
+
* @template C - Type for context, defaults to Context<F>
|
|
31
|
+
* @param {Model} model - The model for which to retrieve decorator objects
|
|
32
|
+
* @param {Record<string, DecoratorMetadata[]>} decorators - The decorators associated with the model properties
|
|
33
|
+
* @param {string} prefix - The operation prefix (e.g., 'on', 'after')
|
|
34
|
+
* @return {DecoratorObject[]} An array of decorator objects representing operation handlers
|
|
35
|
+
* @function getHandlersDecorators
|
|
36
|
+
* @category Function
|
|
37
|
+
*/
|
|
38
|
+
export function getHandlersDecorators(model, decorators, prefix) {
|
|
39
|
+
const accum = [];
|
|
40
|
+
for (const prop in decorators) {
|
|
41
|
+
const decs = decorators[prop];
|
|
42
|
+
for (const dec of decs) {
|
|
43
|
+
const { key } = dec;
|
|
44
|
+
const handlers = Operations.get(model, prop, prefix + key);
|
|
45
|
+
if (!handlers || !handlers.length)
|
|
46
|
+
throw new InternalError(`Could not find registered handler for the operation ${prefix + key} under property ${prop}`);
|
|
47
|
+
const handlerArgs = getHandlerArgs(dec, prop, model);
|
|
48
|
+
if (!handlerArgs || Object.values(handlerArgs).length !== handlers.length)
|
|
49
|
+
throw new InternalError("Args and handlers length do not match");
|
|
50
|
+
for (let i = 0; i < handlers.length; i++) {
|
|
51
|
+
const data = handlerArgs[handlers[i].name]
|
|
52
|
+
.data;
|
|
53
|
+
accum.push({
|
|
54
|
+
handler: handlers[i],
|
|
55
|
+
data: [data],
|
|
56
|
+
prop: [prop],
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
return accum;
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* @description Groups decorators based on their group property
|
|
65
|
+
* @summary Groups decorator objects by their group property, combining data and properties within each group
|
|
66
|
+
* @param {DecoratorObject[]} decorators - The array of decorator objects to group
|
|
67
|
+
* @return {DecoratorObject[]} An array of grouped decorator objects
|
|
68
|
+
* @function groupDecorators
|
|
69
|
+
* @category Function
|
|
70
|
+
*/
|
|
71
|
+
export function groupDecorators(decorators) {
|
|
72
|
+
const grouped = decorators.reduce((acc, dec) => {
|
|
73
|
+
if (!dec || !dec.data || !dec.prop)
|
|
74
|
+
throw new InternalError("Missing decorator properties or data");
|
|
75
|
+
// If decorator have no group
|
|
76
|
+
if (!dec.data[0].group) {
|
|
77
|
+
acc.set(Symbol(), dec);
|
|
78
|
+
return acc;
|
|
79
|
+
}
|
|
80
|
+
const groupKey = dec.data[0].group;
|
|
81
|
+
if (!acc.has(groupKey)) {
|
|
82
|
+
// first handler is saved in the group
|
|
83
|
+
acc.set(groupKey, { ...dec });
|
|
84
|
+
}
|
|
85
|
+
else {
|
|
86
|
+
const existing = acc.get(groupKey);
|
|
87
|
+
acc.set(groupKey, {
|
|
88
|
+
handler: existing.handler,
|
|
89
|
+
data: [...existing.data, ...dec.data],
|
|
90
|
+
prop: [...existing.prop, ...dec.prop],
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
return acc;
|
|
94
|
+
}, new Map());
|
|
95
|
+
const groups = Array.from(grouped.values());
|
|
96
|
+
// Sort inside each group by priority
|
|
97
|
+
groups.forEach((group) => {
|
|
98
|
+
const combined = group.data.map((d, i) => ({
|
|
99
|
+
data: d,
|
|
100
|
+
prop: group.prop[i],
|
|
101
|
+
}));
|
|
102
|
+
combined.sort((a, b) => (a.data.groupPriority ?? 50) - (b.data.groupPriority ?? 50));
|
|
103
|
+
group.data = combined.map((c) => c.data);
|
|
104
|
+
group.prop = combined.map((c) => c.prop);
|
|
105
|
+
});
|
|
106
|
+
return groups;
|
|
107
|
+
}
|
|
108
|
+
/**
|
|
109
|
+
* @description Sorts decorator objects based on their priority
|
|
110
|
+
* @summary Sorts an array of decorator objects by the priority of their first data element
|
|
111
|
+
* @param {DecoratorObject[]} decorators - The array of decorator objects to sort
|
|
112
|
+
* @return {DecoratorObject[]} The sorted array of decorator objects
|
|
113
|
+
* @function sortDecorators
|
|
114
|
+
* @category Function
|
|
115
|
+
*/
|
|
116
|
+
export function sortDecorators(decorators) {
|
|
117
|
+
// Sort by groupPriority
|
|
118
|
+
decorators.sort((a, b) => {
|
|
119
|
+
const priorityA = a.data[0].priority ?? defaultPriority;
|
|
120
|
+
const priorityB = b.data[0].priority ?? defaultPriority;
|
|
121
|
+
return priorityA - priorityB; // lower number = higher priority
|
|
122
|
+
});
|
|
123
|
+
return decorators;
|
|
124
|
+
}
|
|
19
125
|
/**
|
|
20
126
|
* @description Decorator for handling create and update operations
|
|
21
127
|
* @summary Defines a behavior to execute during both create and update operations
|
|
22
128
|
* @template V - Type for metadata, defaults to object
|
|
23
|
-
* @param {
|
|
129
|
+
* @param {GeneralOperationHandler<any, any, V, any, any> | GeneralUpdateOperationHandler<any, any, V, any, any>} handler - The method called upon the operation
|
|
24
130
|
* @param {V} [data] - Optional metadata to pass to the handler
|
|
25
131
|
* @return {PropertyDecorator} A decorator that can be applied to class properties
|
|
26
132
|
* @function onCreateUpdate
|
|
27
133
|
* @category Property Decorators
|
|
28
134
|
*/
|
|
29
|
-
export function onCreateUpdate(handler, data) {
|
|
30
|
-
return on(DBOperations.CREATE_UPDATE, handler, data);
|
|
135
|
+
export function onCreateUpdate(handler, data, groupsort) {
|
|
136
|
+
return on(DBOperations.CREATE_UPDATE, handler, data, groupsort);
|
|
31
137
|
}
|
|
32
138
|
/**
|
|
33
139
|
* @description Decorator for handling update operations
|
|
@@ -39,21 +145,21 @@ export function onCreateUpdate(handler, data) {
|
|
|
39
145
|
* @function onUpdate
|
|
40
146
|
* @category Property Decorators
|
|
41
147
|
*/
|
|
42
|
-
export function onUpdate(handler, data) {
|
|
43
|
-
return on(DBOperations.UPDATE, handler, data);
|
|
148
|
+
export function onUpdate(handler, data, groupsort) {
|
|
149
|
+
return on(DBOperations.UPDATE, handler, data, groupsort);
|
|
44
150
|
}
|
|
45
151
|
/**
|
|
46
152
|
* @description Decorator for handling create operations
|
|
47
153
|
* @summary Defines a behavior to execute during create operations
|
|
48
154
|
* @template V - Type for metadata, defaults to object
|
|
49
|
-
* @param {
|
|
155
|
+
* @param {GeneralOperationHandler<any, any, V, any, any>} handler - The method called upon the operation
|
|
50
156
|
* @param {V} [data] - Optional metadata to pass to the handler
|
|
51
157
|
* @return {PropertyDecorator} A decorator that can be applied to class properties
|
|
52
158
|
* @function onCreate
|
|
53
159
|
* @category Property Decorators
|
|
54
160
|
*/
|
|
55
|
-
export function onCreate(handler, data) {
|
|
56
|
-
return on(DBOperations.CREATE, handler, data);
|
|
161
|
+
export function onCreate(handler, data, groupsort) {
|
|
162
|
+
return on(DBOperations.CREATE, handler, data, groupsort);
|
|
57
163
|
}
|
|
58
164
|
/**
|
|
59
165
|
* @description Decorator for handling read operations
|
|
@@ -65,8 +171,8 @@ export function onCreate(handler, data) {
|
|
|
65
171
|
* @function onRead
|
|
66
172
|
* @category Property Decorators
|
|
67
173
|
*/
|
|
68
|
-
export function onRead(handler, data) {
|
|
69
|
-
return on(DBOperations.READ, handler, data);
|
|
174
|
+
export function onRead(handler, data, groupsort) {
|
|
175
|
+
return on(DBOperations.READ, handler, data, groupsort);
|
|
70
176
|
}
|
|
71
177
|
/**
|
|
72
178
|
* @description Decorator for handling delete operations
|
|
@@ -78,8 +184,8 @@ export function onRead(handler, data) {
|
|
|
78
184
|
* @function onDelete
|
|
79
185
|
* @category Property Decorators
|
|
80
186
|
*/
|
|
81
|
-
export function onDelete(handler, data) {
|
|
82
|
-
return on(DBOperations.DELETE, handler, data);
|
|
187
|
+
export function onDelete(handler, data, groupsort) {
|
|
188
|
+
return on(DBOperations.DELETE, handler, data, groupsort);
|
|
83
189
|
}
|
|
84
190
|
/**
|
|
85
191
|
* @description Decorator for handling all operation types
|
|
@@ -91,8 +197,8 @@ export function onDelete(handler, data) {
|
|
|
91
197
|
* @function onAny
|
|
92
198
|
* @category Property Decorators
|
|
93
199
|
*/
|
|
94
|
-
export function onAny(handler, data) {
|
|
95
|
-
return on(DBOperations.ALL, handler, data);
|
|
200
|
+
export function onAny(handler, data, groupsort) {
|
|
201
|
+
return on(DBOperations.ALL, handler, data, groupsort);
|
|
96
202
|
}
|
|
97
203
|
/**
|
|
98
204
|
* @description Base decorator for handling database operations
|
|
@@ -111,8 +217,8 @@ export function onAny(handler, data) {
|
|
|
111
217
|
* myProperty: string;
|
|
112
218
|
* }
|
|
113
219
|
*/
|
|
114
|
-
export function on(op = DBOperations.ALL, handler, data) {
|
|
115
|
-
return operation(OperationKeys.ON, op, handler, data);
|
|
220
|
+
export function on(op = DBOperations.ALL, handler, data, groupsort) {
|
|
221
|
+
return operation(OperationKeys.ON, op, handler, data, groupsort);
|
|
116
222
|
}
|
|
117
223
|
/**
|
|
118
224
|
* @description Decorator for handling post-create and post-update operations
|
|
@@ -124,8 +230,8 @@ export function on(op = DBOperations.ALL, handler, data) {
|
|
|
124
230
|
* @function afterCreateUpdate
|
|
125
231
|
* @category Property Decorators
|
|
126
232
|
*/
|
|
127
|
-
export function afterCreateUpdate(handler, data) {
|
|
128
|
-
return after(DBOperations.CREATE_UPDATE, handler, data);
|
|
233
|
+
export function afterCreateUpdate(handler, data, groupsort) {
|
|
234
|
+
return after(DBOperations.CREATE_UPDATE, handler, data, groupsort);
|
|
129
235
|
}
|
|
130
236
|
/**
|
|
131
237
|
* @description Decorator for handling post-update operations
|
|
@@ -137,8 +243,8 @@ export function afterCreateUpdate(handler, data) {
|
|
|
137
243
|
* @function afterUpdate
|
|
138
244
|
* @category Property Decorators
|
|
139
245
|
*/
|
|
140
|
-
export function afterUpdate(handler, data) {
|
|
141
|
-
return after(DBOperations.UPDATE, handler, data);
|
|
246
|
+
export function afterUpdate(handler, data, groupsort) {
|
|
247
|
+
return after(DBOperations.UPDATE, handler, data, groupsort);
|
|
142
248
|
}
|
|
143
249
|
/**
|
|
144
250
|
* @description Decorator for handling post-create operations
|
|
@@ -150,8 +256,8 @@ export function afterUpdate(handler, data) {
|
|
|
150
256
|
* @function afterCreate
|
|
151
257
|
* @category Property Decorators
|
|
152
258
|
*/
|
|
153
|
-
export function afterCreate(handler, data) {
|
|
154
|
-
return after(DBOperations.CREATE, handler, data);
|
|
259
|
+
export function afterCreate(handler, data, groupsort) {
|
|
260
|
+
return after(DBOperations.CREATE, handler, data, groupsort);
|
|
155
261
|
}
|
|
156
262
|
/**
|
|
157
263
|
* @description Decorator for handling post-read operations
|
|
@@ -163,8 +269,8 @@ export function afterCreate(handler, data) {
|
|
|
163
269
|
* @function afterRead
|
|
164
270
|
* @category Property Decorators
|
|
165
271
|
*/
|
|
166
|
-
export function afterRead(handler, data) {
|
|
167
|
-
return after(DBOperations.READ, handler, data);
|
|
272
|
+
export function afterRead(handler, data, groupsort) {
|
|
273
|
+
return after(DBOperations.READ, handler, data, groupsort);
|
|
168
274
|
}
|
|
169
275
|
/**
|
|
170
276
|
* @description Decorator for handling post-delete operations
|
|
@@ -176,8 +282,8 @@ export function afterRead(handler, data) {
|
|
|
176
282
|
* @function afterDelete
|
|
177
283
|
* @category Property Decorators
|
|
178
284
|
*/
|
|
179
|
-
export function afterDelete(handler, data) {
|
|
180
|
-
return after(DBOperations.DELETE, handler, data);
|
|
285
|
+
export function afterDelete(handler, data, groupsort) {
|
|
286
|
+
return after(DBOperations.DELETE, handler, data, groupsort);
|
|
181
287
|
}
|
|
182
288
|
/**
|
|
183
289
|
* @description Decorator for handling post-operation for all operation types
|
|
@@ -189,8 +295,8 @@ export function afterDelete(handler, data) {
|
|
|
189
295
|
* @function afterAny
|
|
190
296
|
* @category Property Decorators
|
|
191
297
|
*/
|
|
192
|
-
export function afterAny(handler, data) {
|
|
193
|
-
return after(DBOperations.ALL, handler, data);
|
|
298
|
+
export function afterAny(handler, data, groupsort) {
|
|
299
|
+
return after(DBOperations.ALL, handler, data, groupsort);
|
|
194
300
|
}
|
|
195
301
|
/**
|
|
196
302
|
* @description Base decorator for handling post-operation behaviors
|
|
@@ -209,8 +315,8 @@ export function afterAny(handler, data) {
|
|
|
209
315
|
* myProperty: string;
|
|
210
316
|
* }
|
|
211
317
|
*/
|
|
212
|
-
export function after(op = DBOperations.ALL, handler, data) {
|
|
213
|
-
return operation(OperationKeys.AFTER, op, handler, data);
|
|
318
|
+
export function after(op = DBOperations.ALL, handler, data, groupsort) {
|
|
319
|
+
return operation(OperationKeys.AFTER, op, handler, data, groupsort);
|
|
214
320
|
}
|
|
215
321
|
/**
|
|
216
322
|
* @description Core decorator factory for operation handlers
|
|
@@ -240,7 +346,7 @@ export function after(op = DBOperations.ALL, handler, data) {
|
|
|
240
346
|
* Handler-->>Operations: Return result
|
|
241
347
|
* Operations-->>Client: Return final result
|
|
242
348
|
*/
|
|
243
|
-
export function operation(baseOp, operation = DBOperations.ALL, handler, dataToAdd) {
|
|
349
|
+
export function operation(baseOp, operation = DBOperations.ALL, handler, dataToAdd, groupsort = DefaultGroupSort) {
|
|
244
350
|
return (target, propertyKey) => {
|
|
245
351
|
const name = target.constructor.name;
|
|
246
352
|
const decorators = operation.reduce((accum, op) => {
|
|
@@ -252,6 +358,12 @@ export function operation(baseOp, operation = DBOperations.ALL, handler, dataToA
|
|
|
252
358
|
handlers: {},
|
|
253
359
|
};
|
|
254
360
|
const handlerKey = Operations.getHandlerName(handler);
|
|
361
|
+
let mergeData = groupsort;
|
|
362
|
+
if (dataToAdd) {
|
|
363
|
+
if (Object.keys(dataToAdd).filter((key) => key in groupsort).length > 0)
|
|
364
|
+
throw new InternalError(`Unable to merge groupSort into dataToAdd due to overlaping keys`);
|
|
365
|
+
mergeData = { ...groupsort, ...dataToAdd };
|
|
366
|
+
}
|
|
255
367
|
if (!data.handlers[name] ||
|
|
256
368
|
!data.handlers[name][propertyKey] ||
|
|
257
369
|
!(handlerKey in data.handlers[name][propertyKey])) {
|
|
@@ -259,7 +371,7 @@ export function operation(baseOp, operation = DBOperations.ALL, handler, dataToA
|
|
|
259
371
|
data.handlers[name][propertyKey] =
|
|
260
372
|
data.handlers[name][propertyKey] || {};
|
|
261
373
|
data.handlers[name][propertyKey][handlerKey] = {
|
|
262
|
-
data:
|
|
374
|
+
data: mergeData,
|
|
263
375
|
};
|
|
264
376
|
accum.push(handle(compoundKey, handler), propMetadata(Operations.key(compoundKey), data));
|
|
265
377
|
}
|
|
@@ -268,4 +380,4 @@ export function operation(baseOp, operation = DBOperations.ALL, handler, dataToA
|
|
|
268
380
|
return apply(...decorators)(target, propertyKey);
|
|
269
381
|
};
|
|
270
382
|
}
|
|
271
|
-
//# 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  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"]}
|
|
383
|
+
//# 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"]}
|
|
@@ -18,7 +18,131 @@ export type OperationMetadata<V> = {
|
|
|
18
18
|
handler: string;
|
|
19
19
|
metadata?: V;
|
|
20
20
|
};
|
|
21
|
-
|
|
21
|
+
/**
|
|
22
|
+
* @description Union type for all operation handler types
|
|
23
|
+
* @summary Represents any type of operation handler function that can be used with database operations
|
|
24
|
+
* @template M - Model type extending Model
|
|
25
|
+
* @template R - Repository type extending IRepository
|
|
26
|
+
* @template V - Metadata type, defaults to object
|
|
27
|
+
* @template F - Repository flags extending RepositoryFlags
|
|
28
|
+
* @template C - Context type extending Context<F>
|
|
29
|
+
* @typedef {(StandardOperationHandler<M, R, V, F, C> | UpdateOperationHandler<M, R, V, F, C> | IdOperationHandler<M, R, V, F, C>)} OperationHandler
|
|
30
|
+
* @memberOf module:db-decorators
|
|
31
|
+
*/
|
|
32
|
+
export type OperationHandler<M extends Model, R extends IRepository<M, F, C>, V = object, F extends RepositoryFlags = RepositoryFlags, C extends Context<F> = Context<F>> = StandardOperationHandler<M, R, V, F, C> | UpdateOperationHandler<M, R, V, F, C> | IdOperationHandler<M, R, V, F, C> | GroupOperationHandler<M, R, V, F, C> | GroupUpdateOperationHandler<M, R, V, F, C>;
|
|
33
|
+
/**
|
|
34
|
+
* @description Handler type for standard database operations
|
|
35
|
+
* @summary Function signature for handlers that process standard operations like create and read
|
|
36
|
+
* @template M - Model type extending Model
|
|
37
|
+
* @template R - Repository type extending IRepository
|
|
38
|
+
* @template V - Metadata type, defaults to object
|
|
39
|
+
* @template F - Repository flags extending RepositoryFlags
|
|
40
|
+
* @template C - Context type extending Context<F>
|
|
41
|
+
* @typedef {Function} StandardOperationHandler
|
|
42
|
+
* @param {R} this - The repository instance (this context)
|
|
43
|
+
* @param {C} context - The operation context
|
|
44
|
+
* @param {V} metadata - Metadata associated with the operation
|
|
45
|
+
* @param {keyof M} key - The property key being operated on
|
|
46
|
+
* @param {M} model - The model instance being operated on
|
|
47
|
+
* @return {Promise<void> | void} Nothing or a Promise resolving to nothing
|
|
48
|
+
* @memberOf module:db-decorators
|
|
49
|
+
*/
|
|
22
50
|
export type StandardOperationHandler<M extends Model, R extends IRepository<M, F, C>, V = object, F extends RepositoryFlags = RepositoryFlags, C extends Context<F> = Context<F>> = (this: R, context: C, metadata: V, key: keyof M, model: M) => Promise<void> | void;
|
|
51
|
+
/**
|
|
52
|
+
* @description Handler type for ID-based database operations
|
|
53
|
+
* @summary Function signature for handlers that process operations using only an ID (like read by ID)
|
|
54
|
+
* @template M - Model type extending Model
|
|
55
|
+
* @template R - Repository type extending IRepository
|
|
56
|
+
* @template V - Metadata type, defaults to object
|
|
57
|
+
* @template F - Repository flags extending RepositoryFlags
|
|
58
|
+
* @template C - Context type extending Context<F>
|
|
59
|
+
* @typedef {Function} IdOperationHandler
|
|
60
|
+
* @param {R} this - The repository instance (this context)
|
|
61
|
+
* @param {C} context - The operation context
|
|
62
|
+
* @param {V} decorator - Metadata associated with the operation
|
|
63
|
+
* @param {keyof M} key - The property key being operated on
|
|
64
|
+
* @param {string} id - The ID of the model being operated on
|
|
65
|
+
* @return {Promise<void> | void} Nothing or a Promise resolving to nothing
|
|
66
|
+
* @memberOf module:db-decorators
|
|
67
|
+
*/
|
|
23
68
|
export type IdOperationHandler<M extends Model, R extends IRepository<M, F, C>, V = object, F extends RepositoryFlags = RepositoryFlags, C extends Context<F> = Context<F>> = (this: R, context: C, decorator: V, key: keyof M, id: string) => Promise<void> | void;
|
|
69
|
+
/**
|
|
70
|
+
* @description Handler type for update database operations
|
|
71
|
+
* @summary Function signature for handlers that process update operations with both new and old model states
|
|
72
|
+
* @template M - Model type extending Model
|
|
73
|
+
* @template R - Repository type extending IRepository
|
|
74
|
+
* @template V - Metadata type, defaults to object
|
|
75
|
+
* @template F - Repository flags extending RepositoryFlags
|
|
76
|
+
* @template C - Context type extending Context<F>
|
|
77
|
+
* @typedef {Function} UpdateOperationHandler
|
|
78
|
+
* @param {R} this - The repository instance (this context)
|
|
79
|
+
* @param {C} context - The operation context
|
|
80
|
+
* @param {V} decorator - Metadata associated with the operation
|
|
81
|
+
* @param {keyof M} key - The property key being operated on
|
|
82
|
+
* @param {M} model - The new model instance after update
|
|
83
|
+
* @param {M} oldModel - The original model instance before update
|
|
84
|
+
* @return {Promise<void> | void} Nothing or a Promise resolving to nothing
|
|
85
|
+
* @memberOf module:db-decorators
|
|
86
|
+
*/
|
|
24
87
|
export type UpdateOperationHandler<M extends Model, R extends IRepository<M, F, C>, V = object, F extends RepositoryFlags = RepositoryFlags, C extends Context<F> = Context<F>> = (this: R, context: C, decorator: V, key: keyof M, model: M, oldModel: M) => Promise<void> | void;
|
|
88
|
+
/**
|
|
89
|
+
* @description Handler type for standard database operations
|
|
90
|
+
* @summary Function signature for handlers that process standard operations like create and read
|
|
91
|
+
* @template M - Model type extending Model
|
|
92
|
+
* @template R - Repository type extending IRepository
|
|
93
|
+
* @template V - Metadata type, defaults to object
|
|
94
|
+
* @template F - Repository flags extending RepositoryFlags
|
|
95
|
+
* @template C - Context type extending Context<F>
|
|
96
|
+
* @typedef {Function} StandardOperationHandler
|
|
97
|
+
* @param {R} this - The repository instance (this context)
|
|
98
|
+
* @param {C} context - The operation context
|
|
99
|
+
* @param {V} metadata - Metadata associated with the operation
|
|
100
|
+
* @param {keyof M} key - The property key being operated on
|
|
101
|
+
* @param {M} model - The model instance being operated on
|
|
102
|
+
* @return {Promise<void> | void} Nothing or a Promise resolving to nothing
|
|
103
|
+
* @memberOf module:db-decorators
|
|
104
|
+
*/
|
|
105
|
+
export type GroupOperationHandler<M extends Model, R extends IRepository<M, F, C>, V = object, F extends RepositoryFlags = RepositoryFlags, C extends Context<F> = Context<F>> = (this: R, context: C, metadata: V[], keys: (keyof M)[], model: M) => Promise<void> | void;
|
|
106
|
+
/**
|
|
107
|
+
* @description Handler type for grouped update database operations
|
|
108
|
+
* @summary Function signature for handlers that process update operations with both new and old model states
|
|
109
|
+
* @template M - Model type extending Model
|
|
110
|
+
* @template R - Repository type extending IRepository
|
|
111
|
+
* @template V - Metadata type, defaults to object
|
|
112
|
+
* @template F - Repository flags extending RepositoryFlags
|
|
113
|
+
* @template C - Context type extending Context<F>
|
|
114
|
+
* @typedef {Function} GroupUpdateOperationHandler
|
|
115
|
+
* @param {R} this - The repository instance (this context)
|
|
116
|
+
* @param {C} context - The operation context
|
|
117
|
+
* @param {V} metadata - Metadata associated with the operation
|
|
118
|
+
* @param {keyof M} keys - The property key being operated on
|
|
119
|
+
* @param {M} model - The model instance being operated on
|
|
120
|
+
* @return {Promise<void> | void} Nothing or a Promise resolving to nothing
|
|
121
|
+
* @memberOf module:db-decorators
|
|
122
|
+
*/
|
|
123
|
+
export type GroupUpdateOperationHandler<M extends Model, R extends IRepository<M, F, C>, V = object, F extends RepositoryFlags = RepositoryFlags, C extends Context<F> = Context<F>> = (this: R, context: C, decorator: V[], keys: (keyof M)[], model: M, oldModel: M) => Promise<void> | void;
|
|
124
|
+
/**
|
|
125
|
+
* @description General handler type for database operations
|
|
126
|
+
* @summary Function signature for handlers that process operations like create and read
|
|
127
|
+
* @template M - Model type extending Model
|
|
128
|
+
* @template R - Repository type extending IRepository
|
|
129
|
+
* @template V - Metadata type, defaults to object
|
|
130
|
+
* @template F - Repository flags extending RepositoryFlags
|
|
131
|
+
* @template C - Context type extending Context<F>
|
|
132
|
+
* @typedef {Function} GeneralOperationHandler
|
|
133
|
+
* @return {Promise<void> | void} Nothing or a Promise resolving to nothing
|
|
134
|
+
* @memberOf module:db-decorators
|
|
135
|
+
*/
|
|
136
|
+
export type GeneralOperationHandler<M extends Model, R extends IRepository<M, F, C>, V = object, F extends RepositoryFlags = RepositoryFlags, C extends Context<F> = Context<F>> = StandardOperationHandler<M, R, V, F, C> | GroupOperationHandler<M, R, V, F, C>;
|
|
137
|
+
/**
|
|
138
|
+
* @description General handler type for group update database operations
|
|
139
|
+
* @summary Function signature for handlers that process update operations with both new and old model states
|
|
140
|
+
* @template M - Model type extending Model
|
|
141
|
+
* @template R - Repository type extending IRepository
|
|
142
|
+
* @template V - Metadata type, defaults to object
|
|
143
|
+
* @template F - Repository flags extending RepositoryFlags
|
|
144
|
+
* @template C - Context type extending Context<F>
|
|
145
|
+
* @typedef {Function} GeneralUpdateOperationHandler
|
|
146
|
+
* @memberOf module:db-decorators
|
|
147
|
+
*/
|
|
148
|
+
export type GeneralUpdateOperationHandler<M extends Model, R extends IRepository<M, F, C>, V = object, F extends RepositoryFlags = RepositoryFlags, C extends Context<F> = Context<F>> = UpdateOperationHandler<M, R, V, F, C> | GroupUpdateOperationHandler<M, R, V, F, C>;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvb3BlcmF0aW9ucy90eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT3BlcmF0aW9uS2V5cyB9IGZyb20gXCIuL2NvbnN0YW50c1wiO1xuaW1wb3J0IHsgSVJlcG9zaXRvcnkgfSBmcm9tIFwiLi4vaW50ZXJmYWNlcy9JUmVwb3NpdG9yeVwiO1xuaW1wb3J0IHsgTW9kZWwgfSBmcm9tIFwiQGRlY2FmLXRzL2RlY29yYXRvci12YWxpZGF0aW9uXCI7XG5pbXBvcnQgeyBDb250ZXh0IH0gZnJvbSBcIi4uL3JlcG9zaXRvcnkvQ29udGV4dFwiO1xuaW1wb3J0IHsgUmVwb3NpdG9yeUZsYWdzIH0gZnJvbSBcIi4uL3JlcG9zaXRvcnkvdHlwZXNcIjtcblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gTWV0YWRhdGEgZm9yIGRhdGFiYXNlIG9wZXJhdGlvbnNcbiAqIEBzdW1tYXJ5IENvbnRhaW5zIGluZm9ybWF0aW9uIGFib3V0IGFuIG9wZXJhdGlvbiwgaXRzIGhhbmRsZXIsIGFuZCBhc3NvY2lhdGVkIG1ldGFkYXRhXG4gKiBAdGVtcGxhdGUgViAtIFR5cGUgb2YgdGhlIG1ldGFkYXRhXG4gKiBAdHlwZWRlZiB7T2JqZWN0fSBPcGVyYXRpb25NZXRhZGF0YVxuICogQHByb3BlcnR5IHtPcGVyYXRpb25LZXlzfSBvcGVyYXRpb24gLSBUaGUgdHlwZSBvZiBvcGVyYXRpb25cbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBoYW5kbGVyIC0gVGhlIG5hbWUgb2YgdGhlIGhhbmRsZXIgZnVuY3Rpb25cbiAqIEBwcm9wZXJ0eSB7Vn0gW21ldGFkYXRhXSAtIE9wdGlvbmFsIG1ldGFkYXRhIGFzc29jaWF0ZWQgd2l0aCB0aGUgb3BlcmF0aW9uXG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRiLWRlY29yYXRvcnNcbiAqL1xuZXhwb3J0IHR5cGUgT3BlcmF0aW9uTWV0YWRhdGE8Vj4gPSB7XG4gIG9wZXJhdGlvbjogT3BlcmF0aW9uS2V5cztcbiAgaGFuZGxlcjogc3RyaW5nO1xuICBtZXRhZGF0YT86IFY7XG59O1xuXG5leHBvcnQgdHlwZSBPcGVyYXRpb25IYW5kbGVyPFxuICBNIGV4dGVuZHMgTW9kZWwsXG4gIFIgZXh0ZW5kcyBJUmVwb3NpdG9yeTxNLCBGLCBDPixcbiAgViA9IG9iamVjdCxcbiAgRiBleHRlbmRzIFJlcG9zaXRvcnlGbGFncyA9IFJlcG9zaXRvcnlGbGFncyxcbiAgQyBleHRlbmRzIENvbnRleHQ8Rj4gPSBDb250ZXh0PEY+LFxuPiA9XG4gIHwgU3RhbmRhcmRPcGVyYXRpb25IYW5kbGVyPE0sIFIsIFYsIEYsIEM+XG4gIHwgVXBkYXRlT3BlcmF0aW9uSGFuZGxlcjxNLCBSLCBWLCBGLCBDPlxuICB8IElkT3BlcmF0aW9uSGFuZGxlcjxNLCBSLCBWLCBGLCBDPjtcblxuZXhwb3J0IHR5cGUgU3RhbmRhcmRPcGVyYXRpb25IYW5kbGVyPFxuICBNIGV4dGVuZHMgTW9kZWwsXG4gIFIgZXh0ZW5kcyBJUmVwb3NpdG9yeTxNLCBGLCBDPixcbiAgViA9IG9iamVjdCxcbiAgRiBleHRlbmRzIFJlcG9zaXRvcnlGbGFncyA9IFJlcG9zaXRvcnlGbGFncyxcbiAgQyBleHRlbmRzIENvbnRleHQ8Rj4gPSBDb250ZXh0PEY+LFxuPiA9IChcbiAgdGhpczogUixcbiAgY29udGV4dDogQyxcbiAgbWV0YWRhdGE6IFYsXG4gIGtleToga2V5b2YgTSxcbiAgbW9kZWw6IE1cbikgPT4gUHJvbWlzZTx2b2lkPiB8IHZvaWQ7XG5cbmV4cG9ydCB0eXBlIElkT3BlcmF0aW9uSGFuZGxlcjxcbiAgTSBleHRlbmRzIE1vZGVsLFxuICBSIGV4dGVuZHMgSVJlcG9zaXRvcnk8TSwgRiwgQz4sXG4gIFYgPSBvYmplY3QsXG4gIEYgZXh0ZW5kcyBSZXBvc2l0b3J5RmxhZ3MgPSBSZXBvc2l0b3J5RmxhZ3MsXG4gIEMgZXh0ZW5kcyBDb250ZXh0PEY+ID0gQ29udGV4dDxGPixcbj4gPSAoXG4gIHRoaXM6IFIsXG4gIGNvbnRleHQ6IEMsXG4gIGRlY29yYXRvcjogVixcbiAga2V5OiBrZXlvZiBNLFxuICBpZDogc3RyaW5nXG4pID0+IFByb21pc2U8dm9pZD4gfCB2b2lkO1xuXG5leHBvcnQgdHlwZSBVcGRhdGVPcGVyYXRpb25IYW5kbGVyPFxuICBNIGV4dGVuZHMgTW9kZWwsXG4gIFIgZXh0ZW5kcyBJUmVwb3NpdG9yeTxNLCBGLCBDPixcbiAgViA9IG9iamVjdCxcbiAgRiBleHRlbmRzIFJlcG9zaXRvcnlGbGFncyA9IFJlcG9zaXRvcnlGbGFncyxcbiAgQyBleHRlbmRzIENvbnRleHQ8Rj4gPSBDb250ZXh0PEY+LFxuPiA9IChcbiAgdGhpczogUixcbiAgY29udGV4dDogQyxcbiAgZGVjb3JhdG9yOiBWLFxuICBrZXk6IGtleW9mIE0sXG4gIG1vZGVsOiBNLFxuICBvbGRNb2RlbDogTVxuKSA9PiBQcm9taXNlPHZvaWQ+IHwgdm9pZDtcbiJdfQ==
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/operations/types.ts"],"names":[],"mappings":"","sourcesContent":["import { OperationKeys } from \"./constants\";\nimport { IRepository } from \"../interfaces/IRepository\";\nimport { Model } from \"@decaf-ts/decorator-validation\";\nimport { Context } from \"../repository/Context\";\nimport { RepositoryFlags } from \"../repository/types\";\n\n/**\n * @description Metadata for database operations\n * @summary Contains information about an operation, its handler, and associated metadata\n * @template V - Type of the metadata\n * @typedef {Object} OperationMetadata\n * @property {OperationKeys} operation - The type of operation\n * @property {string} handler - The name of the handler function\n * @property {V} [metadata] - Optional metadata associated with the operation\n * @memberOf module:db-decorators\n */\nexport type OperationMetadata<V> = {\n  operation: OperationKeys;\n  handler: string;\n  metadata?: V;\n};\n\n/**\n * @description Union type for all operation handler types\n * @summary Represents any type of operation handler function that can be used with database operations\n * @template M - Model type extending Model\n * @template R - Repository type extending IRepository\n * @template V - Metadata type, defaults to object\n * @template F - Repository flags extending RepositoryFlags\n * @template C - Context type extending Context<F>\n * @typedef {(StandardOperationHandler<M, R, V, F, C> | UpdateOperationHandler<M, R, V, F, C> | IdOperationHandler<M, R, V, F, C>)} OperationHandler\n * @memberOf module:db-decorators\n */\nexport type OperationHandler<\n  M extends Model,\n  R extends IRepository<M, F, C>,\n  V = object,\n  F extends RepositoryFlags = RepositoryFlags,\n  C extends Context<F> = Context<F>,\n> =\n  | StandardOperationHandler<M, R, V, F, C>\n  | UpdateOperationHandler<M, R, V, F, C>\n  | IdOperationHandler<M, R, V, F, C>\n  | GroupOperationHandler<M, R, V, F, C>\n  | GroupUpdateOperationHandler<M, R, V, F, C>;\n\n/**\n * @description Handler type for standard database operations\n * @summary Function signature for handlers that process standard operations like create and read\n * @template M - Model type extending Model\n * @template R - Repository type extending IRepository\n * @template V - Metadata type, defaults to object\n * @template F - Repository flags extending RepositoryFlags\n * @template C - Context type extending Context<F>\n * @typedef {Function} StandardOperationHandler\n * @param {R} this - The repository instance (this context)\n * @param {C} context - The operation context\n * @param {V} metadata - Metadata associated with the operation\n * @param {keyof M} key - The property key being operated on\n * @param {M} model - The model instance being operated on\n * @return {Promise<void> | void} Nothing or a Promise resolving to nothing\n * @memberOf module:db-decorators\n */\nexport type StandardOperationHandler<\n  M extends Model,\n  R extends IRepository<M, F, C>,\n  V = object,\n  F extends RepositoryFlags = RepositoryFlags,\n  C extends Context<F> = Context<F>,\n> = (\n  this: R,\n  context: C,\n  metadata: V,\n  key: keyof M,\n  model: M\n) => Promise<void> | void;\n\n/**\n * @description Handler type for ID-based database operations\n * @summary Function signature for handlers that process operations using only an ID (like read by ID)\n * @template M - Model type extending Model\n * @template R - Repository type extending IRepository\n * @template V - Metadata type, defaults to object\n * @template F - Repository flags extending RepositoryFlags\n * @template C - Context type extending Context<F>\n * @typedef {Function} IdOperationHandler\n * @param {R} this - The repository instance (this context)\n * @param {C} context - The operation context\n * @param {V} decorator - Metadata associated with the operation\n * @param {keyof M} key - The property key being operated on\n * @param {string} id - The ID of the model being operated on\n * @return {Promise<void> | void} Nothing or a Promise resolving to nothing\n * @memberOf module:db-decorators\n */\nexport type IdOperationHandler<\n  M extends Model,\n  R extends IRepository<M, F, C>,\n  V = object,\n  F extends RepositoryFlags = RepositoryFlags,\n  C extends Context<F> = Context<F>,\n> = (\n  this: R,\n  context: C,\n  decorator: V,\n  key: keyof M,\n  id: string\n) => Promise<void> | void;\n\n/**\n * @description Handler type for update database operations\n * @summary Function signature for handlers that process update operations with both new and old model states\n * @template M - Model type extending Model\n * @template R - Repository type extending IRepository\n * @template V - Metadata type, defaults to object\n * @template F - Repository flags extending RepositoryFlags\n * @template C - Context type extending Context<F>\n * @typedef {Function} UpdateOperationHandler\n * @param {R} this - The repository instance (this context)\n * @param {C} context - The operation context\n * @param {V} decorator - Metadata associated with the operation\n * @param {keyof M} key - The property key being operated on\n * @param {M} model - The new model instance after update\n * @param {M} oldModel - The original model instance before update\n * @return {Promise<void> | void} Nothing or a Promise resolving to nothing\n * @memberOf module:db-decorators\n */\nexport type UpdateOperationHandler<\n  M extends Model,\n  R extends IRepository<M, F, C>,\n  V = object,\n  F extends RepositoryFlags = RepositoryFlags,\n  C extends Context<F> = Context<F>,\n> = (\n  this: R,\n  context: C,\n  decorator: V,\n  key: keyof M,\n  model: M,\n  oldModel: M\n) => Promise<void> | void;\n\n/**\n * @description Handler type for standard database operations\n * @summary Function signature for handlers that process standard operations like create and read\n * @template M - Model type extending Model\n * @template R - Repository type extending IRepository\n * @template V - Metadata type, defaults to object\n * @template F - Repository flags extending RepositoryFlags\n * @template C - Context type extending Context<F>\n * @typedef {Function} StandardOperationHandler\n * @param {R} this - The repository instance (this context)\n * @param {C} context - The operation context\n * @param {V} metadata - Metadata associated with the operation\n * @param {keyof M} key - The property key being operated on\n * @param {M} model - The model instance being operated on\n * @return {Promise<void> | void} Nothing or a Promise resolving to nothing\n * @memberOf module:db-decorators\n */\nexport type GroupOperationHandler<\n  M extends Model,\n  R extends IRepository<M, F, C>,\n  V = object,\n  F extends RepositoryFlags = RepositoryFlags,\n  C extends Context<F> = Context<F>,\n> = (\n  this: R,\n  context: C,\n  metadata: V[],\n  keys: (keyof M)[],\n  model: M\n) => Promise<void> | void;\n\n/**\n * @description Handler type for grouped update database operations\n * @summary Function signature for handlers that process update operations with both new and old model states\n * @template M - Model type extending Model\n * @template R - Repository type extending IRepository\n * @template V - Metadata type, defaults to object\n * @template F - Repository flags extending RepositoryFlags\n * @template C - Context type extending Context<F>\n * @typedef {Function} GroupUpdateOperationHandler\n * @param {R} this - The repository instance (this context)\n * @param {C} context - The operation context\n * @param {V} metadata - Metadata associated with the operation\n * @param {keyof M} keys - The property key being operated on\n * @param {M} model - The model instance being operated on\n * @return {Promise<void> | void} Nothing or a Promise resolving to nothing\n * @memberOf module:db-decorators\n */\nexport type GroupUpdateOperationHandler<\n  M extends Model,\n  R extends IRepository<M, F, C>,\n  V = object,\n  F extends RepositoryFlags = RepositoryFlags,\n  C extends Context<F> = Context<F>,\n> = (\n  this: R,\n  context: C,\n  decorator: V[],\n  keys: (keyof M)[],\n  model: M,\n  oldModel: M\n) => Promise<void> | void;\n\n/**\n * @description General handler type for database operations\n * @summary Function signature for handlers that process operations like create and read\n * @template M - Model type extending Model\n * @template R - Repository type extending IRepository\n * @template V - Metadata type, defaults to object\n * @template F - Repository flags extending RepositoryFlags\n * @template C - Context type extending Context<F>\n * @typedef {Function} GeneralOperationHandler\n * @return {Promise<void> | void} Nothing or a Promise resolving to nothing\n * @memberOf module:db-decorators\n */\nexport type GeneralOperationHandler<\n  M extends Model,\n  R extends IRepository<M, F, C>,\n  V = object,\n  F extends RepositoryFlags = RepositoryFlags,\n  C extends Context<F> = Context<F>,\n> =\n  | StandardOperationHandler<M, R, V, F, C>\n  | GroupOperationHandler<M, R, V, F, C>;\n\n/**\n * @description General handler type for group update database operations\n * @summary Function signature for handlers that process update operations with both new and old model states\n * @template M - Model type extending Model\n * @template R - Repository type extending IRepository\n * @template V - Metadata type, defaults to object\n * @template F - Repository flags extending RepositoryFlags\n * @template C - Context type extending Context<F>\n * @typedef {Function} GeneralUpdateOperationHandler\n * @memberOf module:db-decorators\n */\nexport type GeneralUpdateOperationHandler<\n  M extends Model,\n  R extends IRepository<M, F, C>,\n  V = object,\n  F extends RepositoryFlags = RepositoryFlags,\n  C extends Context<F> = Context<F>,\n> =\n  | UpdateOperationHandler<M, R, V, F, C>\n  | GroupUpdateOperationHandler<M, R, V, F, C>;\n"]}
|