@woltz/rich-domain 1.7.0 → 1.8.0

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.
Files changed (204) hide show
  1. package/dist/cjs/core/aggregate-changes.d.ts +206 -0
  2. package/dist/cjs/core/aggregate-changes.d.ts.map +1 -0
  3. package/dist/cjs/core/aggregate-changes.js +365 -0
  4. package/dist/cjs/core/aggregate-changes.js.map +1 -0
  5. package/dist/cjs/core/base-entity.d.ts +88 -0
  6. package/dist/cjs/core/base-entity.d.ts.map +1 -0
  7. package/dist/cjs/core/base-entity.js +329 -0
  8. package/dist/cjs/core/base-entity.js.map +1 -0
  9. package/dist/cjs/core/change-tracker.d.ts +96 -0
  10. package/dist/cjs/core/change-tracker.d.ts.map +1 -0
  11. package/dist/cjs/core/change-tracker.js +789 -0
  12. package/dist/cjs/core/change-tracker.js.map +1 -0
  13. package/dist/cjs/core/domain-event.d.ts +23 -0
  14. package/dist/cjs/core/domain-event.d.ts.map +1 -0
  15. package/dist/cjs/core/domain-event.js +36 -0
  16. package/dist/cjs/core/domain-event.js.map +1 -0
  17. package/dist/cjs/core/entity-changes.d.ts +84 -0
  18. package/dist/cjs/core/entity-changes.d.ts.map +1 -0
  19. package/dist/cjs/core/entity-changes.js +136 -0
  20. package/dist/cjs/core/entity-changes.js.map +1 -0
  21. package/dist/cjs/core/entity.d.ts +7 -0
  22. package/dist/cjs/core/entity.d.ts.map +1 -0
  23. package/dist/cjs/core/entity.js +11 -0
  24. package/dist/cjs/core/entity.js.map +1 -0
  25. package/dist/cjs/core/id.d.ts +59 -0
  26. package/dist/cjs/core/id.d.ts.map +1 -0
  27. package/dist/cjs/core/id.js +92 -0
  28. package/dist/cjs/core/id.js.map +1 -0
  29. package/dist/cjs/core/index.d.ts +9 -0
  30. package/dist/cjs/core/index.d.ts.map +1 -0
  31. package/dist/cjs/core/index.js +25 -0
  32. package/dist/cjs/core/index.js.map +1 -0
  33. package/dist/cjs/core/value-object.d.ts +49 -0
  34. package/dist/cjs/core/value-object.d.ts.map +1 -0
  35. package/dist/cjs/core/value-object.js +129 -0
  36. package/dist/cjs/core/value-object.js.map +1 -0
  37. package/dist/cjs/index.d.ts +5 -11
  38. package/dist/cjs/index.d.ts.map +1 -1
  39. package/dist/cjs/index.js +21 -19
  40. package/dist/cjs/index.js.map +1 -1
  41. package/dist/cjs/repository/base-repository.d.ts +49 -3
  42. package/dist/cjs/repository/base-repository.d.ts.map +1 -1
  43. package/dist/cjs/repository/base-repository.js.map +1 -1
  44. package/dist/cjs/repository/entity-schema-registry.d.ts +281 -0
  45. package/dist/cjs/repository/entity-schema-registry.d.ts.map +1 -0
  46. package/dist/cjs/repository/entity-schema-registry.js +370 -0
  47. package/dist/cjs/repository/entity-schema-registry.js.map +1 -0
  48. package/dist/cjs/repository/index.d.ts +4 -2
  49. package/dist/cjs/repository/index.d.ts.map +1 -1
  50. package/dist/cjs/repository/index.js +4 -6
  51. package/dist/cjs/repository/index.js.map +1 -1
  52. package/dist/cjs/repository/mapper.d.ts +4 -0
  53. package/dist/cjs/repository/mapper.d.ts.map +1 -0
  54. package/dist/cjs/repository/mapper.js +7 -0
  55. package/dist/cjs/repository/mapper.js.map +1 -0
  56. package/dist/cjs/repository/paginated-result.d.ts +54 -0
  57. package/dist/cjs/repository/paginated-result.d.ts.map +1 -0
  58. package/dist/cjs/repository/paginated-result.js +197 -0
  59. package/dist/cjs/repository/paginated-result.js.map +1 -0
  60. package/dist/cjs/types/change-tracker.d.ts +1 -2
  61. package/dist/cjs/types/change-tracker.d.ts.map +1 -1
  62. package/dist/cjs/types/criteria.d.ts +13 -5
  63. package/dist/cjs/types/criteria.d.ts.map +1 -1
  64. package/dist/cjs/types/criteria.js +2 -2
  65. package/dist/cjs/types/criteria.js.map +1 -1
  66. package/dist/cjs/types/domain.d.ts +1 -1
  67. package/dist/cjs/types/domain.d.ts.map +1 -1
  68. package/dist/cjs/types/unit-of-work.d.ts +1 -1
  69. package/dist/cjs/types/unit-of-work.d.ts.map +1 -1
  70. package/dist/cjs/types/utils.d.ts +1 -2
  71. package/dist/cjs/types/utils.d.ts.map +1 -1
  72. package/dist/cjs/utils/criteria-operator-validation.d.ts.map +1 -1
  73. package/dist/cjs/utils/criteria-operator-validation.js +1 -1
  74. package/dist/cjs/utils/criteria-operator-validation.js.map +1 -1
  75. package/dist/cjs/utils/crypto.d.ts +3 -0
  76. package/dist/cjs/utils/crypto.d.ts.map +1 -0
  77. package/dist/cjs/utils/crypto.js +32 -0
  78. package/dist/cjs/utils/crypto.js.map +1 -0
  79. package/dist/esm/core/aggregate-changes.d.ts +206 -0
  80. package/dist/esm/core/aggregate-changes.d.ts.map +1 -0
  81. package/dist/esm/core/aggregate-changes.js +361 -0
  82. package/dist/esm/core/aggregate-changes.js.map +1 -0
  83. package/dist/esm/core/base-entity.d.ts +88 -0
  84. package/dist/esm/core/base-entity.d.ts.map +1 -0
  85. package/dist/esm/core/base-entity.js +325 -0
  86. package/dist/esm/core/base-entity.js.map +1 -0
  87. package/dist/esm/core/change-tracker.d.ts +96 -0
  88. package/dist/esm/core/change-tracker.d.ts.map +1 -0
  89. package/dist/esm/core/change-tracker.js +785 -0
  90. package/dist/esm/core/change-tracker.js.map +1 -0
  91. package/dist/esm/core/domain-event.d.ts +23 -0
  92. package/dist/esm/core/domain-event.d.ts.map +1 -0
  93. package/dist/esm/core/domain-event.js +32 -0
  94. package/dist/esm/core/domain-event.js.map +1 -0
  95. package/dist/esm/core/entity-changes.d.ts +84 -0
  96. package/dist/esm/core/entity-changes.d.ts.map +1 -0
  97. package/dist/esm/core/entity-changes.js +132 -0
  98. package/dist/esm/core/entity-changes.js.map +1 -0
  99. package/dist/esm/core/entity.d.ts +7 -0
  100. package/dist/esm/core/entity.d.ts.map +1 -0
  101. package/dist/esm/core/entity.js +6 -0
  102. package/dist/esm/core/entity.js.map +1 -0
  103. package/dist/esm/core/id.d.ts +59 -0
  104. package/dist/esm/core/id.d.ts.map +1 -0
  105. package/dist/esm/core/id.js +85 -0
  106. package/dist/esm/core/id.js.map +1 -0
  107. package/dist/esm/core/index.d.ts +9 -0
  108. package/dist/esm/core/index.d.ts.map +1 -0
  109. package/dist/esm/core/index.js +9 -0
  110. package/dist/esm/core/index.js.map +1 -0
  111. package/dist/esm/core/value-object.d.ts +49 -0
  112. package/dist/esm/core/value-object.d.ts.map +1 -0
  113. package/dist/esm/core/value-object.js +125 -0
  114. package/dist/esm/core/value-object.js.map +1 -0
  115. package/dist/esm/index.d.ts +5 -11
  116. package/dist/esm/index.d.ts.map +1 -1
  117. package/dist/esm/index.js +4 -10
  118. package/dist/esm/index.js.map +1 -1
  119. package/dist/esm/repository/base-repository.d.ts +49 -3
  120. package/dist/esm/repository/base-repository.d.ts.map +1 -1
  121. package/dist/esm/repository/base-repository.js.map +1 -1
  122. package/dist/esm/repository/entity-schema-registry.d.ts +281 -0
  123. package/dist/esm/repository/entity-schema-registry.d.ts.map +1 -0
  124. package/dist/esm/repository/entity-schema-registry.js +366 -0
  125. package/dist/esm/repository/entity-schema-registry.js.map +1 -0
  126. package/dist/esm/repository/index.d.ts +4 -2
  127. package/dist/esm/repository/index.d.ts.map +1 -1
  128. package/dist/esm/repository/index.js +4 -2
  129. package/dist/esm/repository/index.js.map +1 -1
  130. package/dist/esm/repository/mapper.d.ts +4 -0
  131. package/dist/esm/repository/mapper.d.ts.map +1 -0
  132. package/dist/esm/repository/mapper.js +3 -0
  133. package/dist/esm/repository/mapper.js.map +1 -0
  134. package/dist/esm/repository/paginated-result.d.ts +54 -0
  135. package/dist/esm/repository/paginated-result.d.ts.map +1 -0
  136. package/dist/esm/repository/paginated-result.js +193 -0
  137. package/dist/esm/repository/paginated-result.js.map +1 -0
  138. package/dist/esm/types/change-tracker.d.ts +1 -2
  139. package/dist/esm/types/change-tracker.d.ts.map +1 -1
  140. package/dist/esm/types/criteria.d.ts +13 -5
  141. package/dist/esm/types/criteria.d.ts.map +1 -1
  142. package/dist/esm/types/criteria.js +3 -1
  143. package/dist/esm/types/criteria.js.map +1 -1
  144. package/dist/esm/types/domain.d.ts +1 -1
  145. package/dist/esm/types/domain.d.ts.map +1 -1
  146. package/dist/esm/types/unit-of-work.d.ts +1 -1
  147. package/dist/esm/types/unit-of-work.d.ts.map +1 -1
  148. package/dist/esm/types/utils.d.ts +1 -2
  149. package/dist/esm/types/utils.d.ts.map +1 -1
  150. package/dist/esm/utils/criteria-operator-validation.d.ts.map +1 -1
  151. package/dist/esm/utils/criteria-operator-validation.js +1 -1
  152. package/dist/esm/utils/criteria-operator-validation.js.map +1 -1
  153. package/dist/esm/utils/crypto.d.ts +3 -0
  154. package/dist/esm/utils/crypto.d.ts.map +1 -0
  155. package/dist/esm/utils/crypto.js +29 -0
  156. package/dist/esm/utils/crypto.js.map +1 -0
  157. package/dist/tsconfig.cjs.tsbuildinfo +1 -1
  158. package/dist/tsconfig.esm.tsbuildinfo +1 -1
  159. package/dist/tsconfig.types.tsbuildinfo +1 -1
  160. package/dist/types/core/aggregate-changes.d.ts +206 -0
  161. package/dist/types/core/aggregate-changes.d.ts.map +1 -0
  162. package/dist/types/core/base-entity.d.ts +88 -0
  163. package/dist/types/core/base-entity.d.ts.map +1 -0
  164. package/dist/types/core/change-tracker.d.ts +96 -0
  165. package/dist/types/core/change-tracker.d.ts.map +1 -0
  166. package/dist/types/core/domain-event.d.ts +23 -0
  167. package/dist/types/core/domain-event.d.ts.map +1 -0
  168. package/dist/types/core/entity-changes.d.ts +84 -0
  169. package/dist/types/core/entity-changes.d.ts.map +1 -0
  170. package/dist/types/core/entity.d.ts +7 -0
  171. package/dist/types/core/entity.d.ts.map +1 -0
  172. package/dist/types/core/id.d.ts +59 -0
  173. package/dist/types/core/id.d.ts.map +1 -0
  174. package/dist/types/core/index.d.ts +9 -0
  175. package/dist/types/core/index.d.ts.map +1 -0
  176. package/dist/types/core/value-object.d.ts +49 -0
  177. package/dist/types/core/value-object.d.ts.map +1 -0
  178. package/dist/types/index.d.ts +5 -11
  179. package/dist/types/index.d.ts.map +1 -1
  180. package/dist/types/paginated-result.d.ts +54 -46
  181. package/dist/types/repository/base-repository.d.ts +49 -3
  182. package/dist/types/repository/base-repository.d.ts.map +1 -1
  183. package/dist/types/repository/entity-schema-registry.d.ts +281 -0
  184. package/dist/types/repository/entity-schema-registry.d.ts.map +1 -0
  185. package/dist/types/repository/index.d.ts +4 -2
  186. package/dist/types/repository/index.d.ts.map +1 -1
  187. package/dist/types/repository/mapper.d.ts +4 -0
  188. package/dist/types/repository/mapper.d.ts.map +1 -0
  189. package/dist/types/repository/paginated-result.d.ts +54 -0
  190. package/dist/types/repository/paginated-result.d.ts.map +1 -0
  191. package/dist/types/types/change-tracker.d.ts +1 -2
  192. package/dist/types/types/change-tracker.d.ts.map +1 -1
  193. package/dist/types/types/criteria.d.ts +13 -5
  194. package/dist/types/types/criteria.d.ts.map +1 -1
  195. package/dist/types/types/domain.d.ts +1 -1
  196. package/dist/types/types/domain.d.ts.map +1 -1
  197. package/dist/types/types/unit-of-work.d.ts +1 -1
  198. package/dist/types/types/unit-of-work.d.ts.map +1 -1
  199. package/dist/types/types/utils.d.ts +1 -2
  200. package/dist/types/types/utils.d.ts.map +1 -1
  201. package/dist/types/utils/criteria-operator-validation.d.ts.map +1 -1
  202. package/dist/types/utils/crypto.d.ts +3 -0
  203. package/dist/types/utils/crypto.d.ts.map +1 -0
  204. package/package.json +1 -1
