@decaf-ts/db-decorators 0.6.1 → 0.6.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE.md +21 -157
- package/README.md +571 -10
- package/dist/db-decorators.cjs +1352 -322
- package/dist/db-decorators.esm.cjs +1352 -323
- package/lib/esm/identity/decorators.d.ts +7 -0
- package/lib/esm/identity/decorators.js +11 -4
- package/lib/esm/identity/index.js +3 -3
- package/lib/esm/identity/utils.d.ts +36 -23
- package/lib/esm/identity/utils.js +38 -25
- package/lib/esm/index.d.ts +12 -27
- package/lib/esm/index.js +13 -28
- package/lib/esm/interfaces/BulkCrudOperator.d.ts +39 -0
- package/lib/esm/interfaces/BulkCrudOperator.js +1 -1
- package/lib/esm/interfaces/Contextual.d.ts +17 -0
- package/lib/esm/interfaces/Contextual.js +1 -1
- package/lib/esm/interfaces/CrudOperator.d.ts +26 -23
- package/lib/esm/interfaces/CrudOperator.js +1 -1
- package/lib/esm/interfaces/IRepository.d.ts +10 -2
- package/lib/esm/interfaces/IRepository.js +1 -1
- package/lib/esm/interfaces/index.js +5 -5
- package/lib/esm/model/constants.d.ts +11 -13
- package/lib/esm/model/constants.js +12 -14
- package/lib/esm/model/decorators.d.ts +112 -23
- package/lib/esm/model/decorators.js +119 -29
- package/lib/esm/model/index.d.ts +1 -0
- package/lib/esm/model/index.js +7 -6
- package/lib/esm/model/model.d.ts +2 -141
- package/lib/esm/model/model.js +2 -13
- package/lib/esm/model/overrides.d.ts +1 -0
- package/lib/esm/model/overrides.js +23 -0
- package/lib/esm/model/utils.d.ts +39 -0
- package/lib/esm/model/utils.js +42 -3
- package/lib/esm/model/validation.d.ts +26 -8
- package/lib/esm/model/validation.js +29 -11
- package/lib/esm/operations/Operations.d.ts +65 -3
- package/lib/esm/operations/Operations.js +68 -6
- package/lib/esm/operations/OperationsRegistry.d.ts +44 -16
- package/lib/esm/operations/OperationsRegistry.js +46 -18
- package/lib/esm/operations/constants.d.ts +27 -8
- package/lib/esm/operations/constants.js +16 -9
- package/lib/esm/operations/decorators.d.ts +140 -134
- package/lib/esm/operations/decorators.js +152 -137
- package/lib/esm/operations/index.js +6 -6
- package/lib/esm/operations/types.d.ts +10 -0
- package/lib/esm/operations/types.js +1 -1
- package/lib/esm/repository/BaseRepository.d.ts +322 -0
- package/lib/esm/repository/BaseRepository.js +297 -7
- package/lib/esm/repository/Context.d.ts +153 -2
- package/lib/esm/repository/Context.js +154 -6
- package/lib/esm/repository/Repository.d.ts +89 -0
- package/lib/esm/repository/Repository.js +96 -7
- package/lib/esm/repository/constants.d.ts +7 -0
- package/lib/esm/repository/constants.js +8 -1
- package/lib/esm/repository/errors.d.ts +61 -34
- package/lib/esm/repository/errors.js +62 -35
- package/lib/esm/repository/index.js +9 -9
- package/lib/esm/repository/types.d.ts +25 -0
- package/lib/esm/repository/types.js +1 -1
- package/lib/esm/repository/utils.d.ts +11 -0
- package/lib/esm/repository/utils.js +4 -4
- package/lib/esm/repository/wrappers.d.ts +2 -2
- package/lib/esm/repository/wrappers.js +5 -5
- package/lib/esm/validation/constants.d.ts +20 -5
- package/lib/esm/validation/constants.js +22 -7
- package/lib/esm/validation/decorators.d.ts +101 -19
- package/lib/esm/validation/decorators.js +109 -27
- package/lib/esm/validation/index.js +5 -5
- package/lib/esm/validation/validation.js +10 -2
- package/lib/esm/validation/validators/ReadOnlyValidator.d.ts +32 -8
- package/lib/esm/validation/validators/ReadOnlyValidator.js +34 -10
- package/lib/esm/validation/validators/TimestampValidator.d.ts +37 -3
- package/lib/esm/validation/validators/TimestampValidator.js +39 -5
- package/lib/esm/validation/validators/UpdateValidator.d.ts +28 -11
- package/lib/esm/validation/validators/UpdateValidator.js +23 -8
- package/lib/esm/validation/validators/index.js +4 -4
- package/lib/identity/decorators.cjs +8 -1
- package/lib/identity/decorators.d.ts +7 -0
- package/lib/identity/utils.cjs +35 -22
- package/lib/identity/utils.d.ts +36 -23
- package/lib/index.cjs +14 -28
- package/lib/index.d.ts +12 -27
- package/lib/interfaces/BulkCrudOperator.cjs +1 -1
- package/lib/interfaces/BulkCrudOperator.d.ts +39 -0
- package/lib/interfaces/Contextual.cjs +1 -1
- package/lib/interfaces/Contextual.d.ts +17 -0
- package/lib/interfaces/CrudOperator.cjs +1 -1
- package/lib/interfaces/CrudOperator.d.ts +26 -23
- package/lib/interfaces/IRepository.cjs +1 -1
- package/lib/interfaces/IRepository.d.ts +10 -2
- package/lib/model/constants.cjs +12 -14
- package/lib/model/constants.d.ts +11 -13
- package/lib/model/decorators.cjs +114 -24
- package/lib/model/decorators.d.ts +112 -23
- package/lib/model/index.cjs +2 -1
- package/lib/model/index.d.ts +1 -0
- package/lib/model/model.cjs +1 -13
- package/lib/model/model.d.ts +2 -141
- package/lib/model/overrides.cjs +25 -0
- package/lib/model/overrides.d.ts +1 -0
- package/lib/model/utils.cjs +40 -1
- package/lib/model/utils.d.ts +39 -0
- package/lib/model/validation.cjs +27 -9
- package/lib/model/validation.d.ts +26 -8
- package/lib/operations/Operations.cjs +66 -4
- package/lib/operations/Operations.d.ts +65 -3
- package/lib/operations/OperationsRegistry.cjs +45 -17
- package/lib/operations/OperationsRegistry.d.ts +44 -16
- package/lib/operations/constants.cjs +16 -9
- package/lib/operations/constants.d.ts +27 -8
- package/lib/operations/decorators.cjs +150 -135
- package/lib/operations/decorators.d.ts +140 -134
- package/lib/operations/types.cjs +1 -1
- package/lib/operations/types.d.ts +10 -0
- package/lib/repository/BaseRepository.cjs +291 -1
- package/lib/repository/BaseRepository.d.ts +322 -0
- package/lib/repository/Context.cjs +153 -5
- package/lib/repository/Context.d.ts +153 -2
- package/lib/repository/Repository.cjs +90 -1
- package/lib/repository/Repository.d.ts +89 -0
- package/lib/repository/constants.cjs +8 -1
- package/lib/repository/constants.d.ts +7 -0
- package/lib/repository/errors.cjs +62 -35
- package/lib/repository/errors.d.ts +61 -34
- package/lib/repository/types.cjs +1 -1
- package/lib/repository/types.d.ts +25 -0
- package/lib/repository/utils.cjs +1 -1
- package/lib/repository/utils.d.ts +11 -0
- package/lib/repository/wrappers.cjs +3 -3
- package/lib/repository/wrappers.d.ts +2 -2
- package/lib/validation/constants.cjs +21 -6
- package/lib/validation/constants.d.ts +20 -5
- package/lib/validation/decorators.cjs +102 -20
- package/lib/validation/decorators.d.ts +101 -19
- package/lib/validation/validation.cjs +9 -1
- package/lib/validation/validators/ReadOnlyValidator.cjs +33 -9
- package/lib/validation/validators/ReadOnlyValidator.d.ts +32 -8
- package/lib/validation/validators/TimestampValidator.cjs +38 -4
- package/lib/validation/validators/TimestampValidator.d.ts +37 -3
- package/lib/validation/validators/UpdateValidator.cjs +23 -8
- package/lib/validation/validators/UpdateValidator.d.ts +28 -11
- package/package.json +2 -2
|
@@ -19,229 +19,244 @@ const constants_1 = require("./constants.cjs");
|
|
|
19
19
|
const Operations_1 = require("./Operations.cjs");
|
|
20
20
|
const reflection_1 = require("@decaf-ts/reflection");
|
|
21
21
|
const decorator_validation_1 = require("@decaf-ts/decorator-validation");
|
|
22
|
+
/**
|
|
23
|
+
* @description Internal function to register operation handlers
|
|
24
|
+
* @summary Registers an operation handler for a specific operation key on a target property
|
|
25
|
+
* @param {OperationKeys} op - The operation key to handle
|
|
26
|
+
* @param {OperationHandler<any, any, any, any, any>} handler - The handler function to register
|
|
27
|
+
* @return {PropertyDecorator} A decorator that registers the handler
|
|
28
|
+
* @function handle
|
|
29
|
+
* @category Property Decorators
|
|
30
|
+
*/
|
|
22
31
|
function handle(op, handler) {
|
|
23
32
|
return (target, propertyKey) => {
|
|
24
33
|
Operations_1.Operations.register(handler, op, target, propertyKey);
|
|
25
34
|
};
|
|
26
35
|
}
|
|
27
36
|
/**
|
|
28
|
-
* @
|
|
29
|
-
*
|
|
30
|
-
* @
|
|
31
|
-
* @param
|
|
32
|
-
* @param {
|
|
33
|
-
*
|
|
34
|
-
* @see on
|
|
35
|
-
*
|
|
37
|
+
* @description Decorator for handling create and update operations
|
|
38
|
+
* @summary Defines a behavior to execute during both create and update operations
|
|
39
|
+
* @template V - Type for metadata, defaults to object
|
|
40
|
+
* @param {StandardOperationHandler<any, any, V, any, any> | UpdateOperationHandler<any, any, V, any, any>} handler - The method called upon the operation
|
|
41
|
+
* @param {V} [data] - Optional metadata to pass to the handler
|
|
42
|
+
* @return {PropertyDecorator} A decorator that can be applied to class properties
|
|
36
43
|
* @function onCreateUpdate
|
|
37
|
-
*
|
|
38
|
-
* @category Decorators
|
|
44
|
+
* @category Property Decorators
|
|
39
45
|
*/
|
|
40
46
|
function onCreateUpdate(handler, data) {
|
|
41
47
|
return on(constants_1.DBOperations.CREATE_UPDATE, handler, data);
|
|
42
48
|
}
|
|
43
49
|
/**
|
|
44
|
-
* @
|
|
45
|
-
*
|
|
46
|
-
* @
|
|
47
|
-
* @param
|
|
48
|
-
* @param {
|
|
49
|
-
*
|
|
50
|
-
* @see on
|
|
51
|
-
*
|
|
50
|
+
* @description Decorator for handling update operations
|
|
51
|
+
* @summary Defines a behavior to execute during update operations
|
|
52
|
+
* @template V - Type for metadata, defaults to object
|
|
53
|
+
* @param {UpdateOperationHandler<any, any, V, any>} handler - The method called upon the operation
|
|
54
|
+
* @param {V} [data] - Optional metadata to pass to the handler
|
|
55
|
+
* @return {PropertyDecorator} A decorator that can be applied to class properties
|
|
52
56
|
* @function onUpdate
|
|
53
|
-
*
|
|
54
|
-
* @category Decorators
|
|
57
|
+
* @category Property Decorators
|
|
55
58
|
*/
|
|
56
59
|
function onUpdate(handler, data) {
|
|
57
60
|
return on(constants_1.DBOperations.UPDATE, handler, data);
|
|
58
61
|
}
|
|
59
62
|
/**
|
|
60
|
-
* @
|
|
61
|
-
*
|
|
62
|
-
* @
|
|
63
|
-
* @param
|
|
64
|
-
*
|
|
65
|
-
* @
|
|
66
|
-
*
|
|
63
|
+
* @description Decorator for handling create operations
|
|
64
|
+
* @summary Defines a behavior to execute during create operations
|
|
65
|
+
* @template V - Type for metadata, defaults to object
|
|
66
|
+
* @param {StandardOperationHandler<any, any, V, any, any>} handler - The method called upon the operation
|
|
67
|
+
* @param {V} [data] - Optional metadata to pass to the handler
|
|
68
|
+
* @return {PropertyDecorator} A decorator that can be applied to class properties
|
|
67
69
|
* @function onCreate
|
|
68
|
-
*
|
|
69
|
-
* @category Decorators
|
|
70
|
+
* @category Property Decorators
|
|
70
71
|
*/
|
|
71
72
|
function onCreate(handler, data) {
|
|
72
73
|
return on(constants_1.DBOperations.CREATE, handler, data);
|
|
73
74
|
}
|
|
74
75
|
/**
|
|
75
|
-
* @
|
|
76
|
-
*
|
|
77
|
-
* @
|
|
78
|
-
* @param
|
|
79
|
-
*
|
|
80
|
-
* @
|
|
81
|
-
*
|
|
76
|
+
* @description Decorator for handling read operations
|
|
77
|
+
* @summary Defines a behavior to execute during read operations
|
|
78
|
+
* @template V - Type for metadata, defaults to object
|
|
79
|
+
* @param {IdOperationHandler<any, any, V, any, any>} handler - The method called upon the operation
|
|
80
|
+
* @param {V} [data] - Optional metadata to pass to the handler
|
|
81
|
+
* @return {PropertyDecorator} A decorator that can be applied to class properties
|
|
82
82
|
* @function onRead
|
|
83
|
-
*
|
|
84
|
-
* @category Decorators
|
|
83
|
+
* @category Property Decorators
|
|
85
84
|
*/
|
|
86
85
|
function onRead(handler, data) {
|
|
87
86
|
return on(constants_1.DBOperations.READ, handler, data);
|
|
88
87
|
}
|
|
89
88
|
/**
|
|
90
|
-
* @
|
|
91
|
-
*
|
|
92
|
-
* @
|
|
93
|
-
* @param
|
|
94
|
-
*
|
|
95
|
-
* @
|
|
96
|
-
*
|
|
89
|
+
* @description Decorator for handling delete operations
|
|
90
|
+
* @summary Defines a behavior to execute during delete operations
|
|
91
|
+
* @template V - Type for metadata, defaults to object
|
|
92
|
+
* @param {OperationHandler<any, any, V, any, any>} handler - The method called upon the operation
|
|
93
|
+
* @param {V} [data] - Optional metadata to pass to the handler
|
|
94
|
+
* @return {PropertyDecorator} A decorator that can be applied to class properties
|
|
97
95
|
* @function onDelete
|
|
98
|
-
*
|
|
99
|
-
* @category Decorators
|
|
96
|
+
* @category Property Decorators
|
|
100
97
|
*/
|
|
101
98
|
function onDelete(handler, data) {
|
|
102
99
|
return on(constants_1.DBOperations.DELETE, handler, data);
|
|
103
100
|
}
|
|
104
101
|
/**
|
|
105
|
-
* @
|
|
106
|
-
*
|
|
107
|
-
* @
|
|
108
|
-
* @param
|
|
109
|
-
*
|
|
110
|
-
* @
|
|
111
|
-
*
|
|
102
|
+
* @description Decorator for handling all operation types
|
|
103
|
+
* @summary Defines a behavior to execute during any database operation
|
|
104
|
+
* @template V - Type for metadata, defaults to object
|
|
105
|
+
* @param {OperationHandler<any, any, V, any, any>} handler - The method called upon the operation
|
|
106
|
+
* @param {V} [data] - Optional metadata to pass to the handler
|
|
107
|
+
* @return {PropertyDecorator} A decorator that can be applied to class properties
|
|
112
108
|
* @function onAny
|
|
113
|
-
*
|
|
114
|
-
* @category Decorators
|
|
109
|
+
* @category Property Decorators
|
|
115
110
|
*/
|
|
116
111
|
function onAny(handler, data) {
|
|
117
112
|
return on(constants_1.DBOperations.ALL, handler, data);
|
|
118
113
|
}
|
|
119
114
|
/**
|
|
120
|
-
* @
|
|
121
|
-
*
|
|
122
|
-
* @
|
|
123
|
-
* @param {
|
|
124
|
-
* @param
|
|
125
|
-
*
|
|
126
|
-
*
|
|
127
|
-
*
|
|
115
|
+
* @description Base decorator for handling database operations
|
|
116
|
+
* @summary Defines a behavior to execute during specified database operations
|
|
117
|
+
* @template V - Type for metadata, defaults to object
|
|
118
|
+
* @param {OperationKeys[] | DBOperations} [op=DBOperations.ALL] - One or more operation types to handle
|
|
119
|
+
* @param {OperationHandler<any, any, V, any, any>} handler - The method called upon the operation
|
|
120
|
+
* @param {V} [data] - Optional metadata to pass to the handler
|
|
121
|
+
* @return {PropertyDecorator} A decorator that can be applied to class properties
|
|
128
122
|
* @function on
|
|
129
|
-
*
|
|
130
|
-
* @
|
|
123
|
+
* @category Property Decorators
|
|
124
|
+
* @example
|
|
125
|
+
* // Example usage:
|
|
126
|
+
* class MyModel {
|
|
127
|
+
* @on(DBOperations.CREATE, myHandler)
|
|
128
|
+
* myProperty: string;
|
|
129
|
+
* }
|
|
131
130
|
*/
|
|
132
131
|
function on(op = constants_1.DBOperations.ALL, handler, data) {
|
|
133
132
|
return operation(constants_1.OperationKeys.ON, op, handler, data);
|
|
134
133
|
}
|
|
135
134
|
/**
|
|
136
|
-
* @
|
|
137
|
-
*
|
|
138
|
-
* @
|
|
139
|
-
* @param
|
|
140
|
-
*
|
|
141
|
-
* @
|
|
142
|
-
*
|
|
135
|
+
* @description Decorator for handling post-create and post-update operations
|
|
136
|
+
* @summary Defines a behavior to execute after both create and update operations
|
|
137
|
+
* @template V - Type for metadata, defaults to object
|
|
138
|
+
* @param {StandardOperationHandler<any, any, V, any, any> | UpdateOperationHandler<any, any, V, any, any>} handler - The method called after the operation
|
|
139
|
+
* @param {V} [data] - Optional metadata to pass to the handler
|
|
140
|
+
* @return {PropertyDecorator} A decorator that can be applied to class properties
|
|
143
141
|
* @function afterCreateUpdate
|
|
144
|
-
*
|
|
145
|
-
* @category Decorators
|
|
142
|
+
* @category Property Decorators
|
|
146
143
|
*/
|
|
147
144
|
function afterCreateUpdate(handler, data) {
|
|
148
145
|
return after(constants_1.DBOperations.CREATE_UPDATE, handler, data);
|
|
149
146
|
}
|
|
150
147
|
/**
|
|
151
|
-
* @
|
|
152
|
-
*
|
|
153
|
-
* @
|
|
154
|
-
* @param
|
|
155
|
-
*
|
|
156
|
-
* @
|
|
157
|
-
*
|
|
148
|
+
* @description Decorator for handling post-update operations
|
|
149
|
+
* @summary Defines a behavior to execute after update operations
|
|
150
|
+
* @template V - Type for metadata, defaults to object
|
|
151
|
+
* @param {UpdateOperationHandler<any, any, V, any, any>} handler - The method called after the operation
|
|
152
|
+
* @param {V} [data] - Optional metadata to pass to the handler
|
|
153
|
+
* @return {PropertyDecorator} A decorator that can be applied to class properties
|
|
158
154
|
* @function afterUpdate
|
|
159
|
-
*
|
|
160
|
-
* @category Decorators
|
|
155
|
+
* @category Property Decorators
|
|
161
156
|
*/
|
|
162
157
|
function afterUpdate(handler, data) {
|
|
163
158
|
return after(constants_1.DBOperations.UPDATE, handler, data);
|
|
164
159
|
}
|
|
165
160
|
/**
|
|
166
|
-
* @
|
|
167
|
-
*
|
|
168
|
-
* @
|
|
169
|
-
* @param
|
|
170
|
-
*
|
|
171
|
-
* @
|
|
172
|
-
*
|
|
161
|
+
* @description Decorator for handling post-create operations
|
|
162
|
+
* @summary Defines a behavior to execute after create operations
|
|
163
|
+
* @template V - Type for metadata, defaults to object
|
|
164
|
+
* @param {StandardOperationHandler<any, any, V, any, any>} handler - The method called after the operation
|
|
165
|
+
* @param {V} [data] - Optional metadata to pass to the handler
|
|
166
|
+
* @return {PropertyDecorator} A decorator that can be applied to class properties
|
|
173
167
|
* @function afterCreate
|
|
174
|
-
*
|
|
175
|
-
* @category Decorators
|
|
168
|
+
* @category Property Decorators
|
|
176
169
|
*/
|
|
177
170
|
function afterCreate(handler, data) {
|
|
178
171
|
return after(constants_1.DBOperations.CREATE, handler, data);
|
|
179
172
|
}
|
|
180
173
|
/**
|
|
181
|
-
* @
|
|
182
|
-
*
|
|
183
|
-
* @
|
|
184
|
-
* @param
|
|
185
|
-
* @param {
|
|
186
|
-
*
|
|
187
|
-
* @see after
|
|
188
|
-
*
|
|
174
|
+
* @description Decorator for handling post-read operations
|
|
175
|
+
* @summary Defines a behavior to execute after read operations
|
|
176
|
+
* @template V - Type for metadata, defaults to object
|
|
177
|
+
* @param {StandardOperationHandler<any, any, V, any, any>} handler - The method called after the operation
|
|
178
|
+
* @param {V} [data] - Optional metadata to pass to the handler
|
|
179
|
+
* @return {PropertyDecorator} A decorator that can be applied to class properties
|
|
189
180
|
* @function afterRead
|
|
190
|
-
*
|
|
191
|
-
* @category Decorators
|
|
181
|
+
* @category Property Decorators
|
|
192
182
|
*/
|
|
193
183
|
function afterRead(handler, data) {
|
|
194
184
|
return after(constants_1.DBOperations.READ, handler, data);
|
|
195
185
|
}
|
|
196
186
|
/**
|
|
197
|
-
* @
|
|
198
|
-
*
|
|
199
|
-
* @
|
|
200
|
-
* @param
|
|
201
|
-
* @param {
|
|
202
|
-
*
|
|
203
|
-
* @see after
|
|
204
|
-
*
|
|
187
|
+
* @description Decorator for handling post-delete operations
|
|
188
|
+
* @summary Defines a behavior to execute after delete operations
|
|
189
|
+
* @template V - Type for metadata, defaults to object
|
|
190
|
+
* @param {StandardOperationHandler<any, any, V, any, any>} handler - The method called after the operation
|
|
191
|
+
* @param {V} [data] - Optional metadata to pass to the handler
|
|
192
|
+
* @return {PropertyDecorator} A decorator that can be applied to class properties
|
|
205
193
|
* @function afterDelete
|
|
206
|
-
*
|
|
207
|
-
* @category Decorators
|
|
194
|
+
* @category Property Decorators
|
|
208
195
|
*/
|
|
209
196
|
function afterDelete(handler, data) {
|
|
210
197
|
return after(constants_1.DBOperations.DELETE, handler, data);
|
|
211
198
|
}
|
|
212
199
|
/**
|
|
213
|
-
* @
|
|
214
|
-
*
|
|
215
|
-
* @
|
|
216
|
-
* @param
|
|
217
|
-
* @param {
|
|
218
|
-
*
|
|
219
|
-
* @see after
|
|
220
|
-
*
|
|
200
|
+
* @description Decorator for handling post-operation for all operation types
|
|
201
|
+
* @summary Defines a behavior to execute after any database operation
|
|
202
|
+
* @template V - Type for metadata, defaults to object
|
|
203
|
+
* @param {StandardOperationHandler<any, any, V, any, any>} handler - The method called after the operation
|
|
204
|
+
* @param {V} [data] - Optional metadata to pass to the handler
|
|
205
|
+
* @return {PropertyDecorator} A decorator that can be applied to class properties
|
|
221
206
|
* @function afterAny
|
|
222
|
-
*
|
|
223
|
-
* @category Decorators
|
|
207
|
+
* @category Property Decorators
|
|
224
208
|
*/
|
|
225
209
|
function afterAny(handler, data) {
|
|
226
210
|
return after(constants_1.DBOperations.ALL, handler, data);
|
|
227
211
|
}
|
|
228
212
|
/**
|
|
229
|
-
* @
|
|
230
|
-
*
|
|
231
|
-
* @
|
|
232
|
-
* @param {
|
|
233
|
-
*
|
|
234
|
-
*
|
|
235
|
-
*
|
|
236
|
-
* @param data
|
|
237
|
-
* @param args
|
|
213
|
+
* @description Base decorator for handling post-operation behaviors
|
|
214
|
+
* @summary Defines a behavior to execute after specified database operations
|
|
215
|
+
* @template V - Type for metadata, defaults to object
|
|
216
|
+
* @param {OperationKeys[] | DBOperations} [op=DBOperations.ALL] - One or more operation types to handle
|
|
217
|
+
* @param {OperationHandler<any, any, V, any, any>} handler - The method called after the operation
|
|
218
|
+
* @param {V} [data] - Optional metadata to pass to the handler
|
|
219
|
+
* @return {PropertyDecorator} A decorator that can be applied to class properties
|
|
238
220
|
* @function after
|
|
239
|
-
*
|
|
240
|
-
* @
|
|
221
|
+
* @category Property Decorators
|
|
222
|
+
* @example
|
|
223
|
+
* // Example usage:
|
|
224
|
+
* class MyModel {
|
|
225
|
+
* @after(DBOperations.CREATE, myHandler)
|
|
226
|
+
* myProperty: string;
|
|
227
|
+
* }
|
|
241
228
|
*/
|
|
242
229
|
function after(op = constants_1.DBOperations.ALL, handler, data) {
|
|
243
230
|
return operation(constants_1.OperationKeys.AFTER, op, handler, data);
|
|
244
231
|
}
|
|
232
|
+
/**
|
|
233
|
+
* @description Core decorator factory for operation handlers
|
|
234
|
+
* @summary Creates decorators that register handlers for database operations
|
|
235
|
+
* @template V - Type for metadata, defaults to object
|
|
236
|
+
* @param {OperationKeys.ON | OperationKeys.AFTER} baseOp - Whether the handler runs during or after the operation
|
|
237
|
+
* @param {OperationKeys[]} [operation=DBOperations.ALL] - The specific operations to handle
|
|
238
|
+
* @param {OperationHandler<any, any, V, any, any>} handler - The handler function to execute
|
|
239
|
+
* @param {V} [dataToAdd] - Optional metadata to pass to the handler
|
|
240
|
+
* @return {PropertyDecorator} A decorator that can be applied to class properties
|
|
241
|
+
* @function operation
|
|
242
|
+
* @category Property Decorators
|
|
243
|
+
* @mermaid
|
|
244
|
+
* sequenceDiagram
|
|
245
|
+
* participant Client
|
|
246
|
+
* participant Decorator as @operation
|
|
247
|
+
* participant Operations as Operations Registry
|
|
248
|
+
* participant Handler
|
|
249
|
+
*
|
|
250
|
+
* Client->>Decorator: Apply to property
|
|
251
|
+
* Decorator->>Operations: Register handler
|
|
252
|
+
* Decorator->>Decorator: Store metadata
|
|
253
|
+
*
|
|
254
|
+
* Note over Client,Handler: Later, during operation execution
|
|
255
|
+
* Client->>Operations: Execute operation
|
|
256
|
+
* Operations->>Handler: Call registered handler
|
|
257
|
+
* Handler-->>Operations: Return result
|
|
258
|
+
* Operations-->>Client: Return final result
|
|
259
|
+
*/
|
|
245
260
|
function operation(baseOp, operation = constants_1.DBOperations.ALL, handler, dataToAdd) {
|
|
246
261
|
return (target, propertyKey) => {
|
|
247
262
|
const name = target.constructor.name;
|
|
@@ -270,4 +285,4 @@ function operation(baseOp, operation = constants_1.DBOperations.ALL, handler, da
|
|
|
270
285
|
return (0, reflection_1.apply)(...decorators)(target, propertyKey);
|
|
271
286
|
};
|
|
272
287
|
}
|
|
273
|
-
//# 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\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 * @summary Defines a behaviour to set on the defined {@link DBOperations.CREATE_UPDATE}\n *\n * @param {OnOperationHandler<any>} handler The method called upon the operation\n * @param data\n * @param {any[]} [args] Arguments that will be passed in order to the handler method\n *\n * @see on\n *\n * @function onCreateUpdate\n *\n * @category 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 * @summary Defines a behaviour to set on the defined {@link DBOperations.UPDATE}\n *\n * @param {OnOperationHandler<any>} handler The method called upon the operation\n * @param data\n * @param {any[]} [args] Arguments that will be passed in order to the handler method\n *\n * @see on\n *\n * @function onUpdate\n *\n * @category 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 * @summary Defines a behaviour to set on the defined {@link DBOperations.CREATE}\n *\n * @param {OnOperationHandler<any>} handler The method called upon the operation\n * @param data\n *\n * @see on\n *\n * @function onCreate\n *\n * @category 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 * @summary Defines a behaviour to set on the defined {@link DBOperations.READ}\n *\n * @param {OnOperationHandler<any>} handler The method called upon the operation\n * @param data\n *\n * @see on\n *\n * @function onRead\n *\n * @category 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 * @summary Defines a behaviour to set on the defined {@link DBOperations.DELETE}\n *\n * @param {OnOperationHandler<any>} handler The method called upon the operation\n * @param data\n *\n * @see on\n *\n * @function onDelete\n *\n * @category 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 * @summary Defines a behaviour to set on the defined {@link DBOperations.DELETE}\n *\n * @param {OnOperationHandler<any>} handler The method called upon the operation\n * @param data\n *\n * @see on\n *\n * @function onAny\n *\n * @category 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 * @summary Defines a behaviour to set on the defined {@link DBOperations}\n *\n * @param {OperationKeys[] | DBOperations} op One of {@link DBOperations}\n * @param {OnOperationHandler<any>} handler The method called upon the operation\n * @param data\n *\n * ex: handler(...args, ...props.map(p => target[p]))\n *\n * @function on\n *\n * @category Decorators\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 * @summary Defines a behaviour to set after the defined {@link DBOperations.CREATE_UPDATE}\n *\n * @param {AfterOperationHandler<any>} handler The method called upon the operation\n * @param data\n *\n * @see after\n *\n * @function afterCreateUpdate\n *\n * @category 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 * @summary Defines a behaviour to set after the defined {@link DBOperations.UPDATE}\n *\n * @param {AfterOperationHandler<any>} handler The method called upon the operation\n * @param data\n *\n * @see after\n *\n * @function afterUpdate\n *\n * @category 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 * @summary Defines a behaviour to set after the defined {@link DBOperations.CREATE}\n *\n * @param {AfterOperationHandler<any>} handler The method called upon the operation\n * @param data\n *\n * @see after\n *\n * @function afterCreate\n *\n * @category 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 * @summary Defines a behaviour to set after the defined {@link DBOperations.READ}\n *\n * @param {AfterOperationHandler<any>} handler The method called upon the operation\n * @param data\n * @param {any[]} [args] Arguments that will be passed in order to the handler method\n *\n * @see after\n *\n * @function afterRead\n *\n * @category 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 * @summary Defines a behaviour to set after the defined {@link DBOperations.DELETE}\n *\n * @param {AfterOperationHandler<any>} handler The method called upon the operation\n * @param data\n * @param {any[]} [args] Arguments that will be passed in order to the handler method\n *\n * @see after\n *\n * @function afterDelete\n *\n * @category 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 * @summary Defines a behaviour to set after the defined {@link DBOperations.DELETE}\n *\n * @param {AfterOperationHandler<any>} handler The method called upon the operation\n * @param data\n * @param {any[]} [args] Arguments that will be passed in order to the handler method\n *\n * @see after\n *\n * @function afterAny\n *\n * @category 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 * @summary Defines a behaviour to set on the defined {@link DBOperations}\n *\n * @param {OperationKeys[] | DBOperations} op One of {@link DBOperations}\n * @param {AfterOperationHandler<any>} handler The method called upon the operation\n *\n * ex: handler(...args, ...props.map(p => target[p]))\n *\n * @param data\n * @param args\n * @function after\n *\n * @category Decorators\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\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"]}
|
|
288
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../src/operations/decorators.ts"],"names":[],"mappings":";;AAuCA,wCAOC;AAWD,4BAKC;AAWD,4BAKC;AAYD,wBAKC;AAYD,4BAKC;AAYD,sBAKC;AAmBD,gBAMC;AAWD,8CAOC;AAYD,kCAKC;AAYD,kCAKC;AAYD,8BAKC;AAWD,kCAKC;AAYD,4BAKC;AAmBD,sBAMC;AA8BD,8BA4CC;AA7VD,+CAA0D;AAC1D,iDAA0C;AAC1C,qDAA6C;AAC7C,yEAA8D;AAE9D;;;;;;;;GAQG;AACH,SAAS,MAAM,CACb,EAAiB,EACjB,OAAkD;IAElD,OAAO,CAAC,MAAW,EAAE,WAAmB,EAAE,EAAE;QAC1C,uBAAU,CAAC,QAAQ,CAAC,OAAO,EAAE,EAAE,EAAE,MAAM,EAAE,WAAW,CAAC,CAAC;IACxD,CAAC,CAAC;AACJ,CAAC;AAED;;;;;;;;;GASG;AACH,SAAgB,cAAc,CAC5B,OAEiD,EACjD,IAAQ;IAER,OAAO,EAAE,CAAC,wBAAY,CAAC,aAAa,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;AACvD,CAAC;AACD;;;;;;;;;GASG;AACH,SAAgB,QAAQ,CACtB,OAAiD,EACjD,IAAQ;IAER,OAAO,EAAE,CAAC,wBAAY,CAAC,MAAM,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;AAChD,CAAC;AACD;;;;;;;;;GASG;AACH,SAAgB,QAAQ,CACtB,OAAwD,EACxD,IAAQ;IAER,OAAO,EAAE,CAAC,wBAAY,CAAC,MAAM,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;AAChD,CAAC;AAED;;;;;;;;;GASG;AACH,SAAgB,MAAM,CACpB,OAAkD,EAClD,IAAO;IAEP,OAAO,EAAE,CAAC,wBAAY,CAAC,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;AAC9C,CAAC;AAED;;;;;;;;;GASG;AACH,SAAgB,QAAQ,CACtB,OAAgD,EAChD,IAAO;IAEP,OAAO,EAAE,CAAC,wBAAY,CAAC,MAAM,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;AAChD,CAAC;AAED;;;;;;;;;GASG;AACH,SAAgB,KAAK,CACnB,OAAgD,EAChD,IAAO;IAEP,OAAO,EAAE,CAAC,wBAAY,CAAC,GAAG,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;AAC7C,CAAC;AAED;;;;;;;;;;;;;;;;GAgBG;AACH,SAAgB,EAAE,CAChB,KAAsB,wBAAY,CAAC,GAAG,EACtC,OAAgD,EAChD,IAAQ;IAER,OAAO,SAAS,CAAC,yBAAa,CAAC,EAAE,EAAE,EAAE,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;AACxD,CAAC;AACD;;;;;;;;;GASG;AACH,SAAgB,iBAAiB,CAC/B,OAEiD,EACjD,IAAO;IAEP,OAAO,KAAK,CAAC,wBAAY,CAAC,aAAa,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;AAC1D,CAAC;AAED;;;;;;;;;GASG;AACH,SAAgB,WAAW,CACzB,OAAsD,EACtD,IAAO;IAEP,OAAO,KAAK,CAAC,wBAAY,CAAC,MAAM,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;AACnD,CAAC;AAED;;;;;;;;;GASG;AACH,SAAgB,WAAW,CACzB,OAAwD,EACxD,IAAO;IAEP,OAAO,KAAK,CAAC,wBAAY,CAAC,MAAM,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;AACnD,CAAC;AAED;;;;;;;;;GASG;AACH,SAAgB,SAAS,CACvB,OAAwD,EACxD,IAAQ;IAER,OAAO,KAAK,CAAC,wBAAY,CAAC,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;AACjD,CAAC;AACD;;;;;;;;;GASG;AACH,SAAgB,WAAW,CACzB,OAAwD,EACxD,IAAQ;IAER,OAAO,KAAK,CAAC,wBAAY,CAAC,MAAM,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;AACnD,CAAC;AAED;;;;;;;;;GASG;AACH,SAAgB,QAAQ,CACtB,OAAwD,EACxD,IAAQ;IAER,OAAO,KAAK,CAAC,wBAAY,CAAC,GAAG,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;AAChD,CAAC;AAED;;;;;;;;;;;;;;;;GAgBG;AACH,SAAgB,KAAK,CACnB,KAAsB,wBAAY,CAAC,GAAG,EACtC,OAAgD,EAChD,IAAQ;IAER,OAAO,SAAS,CAAC,yBAAa,CAAC,KAAK,EAAE,EAAE,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;AAC3D,CAAC;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2BG;AACH,SAAgB,SAAS,CACvB,MAA8C,EAC9C,YAA6B,wBAAY,CAAC,GAAG,EAC7C,OAAgD,EAChD,SAAa;IAEb,OAAO,CAAC,MAAc,EAAE,WAAiB,EAAE,EAAE;QAC3C,MAAM,IAAI,GAAG,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC;QACrC,MAAM,UAAU,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC,KAAY,EAAE,EAAE,EAAE,EAAE;YACvD,MAAM,WAAW,GAAG,MAAM,GAAG,EAAE,CAAC;YAChC,IAAI,IAAI,GAAG,OAAO,CAAC,WAAW,CAC5B,uBAAU,CAAC,GAAG,CAAC,WAAW,CAAC,EAC3B,MAAM,EACN,WAAW,CACZ,CAAC;YACF,IAAI,CAAC,IAAI;gBACP,IAAI,GAAG;oBACL,SAAS,EAAE,EAAE;oBACb,QAAQ,EAAE,EAAE;iBACb,CAAC;YAEJ,MAAM,UAAU,GAAG,uBAAU,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;YAEtD,IACE,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;gBACpB,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;gBACjC,CAAC,CAAC,UAAU,IAAI,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC,CAAC,EACjD,CAAC;gBACD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;gBAChD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;oBAC9B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC;gBACzC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC,CAAC,UAAU,CAAC,GAAG;oBAC7C,IAAI,EAAE,SAAS;iBAChB,CAAC;gBAEF,KAAK,CAAC,IAAI,CACR,MAAM,CAAC,WAA4B,EAAE,OAAO,CAAC,EAC7C,IAAA,mCAAY,EAAC,uBAAU,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE,IAAI,CAAC,CAChD,CAAC;YACJ,CAAC;YACD,OAAO,KAAK,CAAC;QACf,CAAC,EAAE,EAAE,CAAC,CAAC;QACP,OAAO,IAAA,kBAAK,EAAC,GAAG,UAAU,CAAC,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IACnD,CAAC,CAAC;AACJ,CAAC","sourcesContent":["import {\n  IdOperationHandler,\n  OperationHandler,\n  StandardOperationHandler,\n  UpdateOperationHandler,\n} from \"./types\";\nimport { DBOperations, OperationKeys } from \"./constants\";\nimport { Operations } from \"./Operations\";\nimport { apply } from \"@decaf-ts/reflection\";\nimport { propMetadata } from \"@decaf-ts/decorator-validation\";\n\n/**\n * @description Internal function to register operation handlers\n * @summary Registers an operation handler for a specific operation key on a target property\n * @param {OperationKeys} op - The operation key to handle\n * @param {OperationHandler<any, any, any, any, any>} handler - The handler function to register\n * @return {PropertyDecorator} A decorator that registers the handler\n * @function handle\n * @category Property Decorators\n */\nfunction handle(\n  op: OperationKeys,\n  handler: OperationHandler<any, any, any, any, any>\n) {\n  return (target: any, propertyKey: string) => {\n    Operations.register(handler, op, target, propertyKey);\n  };\n}\n\n/**\n * @description Decorator for handling create and update operations\n * @summary Defines a behavior to execute during both create and update operations\n * @template V - Type for metadata, defaults to object\n * @param {StandardOperationHandler<any, any, V, any, any> | UpdateOperationHandler<any, any, V, any, any>} handler - The method called upon the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function onCreateUpdate\n * @category Property Decorators\n */\nexport function onCreateUpdate<V = object>(\n  handler:\n    | StandardOperationHandler<any, any, V, any, any>\n    | UpdateOperationHandler<any, any, V, any, any>,\n  data?: V\n) {\n  return on(DBOperations.CREATE_UPDATE, handler, data);\n}\n/**\n * @description Decorator for handling update operations\n * @summary Defines a behavior to execute during update operations\n * @template V - Type for metadata, defaults to object\n * @param {UpdateOperationHandler<any, any, V, any>} handler - The method called upon the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function onUpdate\n * @category Property Decorators\n */\nexport function onUpdate<V = object>(\n  handler: UpdateOperationHandler<any, any, V, any>,\n  data?: V\n) {\n  return on(DBOperations.UPDATE, handler, data);\n}\n/**\n * @description Decorator for handling create operations\n * @summary Defines a behavior to execute during create operations\n * @template V - Type for metadata, defaults to object\n * @param {StandardOperationHandler<any, any, V, any, any>} handler - The method called upon the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function onCreate\n * @category Property Decorators\n */\nexport function onCreate<V = object>(\n  handler: StandardOperationHandler<any, any, V, any, any>,\n  data?: V\n) {\n  return on(DBOperations.CREATE, handler, data);\n}\n\n/**\n * @description Decorator for handling read operations\n * @summary Defines a behavior to execute during read operations\n * @template V - Type for metadata, defaults to object\n * @param {IdOperationHandler<any, any, V, any, any>} handler - The method called upon the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function onRead\n * @category Property Decorators\n */\nexport function onRead<V = object>(\n  handler: IdOperationHandler<any, any, V, any, any>,\n  data: V\n) {\n  return on(DBOperations.READ, handler, data);\n}\n\n/**\n * @description Decorator for handling delete operations\n * @summary Defines a behavior to execute during delete operations\n * @template V - Type for metadata, defaults to object\n * @param {OperationHandler<any, any, V, any, any>} handler - The method called upon the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function onDelete\n * @category Property Decorators\n */\nexport function onDelete<V = object>(\n  handler: OperationHandler<any, any, V, any, any>,\n  data: V\n) {\n  return on(DBOperations.DELETE, handler, data);\n}\n\n/**\n * @description Decorator for handling all operation types\n * @summary Defines a behavior to execute during any database operation\n * @template V - Type for metadata, defaults to object\n * @param {OperationHandler<any, any, V, any, any>} handler - The method called upon the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function onAny\n * @category Property Decorators\n */\nexport function onAny<V = object>(\n  handler: OperationHandler<any, any, V, any, any>,\n  data: V\n) {\n  return on(DBOperations.ALL, handler, data);\n}\n\n/**\n * @description Base decorator for handling database operations\n * @summary Defines a behavior to execute during specified database operations\n * @template V - Type for metadata, defaults to object\n * @param {OperationKeys[] | DBOperations} [op=DBOperations.ALL] - One or more operation types to handle\n * @param {OperationHandler<any, any, V, any, any>} handler - The method called upon the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function on\n * @category Property Decorators\n * @example\n * // Example usage:\n * class MyModel {\n *   @on(DBOperations.CREATE, myHandler)\n *   myProperty: string;\n * }\n */\nexport function on<V = object>(\n  op: OperationKeys[] = DBOperations.ALL,\n  handler: OperationHandler<any, any, V, any, any>,\n  data?: V\n) {\n  return operation(OperationKeys.ON, op, handler, data);\n}\n/**\n * @description Decorator for handling post-create and post-update operations\n * @summary Defines a behavior to execute after both create and update operations\n * @template V - Type for metadata, defaults to object\n * @param {StandardOperationHandler<any, any, V, any, any> | UpdateOperationHandler<any, any, V, any, any>} handler - The method called after the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function afterCreateUpdate\n * @category Property Decorators\n */\nexport function afterCreateUpdate<V = object>(\n  handler:\n    | StandardOperationHandler<any, any, V, any, any>\n    | UpdateOperationHandler<any, any, V, any, any>,\n  data: V\n) {\n  return after(DBOperations.CREATE_UPDATE, handler, data);\n}\n\n/**\n * @description Decorator for handling post-update operations\n * @summary Defines a behavior to execute after update operations\n * @template V - Type for metadata, defaults to object\n * @param {UpdateOperationHandler<any, any, V, any, any>} handler - The method called after the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function afterUpdate\n * @category Property Decorators\n */\nexport function afterUpdate<V = object>(\n  handler: UpdateOperationHandler<any, any, V, any, any>,\n  data: V\n) {\n  return after(DBOperations.UPDATE, handler, data);\n}\n\n/**\n * @description Decorator for handling post-create operations\n * @summary Defines a behavior to execute after create operations\n * @template V - Type for metadata, defaults to object\n * @param {StandardOperationHandler<any, any, V, any, any>} handler - The method called after the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function afterCreate\n * @category Property Decorators\n */\nexport function afterCreate<V = object>(\n  handler: StandardOperationHandler<any, any, V, any, any>,\n  data: V\n) {\n  return after(DBOperations.CREATE, handler, data);\n}\n\n/**\n * @description Decorator for handling post-read operations\n * @summary Defines a behavior to execute after read operations\n * @template V - Type for metadata, defaults to object\n * @param {StandardOperationHandler<any, any, V, any, any>} handler - The method called after the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function afterRead\n * @category Property Decorators\n */\nexport function afterRead<V = object>(\n  handler: StandardOperationHandler<any, any, V, any, any>,\n  data?: V\n) {\n  return after(DBOperations.READ, handler, data);\n}\n/**\n * @description Decorator for handling post-delete operations\n * @summary Defines a behavior to execute after delete operations\n * @template V - Type for metadata, defaults to object\n * @param {StandardOperationHandler<any, any, V, any, any>} handler - The method called after the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function afterDelete\n * @category Property Decorators\n */\nexport function afterDelete<V = object>(\n  handler: StandardOperationHandler<any, any, V, any, any>,\n  data?: V\n) {\n  return after(DBOperations.DELETE, handler, data);\n}\n\n/**\n * @description Decorator for handling post-operation for all operation types\n * @summary Defines a behavior to execute after any database operation\n * @template V - Type for metadata, defaults to object\n * @param {StandardOperationHandler<any, any, V, any, any>} handler - The method called after the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function afterAny\n * @category Property Decorators\n */\nexport function afterAny<V = object>(\n  handler: StandardOperationHandler<any, any, V, any, any>,\n  data?: V\n) {\n  return after(DBOperations.ALL, handler, data);\n}\n\n/**\n * @description Base decorator for handling post-operation behaviors\n * @summary Defines a behavior to execute after specified database operations\n * @template V - Type for metadata, defaults to object\n * @param {OperationKeys[] | DBOperations} [op=DBOperations.ALL] - One or more operation types to handle\n * @param {OperationHandler<any, any, V, any, any>} handler - The method called after the operation\n * @param {V} [data] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function after\n * @category Property Decorators\n * @example\n * // Example usage:\n * class MyModel {\n *   @after(DBOperations.CREATE, myHandler)\n *   myProperty: string;\n * }\n */\nexport function after<V = object>(\n  op: OperationKeys[] = DBOperations.ALL,\n  handler: OperationHandler<any, any, V, any, any>,\n  data?: V\n) {\n  return operation(OperationKeys.AFTER, op, handler, data);\n}\n\n/**\n * @description Core decorator factory for operation handlers\n * @summary Creates decorators that register handlers for database operations\n * @template V - Type for metadata, defaults to object\n * @param {OperationKeys.ON | OperationKeys.AFTER} baseOp - Whether the handler runs during or after the operation\n * @param {OperationKeys[]} [operation=DBOperations.ALL] - The specific operations to handle\n * @param {OperationHandler<any, any, V, any, any>} handler - The handler function to execute\n * @param {V} [dataToAdd] - Optional metadata to pass to the handler\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function operation\n * @category Property Decorators\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant Decorator as @operation\n *   participant Operations as Operations Registry\n *   participant Handler\n *\n *   Client->>Decorator: Apply to property\n *   Decorator->>Operations: Register handler\n *   Decorator->>Decorator: Store metadata\n *\n *   Note over Client,Handler: Later, during operation execution\n *   Client->>Operations: Execute operation\n *   Operations->>Handler: Call registered handler\n *   Handler-->>Operations: Return result\n *   Operations-->>Client: Return final result\n */\nexport function operation<V = object>(\n  baseOp: OperationKeys.ON | OperationKeys.AFTER,\n  operation: OperationKeys[] = DBOperations.ALL,\n  handler: OperationHandler<any, any, V, any, any>,\n  dataToAdd?: V\n) {\n  return (target: object, propertyKey?: any) => {\n    const name = target.constructor.name;\n    const decorators = operation.reduce((accum: any[], op) => {\n      const compoundKey = baseOp + op;\n      let data = Reflect.getMetadata(\n        Operations.key(compoundKey),\n        target,\n        propertyKey\n      );\n      if (!data)\n        data = {\n          operation: op,\n          handlers: {},\n        };\n\n      const handlerKey = Operations.getHandlerName(handler);\n\n      if (\n        !data.handlers[name] ||\n        !data.handlers[name][propertyKey] ||\n        !(handlerKey in data.handlers[name][propertyKey])\n      ) {\n        data.handlers[name] = data.handlers[name] || {};\n        data.handlers[name][propertyKey] =\n          data.handlers[name][propertyKey] || {};\n        data.handlers[name][propertyKey][handlerKey] = {\n          data: dataToAdd,\n        };\n\n        accum.push(\n          handle(compoundKey as OperationKeys, handler),\n          propMetadata(Operations.key(compoundKey), data)\n        );\n      }\n      return accum;\n    }, []);\n    return apply(...decorators)(target, propertyKey);\n  };\n}\n"]}
|