@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
|
@@ -1,8 +1,18 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* @
|
|
2
|
+
* @description Collection of default error messages used by validators.
|
|
3
|
+
* @summary Holds the default error messages for various validation scenarios including ID validation, readonly properties, and timestamps.
|
|
4
|
+
* @typedef {Object} ErrorMessages
|
|
5
|
+
* @property {Object} ID - Error messages for ID validation
|
|
6
|
+
* @property {string} ID.INVALID - Error message when an ID is invalid
|
|
7
|
+
* @property {string} ID.REQUIRED - Error message when an ID is missing
|
|
8
|
+
* @property {Object} READONLY - Error messages for readonly properties
|
|
9
|
+
* @property {string} READONLY.INVALID - Error message when attempting to update a readonly property
|
|
10
|
+
* @property {Object} TIMESTAMP - Error messages for timestamp validation
|
|
11
|
+
* @property {string} TIMESTAMP.REQUIRED - Error message when a timestamp is missing
|
|
12
|
+
* @property {string} TIMESTAMP.DATE - Error message when a timestamp is not a valid date
|
|
13
|
+
* @property {string} TIMESTAMP.INVALID - Error message when a timestamp is not increasing
|
|
3
14
|
* @const DEFAULT_ERROR_MESSAGES
|
|
4
|
-
*
|
|
5
|
-
* @memberOf module:db-decorators.Model
|
|
15
|
+
* @memberOf module:validation
|
|
6
16
|
*/
|
|
7
17
|
export declare const DEFAULT_ERROR_MESSAGES: {
|
|
8
18
|
ID: {
|
|
@@ -19,9 +29,14 @@ export declare const DEFAULT_ERROR_MESSAGES: {
|
|
|
19
29
|
};
|
|
20
30
|
};
|
|
21
31
|
/**
|
|
22
|
-
* @
|
|
32
|
+
* @description Constants used for reflection-based validation during update operations.
|
|
33
|
+
* @summary Keys used for storing and retrieving validation metadata on model properties during update operations.
|
|
34
|
+
* @typedef {Object} ValidationKeys
|
|
35
|
+
* @property {string} REFLECT - Base reflection key prefix for update validation
|
|
36
|
+
* @property {string} TIMESTAMP - Key for timestamp validation
|
|
37
|
+
* @property {string} READONLY - Key for readonly property validation
|
|
23
38
|
* @const UpdateValidationKeys
|
|
24
|
-
* @memberOf module:
|
|
39
|
+
* @memberOf module:validation
|
|
25
40
|
*/
|
|
26
41
|
export declare const UpdateValidationKeys: {
|
|
27
42
|
REFLECT: string;
|
|
@@ -16,13 +16,12 @@ const errors_1 = require("./../repository/errors.cjs");
|
|
|
16
16
|
const reflection_1 = require("@decaf-ts/reflection");
|
|
17
17
|
const repository_1 = require("./../repository/index.cjs");
|
|
18
18
|
/**
|
|
19
|
-
*
|
|
20
|
-
*
|
|
21
|
-
* @param {string} [message]
|
|
22
|
-
*
|
|
23
|
-
* @
|
|
24
|
-
*
|
|
25
|
-
* @category Decorators
|
|
19
|
+
* @description Prevents a property from being modified after initial creation.
|
|
20
|
+
* @summary Marks the property as readonly, causing validation errors if attempts are made to modify it during updates.
|
|
21
|
+
* @param {string} [message] - The error message to display when validation fails. Defaults to {@link DEFAULT_ERROR_MESSAGES.READONLY.INVALID}
|
|
22
|
+
* @return {PropertyDecorator} A decorator function that can be applied to class properties
|
|
23
|
+
* @function readonly
|
|
24
|
+
* @category Property Decorators
|
|
26
25
|
*/
|
|
27
26
|
function readonly(message = constants_2.DEFAULT_ERROR_MESSAGES.READONLY.INVALID) {
|
|
28
27
|
const key = decorator_validation_1.Validation.updateKey(constants_1.DBKeys.READONLY);
|
|
@@ -32,13 +31,28 @@ function readonly(message = constants_2.DEFAULT_ERROR_MESSAGES.READONLY.INVALID)
|
|
|
32
31
|
}))
|
|
33
32
|
.apply();
|
|
34
33
|
}
|
|
34
|
+
/**
|
|
35
|
+
* @description Handler function that sets a timestamp property to the current timestamp.
|
|
36
|
+
* @summary Updates a model property with the current timestamp from the repository context.
|
|
37
|
+
* @template M - The model type extending Model
|
|
38
|
+
* @template R - The repository type extending IRepository
|
|
39
|
+
* @template V - The data type for the operation
|
|
40
|
+
* @template F - The repository flags type
|
|
41
|
+
* @template C - The context type
|
|
42
|
+
* @param {C} context - The repository context containing the current timestamp
|
|
43
|
+
* @param {V} data - The data being processed
|
|
44
|
+
* @param key - The property key to update
|
|
45
|
+
* @param {M} model - The model instance being updated
|
|
46
|
+
* @return {Promise<void>} A promise that resolves when the timestamp has been set
|
|
47
|
+
* @function timestampHandler
|
|
48
|
+
* @memberOf module:db-decorators
|
|
49
|
+
*/
|
|
35
50
|
async function timestampHandler(context, data, key, model) {
|
|
36
51
|
model[key] = context.timestamp;
|
|
37
52
|
}
|
|
38
53
|
/**
|
|
39
|
-
*
|
|
40
|
-
*
|
|
41
|
-
* Makes it a {@link date}
|
|
54
|
+
* @description Automatically manages timestamp properties for tracking creation and update times.
|
|
55
|
+
* @summary Marks the property as a timestamp, making it required and ensuring it's a valid date. The property will be automatically updated with the current timestamp during specified operations.
|
|
42
56
|
*
|
|
43
57
|
* Date Format:
|
|
44
58
|
*
|
|
@@ -58,13 +72,30 @@ async function timestampHandler(context, data, key, model) {
|
|
|
58
72
|
* S = miliseconds
|
|
59
73
|
* </pre>
|
|
60
74
|
*
|
|
61
|
-
* @param {
|
|
62
|
-
* @param {string} [format] The
|
|
63
|
-
* @
|
|
75
|
+
* @param {OperationKeys[]} operation - The operations to act on. Defaults to {@link DBOperations.CREATE_UPDATE}
|
|
76
|
+
* @param {string} [format] - The timestamp format. Defaults to {@link DEFAULT_TIMESTAMP_FORMAT}
|
|
77
|
+
* @return {PropertyDecorator} A decorator function that can be applied to class properties
|
|
78
|
+
* @function timestamp
|
|
79
|
+
* @category Property Decorators
|
|
80
|
+
* @mermaid
|
|
81
|
+
* sequenceDiagram
|
|
82
|
+
* participant C as Client
|
|
83
|
+
* participant M as Model
|
|
84
|
+
* participant T as TimestampDecorator
|
|
85
|
+
* participant V as Validator
|
|
86
|
+
*
|
|
87
|
+
* C->>M: Create/Update model
|
|
88
|
+
* M->>T: Process timestamp property
|
|
89
|
+
* T->>M: Apply required validation
|
|
90
|
+
* T->>M: Apply date format validation
|
|
64
91
|
*
|
|
65
|
-
*
|
|
92
|
+
* alt Update operation
|
|
93
|
+
* T->>V: Register timestamp validator
|
|
94
|
+
* V->>M: Validate timestamp is newer
|
|
95
|
+
* end
|
|
66
96
|
*
|
|
67
|
-
*
|
|
97
|
+
* T->>M: Set current timestamp
|
|
98
|
+
* M->>C: Return updated model
|
|
68
99
|
*/
|
|
69
100
|
function timestamp(operation = constants_3.DBOperations.CREATE_UPDATE, format = constants_1.DEFAULT_TIMESTAMP_FORMAT) {
|
|
70
101
|
const key = decorator_validation_1.Validation.updateKey(constants_1.DBKeys.TIMESTAMP);
|
|
@@ -81,6 +112,22 @@ function timestamp(operation = constants_3.DBOperations.CREATE_UPDATE, format =
|
|
|
81
112
|
.define(...decorators)
|
|
82
113
|
.apply();
|
|
83
114
|
}
|
|
115
|
+
/**
|
|
116
|
+
* @description Handler function that serializes a property to JSON string during create and update operations.
|
|
117
|
+
* @summary Converts a complex object property to a JSON string before storing it in the database.
|
|
118
|
+
* @template M - The model type extending Model
|
|
119
|
+
* @template R - The repository type extending IRepository
|
|
120
|
+
* @template V - The data type for the operation
|
|
121
|
+
* @template F - The repository flags type
|
|
122
|
+
* @template C - The context type
|
|
123
|
+
* @param {C} context - The repository context
|
|
124
|
+
* @param {V} data - The data being processed
|
|
125
|
+
* @param key - The property key to serialize
|
|
126
|
+
* @param {M} model - The model instance being processed
|
|
127
|
+
* @return {Promise<void>} A promise that resolves when the property has been serialized
|
|
128
|
+
* @function serializeOnCreateUpdate
|
|
129
|
+
* @memberOf module:db-decorators
|
|
130
|
+
*/
|
|
84
131
|
async function serializeOnCreateUpdate(context, data, key, model) {
|
|
85
132
|
if (!model[key])
|
|
86
133
|
return;
|
|
@@ -92,6 +139,22 @@ async function serializeOnCreateUpdate(context, data, key, model) {
|
|
|
92
139
|
throw new errors_1.SerializationError(`Failed to serialize ${key.toString()} property of model ${model.constructor.name}: e`);
|
|
93
140
|
}
|
|
94
141
|
}
|
|
142
|
+
/**
|
|
143
|
+
* @description Handler function that deserializes a property from JSON string after database operations.
|
|
144
|
+
* @summary Converts a JSON string property back to its original complex object form after retrieving it from the database.
|
|
145
|
+
* @template M - The model type extending Model
|
|
146
|
+
* @template R - The repository type extending IRepository
|
|
147
|
+
* @template V - The data type for the operation
|
|
148
|
+
* @template F - The repository flags type
|
|
149
|
+
* @template C - The context type
|
|
150
|
+
* @param {C} context - The repository context
|
|
151
|
+
* @param {V} data - The data being processed
|
|
152
|
+
* @param key - The property key to deserialize
|
|
153
|
+
* @param {M} model - The model instance being processed
|
|
154
|
+
* @return {Promise<void>} A promise that resolves when the property has been deserialized
|
|
155
|
+
* @function serializeAfterAll
|
|
156
|
+
* @memberOf module:db-decorators
|
|
157
|
+
*/
|
|
95
158
|
async function serializeAfterAll(context, data, key, model) {
|
|
96
159
|
if (!model[key])
|
|
97
160
|
return;
|
|
@@ -105,14 +168,33 @@ async function serializeAfterAll(context, data, key, model) {
|
|
|
105
168
|
}
|
|
106
169
|
}
|
|
107
170
|
/**
|
|
108
|
-
* @
|
|
109
|
-
* @
|
|
110
|
-
*
|
|
171
|
+
* @description Enables automatic JSON serialization and deserialization for complex object properties.
|
|
172
|
+
* @summary Decorator that automatically converts complex objects to JSON strings before storing in the database and back to objects when retrieving them.
|
|
173
|
+
* @return {PropertyDecorator} A decorator function that can be applied to class properties
|
|
111
174
|
* @function serialize
|
|
175
|
+
* @category Property Decorators
|
|
176
|
+
* @mermaid
|
|
177
|
+
* sequenceDiagram
|
|
178
|
+
* participant C as Client
|
|
179
|
+
* participant M as Model
|
|
180
|
+
* participant S as SerializeDecorator
|
|
181
|
+
* participant DB as Database
|
|
182
|
+
*
|
|
183
|
+
* Note over C,DB: Create/Update Flow
|
|
184
|
+
* C->>M: Set complex object property
|
|
185
|
+
* M->>S: Process property (create/update)
|
|
186
|
+
* S->>M: Convert to JSON string
|
|
187
|
+
* M->>DB: Store serialized data
|
|
112
188
|
*
|
|
113
|
-
*
|
|
189
|
+
* Note over C,DB: Retrieval Flow
|
|
190
|
+
* C->>M: Request model
|
|
191
|
+
* M->>DB: Fetch data
|
|
192
|
+
* DB->>M: Return with serialized property
|
|
193
|
+
* M->>S: Process property (after all ops)
|
|
194
|
+
* S->>M: Parse JSON back to object
|
|
195
|
+
* M->>C: Return model with deserialized property
|
|
114
196
|
*/
|
|
115
197
|
function serialize() {
|
|
116
198
|
return (0, reflection_1.apply)((0, decorators_1.onCreateUpdate)(serializeOnCreateUpdate), (0, decorators_1.after)(constants_3.DBOperations.ALL, serializeAfterAll), (0, decorator_validation_1.type)([String.name, Object.name]), (0, reflection_1.metadata)(repository_1.Repository.key(constants_1.DBKeys.SERIALIZE), {}));
|
|
117
199
|
}
|
|
118
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../src/validation/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["import \"./validation\";\nimport {\n  date,\n  Decoration,\n  Model,\n  propMetadata,\n  required,\n  type,\n  Validation,\n} from \"@decaf-ts/decorator-validation\";\nimport { DBKeys, DEFAULT_TIMESTAMP_FORMAT } from \"../model/constants\";\nimport { DEFAULT_ERROR_MESSAGES } from \"./constants\";\nimport { DBOperations, OperationKeys } from \"../operations/constants\";\nimport { after, on, onCreateUpdate } from \"../operations/decorators\";\nimport { IRepository } from \"../interfaces/IRepository\";\nimport { SerializationError } from \"../repository/errors\";\nimport { apply, metadata } from \"@decaf-ts/reflection\";\nimport { Repository } from \"../repository\";\nimport { Context } from \"../repository/Context\";\nimport { RepositoryFlags } from \"../repository/types\";\n\n/**\n * Marks the property as readonly.\n *\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES.READONLY.INVALID}\n *\n * @decorator readonly\n *\n * @category Decorators\n */\nexport function readonly(\n  message: string = DEFAULT_ERROR_MESSAGES.READONLY.INVALID\n) {\n  const key = Validation.updateKey(DBKeys.READONLY);\n  return Decoration.for(key)\n    .define(\n      propMetadata(key, {\n        message: message,\n      })\n    )\n    .apply();\n}\n\nexport async function timestampHandler<\n  M extends Model,\n  R extends IRepository<M, F, C>,\n  V,\n  F extends RepositoryFlags = RepositoryFlags,\n  C extends Context<F> = Context<F>,\n>(this: R, context: C, data: V, key: keyof M, model: M): Promise<void> {\n  (model as any)[key] = context.timestamp;\n}\n\n/**\n * Marks the property as timestamp.\n * Makes it {@link required}\n * Makes it a {@link date}\n *\n * Date Format:\n *\n * <pre>\n *      Using similar formatting as Moment.js, Class DateTimeFormatter (Java), and Class SimpleDateFormat (Java),\n *      I implemented a comprehensive solution formatDate(date, patternStr) where the code is easy to read and modify.\n *      You can display date, time, AM/PM, etc.\n *\n *      Date and Time Patterns\n *      yy = 2-digit year; yyyy = full year\n *      M = digit month; MM = 2-digit month; MMM = short month name; MMMM = full month name\n *      EEEE = full weekday name; EEE = short weekday name\n *      d = digit day; dd = 2-digit day\n *      h = hours am/pm; hh = 2-digit hours am/pm; H = hours; HH = 2-digit hours\n *      m = minutes; mm = 2-digit minutes; aaa = AM/PM\n *      s = seconds; ss = 2-digit seconds\n *      S = miliseconds\n * </pre>\n *\n * @param {string[]} operation The {@link DBOperations} to act on. Defaults to {@link DBOperations.CREATE_UPDATE}\n * @param {string} [format] The TimeStamp format. defaults to {@link DEFAULT_TIMESTAMP_FORMAT}\n * @param {{new: UpdateValidator}} [validator] defaults to {@link TimestampValidator}\n *\n * @decorator timestamp\n *\n * @category Decorators\n */\nexport function timestamp(\n  operation: OperationKeys[] = DBOperations.CREATE_UPDATE as unknown as OperationKeys[],\n  format: string = DEFAULT_TIMESTAMP_FORMAT\n) {\n  const key = Validation.updateKey(DBKeys.TIMESTAMP);\n\n  const decorators: any[] = [\n    date(format, DEFAULT_ERROR_MESSAGES.TIMESTAMP.DATE),\n    required(DEFAULT_ERROR_MESSAGES.TIMESTAMP.REQUIRED),\n    on(operation, timestampHandler),\n  ];\n\n  if (operation.indexOf(OperationKeys.UPDATE) !== -1)\n    decorators.push(\n      propMetadata(Validation.updateKey(DBKeys.TIMESTAMP), {\n        message: DEFAULT_ERROR_MESSAGES.TIMESTAMP.INVALID,\n      })\n    );\n  return Decoration.for(key)\n    .define(...decorators)\n    .apply();\n}\n\nexport async function serializeOnCreateUpdate<\n  M extends Model,\n  R extends IRepository<M, F, C>,\n  V,\n  F extends RepositoryFlags = RepositoryFlags,\n  C extends Context<F> = Context<F>,\n>(this: R, context: C, data: V, key: keyof M, model: M): Promise<void> {\n  if (!model[key]) return;\n  try {\n    model[key] = JSON.stringify(model[key]) as M[keyof M];\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  } catch (e: unknown) {\n    throw new SerializationError(\n      `Failed to serialize ${key.toString()} property of model ${model.constructor.name}: e`\n    );\n  }\n}\n\nexport async function serializeAfterAll<\n  M extends Model,\n  R extends IRepository<M, F, C>,\n  V,\n  F extends RepositoryFlags = RepositoryFlags,\n  C extends Context<F> = Context<F>,\n>(this: R, context: C, data: V, key: keyof M, model: M): Promise<void> {\n  if (!model[key]) return;\n  if (typeof model[key] !== \"string\") return;\n\n  try {\n    model[key] = JSON.parse(model[key]);\n  } catch (e: unknown) {\n    throw new SerializationError(\n      `Failed to deserialize ${key.toString()} property of model ${model.constructor.name}: ${e}`\n    );\n  }\n}\n\n/**\n * @summary Serialize Decorator\n * @description properties decorated will the serialized before stored in the db\n *\n * @function serialize\n *\n * @memberOf module:wallet-db.Decorators\n */\nexport function serialize() {\n  return apply(\n    onCreateUpdate(serializeOnCreateUpdate),\n    after(DBOperations.ALL, serializeAfterAll),\n    type([String.name, Object.name]),\n    metadata(Repository.key(DBKeys.SERIALIZE), {})\n  );\n}\n"]}
|
|
200
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../src/validation/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["import \"./validation\";\nimport {\n  date,\n  Decoration,\n  Model,\n  propMetadata,\n  required,\n  type,\n  Validation,\n} from \"@decaf-ts/decorator-validation\";\nimport { DBKeys, DEFAULT_TIMESTAMP_FORMAT } from \"../model/constants\";\nimport { DEFAULT_ERROR_MESSAGES } from \"./constants\";\nimport { DBOperations, OperationKeys } from \"../operations/constants\";\nimport { after, on, onCreateUpdate } from \"../operations/decorators\";\nimport { IRepository } from \"../interfaces/IRepository\";\nimport { SerializationError } from \"../repository/errors\";\nimport { apply, metadata } from \"@decaf-ts/reflection\";\nimport { Repository } from \"../repository\";\nimport { Context } from \"../repository/Context\";\nimport { RepositoryFlags } from \"../repository/types\";\n\n/**\n * @description Prevents a property from being modified after initial creation.\n * @summary Marks the property as readonly, causing validation errors if attempts are made to modify it during updates.\n * @param {string} [message] - The error message to display when validation fails. Defaults to {@link DEFAULT_ERROR_MESSAGES.READONLY.INVALID}\n * @return {PropertyDecorator} A decorator function that can be applied to class properties\n * @function readonly\n * @category Property Decorators\n */\nexport function readonly(\n  message: string = DEFAULT_ERROR_MESSAGES.READONLY.INVALID\n) {\n  const key = Validation.updateKey(DBKeys.READONLY);\n  return Decoration.for(key)\n    .define(\n      propMetadata(key, {\n        message: message,\n      })\n    )\n    .apply();\n}\n\n/**\n * @description Handler function that sets a timestamp property to the current timestamp.\n * @summary Updates a model property with the current timestamp from the repository context.\n * @template M - The model type extending Model\n * @template R - The repository type extending IRepository\n * @template V - The data type for the operation\n * @template F - The repository flags type\n * @template C - The context type\n * @param {C} context - The repository context containing the current timestamp\n * @param {V} data - The data being processed\n * @param key - The property key to update\n * @param {M} model - The model instance being updated\n * @return {Promise<void>} A promise that resolves when the timestamp has been set\n * @function timestampHandler\n * @memberOf module:db-decorators\n */\nexport async function timestampHandler<\n  M extends Model,\n  R extends IRepository<M, F, C>,\n  V,\n  F extends RepositoryFlags = RepositoryFlags,\n  C extends Context<F> = Context<F>,\n>(this: R, context: C, data: V, key: keyof M, model: M): Promise<void> {\n  (model as any)[key] = context.timestamp;\n}\n\n/**\n * @description Automatically manages timestamp properties for tracking creation and update times.\n * @summary Marks the property as a timestamp, making it required and ensuring it's a valid date. The property will be automatically updated with the current timestamp during specified operations.\n *\n * Date Format:\n *\n * <pre>\n *      Using similar formatting as Moment.js, Class DateTimeFormatter (Java), and Class SimpleDateFormat (Java),\n *      I implemented a comprehensive solution formatDate(date, patternStr) where the code is easy to read and modify.\n *      You can display date, time, AM/PM, etc.\n *\n *      Date and Time Patterns\n *      yy = 2-digit year; yyyy = full year\n *      M = digit month; MM = 2-digit month; MMM = short month name; MMMM = full month name\n *      EEEE = full weekday name; EEE = short weekday name\n *      d = digit day; dd = 2-digit day\n *      h = hours am/pm; hh = 2-digit hours am/pm; H = hours; HH = 2-digit hours\n *      m = minutes; mm = 2-digit minutes; aaa = AM/PM\n *      s = seconds; ss = 2-digit seconds\n *      S = miliseconds\n * </pre>\n *\n * @param {OperationKeys[]} operation - The operations to act on. Defaults to {@link DBOperations.CREATE_UPDATE}\n * @param {string} [format] - The timestamp format. Defaults to {@link DEFAULT_TIMESTAMP_FORMAT}\n * @return {PropertyDecorator} A decorator function that can be applied to class properties\n * @function timestamp\n * @category Property Decorators\n * @mermaid\n * sequenceDiagram\n *   participant C as Client\n *   participant M as Model\n *   participant T as TimestampDecorator\n *   participant V as Validator\n *\n *   C->>M: Create/Update model\n *   M->>T: Process timestamp property\n *   T->>M: Apply required validation\n *   T->>M: Apply date format validation\n *\n *   alt Update operation\n *     T->>V: Register timestamp validator\n *     V->>M: Validate timestamp is newer\n *   end\n *\n *   T->>M: Set current timestamp\n *   M->>C: Return updated model\n */\nexport function timestamp(\n  operation: OperationKeys[] = DBOperations.CREATE_UPDATE as unknown as OperationKeys[],\n  format: string = DEFAULT_TIMESTAMP_FORMAT\n) {\n  const key = Validation.updateKey(DBKeys.TIMESTAMP);\n\n  const decorators: any[] = [\n    date(format, DEFAULT_ERROR_MESSAGES.TIMESTAMP.DATE),\n    required(DEFAULT_ERROR_MESSAGES.TIMESTAMP.REQUIRED),\n    on(operation, timestampHandler),\n  ];\n\n  if (operation.indexOf(OperationKeys.UPDATE) !== -1)\n    decorators.push(\n      propMetadata(Validation.updateKey(DBKeys.TIMESTAMP), {\n        message: DEFAULT_ERROR_MESSAGES.TIMESTAMP.INVALID,\n      })\n    );\n  return Decoration.for(key)\n    .define(...decorators)\n    .apply();\n}\n\n/**\n * @description Handler function that serializes a property to JSON string during create and update operations.\n * @summary Converts a complex object property to a JSON string before storing it in the database.\n * @template M - The model type extending Model\n * @template R - The repository type extending IRepository\n * @template V - The data type for the operation\n * @template F - The repository flags type\n * @template C - The context type\n * @param {C} context - The repository context\n * @param {V} data - The data being processed\n * @param key - The property key to serialize\n * @param {M} model - The model instance being processed\n * @return {Promise<void>} A promise that resolves when the property has been serialized\n * @function serializeOnCreateUpdate\n * @memberOf module:db-decorators\n */\nexport async function serializeOnCreateUpdate<\n  M extends Model,\n  R extends IRepository<M, F, C>,\n  V,\n  F extends RepositoryFlags = RepositoryFlags,\n  C extends Context<F> = Context<F>,\n>(this: R, context: C, data: V, key: keyof M, model: M): Promise<void> {\n  if (!model[key]) return;\n  try {\n    model[key] = JSON.stringify(model[key]) as M[keyof M];\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  } catch (e: unknown) {\n    throw new SerializationError(\n      `Failed to serialize ${key.toString()} property of model ${model.constructor.name}: e`\n    );\n  }\n}\n\n/**\n * @description Handler function that deserializes a property from JSON string after database operations.\n * @summary Converts a JSON string property back to its original complex object form after retrieving it from the database.\n * @template M - The model type extending Model\n * @template R - The repository type extending IRepository\n * @template V - The data type for the operation\n * @template F - The repository flags type\n * @template C - The context type\n * @param {C} context - The repository context\n * @param {V} data - The data being processed\n * @param key - The property key to deserialize\n * @param {M} model - The model instance being processed\n * @return {Promise<void>} A promise that resolves when the property has been deserialized\n * @function serializeAfterAll\n * @memberOf module:db-decorators\n */\nexport async function serializeAfterAll<\n  M extends Model,\n  R extends IRepository<M, F, C>,\n  V,\n  F extends RepositoryFlags = RepositoryFlags,\n  C extends Context<F> = Context<F>,\n>(this: R, context: C, data: V, key: keyof M, model: M): Promise<void> {\n  if (!model[key]) return;\n  if (typeof model[key] !== \"string\") return;\n\n  try {\n    model[key] = JSON.parse(model[key]);\n  } catch (e: unknown) {\n    throw new SerializationError(\n      `Failed to deserialize ${key.toString()} property of model ${model.constructor.name}: ${e}`\n    );\n  }\n}\n\n/**\n * @description Enables automatic JSON serialization and deserialization for complex object properties.\n * @summary Decorator that automatically converts complex objects to JSON strings before storing in the database and back to objects when retrieving them.\n * @return {PropertyDecorator} A decorator function that can be applied to class properties\n * @function serialize\n * @category Property Decorators\n * @mermaid\n * sequenceDiagram\n *   participant C as Client\n *   participant M as Model\n *   participant S as SerializeDecorator\n *   participant DB as Database\n *\n *   Note over C,DB: Create/Update Flow\n *   C->>M: Set complex object property\n *   M->>S: Process property (create/update)\n *   S->>M: Convert to JSON string\n *   M->>DB: Store serialized data\n *\n *   Note over C,DB: Retrieval Flow\n *   C->>M: Request model\n *   M->>DB: Fetch data\n *   DB->>M: Return with serialized property\n *   M->>S: Process property (after all ops)\n *   S->>M: Parse JSON back to object\n *   M->>C: Return model with deserialized property\n */\nexport function serialize() {\n  return apply(\n    onCreateUpdate(serializeOnCreateUpdate),\n    after(DBOperations.ALL, serializeAfterAll),\n    type([String.name, Object.name]),\n    metadata(Repository.key(DBKeys.SERIALIZE), {})\n  );\n}\n"]}
|
|
@@ -5,20 +5,34 @@ import { IRepository } from "../interfaces/IRepository";
|
|
|
5
5
|
import { Context } from "../repository/Context";
|
|
6
6
|
import { RepositoryFlags } from "../repository/types";
|
|
7
7
|
/**
|
|
8
|
-
*
|
|
9
|
-
*
|
|
10
|
-
* @param {string} [message]
|
|
11
|
-
*
|
|
12
|
-
* @
|
|
13
|
-
*
|
|
14
|
-
* @category Decorators
|
|
8
|
+
* @description Prevents a property from being modified after initial creation.
|
|
9
|
+
* @summary Marks the property as readonly, causing validation errors if attempts are made to modify it during updates.
|
|
10
|
+
* @param {string} [message] - The error message to display when validation fails. Defaults to {@link DEFAULT_ERROR_MESSAGES.READONLY.INVALID}
|
|
11
|
+
* @return {PropertyDecorator} A decorator function that can be applied to class properties
|
|
12
|
+
* @function readonly
|
|
13
|
+
* @category Property Decorators
|
|
15
14
|
*/
|
|
16
15
|
export declare function readonly(message?: string): (target: any, propertyKey?: any, descriptor?: TypedPropertyDescriptor<any>) => any;
|
|
16
|
+
/**
|
|
17
|
+
* @description Handler function that sets a timestamp property to the current timestamp.
|
|
18
|
+
* @summary Updates a model property with the current timestamp from the repository context.
|
|
19
|
+
* @template M - The model type extending Model
|
|
20
|
+
* @template R - The repository type extending IRepository
|
|
21
|
+
* @template V - The data type for the operation
|
|
22
|
+
* @template F - The repository flags type
|
|
23
|
+
* @template C - The context type
|
|
24
|
+
* @param {C} context - The repository context containing the current timestamp
|
|
25
|
+
* @param {V} data - The data being processed
|
|
26
|
+
* @param key - The property key to update
|
|
27
|
+
* @param {M} model - The model instance being updated
|
|
28
|
+
* @return {Promise<void>} A promise that resolves when the timestamp has been set
|
|
29
|
+
* @function timestampHandler
|
|
30
|
+
* @memberOf module:db-decorators
|
|
31
|
+
*/
|
|
17
32
|
export declare function timestampHandler<M extends Model, R extends IRepository<M, F, C>, V, F extends RepositoryFlags = RepositoryFlags, C extends Context<F> = Context<F>>(this: R, context: C, data: V, key: keyof M, model: M): Promise<void>;
|
|
18
33
|
/**
|
|
19
|
-
*
|
|
20
|
-
*
|
|
21
|
-
* Makes it a {@link date}
|
|
34
|
+
* @description Automatically manages timestamp properties for tracking creation and update times.
|
|
35
|
+
* @summary Marks the property as a timestamp, making it required and ensuring it's a valid date. The property will be automatically updated with the current timestamp during specified operations.
|
|
22
36
|
*
|
|
23
37
|
* Date Format:
|
|
24
38
|
*
|
|
@@ -38,23 +52,91 @@ export declare function timestampHandler<M extends Model, R extends IRepository<
|
|
|
38
52
|
* S = miliseconds
|
|
39
53
|
* </pre>
|
|
40
54
|
*
|
|
41
|
-
* @param {
|
|
42
|
-
* @param {string} [format] The
|
|
43
|
-
* @
|
|
55
|
+
* @param {OperationKeys[]} operation - The operations to act on. Defaults to {@link DBOperations.CREATE_UPDATE}
|
|
56
|
+
* @param {string} [format] - The timestamp format. Defaults to {@link DEFAULT_TIMESTAMP_FORMAT}
|
|
57
|
+
* @return {PropertyDecorator} A decorator function that can be applied to class properties
|
|
58
|
+
* @function timestamp
|
|
59
|
+
* @category Property Decorators
|
|
60
|
+
* @mermaid
|
|
61
|
+
* sequenceDiagram
|
|
62
|
+
* participant C as Client
|
|
63
|
+
* participant M as Model
|
|
64
|
+
* participant T as TimestampDecorator
|
|
65
|
+
* participant V as Validator
|
|
66
|
+
*
|
|
67
|
+
* C->>M: Create/Update model
|
|
68
|
+
* M->>T: Process timestamp property
|
|
69
|
+
* T->>M: Apply required validation
|
|
70
|
+
* T->>M: Apply date format validation
|
|
44
71
|
*
|
|
45
|
-
*
|
|
72
|
+
* alt Update operation
|
|
73
|
+
* T->>V: Register timestamp validator
|
|
74
|
+
* V->>M: Validate timestamp is newer
|
|
75
|
+
* end
|
|
46
76
|
*
|
|
47
|
-
*
|
|
77
|
+
* T->>M: Set current timestamp
|
|
78
|
+
* M->>C: Return updated model
|
|
48
79
|
*/
|
|
49
80
|
export declare function timestamp(operation?: OperationKeys[], format?: string): (target: any, propertyKey?: any, descriptor?: TypedPropertyDescriptor<any>) => any;
|
|
81
|
+
/**
|
|
82
|
+
* @description Handler function that serializes a property to JSON string during create and update operations.
|
|
83
|
+
* @summary Converts a complex object property to a JSON string before storing it in the database.
|
|
84
|
+
* @template M - The model type extending Model
|
|
85
|
+
* @template R - The repository type extending IRepository
|
|
86
|
+
* @template V - The data type for the operation
|
|
87
|
+
* @template F - The repository flags type
|
|
88
|
+
* @template C - The context type
|
|
89
|
+
* @param {C} context - The repository context
|
|
90
|
+
* @param {V} data - The data being processed
|
|
91
|
+
* @param key - The property key to serialize
|
|
92
|
+
* @param {M} model - The model instance being processed
|
|
93
|
+
* @return {Promise<void>} A promise that resolves when the property has been serialized
|
|
94
|
+
* @function serializeOnCreateUpdate
|
|
95
|
+
* @memberOf module:db-decorators
|
|
96
|
+
*/
|
|
50
97
|
export declare function serializeOnCreateUpdate<M extends Model, R extends IRepository<M, F, C>, V, F extends RepositoryFlags = RepositoryFlags, C extends Context<F> = Context<F>>(this: R, context: C, data: V, key: keyof M, model: M): Promise<void>;
|
|
98
|
+
/**
|
|
99
|
+
* @description Handler function that deserializes a property from JSON string after database operations.
|
|
100
|
+
* @summary Converts a JSON string property back to its original complex object form after retrieving it from the database.
|
|
101
|
+
* @template M - The model type extending Model
|
|
102
|
+
* @template R - The repository type extending IRepository
|
|
103
|
+
* @template V - The data type for the operation
|
|
104
|
+
* @template F - The repository flags type
|
|
105
|
+
* @template C - The context type
|
|
106
|
+
* @param {C} context - The repository context
|
|
107
|
+
* @param {V} data - The data being processed
|
|
108
|
+
* @param key - The property key to deserialize
|
|
109
|
+
* @param {M} model - The model instance being processed
|
|
110
|
+
* @return {Promise<void>} A promise that resolves when the property has been deserialized
|
|
111
|
+
* @function serializeAfterAll
|
|
112
|
+
* @memberOf module:db-decorators
|
|
113
|
+
*/
|
|
51
114
|
export declare function serializeAfterAll<M extends Model, R extends IRepository<M, F, C>, V, F extends RepositoryFlags = RepositoryFlags, C extends Context<F> = Context<F>>(this: R, context: C, data: V, key: keyof M, model: M): Promise<void>;
|
|
52
115
|
/**
|
|
53
|
-
* @
|
|
54
|
-
* @
|
|
55
|
-
*
|
|
116
|
+
* @description Enables automatic JSON serialization and deserialization for complex object properties.
|
|
117
|
+
* @summary Decorator that automatically converts complex objects to JSON strings before storing in the database and back to objects when retrieving them.
|
|
118
|
+
* @return {PropertyDecorator} A decorator function that can be applied to class properties
|
|
56
119
|
* @function serialize
|
|
120
|
+
* @category Property Decorators
|
|
121
|
+
* @mermaid
|
|
122
|
+
* sequenceDiagram
|
|
123
|
+
* participant C as Client
|
|
124
|
+
* participant M as Model
|
|
125
|
+
* participant S as SerializeDecorator
|
|
126
|
+
* participant DB as Database
|
|
127
|
+
*
|
|
128
|
+
* Note over C,DB: Create/Update Flow
|
|
129
|
+
* C->>M: Set complex object property
|
|
130
|
+
* M->>S: Process property (create/update)
|
|
131
|
+
* S->>M: Convert to JSON string
|
|
132
|
+
* M->>DB: Store serialized data
|
|
57
133
|
*
|
|
58
|
-
*
|
|
134
|
+
* Note over C,DB: Retrieval Flow
|
|
135
|
+
* C->>M: Request model
|
|
136
|
+
* M->>DB: Fetch data
|
|
137
|
+
* DB->>M: Return with serialized property
|
|
138
|
+
* M->>S: Process property (after all ops)
|
|
139
|
+
* S->>M: Parse JSON back to object
|
|
140
|
+
* M->>C: Return model with deserialized property
|
|
59
141
|
*/
|
|
60
142
|
export declare function serialize(): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
@@ -2,7 +2,15 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
const decorator_validation_1 = require("@decaf-ts/decorator-validation");
|
|
4
4
|
const constants_1 = require("./constants.cjs");
|
|
5
|
+
/**
|
|
6
|
+
* @description Generates a key for update validation metadata.
|
|
7
|
+
* @summary Builds the key to store as metadata under Reflections for update validation by prefixing the provided key with the update validation prefix.
|
|
8
|
+
* @param {string} key - The base key to be prefixed
|
|
9
|
+
* @return {string} The complete metadata key for update validation
|
|
10
|
+
* @function updateKey
|
|
11
|
+
* @memberOf module:db-decorators
|
|
12
|
+
*/
|
|
5
13
|
decorator_validation_1.Validation.updateKey = function (key) {
|
|
6
14
|
return constants_1.UpdateValidationKeys.REFLECT + key;
|
|
7
15
|
};
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy92YWxpZGF0aW9uL3ZhbGlkYXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSx5RUFLd0M7QUFDeEMsK0NBQW1EO0FBRW5EOzs7Ozs7O0dBT0c7QUFDSCxpQ0FBVSxDQUFDLFNBQVMsR0FBRyxVQUFVLEdBQVc7SUFDMUMsT0FBTyxnQ0FBb0IsQ0FBQyxPQUFPLEdBQUcsR0FBRyxDQUFDO0FBQzVDLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIFZhbGlkYXRvcixcbiAgVmFsaWRhdGlvbixcbiAgVmFsaWRhdG9yRGVmaW5pdGlvbixcbiAgSVZhbGlkYXRvclJlZ2lzdHJ5LFxufSBmcm9tIFwiQGRlY2FmLXRzL2RlY29yYXRvci12YWxpZGF0aW9uXCI7XG5pbXBvcnQgeyBVcGRhdGVWYWxpZGF0aW9uS2V5cyB9IGZyb20gXCIuL2NvbnN0YW50c1wiO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBHZW5lcmF0ZXMgYSBrZXkgZm9yIHVwZGF0ZSB2YWxpZGF0aW9uIG1ldGFkYXRhLlxuICogQHN1bW1hcnkgQnVpbGRzIHRoZSBrZXkgdG8gc3RvcmUgYXMgbWV0YWRhdGEgdW5kZXIgUmVmbGVjdGlvbnMgZm9yIHVwZGF0ZSB2YWxpZGF0aW9uIGJ5IHByZWZpeGluZyB0aGUgcHJvdmlkZWQga2V5IHdpdGggdGhlIHVwZGF0ZSB2YWxpZGF0aW9uIHByZWZpeC5cbiAqIEBwYXJhbSB7c3RyaW5nfSBrZXkgLSBUaGUgYmFzZSBrZXkgdG8gYmUgcHJlZml4ZWRcbiAqIEByZXR1cm4ge3N0cmluZ30gVGhlIGNvbXBsZXRlIG1ldGFkYXRhIGtleSBmb3IgdXBkYXRlIHZhbGlkYXRpb25cbiAqIEBmdW5jdGlvbiB1cGRhdGVLZXlcbiAqIEBtZW1iZXJPZiBtb2R1bGU6ZGItZGVjb3JhdG9yc1xuICovXG5WYWxpZGF0aW9uLnVwZGF0ZUtleSA9IGZ1bmN0aW9uIChrZXk6IHN0cmluZykge1xuICByZXR1cm4gVXBkYXRlVmFsaWRhdGlvbktleXMuUkVGTEVDVCArIGtleTtcbn07XG5cbmRlY2xhcmUgbW9kdWxlIFwiQGRlY2FmLXRzL2RlY29yYXRvci12YWxpZGF0aW9uXCIge1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L2Jhbi10cy1jb21tZW50XG4gIC8vIEB0cy1leHBlY3QtZXJyb3JcbiAgZGVjbGFyZSBjbGFzcyBWYWxpZGF0aW9uIHtcbiAgICBwcml2YXRlIHN0YXRpYyBhY3RpbmdWYWxpZGF0b3JSZWdpc3RyeT87XG4gICAgcHJpdmF0ZSBjb25zdHJ1Y3RvcigpO1xuICAgIC8qKlxuICAgICAqIEBzdW1tYXJ5IERlZmluZXMgdGhlIGFjdGluZyBWYWxpZGF0b3JSZWdpc3RyeVxuICAgICAqXG4gICAgICogQHBhcmFtIHtJVmFsaWRhdG9yUmVnaXN0cnl9IHZhbGlkYXRvclJlZ2lzdHJ5IHRoZSBuZXcgaW1wbGVtZW50YXRpb24gb2YgdGhlIHZhbGlkYXRvciBSZWdpc3RyeVxuICAgICAqIEBwYXJhbSB7ZnVuY3Rpb24oVmFsaWRhdG9yKTogVmFsaWRhdG9yfSBbbWlncmF0aW9uSGFuZGxlcl0gdGhlIG1ldGhvZCB0byBtYXAgdGhlIHZhbGlkYXRvciBpZiByZXF1aXJlZDtcbiAgICAgKi9cbiAgICBzdGF0aWMgc2V0UmVnaXN0cnkoXG4gICAgICB2YWxpZGF0b3JSZWdpc3RyeTogSVZhbGlkYXRvclJlZ2lzdHJ5PFZhbGlkYXRvcj4sXG4gICAgICBtaWdyYXRpb25IYW5kbGVyPzogKHZhbGlkYXRvcjogVmFsaWRhdG9yKSA9PiBWYWxpZGF0b3JcbiAgICApOiB2b2lkO1xuICAgIC8qKlxuICAgICAqIEBzdW1tYXJ5IFJldHVybnMgdGhlIGN1cnJlbnQgVmFsaWRhdG9yUmVnaXN0cnlcbiAgICAgKlxuICAgICAqIEByZXR1cm4gSVZhbGlkYXRvclJlZ2lzdHJ5LCBkZWZhdWx0cyB0byB7QGxpbmsgVmFsaWRhdG9yUmVnaXN0cnl9XG4gICAgICovXG4gICAgcHJpdmF0ZSBzdGF0aWMgZ2V0UmVnaXN0cnk7XG4gICAgLyoqXG4gICAgICogQHN1bW1hcnkgUmV0cmlldmVzIGEgdmFsaWRhdG9yXG4gICAgICpcbiAgICAgKiBAcGFyYW0ge3N0cmluZ30gdmFsaWRhdG9yS2V5IG9uZSBvZiB0aGUge0BsaW5rIFZhbGlkYXRpb25LZXlzfVxuICAgICAqIEByZXR1cm4ge1ZhbGlkYXRvciB8IHVuZGVmaW5lZH0gdGhlIHJlZ2lzdGVyZWQgVmFsaWRhdG9yIG9yIHVuZGVmaW5lZCBpZiB0aGVyZSBpcyBub25vIG1hdGNoaW5nIHRoZSBwcm92aWRlZCBrZXlcbiAgICAgKi9cbiAgICBzdGF0aWMgZ2V0PFQgZXh0ZW5kcyBWYWxpZGF0b3I+KHZhbGlkYXRvcktleTogc3RyaW5nKTogVCB8IHVuZGVmaW5lZDtcbiAgICAvKipcbiAgICAgKiBAc3VtbWFyeSBSZWdpc3RlcnMgdGhlIHByb3ZpZGVkIHZhbGlkYXRvcnMgb250byB0aGUgcmVnaXN0cnlcbiAgICAgKlxuICAgICAqIEBwYXJhbSB7VFtdIHwgVmFsaWRhdG9yRGVmaW5pdGlvbltdfSB2YWxpZGF0b3JcbiAgICAgKi9cbiAgICBzdGF0aWMgcmVnaXN0ZXI8VCBleHRlbmRzIFZhbGlkYXRvcj4oXG4gICAgICAuLi52YWxpZGF0b3I6IChWYWxpZGF0b3JEZWZpbml0aW9uIHwgVClbXVxuICAgICk6IHZvaWQ7XG4gICAgLyoqXG4gICAgICogQHN1bW1hcnkgQnVpbGRzIHRoZSBrZXkgdG8gc3RvcmUgYXMgTWV0YWRhdGEgdW5kZXIgUmVmbGVjdGlvbnNcbiAgICAgKiBAZGVzY3JpcHRpb24gY29uY2F0ZW5hdGVzIHtAbGluayBWYWxpZGF0aW9uS2V5cyNSRUZMRUNUfSB3aXRoIHRoZSBwcm92aWRlZCBrZXlcbiAgICAgKlxuICAgICAqIEBwYXJhbSB7c3RyaW5nfSBrZXlcbiAgICAgKi9cbiAgICBzdGF0aWMga2V5KGtleTogc3RyaW5nKTogc3RyaW5nO1xuXG4gICAgc3RhdGljIHVwZGF0ZUtleShrZXk6IHN0cmluZyk6IHN0cmluZztcbiAgfVxufVxuIl19
|
|
@@ -14,11 +14,29 @@ const decorator_validation_1 = require("@decaf-ts/decorator-validation");
|
|
|
14
14
|
const constants_1 = require("./../constants.cjs");
|
|
15
15
|
const reflection_1 = require("@decaf-ts/reflection");
|
|
16
16
|
/**
|
|
17
|
-
* @
|
|
18
|
-
*
|
|
17
|
+
* @description A validator that ensures properties marked as readonly cannot be modified during updates.
|
|
18
|
+
* @summary Validator for the {@link readonly} decorator that checks if a value has been changed during an update operation. It compares the new value with the old value and returns an error message if they are not equal.
|
|
19
|
+
* @param {any} value - The value to be validated
|
|
20
|
+
* @param {any} oldValue - The previous value to compare against
|
|
21
|
+
* @param {string} [message] - Optional custom error message
|
|
19
22
|
* @class ReadOnlyValidator
|
|
20
|
-
* @
|
|
23
|
+
* @example
|
|
24
|
+
* // Using ReadOnlyValidator with a readonly property
|
|
25
|
+
* class User {
|
|
26
|
+
* @readonly()
|
|
27
|
+
* id: string;
|
|
28
|
+
*
|
|
29
|
+
* name: string;
|
|
30
|
+
*
|
|
31
|
+
* constructor(id: string, name: string) {
|
|
32
|
+
* this.id = id;
|
|
33
|
+
* this.name = name;
|
|
34
|
+
* }
|
|
35
|
+
* }
|
|
21
36
|
*
|
|
37
|
+
* // This will trigger validation error when trying to update
|
|
38
|
+
* const user = new User('123', 'John');
|
|
39
|
+
* user.id = '456'; // Will be prevented by ReadOnlyValidator
|
|
22
40
|
* @category Validators
|
|
23
41
|
*/
|
|
24
42
|
let ReadOnlyValidator = class ReadOnlyValidator extends decorator_validation_1.Validator {
|
|
@@ -26,17 +44,23 @@ let ReadOnlyValidator = class ReadOnlyValidator extends decorator_validation_1.V
|
|
|
26
44
|
super(constants_1.DEFAULT_ERROR_MESSAGES.READONLY.INVALID);
|
|
27
45
|
}
|
|
28
46
|
/**
|
|
29
|
-
* @
|
|
47
|
+
* @description Implementation of the base validator's hasErrors method.
|
|
48
|
+
* @summary This method is required by the Validator interface but not used in this validator as validation only happens during updates.
|
|
49
|
+
* @param {any} value - The value to validate
|
|
50
|
+
* @param {any[]} args - Additional arguments
|
|
51
|
+
* @return {string | undefined} Always returns undefined as this validator only works during updates
|
|
30
52
|
*/
|
|
31
53
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
32
54
|
hasErrors(value, ...args) {
|
|
33
55
|
return undefined;
|
|
34
56
|
}
|
|
35
57
|
/**
|
|
36
|
-
* @
|
|
37
|
-
* @
|
|
38
|
-
* @param {any}
|
|
39
|
-
* @param {
|
|
58
|
+
* @description Checks if a value has been modified during an update operation.
|
|
59
|
+
* @summary Validates a value has not changed by comparing it with the previous value using deep equality.
|
|
60
|
+
* @param {any} value - The new value to validate
|
|
61
|
+
* @param {any} oldValue - The original value to compare against
|
|
62
|
+
* @param {string} [message] - Optional custom error message to override the default
|
|
63
|
+
* @return {string | undefined} An error message if validation fails, undefined otherwise
|
|
40
64
|
*/
|
|
41
65
|
updateHasErrors(value, oldValue, message) {
|
|
42
66
|
if (value === undefined)
|
|
@@ -51,4 +75,4 @@ exports.ReadOnlyValidator = ReadOnlyValidator = __decorate([
|
|
|
51
75
|
(0, decorator_validation_1.validator)(constants_1.UpdateValidationKeys.READONLY),
|
|
52
76
|
__metadata("design:paramtypes", [])
|
|
53
77
|
], ReadOnlyValidator);
|
|
54
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUmVhZE9ubHlWYWxpZGF0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdmFsaWRhdGlvbi92YWxpZGF0b3JzL1JlYWRPbmx5VmFsaWRhdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7OztBQUFBLHlFQUFzRTtBQUN0RSxrREFBNEU7QUFDNUUscURBQStDO0FBRS9DOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBeUJHO0FBRUksSUFBTSxpQkFBaUIsR0FBdkIsTUFBTSxpQkFBa0IsU0FBUSxnQ0FBUztJQUM5QztRQUNFLEtBQUssQ0FBQyxrQ0FBc0IsQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDakQsQ0FBQztJQUVEOzs7Ozs7T0FNRztJQUNILDZEQUE2RDtJQUM3RCxTQUFTLENBQUMsS0FBVSxFQUFFLEdBQUcsSUFBVztRQUNsQyxPQUFPLFNBQVMsQ0FBQztJQUNuQixDQUFDO0lBRUQ7Ozs7Ozs7T0FPRztJQUNJLGVBQWUsQ0FDcEIsS0FBVSxFQUNWLFFBQWEsRUFDYixPQUFnQjtRQUVoQixJQUFJLEtBQUssS0FBSyxTQUFTO1lBQUUsT0FBTztRQUVoQyxPQUFPLElBQUEsb0JBQU8sRUFBQyxLQUFLLEVBQUUsUUFBUSxDQUFDO1lBQzdCLENBQUMsQ0FBQyxTQUFTO1lBQ1gsQ0FBQyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsT0FBTyxJQUFJLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUMvQyxDQUFDO0NBQ0YsQ0FBQTtBQXBDWSw4Q0FBaUI7NEJBQWpCLGlCQUFpQjtJQUQ3QixJQUFBLGdDQUFTLEVBQUMsZ0NBQW9CLENBQUMsUUFBUSxDQUFDOztHQUM1QixpQkFBaUIsQ0FvQzdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdmFsaWRhdG9yLCBWYWxpZGF0b3IgfSBmcm9tIFwiQGRlY2FmLXRzL2RlY29yYXRvci12YWxpZGF0aW9uXCI7XG5pbXBvcnQgeyBERUZBVUxUX0VSUk9SX01FU1NBR0VTLCBVcGRhdGVWYWxpZGF0aW9uS2V5cyB9IGZyb20gXCIuLi9jb25zdGFudHNcIjtcbmltcG9ydCB7IGlzRXF1YWwgfSBmcm9tIFwiQGRlY2FmLXRzL3JlZmxlY3Rpb25cIjtcblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gQSB2YWxpZGF0b3IgdGhhdCBlbnN1cmVzIHByb3BlcnRpZXMgbWFya2VkIGFzIHJlYWRvbmx5IGNhbm5vdCBiZSBtb2RpZmllZCBkdXJpbmcgdXBkYXRlcy5cbiAqIEBzdW1tYXJ5IFZhbGlkYXRvciBmb3IgdGhlIHtAbGluayByZWFkb25seX0gZGVjb3JhdG9yIHRoYXQgY2hlY2tzIGlmIGEgdmFsdWUgaGFzIGJlZW4gY2hhbmdlZCBkdXJpbmcgYW4gdXBkYXRlIG9wZXJhdGlvbi4gSXQgY29tcGFyZXMgdGhlIG5ldyB2YWx1ZSB3aXRoIHRoZSBvbGQgdmFsdWUgYW5kIHJldHVybnMgYW4gZXJyb3IgbWVzc2FnZSBpZiB0aGV5IGFyZSBub3QgZXF1YWwuXG4gKiBAcGFyYW0ge2FueX0gdmFsdWUgLSBUaGUgdmFsdWUgdG8gYmUgdmFsaWRhdGVkXG4gKiBAcGFyYW0ge2FueX0gb2xkVmFsdWUgLSBUaGUgcHJldmlvdXMgdmFsdWUgdG8gY29tcGFyZSBhZ2FpbnN0XG4gKiBAcGFyYW0ge3N0cmluZ30gW21lc3NhZ2VdIC0gT3B0aW9uYWwgY3VzdG9tIGVycm9yIG1lc3NhZ2VcbiAqIEBjbGFzcyBSZWFkT25seVZhbGlkYXRvclxuICogQGV4YW1wbGVcbiAqIC8vIFVzaW5nIFJlYWRPbmx5VmFsaWRhdG9yIHdpdGggYSByZWFkb25seSBwcm9wZXJ0eVxuICogY2xhc3MgVXNlciB7XG4gKiAgIEByZWFkb25seSgpXG4gKiAgIGlkOiBzdHJpbmc7XG4gKiAgIFxuICogICBuYW1lOiBzdHJpbmc7XG4gKiAgIFxuICogICBjb25zdHJ1Y3RvcihpZDogc3RyaW5nLCBuYW1lOiBzdHJpbmcpIHtcbiAqICAgICB0aGlzLmlkID0gaWQ7XG4gKiAgICAgdGhpcy5uYW1lID0gbmFtZTtcbiAqICAgfVxuICogfVxuICogXG4gKiAvLyBUaGlzIHdpbGwgdHJpZ2dlciB2YWxpZGF0aW9uIGVycm9yIHdoZW4gdHJ5aW5nIHRvIHVwZGF0ZVxuICogY29uc3QgdXNlciA9IG5ldyBVc2VyKCcxMjMnLCAnSm9obicpO1xuICogdXNlci5pZCA9ICc0NTYnOyAvLyBXaWxsIGJlIHByZXZlbnRlZCBieSBSZWFkT25seVZhbGlkYXRvclxuICogQGNhdGVnb3J5IFZhbGlkYXRvcnNcbiAqL1xuQHZhbGlkYXRvcihVcGRhdGVWYWxpZGF0aW9uS2V5cy5SRUFET05MWSlcbmV4cG9ydCBjbGFzcyBSZWFkT25seVZhbGlkYXRvciBleHRlbmRzIFZhbGlkYXRvciB7XG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIHN1cGVyKERFRkFVTFRfRVJST1JfTUVTU0FHRVMuUkVBRE9OTFkuSU5WQUxJRCk7XG4gIH1cblxuICAvKipcbiAgICogQGRlc2NyaXB0aW9uIEltcGxlbWVudGF0aW9uIG9mIHRoZSBiYXNlIHZhbGlkYXRvcidzIGhhc0Vycm9ycyBtZXRob2QuXG4gICAqIEBzdW1tYXJ5IFRoaXMgbWV0aG9kIGlzIHJlcXVpcmVkIGJ5IHRoZSBWYWxpZGF0b3IgaW50ZXJmYWNlIGJ1dCBub3QgdXNlZCBpbiB0aGlzIHZhbGlkYXRvciBhcyB2YWxpZGF0aW9uIG9ubHkgaGFwcGVucyBkdXJpbmcgdXBkYXRlcy5cbiAgICogQHBhcmFtIHthbnl9IHZhbHVlIC0gVGhlIHZhbHVlIHRvIHZhbGlkYXRlXG4gICAqIEBwYXJhbSB7YW55W119IGFyZ3MgLSBBZGRpdGlvbmFsIGFyZ3VtZW50c1xuICAgKiBAcmV0dXJuIHtzdHJpbmcgfCB1bmRlZmluZWR9IEFsd2F5cyByZXR1cm5zIHVuZGVmaW5lZCBhcyB0aGlzIHZhbGlkYXRvciBvbmx5IHdvcmtzIGR1cmluZyB1cGRhdGVzXG4gICAqL1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLXVudXNlZC12YXJzXG4gIGhhc0Vycm9ycyh2YWx1ZTogYW55LCAuLi5hcmdzOiBhbnlbXSk6IHN0cmluZyB8IHVuZGVmaW5lZCB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIC8qKlxuICAgKiBAZGVzY3JpcHRpb24gQ2hlY2tzIGlmIGEgdmFsdWUgaGFzIGJlZW4gbW9kaWZpZWQgZHVyaW5nIGFuIHVwZGF0ZSBvcGVyYXRpb24uXG4gICAqIEBzdW1tYXJ5IFZhbGlkYXRlcyBhIHZhbHVlIGhhcyBub3QgY2hhbmdlZCBieSBjb21wYXJpbmcgaXQgd2l0aCB0aGUgcHJldmlvdXMgdmFsdWUgdXNpbmcgZGVlcCBlcXVhbGl0eS5cbiAgICogQHBhcmFtIHthbnl9IHZhbHVlIC0gVGhlIG5ldyB2YWx1ZSB0byB2YWxpZGF0ZVxuICAgKiBAcGFyYW0ge2FueX0gb2xkVmFsdWUgLSBUaGUgb3JpZ2luYWwgdmFsdWUgdG8gY29tcGFyZSBhZ2FpbnN0XG4gICAqIEBwYXJhbSB7c3RyaW5nfSBbbWVzc2FnZV0gLSBPcHRpb25hbCBjdXN0b20gZXJyb3IgbWVzc2FnZSB0byBvdmVycmlkZSB0aGUgZGVmYXVsdFxuICAgKiBAcmV0dXJuIHtzdHJpbmcgfCB1bmRlZmluZWR9IEFuIGVycm9yIG1lc3NhZ2UgaWYgdmFsaWRhdGlvbiBmYWlscywgdW5kZWZpbmVkIG90aGVyd2lzZVxuICAgKi9cbiAgcHVibGljIHVwZGF0ZUhhc0Vycm9ycyhcbiAgICB2YWx1ZTogYW55LFxuICAgIG9sZFZhbHVlOiBhbnksXG4gICAgbWVzc2FnZT86IHN0cmluZyxcbiAgKTogc3RyaW5nIHwgdW5kZWZpbmVkIHtcbiAgICBpZiAodmFsdWUgPT09IHVuZGVmaW5lZCkgcmV0dXJuO1xuXG4gICAgcmV0dXJuIGlzRXF1YWwodmFsdWUsIG9sZFZhbHVlKVxuICAgICAgPyB1bmRlZmluZWRcbiAgICAgIDogdGhpcy5nZXRNZXNzYWdlKG1lc3NhZ2UgfHwgdGhpcy5tZXNzYWdlKTtcbiAgfVxufVxuIl19
|
|
@@ -1,23 +1,47 @@
|
|
|
1
1
|
import { Validator } from "@decaf-ts/decorator-validation";
|
|
2
2
|
/**
|
|
3
|
-
* @
|
|
4
|
-
*
|
|
3
|
+
* @description A validator that ensures properties marked as readonly cannot be modified during updates.
|
|
4
|
+
* @summary Validator for the {@link readonly} decorator that checks if a value has been changed during an update operation. It compares the new value with the old value and returns an error message if they are not equal.
|
|
5
|
+
* @param {any} value - The value to be validated
|
|
6
|
+
* @param {any} oldValue - The previous value to compare against
|
|
7
|
+
* @param {string} [message] - Optional custom error message
|
|
5
8
|
* @class ReadOnlyValidator
|
|
6
|
-
* @
|
|
9
|
+
* @example
|
|
10
|
+
* // Using ReadOnlyValidator with a readonly property
|
|
11
|
+
* class User {
|
|
12
|
+
* @readonly()
|
|
13
|
+
* id: string;
|
|
14
|
+
*
|
|
15
|
+
* name: string;
|
|
16
|
+
*
|
|
17
|
+
* constructor(id: string, name: string) {
|
|
18
|
+
* this.id = id;
|
|
19
|
+
* this.name = name;
|
|
20
|
+
* }
|
|
21
|
+
* }
|
|
7
22
|
*
|
|
23
|
+
* // This will trigger validation error when trying to update
|
|
24
|
+
* const user = new User('123', 'John');
|
|
25
|
+
* user.id = '456'; // Will be prevented by ReadOnlyValidator
|
|
8
26
|
* @category Validators
|
|
9
27
|
*/
|
|
10
28
|
export declare class ReadOnlyValidator extends Validator {
|
|
11
29
|
constructor();
|
|
12
30
|
/**
|
|
13
|
-
* @
|
|
31
|
+
* @description Implementation of the base validator's hasErrors method.
|
|
32
|
+
* @summary This method is required by the Validator interface but not used in this validator as validation only happens during updates.
|
|
33
|
+
* @param {any} value - The value to validate
|
|
34
|
+
* @param {any[]} args - Additional arguments
|
|
35
|
+
* @return {string | undefined} Always returns undefined as this validator only works during updates
|
|
14
36
|
*/
|
|
15
37
|
hasErrors(value: any, ...args: any[]): string | undefined;
|
|
16
38
|
/**
|
|
17
|
-
* @
|
|
18
|
-
* @
|
|
19
|
-
* @param {any}
|
|
20
|
-
* @param {
|
|
39
|
+
* @description Checks if a value has been modified during an update operation.
|
|
40
|
+
* @summary Validates a value has not changed by comparing it with the previous value using deep equality.
|
|
41
|
+
* @param {any} value - The new value to validate
|
|
42
|
+
* @param {any} oldValue - The original value to compare against
|
|
43
|
+
* @param {string} [message] - Optional custom error message to override the default
|
|
44
|
+
* @return {string | undefined} An error message if validation fails, undefined otherwise
|
|
21
45
|
*/
|
|
22
46
|
updateHasErrors(value: any, oldValue: any, message?: string): string | undefined;
|
|
23
47
|
}
|