@@ -0,0 +1,370 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.EntitySchemaRegistry = void 0;
4
+ const index_1 = require("../core/index");
5
+ const exceptions_js_1 = require("../exceptions.js");
6
+ const helpers_js_1 = require("../utils/helpers.js");
7
+ /**
8
+ * Registry for mapping domain entities to database tables and fields.
9
+ *
10
+ * @example
11
+ * ```typescript
12
+ * const registry = new EntitySchemaRegistry()
13
+ * .register({
14
+ * entity: 'User',
15
+ * table: 'users',
16
+ * fields: { email: 'user_email', name: 'user_name' },
17
+ * })
18
+ * .register({
19
+ * entity: 'Post',
20
+ * table: 'blog_posts',
21
+ * fields: { content: 'post_content' },
22
+ * parentFk: { field: 'author_id', parentEntity: 'User' },
23
+ * collections: {
24
+ * comments: { type: 'owned' },
25
+ * tags: { type: 'reference', entity: 'Tag' }
26
+ * }
27
+ * });
28
+ *
29
+ * const table = registry.getTable('Post'); // 'blog_posts'
30
+ * const tagConfig = registry.getCollectionConfig('Post', 'tags');
31
+ * // { type: 'reference', entity: 'Tag' }
32
+ * ```
33
+ */
34
+ class EntitySchemaRegistry {
35
+ schemas = new Map();
36
+ /**
37
+ * Registers an entity schema.
38
+ * @param schema - Schema to be registered.
39
+ * @returns this (for chaining)
40
+ */
41
+ register(schema) {
42
+ if (this.schemas.has(schema.entity)) {
43
+ console.warn(`EntitySchemaRegistry: Schema for '${schema.entity}' is being overwritten`);
44
+ }
45
+ this.schemas.set(schema.entity, schema);
46
+ return this;
47
+ }
48
+ /**
49
+ * Registers multiple schemas at once.
50
+ * @param schemas - Array of schemas.
51
+ * @returns this (for chaining)
52
+ */
53
+ registerAll(schemas) {
54
+ schemas.forEach((schema) => this.register(schema));
55
+ return this;
56
+ }
57
+ /**
58
+ * Gets the schema of an entity.
59
+ * @param entity - Entity name.
60
+ * @throws Error if the entity is not registered.
61
+ */
62
+ getSchema(entity) {
63
+ const schema = this.schemas.get(entity);
64
+ if (!schema) {
65
+ throw new exceptions_js_1.ConfigurationError(`EntitySchemaRegistry: No schema registered for entity '${entity}'. ` +
66
+ `Available entities: ${Array.from(this.schemas.keys()).join(", ") || "none"}`);
67
+ }
68
+ return schema;
69
+ }
70
+ /**
71
+ * Gets all registered schemas.
72
+ */
73
+ getAllSchemas() {
74
+ return Array.from(this.schemas.values());
75
+ }
76
+ /**
77
+ * Tries to get the schema of an entity, returns null if not found.
78
+ * @param entity - Entity name.
79
+ */
80
+ tryGetSchema(entity) {
81
+ return this.schemas.get(entity) ?? null;
82
+ }
83
+ /**
84
+ * Checks if an entity is registered.
85
+ * @param entity - Entity name.
86
+ */
87
+ has(entity) {
88
+ return this.schemas.has(entity);
89
+ }
90
+ /**
91
+ * Gets the table name for an entity.
92
+ * @param entity - Entity name.
93
+ */
94
+ getTable(entity) {
95
+ return this.getSchema(entity).table;
96
+ }
97
+ /**
98
+ * Gets the field mapping for an entity.
99
+ * @param entity - Entity name.
100
+ */
101
+ getFieldsMap(entity) {
102
+ return this.getSchema(entity).fields || {};
103
+ }
104
+ /**
105
+ * Maps a domain field name to the database field name.
106
+ * @param entity - Entity name.
107
+ * @param fieldName - Domain field name.
108
+ */
109
+ mapFieldName(entity, fieldName) {
110
+ const fields = this.getFieldsMap(entity);
111
+ return fields[fieldName] ?? fieldName;
112
+ }
113
+ /**
114
+ * Maps fields of a domain object to database field names.
115
+ * Ignores values that are Entity, ValueObject, or Arrays.
116
+ *
117
+ * @param entity - Entity name.
118
+ * @param data - Data to be mapped.
119
+ */
120
+ mapFields(entity, data) {
121
+ const fields = this.getFieldsMap(entity);
122
+ const result = {};
123
+ for (const [key, value] of Object.entries(data)) {
124
+ if (this.isEntityOrCollection(value))
125
+ continue;
126
+ const mappedKey = fields[key] ?? key;
127
+ result[mappedKey] = this.normalizeValue(value);
128
+ }
129
+ return result;
130
+ }
131
+ /**
132
+ * Maps a complete domain entity to database data.
133
+ * Used for CREATE operations.
134
+ *
135
+ * @param entity - Entity name.
136
+ * @param domainEntity - Domain entity instance.
137
+ */
138
+ mapEntity(entity, domainEntity) {
139
+ const fields = this.getFieldsMap(entity);
140
+ const result = {};
141
+ const hasId = domainEntity.id;
142
+ if (hasId) {
143
+ const idValue = hasId.value ?? hasId;
144
+ result["id"] = idValue;
145
+ }
146
+ const props = domainEntity.props || domainEntity;
147
+ for (const [key, value] of Object.entries(props)) {
148
+ if (key === "id")
149
+ continue;
150
+ if (this.isEntityOrCollection(value))
151
+ continue;
152
+ const mappedKey = fields[key] ?? key;
153
+ result[mappedKey] = this.normalizeValue(value);
154
+ }
155
+ return result;
156
+ }
157
+ /**
158
+ * Gets the FK object to relate with the parent.
159
+ *
160
+ * @param entity - Entity name.
161
+ * @param parentId - Parent ID.
162
+ * @returns Object with the FK field or null if there is no parent.
163
+ */
164
+ getParentFk(entity, parentId) {
165
+ const schema = this.getSchema(entity);
166
+ if (!schema.parentFk)
167
+ return null;
168
+ return { [schema.parentFk.field]: parentId };
169
+ }
170
+ /**
171
+ * Gets the name of the parent entity.
172
+ * @param entity - Entity name.
173
+ */
174
+ getParentEntity(entity) {
175
+ const schema = this.getSchema(entity);
176
+ return schema.parentFk?.parentEntity ?? null;
177
+ }
178
+ /**
179
+ * Gets the FK field name.
180
+ * @param entity - Entity name.
181
+ */
182
+ getParentFkField(entity) {
183
+ const schema = this.getSchema(entity);
184
+ return schema.parentFk?.field ?? null;
185
+ }
186
+ /**
187
+ * Gets the collection configuration for a specific field.
188
+ *
189
+ * @param entity - Parent entity name (e.g., 'Post')
190
+ * @param fieldName - Collection field name (e.g., 'tags')
191
+ * @returns CollectionConfig or null if not configured
192
+ *
193
+ * @example
194
+ * ```typescript
195
+ * const config = registry.getCollectionConfig('Post', 'tags');
196
+ * if (config?.type === 'reference') {
197
+ * // Handle N:N relation - use connect/disconnect
198
+ * } else {
199
+ * // Handle 1:N relation - use create/delete
200
+ * }
201
+ * ```
202
+ */
203
+ getCollectionConfig(entity, fieldName) {
204
+ const schema = this.tryGetSchema(entity);
205
+ if (!schema?.collections)
206
+ return null;
207
+ return schema.collections[fieldName] ?? null;
208
+ }
209
+ /**
210
+ * Checks if a collection is a reference type (N:N).
211
+ *
212
+ * @param entity - Parent entity name
213
+ * @param fieldName - Collection field name
214
+ * @returns true if the collection is a reference (N:N), false otherwise
215
+ *
216
+ * @example
217
+ * ```typescript
218
+ * if (registry.isReferenceCollection('Post', 'tags')) {
219
+ * // Use connect/disconnect instead of create/delete
220
+ * }
221
+ * ```
222
+ */
223
+ isReferenceCollection(entity, fieldName) {
224
+ const config = this.getCollectionConfig(entity, fieldName);
225
+ return config?.type === "reference";
226
+ }
227
+ /**
228
+ * Checks if a collection is owned (1:N).
229
+ * Returns true if explicitly configured as 'owned' or if not configured at all.
230
+ *
231
+ * @param entity - Parent entity name
232
+ * @param fieldName - Collection field name
233
+ * @returns true if the collection is owned (1:N), false if reference
234
+ */
235
+ isOwnedCollection(entity, fieldName) {
236
+ const config = this.getCollectionConfig(entity, fieldName);
237
+ // Default to owned if not configured
238
+ return config?.type !== "reference";
239
+ }
240
+ /**
241
+ * Gets all collections configured for an entity.
242
+ *
243
+ * @param entity - Entity name
244
+ * @returns Record of field names to collection configs, or empty object
245
+ */
246
+ getCollections(entity) {
247
+ const schema = this.tryGetSchema(entity);
248
+ return schema?.collections ?? {};
249
+ }
250
+ /**
251
+ * Gets all reference (N:N) collections for an entity.
252
+ *
253
+ * @param entity - Entity name
254
+ * @returns Array of field names that are reference collections
255
+ */
256
+ getReferenceCollections(entity) {
257
+ const collections = this.getCollections(entity);
258
+ return Object.entries(collections)
259
+ .filter(([_, config]) => config.type === "reference")
260
+ .map(([field]) => field);
261
+ }
262
+ /**
263
+ * Gets the junction table configuration for a reference collection.
264
+ *
265
+ * @param entity - Parent entity name
266
+ * @param fieldName - Collection field name
267
+ * @returns Junction config or null
268
+ */
269
+ getJunctionConfig(entity, fieldName) {
270
+ const config = this.getCollectionConfig(entity, fieldName);
271
+ return config?.junction ?? null;
272
+ }
273
+ /**
274
+ * Lists all registered entities.
275
+ */
276
+ getRegisteredEntities() {
277
+ return Array.from(this.schemas.keys());
278
+ }
279
+ /**
280
+ * Clears all registered schemas.
281
+ */
282
+ clear() {
283
+ this.schemas.clear();
284
+ }
285
+ /**
286
+ * Checks if a value is Entity, ValueObject, or Array.
287
+ */
288
+ isEntityOrCollection(value) {
289
+ if (value === null || value === undefined)
290
+ return false;
291
+ if (Array.isArray(value))
292
+ return true;
293
+ if (value instanceof index_1.Entity)
294
+ return true;
295
+ if (value instanceof index_1.ValueObject)
296
+ return true;
297
+ if (typeof value === "object" &&
298
+ value.id &&
299
+ typeof value.id === "object" &&
300
+ "value" in value.id) {
301
+ return true;
302
+ }
303
+ return false;
304
+ }
305
+ /**
306
+ * Normalizes a value for persistence.
307
+ */
308
+ normalizeValue(input) {
309
+ if (input === null || input === undefined)
310
+ return input;
311
+ if (input instanceof index_1.Id)
312
+ return input.value;
313
+ if (input instanceof index_1.ValueObject)
314
+ return input.value;
315
+ if (input instanceof Date)
316
+ return input;
317
+ if (typeof input === "object" && "value" in input) {
318
+ return input.value;
319
+ }
320
+ return input;
321
+ }
322
+ /**
323
+ * Validates that a relation field exists in the entity's collections.
324
+ *
325
+ * @param entity - Parent entity name
326
+ * @param relationField - Relation field to validate
327
+ * @throws ConfigurationError if the field doesn't exist
328
+ *
329
+ */
330
+ validateRelationField(entity, relationField) {
331
+ const schema = this.tryGetSchema(entity);
332
+ const uuidPattern = /^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i;
333
+ if (uuidPattern.test(entity)) {
334
+ throw new exceptions_js_1.ConfigurationError(`EntitySchemaRegistry: Received an ID '${entity}' instead of an entity name. ` +
335
+ `This usually means 'parentEntity' is not being set correctly in the ChangeTracker. ` +
336
+ `Check that addDelete/addCreate are receiving the entity NAME (e.g., 'Post'), not the ID.`);
337
+ }
338
+ if (!schema) {
339
+ throw new exceptions_js_1.ConfigurationError(`EntitySchemaRegistry: Cannot validate relation '${relationField}' - ` +
340
+ `entity '${entity}' is not registered. ` +
341
+ `Available entities: ${this.getRegisteredEntities().join(", ") || "none"}`);
342
+ }
343
+ const collections = schema.collections ?? {};
344
+ const availableCollections = Object.keys(collections);
345
+ if (availableCollections.length === 0) {
346
+ return;
347
+ }
348
+ if (!collections[relationField]) {
349
+ const suggestions = this.findSimilarNames(relationField, availableCollections);
350
+ const suggestionText = suggestions.length > 0
351
+ ? ` Did you mean: '${suggestions.join("' or '")}'?`
352
+ : "";
353
+ throw new exceptions_js_1.ConfigurationError(`EntitySchemaRegistry: Unknown relation '${relationField}' for entity '${entity}'. ` +
354
+ `Available collections: ${availableCollections.join(", ")}.${suggestionText}`);
355
+ }
356
+ }
357
+ findSimilarNames(input, candidates) {
358
+ return candidates
359
+ .map((candidate) => ({
360
+ name: candidate,
361
+ distance: (0, helpers_js_1.levenshteinDistance)(input.toLowerCase(), candidate.toLowerCase()),
362
+ }))
363
+ .filter(({ distance }) => distance <= 3)
364
+ .sort((a, b) => a.distance - b.distance)
365
+ .slice(0, 2)
366
+ .map(({ name }) => name);
367
+ }
368
+ }
369
+ exports.EntitySchemaRegistry = EntitySchemaRegistry;
370
+ //# sourceMappingURL=entity-schema-registry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"entity-schema-registry.js","sourceRoot":"","sources":["../../../src/repository/entity-schema-registry.ts"],"names":[],"mappings":";;;AAAA,yCAAwD;AACxD,oDAAsD;AACtD,oDAA0D;AAqF1D;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AACH,MAAa,oBAAoB;IACvB,OAAO,GAAG,IAAI,GAAG,EAAwB,CAAC;IAElD;;;;OAIG;IACH,QAAQ,CAAC,MAAoB;QAC3B,IAAI,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC;YACpC,OAAO,CAAC,IAAI,CACV,qCAAqC,MAAM,CAAC,MAAM,wBAAwB,CAC3E,CAAC;QACJ,CAAC;QACD,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;QACxC,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;OAIG;IACH,WAAW,CAAC,OAAuB;QACjC,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC;QACnD,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;OAIG;IACH,SAAS,CAAC,MAAc;QACtB,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QACxC,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,MAAM,IAAI,kCAAkB,CAC1B,0DAA0D,MAAM,KAAK;gBACnE,uBACE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,MAChD,EAAE,CACL,CAAC;QACJ,CAAC;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;IAED;;OAEG;IACH,aAAa;QACX,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC;IAC3C,CAAC;IAED;;;OAGG;IACH,YAAY,CAAC,MAAc;QACzB,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC;IAC1C,CAAC;IAED;;;OAGG;IACH,GAAG,CAAC,MAAc;QAChB,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IAClC,CAAC;IAED;;;OAGG;IACH,QAAQ,CAAC,MAAc;QACrB,OAAO,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC;IACtC,CAAC;IAED;;;OAGG;IACH,YAAY,CAAC,MAAc;QACzB,OAAO,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,MAAM,IAAI,EAAE,CAAC;IAC7C,CAAC;IAED;;;;OAIG;IACH,YAAY,CAAC,MAAc,EAAE,SAAiB;QAC5C,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QACzC,OAAO,MAAM,CAAC,SAAS,CAAC,IAAI,SAAS,CAAC;IACxC,CAAC;IAED;;;;;;OAMG;IACH,SAAS,CAAC,MAAc,EAAE,IAAyB;QACjD,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QACzC,MAAM,MAAM,GAAqB,EAAE,CAAC;QACpC,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;YAChD,IAAI,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC;gBAAE,SAAS;YAC/C,MAAM,SAAS,GAAG,MAAM,CAAC,GAAG,CAAC,IAAI,GAAG,CAAC;YACrC,MAAM,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QACjD,CAAC;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;IAED;;;;;;OAMG;IACH,SAAS,CACP,MAAc,EACd,YAA4C;QAE5C,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QACzC,MAAM,MAAM,GAAqB,EAAE,CAAC;QACpC,MAAM,KAAK,GAAI,YAAoB,CAAC,EAAE,CAAC;QACvC,IAAI,KAAK,EAAE,CAAC;YACV,MAAM,OAAO,GAAG,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC;YACrC,MAAM,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC;QACzB,CAAC;QACD,MAAM,KAAK,GAAI,YAAoB,CAAC,KAAK,IAAI,YAAY,CAAC;QAC1D,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;YACjD,IAAI,GAAG,KAAK,IAAI;gBAAE,SAAS;YAC3B,IAAI,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC;gBAAE,SAAS;YAC/C,MAAM,SAAS,GAAG,MAAM,CAAC,GAAG,CAAC,IAAI,GAAG,CAAC;YACrC,MAAM,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QACjD,CAAC;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;IAED;;;;;;OAMG;IACH,WAAW,CAAC,MAAc,EAAE,QAAgB;QAC1C,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QACtC,IAAI,CAAC,MAAM,CAAC,QAAQ;YAAE,OAAO,IAAI,CAAC;QAClC,OAAO,EAAE,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,QAAQ,EAAE,CAAC;IAC/C,CAAC;IAED;;;OAGG;IACH,eAAe,CAAC,MAAc;QAC5B,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QACtC,OAAO,MAAM,CAAC,QAAQ,EAAE,YAAY,IAAI,IAAI,CAAC;IAC/C,CAAC;IAED;;;OAGG;IACH,gBAAgB,CAAC,MAAc;QAC7B,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QACtC,OAAO,MAAM,CAAC,QAAQ,EAAE,KAAK,IAAI,IAAI,CAAC;IACxC,CAAC;IAED;;;;;;;;;;;;;;;;OAgBG;IACH,mBAAmB,CACjB,MAAc,EACd,SAAiB;QAEjB,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QACzC,IAAI,CAAC,MAAM,EAAE,WAAW;YAAE,OAAO,IAAI,CAAC;QACtC,OAAO,MAAM,CAAC,WAAW,CAAC,SAAS,CAAC,IAAI,IAAI,CAAC;IAC/C,CAAC;IAED;;;;;;;;;;;;;OAaG;IACH,qBAAqB,CAAC,MAAc,EAAE,SAAiB;QACrD,MAAM,MAAM,GAAG,IAAI,CAAC,mBAAmB,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;QAC3D,OAAO,MAAM,EAAE,IAAI,KAAK,WAAW,CAAC;IACtC,CAAC;IAED;;;;;;;OAOG;IACH,iBAAiB,CAAC,MAAc,EAAE,SAAiB;QACjD,MAAM,MAAM,GAAG,IAAI,CAAC,mBAAmB,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;QAC3D,qCAAqC;QACrC,OAAO,MAAM,EAAE,IAAI,KAAK,WAAW,CAAC;IACtC,CAAC;IAED;;;;;OAKG;IACH,cAAc,CAAC,MAAc;QAC3B,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QACzC,OAAO,MAAM,EAAE,WAAW,IAAI,EAAE,CAAC;IACnC,CAAC;IAED;;;;;OAKG;IACH,uBAAuB,CAAC,MAAc;QACpC,MAAM,WAAW,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;QAChD,OAAO,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC;aAC/B,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,WAAW,CAAC;aACpD,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC;IAC7B,CAAC;IAED;;;;;;OAMG;IACH,iBAAiB,CACf,MAAc,EACd,SAAiB;QAEjB,MAAM,MAAM,GAAG,IAAI,CAAC,mBAAmB,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;QAC3D,OAAO,MAAM,EAAE,QAAQ,IAAI,IAAI,CAAC;IAClC,CAAC;IAED;;OAEG;IACH,qBAAqB;QACnB,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC;IACzC,CAAC;IAED;;OAEG;IACH,KAAK;QACH,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;IACvB,CAAC;IAED;;OAEG;IACK,oBAAoB,CAAC,KAAU;QACrC,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS;YAAE,OAAO,KAAK,CAAC;QACxD,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC;YAAE,OAAO,IAAI,CAAC;QACtC,IAAI,KAAK,YAAY,cAAM;YAAE,OAAO,IAAI,CAAC;QACzC,IAAI,KAAK,YAAY,mBAAW;YAAE,OAAO,IAAI,CAAC;QAC9C,IACE,OAAO,KAAK,KAAK,QAAQ;YACzB,KAAK,CAAC,EAAE;YACR,OAAO,KAAK,CAAC,EAAE,KAAK,QAAQ;YAC5B,OAAO,IAAI,KAAK,CAAC,EAAE,EACnB,CAAC;YACD,OAAO,IAAI,CAAC;QACd,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;OAEG;IACK,cAAc,CAAC,KAAU;QAC/B,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS;YAAE,OAAO,KAAK,CAAC;QACxD,IAAI,KAAK,YAAY,UAAE;YAAE,OAAO,KAAK,CAAC,KAAK,CAAC;QAC5C,IAAI,KAAK,YAAY,mBAAW;YAAE,OAAO,KAAK,CAAC,KAAK,CAAC;QACrD,IAAI,KAAK,YAAY,IAAI;YAAE,OAAO,KAAK,CAAC;QACxC,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,OAAO,IAAI,KAAK,EAAE,CAAC;YAClD,OAAO,KAAK,CAAC,KAAK,CAAC;QACrB,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;;;;;;OAOG;IACI,qBAAqB,CAAC,MAAc,EAAE,aAAqB;QAChE,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QAEzC,MAAM,WAAW,GACf,iEAAiE,CAAC;QAEpE,IAAI,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;YAC7B,MAAM,IAAI,kCAAkB,CAC1B,yCAAyC,MAAM,+BAA+B;gBAC5E,qFAAqF;gBACrF,0FAA0F,CAC7F,CAAC;QACJ,CAAC;QAED,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,MAAM,IAAI,kCAAkB,CAC1B,mDAAmD,aAAa,MAAM;gBACpE,WAAW,MAAM,uBAAuB;gBACxC,uBACE,IAAI,CAAC,qBAAqB,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,MAC7C,EAAE,CACL,CAAC;QACJ,CAAC;QAED,MAAM,WAAW,GAAG,MAAM,CAAC,WAAW,IAAI,EAAE,CAAC;QAC7C,MAAM,oBAAoB,GAAG,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAEtD,IAAI,oBAAoB,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACtC,OAAO;QACT,CAAC;QAED,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,EAAE,CAAC;YAChC,MAAM,WAAW,GAAG,IAAI,CAAC,gBAAgB,CACvC,aAAa,EACb,oBAAoB,CACrB,CAAC;YACF,MAAM,cAAc,GAClB,WAAW,CAAC,MAAM,GAAG,CAAC;gBACpB,CAAC,CAAC,mBAAmB,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI;gBACnD,CAAC,CAAC,EAAE,CAAC;YAET,MAAM,IAAI,kCAAkB,CAC1B,2CAA2C,aAAa,iBAAiB,MAAM,KAAK;gBAClF,0BAA0B,oBAAoB,CAAC,IAAI,CACjD,IAAI,CACL,IAAI,cAAc,EAAE,CACxB,CAAC;QACJ,CAAC;IACH,CAAC;IAEO,gBAAgB,CAAC,KAAa,EAAE,UAAoB;QAC1D,OAAO,UAAU;aACd,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;YACnB,IAAI,EAAE,SAAS;YACf,QAAQ,EAAE,IAAA,gCAAmB,EAC3B,KAAK,CAAC,WAAW,EAAE,EACnB,SAAS,CAAC,WAAW,EAAE,CACxB;SACF,CAAC,CAAC;aACF,MAAM,CAAC,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,QAAQ,IAAI,CAAC,CAAC;aACvC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,GAAG,CAAC,CAAC,QAAQ,CAAC;aACvC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC;aACX,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;CACF;AArYD,oDAqYC"}
@@ -1,4 +1,6 @@
1
- export { Mapper } from "../mapper.js";
2
1
  export * from "./base-repository.js";
