@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.
@@ -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 {StandardOperationHandler<any, any, V, any, any> | UpdateOperationHandler<any, any, V, any, any>} handler - The method called upon the operation
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 {StandardOperationHandler<any, any, V, any, any>} handler - The method called upon the operation
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: dataToAdd,
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
- 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>;
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"]}