@decaf-ts/db-decorators 0.6.7 → 0.6.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -2
- package/dist/db-decorators.cjs +418 -377
- package/dist/db-decorators.esm.cjs +417 -379
- package/lib/esm/index.d.ts +1 -1
- package/lib/esm/index.js +1 -1
- package/lib/esm/model/decorators.d.ts +5 -3
- package/lib/esm/model/decorators.js +10 -7
- package/lib/esm/operations/decorators.d.ts +84 -18
- package/lib/esm/operations/decorators.js +145 -33
- package/lib/esm/operations/types.d.ts +125 -1
- package/lib/esm/operations/types.js +1 -1
- package/lib/esm/repository/Context.d.ts +3 -65
- package/lib/esm/repository/Context.js +4 -71
- package/lib/esm/repository/utils.js +25 -33
- package/lib/index.cjs +1 -1
- package/lib/index.d.ts +1 -1
- package/lib/model/decorators.cjs +10 -7
- package/lib/model/decorators.d.ts +5 -3
- package/lib/operations/decorators.cjs +148 -33
- package/lib/operations/decorators.d.ts +84 -18
- package/lib/operations/types.cjs +1 -1
- package/lib/operations/types.d.ts +125 -1
- package/lib/repository/Context.cjs +4 -71
- package/lib/repository/Context.d.ts +3 -65
- package/lib/repository/utils.cjs +25 -33
- package/package.json +1 -1
|
@@ -1,16 +1,82 @@
|
|
|
1
|
-
import { IdOperationHandler, OperationHandler, StandardOperationHandler, UpdateOperationHandler } from "./types";
|
|
1
|
+
import { GeneralOperationHandler, GeneralUpdateOperationHandler, IdOperationHandler, OperationHandler, StandardOperationHandler, UpdateOperationHandler } from "./types";
|
|
2
2
|
import { OperationKeys } from "./constants";
|
|
3
|
+
import { Model } from "@decaf-ts/decorator-validation";
|
|
4
|
+
import { IRepository } from "../interfaces";
|
|
5
|
+
import { RepositoryFlags } from "../repository/types";
|
|
6
|
+
import { Context } from "../repository/Context";
|
|
7
|
+
/**
|
|
8
|
+
* @description Represents sorting parameters for grouping decorators
|
|
9
|
+
* @summary Defines the structure for specifying group sorting options
|
|
10
|
+
* @typedef {Object} GroupSort
|
|
11
|
+
* @property {number} priority - The priority of the sorting operation, lower numbers represent higher priority
|
|
12
|
+
* @property {string} [group] - Optional property to group decorators, used for grouping related operations
|
|
13
|
+
* @property {number} [groupPriority] - Optional property to specify the priority within a group, lower numbers represent higher priority within the group
|
|
14
|
+
* @category Type Definitions
|
|
15
|
+
*/
|
|
16
|
+
export type GroupSort = {
|
|
17
|
+
priority: number;
|
|
18
|
+
group?: string;
|
|
19
|
+
groupPriority?: number;
|
|
20
|
+
};
|
|
21
|
+
/**
|
|
22
|
+
* @description DecoratorObject type definition
|
|
23
|
+
* @summary Defines the structure of an object used to represent a decorator in the context of database operations.
|
|
24
|
+
* @typedef {Object} DecoratorObject
|
|
25
|
+
* @property {OperationHandler<any, any, any, any, any>} handler - The handler function to be executed during the operation
|
|
26
|
+
* @property {object} data - Optional metadata to be passed to the handler function
|
|
27
|
+
* @property {string} prop - The property key to which the decorator is applied
|
|
28
|
+
* @category Type Definitions
|
|
29
|
+
*/
|
|
30
|
+
export type DecoratorObject = {
|
|
31
|
+
handler: OperationHandler<any, any, any, any, any>;
|
|
32
|
+
data: Record<string, any>[];
|
|
33
|
+
prop: string[];
|
|
34
|
+
};
|
|
35
|
+
/**
|
|
36
|
+
* @description Retrieves decorator objects for handling database operations
|
|
37
|
+
* @summary Retrieves a list of decorator objects representing operation handlers for a given model and decorators
|
|
38
|
+
* @template M - Type for the model, defaults to Model<true | false>
|
|
39
|
+
* @template R - Type for the repository, defaults to IRepository<M, F, C>
|
|
40
|
+
* @template V - Type for metadata, defaults to object
|
|
41
|
+
* @template F - Type for repository flags, defaults to RepositoryFlags
|
|
42
|
+
* @template C - Type for context, defaults to Context<F>
|
|
43
|
+
* @param {Model} model - The model for which to retrieve decorator objects
|
|
44
|
+
* @param {Record<string, DecoratorMetadata[]>} decorators - The decorators associated with the model properties
|
|
45
|
+
* @param {string} prefix - The operation prefix (e.g., 'on', 'after')
|
|
46
|
+
* @return {DecoratorObject[]} An array of decorator objects representing operation handlers
|
|
47
|
+
* @function getHandlersDecorators
|
|
48
|
+
* @category Function
|
|
49
|
+
*/
|
|
50
|
+
export declare function getHandlersDecorators<M extends Model<true | false>, R extends IRepository<M, F, C>, V extends object = object, F extends RepositoryFlags = RepositoryFlags, C extends Context<F> = Context<F>>(model: Model, decorators: Record<string, DecoratorMetadata[]>, prefix: string): DecoratorObject[];
|
|
51
|
+
/**
|
|
52
|
+
* @description Groups decorators based on their group property
|
|
53
|
+
* @summary Groups decorator objects by their group property, combining data and properties within each group
|
|
54
|
+
* @param {DecoratorObject[]} decorators - The array of decorator objects to group
|
|
55
|
+
* @return {DecoratorObject[]} An array of grouped decorator objects
|
|
56
|
+
* @function groupDecorators
|
|
57
|
+
* @category Function
|
|
58
|
+
*/
|
|
59
|
+
export declare function groupDecorators(decorators: DecoratorObject[]): DecoratorObject[];
|
|
60
|
+
/**
|
|
61
|
+
* @description Sorts decorator objects based on their priority
|
|
62
|
+
* @summary Sorts an array of decorator objects by the priority of their first data element
|
|
63
|
+
* @param {DecoratorObject[]} decorators - The array of decorator objects to sort
|
|
64
|
+
* @return {DecoratorObject[]} The sorted array of decorator objects
|
|
65
|
+
* @function sortDecorators
|
|
66
|
+
* @category Function
|
|
67
|
+
*/
|
|
68
|
+
export declare function sortDecorators(decorators: DecoratorObject[]): DecoratorObject[];
|
|
3
69
|
/**
|
|
4
70
|
* @description Decorator for handling create and update operations
|
|
5
71
|
* @summary Defines a behavior to execute during both create and update operations
|
|
6
72
|
* @template V - Type for metadata, defaults to object
|
|
7
|
-
* @param {
|
|
73
|
+
* @param {GeneralOperationHandler<any, any, V, any, any> | GeneralUpdateOperationHandler<any, any, V, any, any>} handler - The method called upon the operation
|
|
8
74
|
* @param {V} [data] - Optional metadata to pass to the handler
|
|
9
75
|
* @return {PropertyDecorator} A decorator that can be applied to class properties
|
|
10
76
|
* @function onCreateUpdate
|
|
11
77
|
* @category Property Decorators
|
|
12
78
|
*/
|
|
13
|
-
export declare function onCreateUpdate<V = object>(handler:
|
|
79
|
+
export declare function onCreateUpdate<V = object>(handler: GeneralOperationHandler<any, any, V, any, any> | GeneralUpdateOperationHandler<any, any, V, any, any>, data?: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
|
14
80
|
/**
|
|
15
81
|
* @description Decorator for handling update operations
|
|
16
82
|
* @summary Defines a behavior to execute during update operations
|
|
@@ -21,18 +87,18 @@ export declare function onCreateUpdate<V = object>(handler: StandardOperationHan
|
|
|
21
87
|
* @function onUpdate
|
|
22
88
|
* @category Property Decorators
|
|
23
89
|
*/
|
|
24
|
-
export declare function onUpdate<V = object>(handler: UpdateOperationHandler<any, any, V, any>, data?: V): (target:
|
|
90
|
+
export declare function onUpdate<V = object>(handler: UpdateOperationHandler<any, any, V, any>, data?: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
|
25
91
|
/**
|
|
26
92
|
* @description Decorator for handling create operations
|
|
27
93
|
* @summary Defines a behavior to execute during create operations
|
|
28
94
|
* @template V - Type for metadata, defaults to object
|
|
29
|
-
* @param {
|
|
95
|
+
* @param {GeneralOperationHandler<any, any, V, any, any>} handler - The method called upon the operation
|
|
30
96
|
* @param {V} [data] - Optional metadata to pass to the handler
|
|
31
97
|
* @return {PropertyDecorator} A decorator that can be applied to class properties
|
|
32
98
|
* @function onCreate
|
|
33
99
|
* @category Property Decorators
|
|
34
100
|
*/
|
|
35
|
-
export declare function onCreate<V = object>(handler:
|
|
101
|
+
export declare function onCreate<V = object>(handler: GeneralOperationHandler<any, any, V, any, any>, data?: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
|
36
102
|
/**
|
|
37
103
|
* @description Decorator for handling read operations
|
|
38
104
|
* @summary Defines a behavior to execute during read operations
|
|
@@ -43,7 +109,7 @@ export declare function onCreate<V = object>(handler: StandardOperationHandler<a
|
|
|
43
109
|
* @function onRead
|
|
44
110
|
* @category Property Decorators
|
|
45
111
|
*/
|
|
46
|
-
export declare function onRead<V = object>(handler: IdOperationHandler<any, any, V, any, any>, data: V): (target:
|
|
112
|
+
export declare function onRead<V = object>(handler: IdOperationHandler<any, any, V, any, any>, data: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
|
47
113
|
/**
|
|
48
114
|
* @description Decorator for handling delete operations
|
|
49
115
|
* @summary Defines a behavior to execute during delete operations
|
|
@@ -54,7 +120,7 @@ export declare function onRead<V = object>(handler: IdOperationHandler<any, any,
|
|
|
54
120
|
* @function onDelete
|
|
55
121
|
* @category Property Decorators
|
|
56
122
|
*/
|
|
57
|
-
export declare function onDelete<V = object>(handler: OperationHandler<any, any, V, any, any>, data: V): (target:
|
|
123
|
+
export declare function onDelete<V = object>(handler: OperationHandler<any, any, V, any, any>, data: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
|
58
124
|
/**
|
|
59
125
|
* @description Decorator for handling all operation types
|
|
60
126
|
* @summary Defines a behavior to execute during any database operation
|
|
@@ -65,7 +131,7 @@ export declare function onDelete<V = object>(handler: OperationHandler<any, any,
|
|
|
65
131
|
* @function onAny
|
|
66
132
|
* @category Property Decorators
|
|
67
133
|
*/
|
|
68
|
-
export declare function onAny<V = object>(handler: OperationHandler<any, any, V, any, any>, data: V): (target:
|
|
134
|
+
export declare function onAny<V = object>(handler: OperationHandler<any, any, V, any, any>, data: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
|
69
135
|
/**
|
|
70
136
|
* @description Base decorator for handling database operations
|
|
71
137
|
* @summary Defines a behavior to execute during specified database operations
|
|
@@ -83,7 +149,7 @@ export declare function onAny<V = object>(handler: OperationHandler<any, any, V,
|
|
|
83
149
|
* myProperty: string;
|
|
84
150
|
* }
|
|
85
151
|
*/
|
|
86
|
-
export declare function on<V = object>(op: OperationKeys[] | undefined, handler: OperationHandler<any, any, V, any, any>, data?: V): (target:
|
|
152
|
+
export declare function on<V = object>(op: OperationKeys[] | undefined, handler: OperationHandler<any, any, V, any, any>, data?: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
|
87
153
|
/**
|
|
88
154
|
* @description Decorator for handling post-create and post-update operations
|
|
89
155
|
* @summary Defines a behavior to execute after both create and update operations
|
|
@@ -94,7 +160,7 @@ export declare function on<V = object>(op: OperationKeys[] | undefined, handler:
|
|
|
94
160
|
* @function afterCreateUpdate
|
|
95
161
|
* @category Property Decorators
|
|
96
162
|
*/
|
|
97
|
-
export declare function afterCreateUpdate<V = object>(handler: StandardOperationHandler<any, any, V, any, any> | UpdateOperationHandler<any, any, V, any, any>, data: V): (target:
|
|
163
|
+
export declare function afterCreateUpdate<V = object>(handler: StandardOperationHandler<any, any, V, any, any> | UpdateOperationHandler<any, any, V, any, any>, data: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
|
98
164
|
/**
|
|
99
165
|
* @description Decorator for handling post-update operations
|
|
100
166
|
* @summary Defines a behavior to execute after update operations
|
|
@@ -105,7 +171,7 @@ export declare function afterCreateUpdate<V = object>(handler: StandardOperation
|
|
|
105
171
|
* @function afterUpdate
|
|
106
172
|
* @category Property Decorators
|
|
107
173
|
*/
|
|
108
|
-
export declare function afterUpdate<V = object>(handler: UpdateOperationHandler<any, any, V, any, any>, data: V): (target:
|
|
174
|
+
export declare function afterUpdate<V = object>(handler: UpdateOperationHandler<any, any, V, any, any>, data: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
|
109
175
|
/**
|
|
110
176
|
* @description Decorator for handling post-create operations
|
|
111
177
|
* @summary Defines a behavior to execute after create operations
|
|
@@ -116,7 +182,7 @@ export declare function afterUpdate<V = object>(handler: UpdateOperationHandler<
|
|
|
116
182
|
* @function afterCreate
|
|
117
183
|
* @category Property Decorators
|
|
118
184
|
*/
|
|
119
|
-
export declare function afterCreate<V = object>(handler: StandardOperationHandler<any, any, V, any, any>, data: V): (target:
|
|
185
|
+
export declare function afterCreate<V = object>(handler: StandardOperationHandler<any, any, V, any, any>, data: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
|
120
186
|
/**
|
|
121
187
|
* @description Decorator for handling post-read operations
|
|
122
188
|
* @summary Defines a behavior to execute after read operations
|
|
@@ -127,7 +193,7 @@ export declare function afterCreate<V = object>(handler: StandardOperationHandle
|
|
|
127
193
|
* @function afterRead
|
|
128
194
|
* @category Property Decorators
|
|
129
195
|
*/
|
|
130
|
-
export declare function afterRead<V = object>(handler: StandardOperationHandler<any, any, V, any, any>, data?: V): (target:
|
|
196
|
+
export declare function afterRead<V = object>(handler: StandardOperationHandler<any, any, V, any, any>, data?: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
|
131
197
|
/**
|
|
132
198
|
* @description Decorator for handling post-delete operations
|
|
133
199
|
* @summary Defines a behavior to execute after delete operations
|
|
@@ -138,7 +204,7 @@ export declare function afterRead<V = object>(handler: StandardOperationHandler<
|
|
|
138
204
|
* @function afterDelete
|
|
139
205
|
* @category Property Decorators
|
|
140
206
|
*/
|
|
141
|
-
export declare function afterDelete<V = object>(handler: StandardOperationHandler<any, any, V, any, any>, data?: V): (target:
|
|
207
|
+
export declare function afterDelete<V = object>(handler: StandardOperationHandler<any, any, V, any, any>, data?: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
|
142
208
|
/**
|
|
143
209
|
* @description Decorator for handling post-operation for all operation types
|
|
144
210
|
* @summary Defines a behavior to execute after any database operation
|
|
@@ -149,7 +215,7 @@ export declare function afterDelete<V = object>(handler: StandardOperationHandle
|
|
|
149
215
|
* @function afterAny
|
|
150
216
|
* @category Property Decorators
|
|
151
217
|
*/
|
|
152
|
-
export declare function afterAny<V = object>(handler: StandardOperationHandler<any, any, V, any, any>, data?: V): (target:
|
|
218
|
+
export declare function afterAny<V = object>(handler: StandardOperationHandler<any, any, V, any, any>, data?: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
|
153
219
|
/**
|
|
154
220
|
* @description Base decorator for handling post-operation behaviors
|
|
155
221
|
* @summary Defines a behavior to execute after specified database operations
|
|
@@ -167,7 +233,7 @@ export declare function afterAny<V = object>(handler: StandardOperationHandler<a
|
|
|
167
233
|
* myProperty: string;
|
|
168
234
|
* }
|
|
169
235
|
*/
|
|
170
|
-
export declare function after<V = object>(op: OperationKeys[] | undefined, handler: OperationHandler<any, any, V, any, any>, data?: V): (target:
|
|
236
|
+
export declare function after<V = object>(op: OperationKeys[] | undefined, handler: OperationHandler<any, any, V, any, any>, data?: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
|
171
237
|
/**
|
|
172
238
|
* @description Core decorator factory for operation handlers
|
|
173
239
|
* @summary Creates decorators that register handlers for database operations
|
|
@@ -196,4 +262,4 @@ export declare function after<V = object>(op: OperationKeys[] | undefined, handl
|
|
|
196
262
|
* Handler-->>Operations: Return result
|
|
197
263
|
* Operations-->>Client: Return final result
|
|
198
264
|
*/
|
|
199
|
-
export declare function operation<V = object>(baseOp: OperationKeys.ON | OperationKeys.AFTER, operation: OperationKeys[] | undefined, handler: OperationHandler<any, any, V, any, any>, dataToAdd?: V): (target:
|
|
265
|
+
export declare function operation<V = object>(baseOp: OperationKeys.ON | OperationKeys.AFTER, operation: OperationKeys[] | undefined, handler: OperationHandler<any, any, V, any, any>, dataToAdd?: V, groupsort?: GroupSort): (target: any, propertyKey?: any) => void;
|
package/lib/operations/types.cjs
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvb3BlcmF0aW9ucy90eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT3BlcmF0aW9uS2V5cyB9IGZyb20gXCIuL2NvbnN0YW50c1wiO1xuaW1wb3J0IHsgSVJlcG9zaXRvcnkgfSBmcm9tIFwiLi4vaW50ZXJmYWNlcy9JUmVwb3NpdG9yeVwiO1xuaW1wb3J0IHsgTW9kZWwgfSBmcm9tIFwiQGRlY2FmLXRzL2RlY29yYXRvci12YWxpZGF0aW9uXCI7XG5pbXBvcnQgeyBDb250ZXh0IH0gZnJvbSBcIi4uL3JlcG9zaXRvcnkvQ29udGV4dFwiO1xuaW1wb3J0IHsgUmVwb3NpdG9yeUZsYWdzIH0gZnJvbSBcIi4uL3JlcG9zaXRvcnkvdHlwZXNcIjtcblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gTWV0YWRhdGEgZm9yIGRhdGFiYXNlIG9wZXJhdGlvbnNcbiAqIEBzdW1tYXJ5IENvbnRhaW5zIGluZm9ybWF0aW9uIGFib3V0IGFuIG9wZXJhdGlvbiwgaXRzIGhhbmRsZXIsIGFuZCBhc3NvY2lhdGVkIG1ldGFkYXRhXG4gKiBAdGVtcGxhdGUgViAtIFR5cGUgb2YgdGhlIG1ldGFkYXRhXG4gKiBAdHlwZWRlZiB7T2JqZWN0fSBPcGVyYXRpb25NZXRhZGF0YVxuICogQHByb3BlcnR5IHtPcGVyYXRpb25LZXlzfSBvcGVyYXRpb24gLSBUaGUgdHlwZSBvZiBvcGVyYXRpb25cbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBoYW5kbGVyIC0gVGhlIG5hbWUgb2YgdGhlIGhhbmRsZXIgZnVuY3Rpb25cbiAqIEBwcm9wZXJ0eSB7Vn0gW21ldGFkYXRhXSAtIE9wdGlvbmFsIG1ldGFkYXRhIGFzc29jaWF0ZWQgd2l0aCB0aGUgb3BlcmF0aW9uXG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRiLWRlY29yYXRvcnNcbiAqL1xuZXhwb3J0IHR5cGUgT3BlcmF0aW9uTWV0YWRhdGE8Vj4gPSB7XG4gIG9wZXJhdGlvbjogT3BlcmF0aW9uS2V5cztcbiAgaGFuZGxlcjogc3RyaW5nO1xuICBtZXRhZGF0YT86IFY7XG59O1xuXG5leHBvcnQgdHlwZSBPcGVyYXRpb25IYW5kbGVyPFxuICBNIGV4dGVuZHMgTW9kZWwsXG4gIFIgZXh0ZW5kcyBJUmVwb3NpdG9yeTxNLCBGLCBDPixcbiAgViA9IG9iamVjdCxcbiAgRiBleHRlbmRzIFJlcG9zaXRvcnlGbGFncyA9IFJlcG9zaXRvcnlGbGFncyxcbiAgQyBleHRlbmRzIENvbnRleHQ8Rj4gPSBDb250ZXh0PEY+LFxuPiA9XG4gIHwgU3RhbmRhcmRPcGVyYXRpb25IYW5kbGVyPE0sIFIsIFYsIEYsIEM+XG4gIHwgVXBkYXRlT3BlcmF0aW9uSGFuZGxlcjxNLCBSLCBWLCBGLCBDPlxuICB8IElkT3BlcmF0aW9uSGFuZGxlcjxNLCBSLCBWLCBGLCBDPjtcblxuZXhwb3J0IHR5cGUgU3RhbmRhcmRPcGVyYXRpb25IYW5kbGVyPFxuICBNIGV4dGVuZHMgTW9kZWwsXG4gIFIgZXh0ZW5kcyBJUmVwb3NpdG9yeTxNLCBGLCBDPixcbiAgViA9IG9iamVjdCxcbiAgRiBleHRlbmRzIFJlcG9zaXRvcnlGbGFncyA9IFJlcG9zaXRvcnlGbGFncyxcbiAgQyBleHRlbmRzIENvbnRleHQ8Rj4gPSBDb250ZXh0PEY+LFxuPiA9IChcbiAgdGhpczogUixcbiAgY29udGV4dDogQyxcbiAgbWV0YWRhdGE6IFYsXG4gIGtleToga2V5b2YgTSxcbiAgbW9kZWw6IE1cbikgPT4gUHJvbWlzZTx2b2lkPiB8IHZvaWQ7XG5cbmV4cG9ydCB0eXBlIElkT3BlcmF0aW9uSGFuZGxlcjxcbiAgTSBleHRlbmRzIE1vZGVsLFxuICBSIGV4dGVuZHMgSVJlcG9zaXRvcnk8TSwgRiwgQz4sXG4gIFYgPSBvYmplY3QsXG4gIEYgZXh0ZW5kcyBSZXBvc2l0b3J5RmxhZ3MgPSBSZXBvc2l0b3J5RmxhZ3MsXG4gIEMgZXh0ZW5kcyBDb250ZXh0PEY+ID0gQ29udGV4dDxGPixcbj4gPSAoXG4gIHRoaXM6IFIsXG4gIGNvbnRleHQ6IEMsXG4gIGRlY29yYXRvcjogVixcbiAga2V5OiBrZXlvZiBNLFxuICBpZDogc3RyaW5nXG4pID0+IFByb21pc2U8dm9pZD4gfCB2b2lkO1xuXG5leHBvcnQgdHlwZSBVcGRhdGVPcGVyYXRpb25IYW5kbGVyPFxuICBNIGV4dGVuZHMgTW9kZWwsXG4gIFIgZXh0ZW5kcyBJUmVwb3NpdG9yeTxNLCBGLCBDPixcbiAgViA9IG9iamVjdCxcbiAgRiBleHRlbmRzIFJlcG9zaXRvcnlGbGFncyA9IFJlcG9zaXRvcnlGbGFncyxcbiAgQyBleHRlbmRzIENvbnRleHQ8Rj4gPSBDb250ZXh0PEY+LFxuPiA9IChcbiAgdGhpczogUixcbiAgY29udGV4dDogQyxcbiAgZGVjb3JhdG9yOiBWLFxuICBrZXk6IGtleW9mIE0sXG4gIG1vZGVsOiBNLFxuICBvbGRNb2RlbDogTVxuKSA9PiBQcm9taXNlPHZvaWQ+IHwgdm9pZDtcbiJdfQ==
|
|
3
|
+
//# 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"]}
|
|
@@ -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>;
|
|
@@ -87,11 +87,6 @@ class Context {
|
|
|
87
87
|
* @description Accumulates new values into the context.
|
|
88
88
|
* @summary Merges the provided value object with the existing context state,
|
|
89
89
|
* creating a new immutable cache state.
|
|
90
|
-
*
|
|
91
|
-
* @template F - current accumulator type
|
|
92
|
-
* @template V - Type extending object for the values to accumulate
|
|
93
|
-
* @param {V} value - The object containing values to accumulate
|
|
94
|
-
* @returns A new context instance with accumulated values
|
|
95
90
|
*/
|
|
96
91
|
accumulate(value) {
|
|
97
92
|
Object.defineProperty(this, "cache", {
|
|
@@ -107,64 +102,26 @@ class Context {
|
|
|
107
102
|
}
|
|
108
103
|
/**
|
|
109
104
|
* @description Retrieves a value from the context by key.
|
|
110
|
-
* @summary Attempts to get a value from the current context's cache.
|
|
111
|
-
* If not found, traverses up the parent context chain.
|
|
112
|
-
*
|
|
113
|
-
* @template K - Type extending keyof F for the key to retrieve
|
|
114
|
-
* @template F - Accumulator type
|
|
115
|
-
* @param {K} key - The key to retrieve from the context
|
|
116
|
-
* @returns The value associated with the key
|
|
117
|
-
* @throws {Error} If the key is not found in the context chain
|
|
118
105
|
*/
|
|
119
106
|
get(key) {
|
|
120
107
|
try {
|
|
121
108
|
return this.cache.get(key);
|
|
122
109
|
}
|
|
123
110
|
catch (e) {
|
|
124
|
-
|
|
125
|
-
|
|
111
|
+
const parent = this.cache.parentContext;
|
|
112
|
+
if (parent)
|
|
113
|
+
return parent.get(key);
|
|
126
114
|
throw e;
|
|
127
115
|
}
|
|
128
116
|
}
|
|
129
|
-
/**
|
|
130
|
-
* @description Creates a child context
|
|
131
|
-
* @summary Generates a new context instance with current context as parent
|
|
132
|
-
*
|
|
133
|
-
* @template M - Type extending Model
|
|
134
|
-
* @param {OperationKeys} operation - The operation type
|
|
135
|
-
* @param {Constructor<M>} [model] - Optional model constructor
|
|
136
|
-
* @returns {C} New child context instance
|
|
137
|
-
*/
|
|
138
|
-
child(operation, model) {
|
|
139
|
-
return Context.childFrom(this, {
|
|
140
|
-
operation: operation,
|
|
141
|
-
affectedTables: model ? [model] : [],
|
|
142
|
-
});
|
|
143
|
-
}
|
|
144
117
|
/**
|
|
145
118
|
* @description Creates a child context from another context
|
|
146
|
-
* @summary Generates a new context instance with parent reference
|
|
147
|
-
*
|
|
148
|
-
* @template F - Type extending Repository Flags
|
|
149
|
-
* @template C - Type extending Context<F>
|
|
150
|
-
* @param {C} context - The parent context
|
|
151
|
-
* @param {Partial<F>} [overrides] - Optional flag overrides
|
|
152
|
-
* @returns {C} New child context instance
|
|
153
119
|
*/
|
|
154
120
|
static childFrom(context, overrides) {
|
|
155
121
|
return Context.factory(Object.assign({}, context.cache, overrides || {}));
|
|
156
122
|
}
|
|
157
123
|
/**
|
|
158
124
|
* @description Creates a new context from operation parameters
|
|
159
|
-
* @summary Generates a context instance for specific operation
|
|
160
|
-
*
|
|
161
|
-
* @template F - Type extending Repository Flags
|
|
162
|
-
* @template M - Type extending Model
|
|
163
|
-
* @param {OperationKeys.DELETE} operation - The operation type
|
|
164
|
-
* @param {Partial<F>} overrides - Flag overrides
|
|
165
|
-
* @param {Constructor<M>} model - The model constructor
|
|
166
|
-
* @param {any} args - Operation arguments
|
|
167
|
-
* @returns {Promise<C>} Promise resolving to new context
|
|
168
125
|
*/
|
|
169
126
|
static async from(operation, overrides, model,
|
|
170
127
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
@@ -176,30 +133,6 @@ class Context {
|
|
|
176
133
|
}
|
|
177
134
|
/**
|
|
178
135
|
* @description Prepares arguments for context operations
|
|
179
|
-
* @summary Creates a context args object with the specified operation parameters
|
|
180
|
-
*
|
|
181
|
-
* @template F - Type extending {@link RepositoryFlags}
|
|
182
|
-
* @template M - Type extending {@link Model}
|
|
183
|
-
* @param {OperationKeys.DELETE} operation - The operation type
|
|
184
|
-
* @param {Constructor<M>} model - The model constructor
|
|
185
|
-
* @param {any[]} args - Operation arguments
|
|
186
|
-
* @param {Contextual<F>} [contextual] - Optional contextual object
|
|
187
|
-
* @param {Partial<F>} [overrides] - Optional flag overrides
|
|
188
|
-
* @returns {Promise<ContextArgs>} Promise resolving to context arguments
|
|
189
|
-
*
|
|
190
|
-
* @mermaid
|
|
191
|
-
* sequenceDiagram
|
|
192
|
-
* participant C as Context
|
|
193
|
-
* participant M as Model
|
|
194
|
-
* participant A as Args
|
|
195
|
-
*
|
|
196
|
-
* C->>C: Receive operation request
|
|
197
|
-
* C->>M: Validate model constructor
|
|
198
|
-
* C->>C: Create child context
|
|
199
|
-
* C->>A: Process operation args
|
|
200
|
-
* A->>C: Return context args
|
|
201
|
-
* C->>C: Apply overrides
|
|
202
|
-
* C->>C: Return final context
|
|
203
136
|
*/
|
|
204
137
|
static async args(operation, model, args, contextual, overrides) {
|
|
205
138
|
const last = args.pop();
|
|
@@ -228,4 +161,4 @@ class Context {
|
|
|
228
161
|
}
|
|
229
162
|
}
|
|
230
163
|
exports.Context = Context;
|
|
231
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Context.js","sourceRoot":"","sources":["../../src/repository/Context.ts"],"names":[],"mappings":"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","sourcesContent":["import { ContextArgs } from \"./utils\";\nimport { Contextual } from \"../interfaces/Contextual\";\nimport { OperationKeys } from \"../operations/constants\";\nimport { Constructor, Model } from \"@decaf-ts/decorator-validation\";\nimport { DefaultRepositoryFlags } from \"./constants\";\nimport { ObjectAccumulator } from \"typed-object-accumulator\";\nimport { RepositoryFlags } from \"./types\";\n\n/**\n * @description Factory type for creating context instances.\n * @summary Defines a function type that creates context instances with specific repository flags.\n * @template F - The repository flags type extending RepositoryFlags\n * @typedef {Function} ContextFactory\n * @memberOf module:db-decorators\n */\nexport type ContextFactory<F extends RepositoryFlags> = <C extends Context<F>>(\n  arg: Omit<F, \"timestamp\">\n) => C;\n\n/**\n * @description Default factory for creating context instances.\n * @summary A factory function that creates new Context instances with the provided repository flags.\n * It automatically adds a timestamp to the context and returns a properly typed context instance.\n * @const DefaultContextFactory\n * @memberOf module:db-decorators\n */\nexport const DefaultContextFactory: ContextFactory<any> = <\n  F extends RepositoryFlags,\n  C extends Context<F>,\n>(\n  arg: Omit<F, \"timestamp\">\n) => {\n  return new Context<F>().accumulate(\n    Object.assign({}, arg, { timestamp: new Date() }) as F\n  ) as C;\n};\n\n/**\n * @description A context management class for handling repository operations.\n * @summary The Context class provides a mechanism for managing repository operations with flags,\n * parent-child relationships, and state accumulation. It allows for hierarchical context chains\n * and maintains operation-specific configurations while supporting type safety through generics.\n *\n * @template F - Type extending RepositoryFlags that defines the context configuration\n *\n * @param {ObjectAccumulator<F>} cache - The internal cache storing accumulated values\n *\n * @class\n *\n * @example\n * ```typescript\n * // Creating a new context with repository flags\n * const context = new Context<RepositoryFlags>();\n *\n * // Accumulating values\n * const enrichedContext = context.accumulate({\n *   writeOperation: true,\n *   affectedTables: ['users'],\n *   operation: OperationKeys.CREATE\n * });\n *\n * // Accessing values\n * const isWrite = enrichedContext.get('writeOperation'); // true\n * const tables = enrichedContext.get('affectedTables'); // ['users']\n * ```\n *\n * @mermaid\n * sequenceDiagram\n *   participant C as Client\n *   participant Ctx as Context\n *   participant Cache as ObjectAccumulator\n *\n *   C->>Ctx: new Context()\n *   Ctx->>Cache: create cache\n *\n *   C->>Ctx: accumulate(value)\n *   Ctx->>Cache: accumulate(value)\n *   Cache-->>Ctx: updated cache\n *   Ctx-->>C: updated context\n *\n *   C->>Ctx: get(key)\n *   Ctx->>Cache: get(key)\n *   alt Key exists in cache\n *     Cache-->>Ctx: value\n *   else Key not found\n *     Ctx->>Ctx: check parent context\n *     alt Parent exists\n *       Ctx->>Parent: get(key)\n *       Parent-->>Ctx: value\n *     else No parent\n *       Ctx-->>C: throw error\n *     end\n *   end\n *   Ctx-->>C: requested value\n */\nexport class Context<F extends RepositoryFlags> {\n  constructor() {\n    Object.defineProperty(this, \"cache\", {\n      value: new ObjectAccumulator<F>(),\n      writable: false,\n      enumerable: false,\n      configurable: true,\n    });\n  }\n\n  static factory: ContextFactory<any> = DefaultContextFactory;\n\n  private readonly cache: F & ObjectAccumulator<F> =\n    new ObjectAccumulator() as F & ObjectAccumulator<F>;\n\n  /**\n   * @description Accumulates new values into the context.\n   * @summary Merges the provided value object with the existing context state,\n   * creating a new immutable cache state.\n   *\n   * @template F - current accumulator type\n   * @template V - Type extending object for the values to accumulate\n   * @param {V} value - The object containing values to accumulate\n   * @returns A new context instance with accumulated values\n   */\n  accumulate<V extends object>(value: V) {\n    Object.defineProperty(this, \"cache\", {\n      value: this.cache.accumulate(value),\n      writable: false,\n      enumerable: false,\n      configurable: true,\n    });\n    return this as unknown as Context<F & V>;\n  }\n\n  get timestamp() {\n    return this.cache.timestamp;\n  }\n\n  /**\n   * @description Retrieves a value from the context by key.\n   * @summary Attempts to get a value from the current context's cache.\n   * If not found, traverses up the parent context chain.\n   *\n   * @template K - Type extending keyof F for the key to retrieve\n   * @template F - Accumulator type\n   * @param {K} key - The key to retrieve from the context\n   * @returns The value associated with the key\n   * @throws {Error} If the key is not found in the context chain\n   */\n  get<K extends keyof F>(key: K): F[K] {\n    try {\n      return this.cache.get(key);\n    } catch (e: unknown) {\n      if (this.cache.parentContext) return this.cache.parentContext.get(key);\n      throw e;\n    }\n  }\n\n  /**\n   * @description Creates a child context\n   * @summary Generates a new context instance with current context as parent\n   *\n   * @template M - Type extending Model\n   * @param {OperationKeys} operation - The operation type\n   * @param {Constructor<M>} [model] - Optional model constructor\n   * @returns {C} New child context instance\n   */\n  child<M extends Model, C extends Context<F>>(\n    operation: OperationKeys,\n    model?: Constructor<M>\n  ): C {\n    return Context.childFrom<F, C>(\n      this as unknown as C,\n      {\n        operation: operation,\n        affectedTables: model ? [model] : [],\n      } as unknown as Partial<F>\n    );\n  }\n\n  /**\n   * @description Creates a child context from another context\n   * @summary Generates a new context instance with parent reference\n   *\n   * @template F - Type extending Repository Flags\n   * @template C - Type extending Context<F>\n   * @param {C} context - The parent context\n   * @param {Partial<F>} [overrides] - Optional flag overrides\n   * @returns {C} New child context instance\n   */\n  static childFrom<F extends RepositoryFlags, C extends Context<F>>(\n    context: C,\n    overrides?: Partial<F>\n  ): C {\n    return Context.factory(\n      Object.assign({}, context.cache, overrides || {})\n    ) as unknown as C;\n  }\n\n  /**\n   * @description Creates a new context from operation parameters\n   * @summary Generates a context instance for specific operation\n   *\n   * @template F - Type extending Repository Flags\n   * @template M - Type extending Model\n   * @param {OperationKeys.DELETE} operation - The operation type\n   * @param {Partial<F>} overrides - Flag overrides\n   * @param {Constructor<M>} model - The model constructor\n   * @param {any} args - Operation arguments\n   * @returns {Promise<C>} Promise resolving to new context\n   */\n  static async from<\n    M extends Model,\n    F extends RepositoryFlags,\n    C extends Context<F>,\n  >(\n    operation:\n      | OperationKeys.CREATE\n      | OperationKeys.READ\n      | OperationKeys.UPDATE\n      | OperationKeys.DELETE,\n    overrides: Partial<F>,\n    model: Constructor<M>,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    ...args: any[]\n  ): Promise<C> {\n    return Context.factory(\n      Object.assign({}, DefaultRepositoryFlags, overrides, {\n        operation: operation,\n        model: model,\n      })\n    ) as C;\n  }\n\n  /**\n   * @description Prepares arguments for context operations\n   * @summary Creates a context args object with the specified operation parameters\n   *\n   * @template F - Type extending {@link RepositoryFlags}\n   * @template M - Type extending {@link Model}\n   * @param {OperationKeys.DELETE} operation - The operation type\n   * @param {Constructor<M>} model - The model constructor\n   * @param {any[]} args - Operation arguments\n   * @param {Contextual<F>} [contextual] - Optional contextual object\n   * @param {Partial<F>} [overrides] - Optional flag overrides\n   * @returns {Promise<ContextArgs>} Promise resolving to context arguments\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant C as Context\n   *   participant M as Model\n   *   participant A as Args\n   *\n   *   C->>C: Receive operation request\n   *   C->>M: Validate model constructor\n   *   C->>C: Create child context\n   *   C->>A: Process operation args\n   *   A->>C: Return context args\n   *   C->>C: Apply overrides\n   *   C->>C: Return final context\n   */\n  static async args<\n    M extends Model<any>,\n    C extends Context<F>,\n    F extends RepositoryFlags,\n  >(\n    operation:\n      | OperationKeys.CREATE\n      | OperationKeys.READ\n      | OperationKeys.UPDATE\n      | OperationKeys.DELETE,\n    model: Constructor<M>,\n    args: any[],\n    contextual?: Contextual<F>,\n    overrides?: Partial<F>\n  ): Promise<ContextArgs<F, C>> {\n    const last = args.pop();\n\n    async function getContext() {\n      if (contextual)\n        return contextual.context(operation, overrides || {}, model, ...args);\n      return Context.from(operation, overrides || {}, model, ...args);\n    }\n\n    let c: C;\n    if (last) {\n      if (last instanceof Context) {\n        c = last as C;\n        args.push(last);\n      } else {\n        args.push(last);\n        c = (await getContext()) as C;\n        args.push(c);\n      }\n    } else {\n      c = (await getContext()) as C;\n      args.push(c);\n    }\n\n    return { context: c, args: args };\n  }\n}\n"]}
|
|
164
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Context.js","sourceRoot":"","sources":["../../src/repository/Context.ts"],"names":[],"mappings":"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","sourcesContent":["import { ContextArgs } from \"./utils\";\nimport { Contextual } from \"../interfaces/Contextual\";\nimport { OperationKeys } from \"../operations/constants\";\nimport { Constructor, Model } from \"@decaf-ts/decorator-validation\";\nimport { DefaultRepositoryFlags } from \"./constants\";\nimport { ObjectAccumulator } from \"typed-object-accumulator\";\nimport { RepositoryFlags } from \"./types\";\n\n/**\n * @description Factory type for creating context instances.\n * @summary Defines a function type that creates context instances with specific repository flags.\n * @template F - The repository flags type extending RepositoryFlags\n * @typedef {Function} ContextFactory\n * @memberOf module:db-decorators\n */\nexport type ContextFactory<F extends RepositoryFlags> = <C extends Context<F>>(\n  arg: Omit<F, \"timestamp\">\n) => C;\n\n/**\n * @description Default factory for creating context instances.\n * @summary A factory function that creates new Context instances with the provided repository flags.\n * It automatically adds a timestamp to the context and returns a properly typed context instance.\n * @const DefaultContextFactory\n * @memberOf module:db-decorators\n */\nexport const DefaultContextFactory: ContextFactory<any> = <\n  F extends RepositoryFlags,\n  C extends Context<F>,\n>(\n  arg: Omit<F, \"timestamp\">\n) => {\n  return new Context<F>().accumulate(\n    Object.assign({}, arg, { timestamp: new Date() }) as F\n  ) as C;\n};\n\n/**\n * @description A context management class for handling repository operations.\n * @summary The Context class provides a mechanism for managing repository operations with flags,\n * parent-child relationships, and state accumulation. It allows for hierarchical context chains\n * and maintains operation-specific configurations while supporting type safety through generics.\n *\n * @template F - Type extending RepositoryFlags that defines the context configuration\n *\n * @param {ObjectAccumulator<F>} cache - The internal cache storing accumulated values\n *\n * @class\n *\n * @example\n * ```typescript\n * // Creating a new context with repository flags\n * const context = new Context<RepositoryFlags>();\n *\n * // Accumulating values\n * const enrichedContext = context.accumulate({\n *   writeOperation: true,\n *   affectedTables: ['users'],\n *   operation: OperationKeys.CREATE\n * });\n *\n * // Accessing values\n * const isWrite = enrichedContext.get('writeOperation'); // true\n * const tables = enrichedContext.get('affectedTables'); // ['users']\n * ```\n *\n * @mermaid\n * sequenceDiagram\n *   participant C as Client\n *   participant Ctx as Context\n *   participant Cache as ObjectAccumulator\n *\n *   C->>Ctx: new Context()\n *   Ctx->>Cache: create cache\n *\n *   C->>Ctx: accumulate(value)\n *   Ctx->>Cache: accumulate(value)\n *   Cache-->>Ctx: updated cache\n *   Ctx-->>C: updated context\n *\n *   C->>Ctx: get(key)\n *   Ctx->>Cache: get(key)\n *   alt Key exists in cache\n *     Cache-->>Ctx: value\n *   else Key not found\n *     Ctx->>Ctx: check parent context\n *     alt Parent exists\n *       Ctx->>Parent: get(key)\n *       Parent-->>Ctx: value\n *     else No parent\n *       Ctx-->>C: throw error\n *     end\n *   end\n *   Ctx-->>C: requested value\n */\nexport class Context<F extends RepositoryFlags> {\n  constructor() {\n    Object.defineProperty(this, \"cache\", {\n      value: new ObjectAccumulator<F>(),\n      writable: false,\n      enumerable: false,\n      configurable: true,\n    });\n  }\n\n  static factory: ContextFactory<any> = DefaultContextFactory;\n\n  readonly cache: RepositoryFlags & ObjectAccumulator<any> =\n    new ObjectAccumulator() as unknown as RepositoryFlags &\n      ObjectAccumulator<any>;\n\n  /**\n   * @description Accumulates new values into the context.\n   * @summary Merges the provided value object with the existing context state,\n   * creating a new immutable cache state.\n   */\n  accumulate<V extends object>(value: V) {\n    Object.defineProperty(this, \"cache\", {\n      value: (this.cache as ObjectAccumulator<any>).accumulate(value),\n      writable: false,\n      enumerable: false,\n      configurable: true,\n    });\n    return this as unknown as Context<F & V>;\n  }\n\n  get timestamp() {\n    return (this.cache as any).timestamp as F[\"timestamp\"];\n  }\n\n  /**\n   * @description Retrieves a value from the context by key.\n   */\n  get<K extends keyof F>(key: K): F[K] {\n    try {\n      return (this.cache as ObjectAccumulator<any>).get(\n        key as unknown as string\n      ) as F[K];\n    } catch (e: unknown) {\n      const parent = (this.cache as any).parentContext as\n        | Context<F>\n        | undefined;\n      if (parent) return parent.get(key);\n      throw e;\n    }\n  }\n\n  /**\n   * @description Creates a child context from another context\n   */\n  static childFrom<F extends RepositoryFlags, C extends Context<F>>(\n    context: C,\n    overrides?: Partial<F>\n  ): C {\n    return Context.factory(\n      Object.assign({}, (context as any).cache, overrides || {})\n    ) as unknown as C;\n  }\n\n  /**\n   * @description Creates a new context from operation parameters\n   */\n  static async from<\n    M extends Model,\n    F extends RepositoryFlags,\n    C extends Context<F>,\n  >(\n    operation:\n      | OperationKeys.CREATE\n      | OperationKeys.READ\n      | OperationKeys.UPDATE\n      | OperationKeys.DELETE,\n    overrides: Partial<F>,\n    model: Constructor<M>,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    ...args: any[]\n  ): Promise<C> {\n    return Context.factory(\n      Object.assign({}, DefaultRepositoryFlags as RepositoryFlags, overrides, {\n        operation: operation,\n        model: model,\n      })\n    ) as C;\n  }\n\n  /**\n   * @description Prepares arguments for context operations\n   */\n  static async args<\n    M extends Model<any>,\n    C extends Context<F>,\n    F extends RepositoryFlags,\n  >(\n    operation:\n      | OperationKeys.CREATE\n      | OperationKeys.READ\n      | OperationKeys.UPDATE\n      | OperationKeys.DELETE,\n    model: Constructor<M>,\n    args: any[],\n    contextual?: Contextual<F>,\n    overrides?: Partial<F>\n  ): Promise<ContextArgs<F, C>> {\n    const last = args.pop();\n\n    async function getContext() {\n      if (contextual)\n        return contextual.context(operation, overrides || {}, model, ...args);\n      return Context.from(operation, overrides || {}, model, ...args);\n    }\n\n    let c: C;\n    if (last) {\n      if (last instanceof Context) {\n        c = last as C;\n        args.push(last);\n      } else {\n        args.push(last);\n        c = (await getContext()) as C;\n        args.push(c);\n      }\n    } else {\n      c = (await getContext()) as C;\n      args.push(c);\n    }\n\n    return { context: c, args: args };\n  }\n}\n"]}
|