3
- export { UnitOfWork, BaseTransactionContext } from "./unit-of-work.js";
2
+ export * from "./mapper.js";
3
+ export * from "./unit-of-work.js";
4
+ export * from "./entity-schema-registry.js";
5
+ export * from "./paginated-result.js";
4
6
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/repository/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AACtC,cAAc,sBAAsB,CAAC;AACrC,OAAO,EAAE,UAAU,EAAE,sBAAsB,EAAE,MAAM,mBAAmB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/repository/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAC;AACrC,cAAc,aAAa,CAAC;AAC5B,cAAc,mBAAmB,CAAC;AAClC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,uBAAuB,CAAC"}
@@ -14,11 +14,9 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
14
  for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
15
  };
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
- exports.BaseTransactionContext = exports.UnitOfWork = exports.Mapper = void 0;
18
- var mapper_js_1 = require("../mapper.js");
19
- Object.defineProperty(exports, "Mapper", { enumerable: true, get: function () { return mapper_js_1.Mapper; } });
20
17
  __exportStar(require("./base-repository.js"), exports);
21
- var unit_of_work_js_1 = require("./unit-of-work.js");
22
- Object.defineProperty(exports, "UnitOfWork", { enumerable: true, get: function () { return unit_of_work_js_1.UnitOfWork; } });
23
- Object.defineProperty(exports, "BaseTransactionContext", { enumerable: true, get: function () { return unit_of_work_js_1.BaseTransactionContext; } });
18
+ __exportStar(require("./mapper.js"), exports);
19
+ __exportStar(require("./unit-of-work.js"), exports);
20
+ __exportStar(require("./entity-schema-registry.js"), exports);
21
+ __exportStar(require("./paginated-result.js"), exports);
24
22
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/repository/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,0CAAsC;AAA7B,mGAAA,MAAM,OAAA;AACf,uDAAqC;AACrC,qDAAuE;AAA9D,6GAAA,UAAU,OAAA;AAAE,yHAAA,sBAAsB,OAAA"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/repository/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,uDAAqC;AACrC,8CAA4B;AAC5B,oDAAkC;AAClC,8DAA4C;AAC5C,wDAAsC"}
@@ -0,0 +1,4 @@
1
+ export declare abstract class Mapper<Input, Output> {
2
+ abstract build(input: Input, ...args: unknown[]): Output | Promise<Output>;
3
+ }
4
+ //# sourceMappingURL=mapper.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mapper.d.ts","sourceRoot":"","sources":["../../../src/repository/mapper.ts"],"names":[],"mappings":"AAAA,8BAAsB,MAAM,CAAC,KAAK,EAAE,MAAM;aACxB,KAAK,CACnB,KAAK,EAAE,KAAK,EACZ,GAAG,IAAI,EAAE,OAAO,EAAE,GACjB,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;CAC5B"}
@@ -0,0 +1,7 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Mapper = void 0;
4
+ class Mapper {
5
+ }
6
+ exports.Mapper = Mapper;
7
+ //# sourceMappingURL=mapper.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mapper.js","sourceRoot":"","sources":["../../../src/repository/mapper.ts"],"names":[],"mappings":";;;AAAA,MAAsB,MAAM;CAK3B;AALD,wBAKC"}
@@ -0,0 +1,54 @@
1
+ import type { Criteria } from "../criteria.js";
2
+ import type { Pagination, PaginationMeta, DeepJsonResult } from "../types/index.js";
3
+ /**
4
+ * Type for the serialized result of PaginatedResult.toJSON()
5
+ * Uses DeepJsonResult to ensure all nested entities are converted to plain objects
6
+ */
7
+ export type PaginatedJsonResult<T> = {
8
+ data: DeepJsonResult<T>[];
9
+ meta: PaginationMeta;
10
+ };
11
+ export declare class PaginatedResult<T> {
12
+ readonly data: T[];
13
+ readonly meta: PaginationMeta;
14
+ constructor(data: T[], meta: PaginationMeta);
15
+ /**
16
+ * Creates a PaginatedResult with calculated metadata
17
+ */
18
+ static create<T>(data: T[], pagination: Pagination, total: number): PaginatedResult<T>;
19
+ /**
20
+ * Creates pagination metadata from total count
21
+ */
22
+ static createMeta(pagination: Pagination, total: number): PaginationMeta;
23
+ /**
24
+ * Applies criteria to an in-memory array (useful for testing)
25
+ */
26
+ static fromArray<T>(items: T[], criteria: Criteria<T>): PaginatedResult<T>;
27
+ /**
28
+ * Converts the result to JSON, deeply serializing all entities/aggregates/value objects
29
+ * - Entities/Aggregates → calls toJSON() recursively
30
+ * - Value Objects → converts to value
31
+ * - Id → converts to string
32
+ * - Arrays → maps recursively
33
+ * - Plain objects → serializes properties recursively
34
+ * - Primitives → returns as-is
35
+ */
36
+ toJSON(): PaginatedJsonResult<T>;
37
+ /**
38
+ * Deep serialization logic (similar to BaseEntity.deepToJson)
39
+ */
40
+ private deepSerialize;
41
+ /**
42
+ * Transform each item in the result using a mapper function
43
+ */
44
+ map<U>(fn: (item: T) => U): PaginatedResult<U>;
45
+ /**
46
+ * Check if result has no data
47
+ */
48
+ get isEmpty(): boolean;
49
+ /**
50
+ * Check if there are more pages available
51
+ */
52
+ get hasMore(): boolean;
53
+ }
54
+ //# sourceMappingURL=paginated-result.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"paginated-result.d.ts","sourceRoot":"","sources":["../../../src/repository/paginated-result.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC/C,OAAO,KAAK,EACV,UAAU,EACV,cAAc,EAEd,cAAc,EACf,MAAM,mBAAmB,CAAC;AAE3B;;;GAGG;AACH,MAAM,MAAM,mBAAmB,CAAC,CAAC,IAAI;IACnC,IAAI,EAAE,cAAc,CAAC,CAAC,CAAC,EAAE,CAAC;IAC1B,IAAI,EAAE,cAAc,CAAC;CACtB,CAAC;AAEF,qBAAa,eAAe,CAAC,CAAC;aAEV,IAAI,EAAE,CAAC,EAAE;aACT,IAAI,EAAE,cAAc;gBADpB,IAAI,EAAE,CAAC,EAAE,EACT,IAAI,EAAE,cAAc;IAGtC;;OAEG;IACH,MAAM,CAAC,MAAM,CAAC,CAAC,EACb,IAAI,EAAE,CAAC,EAAE,EACT,UAAU,EAAE,UAAU,EACtB,KAAK,EAAE,MAAM,GACZ,eAAe,CAAC,CAAC,CAAC;IAKrB;;OAEG;IACH,MAAM,CAAC,UAAU,CAAC,UAAU,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,GAAG,cAAc;IAaxE;;OAEG;IACH,MAAM,CAAC,SAAS,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC,CAAC,GAAG,eAAe,CAAC,CAAC,CAAC;IA0C1E;;;;;;;;OAQG;IACH,MAAM,IAAI,mBAAmB,CAAC,CAAC,CAAC;IAShC;;OAEG;IACH,OAAO,CAAC,aAAa;IA2BrB;;OAEG;IACH,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,GAAG,eAAe,CAAC,CAAC,CAAC;IAI9C;;OAEG;IACH,IAAI,OAAO,IAAI,OAAO,CAErB;IAED;;OAEG;IACH,IAAI,OAAO,IAAI,OAAO,CAErB;CACF"}