@mikro-orm/core 7.0.4 → 7.0.5-dev.1

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 (206) hide show
  1. package/EntityManager.d.ts +583 -884
  2. package/EntityManager.js +1895 -1922
  3. package/MikroORM.d.ts +74 -103
  4. package/MikroORM.js +179 -178
  5. package/README.md +1 -1
  6. package/cache/CacheAdapter.d.ts +36 -36
  7. package/cache/FileCacheAdapter.d.ts +24 -30
  8. package/cache/FileCacheAdapter.js +78 -80
  9. package/cache/GeneratedCacheAdapter.d.ts +20 -18
  10. package/cache/GeneratedCacheAdapter.js +30 -30
  11. package/cache/MemoryCacheAdapter.d.ts +20 -18
  12. package/cache/MemoryCacheAdapter.js +36 -35
  13. package/cache/NullCacheAdapter.d.ts +16 -16
  14. package/cache/NullCacheAdapter.js +24 -24
  15. package/connections/Connection.d.ts +84 -95
  16. package/connections/Connection.js +168 -165
  17. package/drivers/DatabaseDriver.d.ts +80 -186
  18. package/drivers/DatabaseDriver.js +443 -450
  19. package/drivers/IDatabaseDriver.d.ts +301 -440
  20. package/entity/BaseEntity.d.ts +83 -120
  21. package/entity/BaseEntity.js +43 -43
  22. package/entity/Collection.d.ts +179 -212
  23. package/entity/Collection.js +721 -727
  24. package/entity/EntityAssigner.d.ts +77 -88
  25. package/entity/EntityAssigner.js +230 -231
  26. package/entity/EntityFactory.d.ts +54 -66
  27. package/entity/EntityFactory.js +383 -425
  28. package/entity/EntityHelper.d.ts +22 -34
  29. package/entity/EntityHelper.js +267 -280
  30. package/entity/EntityIdentifier.d.ts +4 -4
  31. package/entity/EntityIdentifier.js +10 -10
  32. package/entity/EntityLoader.d.ts +72 -98
  33. package/entity/EntityLoader.js +723 -753
  34. package/entity/EntityRepository.d.ts +201 -316
  35. package/entity/EntityRepository.js +213 -213
  36. package/entity/PolymorphicRef.d.ts +5 -5
  37. package/entity/PolymorphicRef.js +10 -10
  38. package/entity/Reference.d.ts +82 -126
  39. package/entity/Reference.js +274 -278
  40. package/entity/WrappedEntity.d.ts +72 -115
  41. package/entity/WrappedEntity.js +166 -168
  42. package/entity/defineEntity.d.ts +636 -1315
  43. package/entity/defineEntity.js +518 -527
  44. package/entity/utils.d.ts +3 -13
  45. package/entity/utils.js +73 -71
  46. package/entity/validators.js +43 -43
  47. package/entity/wrap.js +8 -8
  48. package/enums.d.ts +253 -258
  49. package/enums.js +252 -251
  50. package/errors.d.ts +72 -114
  51. package/errors.js +253 -350
  52. package/events/EventManager.d.ts +14 -26
  53. package/events/EventManager.js +77 -79
  54. package/events/EventSubscriber.d.ts +29 -29
  55. package/events/TransactionEventBroadcaster.d.ts +8 -15
  56. package/events/TransactionEventBroadcaster.js +14 -14
  57. package/exceptions.d.ts +40 -23
  58. package/exceptions.js +52 -35
  59. package/hydration/Hydrator.d.ts +17 -42
  60. package/hydration/Hydrator.js +43 -43
  61. package/hydration/ObjectHydrator.d.ts +17 -50
  62. package/hydration/ObjectHydrator.js +416 -481
  63. package/index.d.ts +2 -116
  64. package/index.js +1 -10
  65. package/logging/DefaultLogger.d.ts +32 -34
  66. package/logging/DefaultLogger.js +86 -86
  67. package/logging/Logger.d.ts +41 -41
  68. package/logging/SimpleLogger.d.ts +11 -13
  69. package/logging/SimpleLogger.js +22 -22
  70. package/logging/colors.d.ts +6 -6
  71. package/logging/colors.js +10 -11
  72. package/logging/inspect.js +7 -7
  73. package/metadata/EntitySchema.d.ts +127 -211
  74. package/metadata/EntitySchema.js +398 -397
  75. package/metadata/MetadataDiscovery.d.ts +114 -114
  76. package/metadata/MetadataDiscovery.js +1870 -1951
  77. package/metadata/MetadataProvider.d.ts +21 -24
  78. package/metadata/MetadataProvider.js +84 -82
  79. package/metadata/MetadataStorage.d.ts +32 -38
  80. package/metadata/MetadataStorage.js +118 -118
  81. package/metadata/MetadataValidator.d.ts +39 -39
  82. package/metadata/MetadataValidator.js +338 -381
  83. package/metadata/discover-entities.d.ts +2 -5
  84. package/metadata/discover-entities.js +37 -35
  85. package/metadata/types.d.ts +531 -615
  86. package/naming-strategy/AbstractNamingStrategy.d.ts +39 -54
  87. package/naming-strategy/AbstractNamingStrategy.js +85 -90
  88. package/naming-strategy/EntityCaseNamingStrategy.d.ts +6 -6
  89. package/naming-strategy/EntityCaseNamingStrategy.js +22 -22
  90. package/naming-strategy/MongoNamingStrategy.d.ts +6 -6
  91. package/naming-strategy/MongoNamingStrategy.js +18 -18
  92. package/naming-strategy/NamingStrategy.d.ts +99 -109
  93. package/naming-strategy/UnderscoreNamingStrategy.d.ts +7 -7
  94. package/naming-strategy/UnderscoreNamingStrategy.js +21 -21
  95. package/not-supported.js +4 -7
  96. package/package.json +1 -1
  97. package/platforms/ExceptionConverter.d.ts +1 -1
  98. package/platforms/ExceptionConverter.js +4 -4
  99. package/platforms/Platform.d.ts +301 -310
  100. package/platforms/Platform.js +640 -663
  101. package/serialization/EntitySerializer.d.ts +26 -49
  102. package/serialization/EntitySerializer.js +218 -224
  103. package/serialization/EntityTransformer.d.ts +6 -10
  104. package/serialization/EntityTransformer.js +217 -219
  105. package/serialization/SerializationContext.d.ts +23 -27
  106. package/serialization/SerializationContext.js +105 -105
  107. package/types/ArrayType.d.ts +8 -8
  108. package/types/ArrayType.js +33 -33
  109. package/types/BigIntType.d.ts +10 -17
  110. package/types/BigIntType.js +37 -37
  111. package/types/BlobType.d.ts +3 -3
  112. package/types/BlobType.js +13 -13
  113. package/types/BooleanType.d.ts +4 -4
  114. package/types/BooleanType.js +12 -12
  115. package/types/CharacterType.d.ts +2 -2
  116. package/types/CharacterType.js +6 -6
  117. package/types/DateTimeType.d.ts +5 -5
  118. package/types/DateTimeType.js +15 -15
  119. package/types/DateType.d.ts +5 -5
  120. package/types/DateType.js +15 -15
  121. package/types/DecimalType.d.ts +7 -7
  122. package/types/DecimalType.js +26 -26
  123. package/types/DoubleType.d.ts +3 -3
  124. package/types/DoubleType.js +12 -12
  125. package/types/EnumArrayType.d.ts +5 -5
  126. package/types/EnumArrayType.js +24 -24
  127. package/types/EnumType.d.ts +3 -3
  128. package/types/EnumType.js +11 -11
  129. package/types/FloatType.d.ts +3 -3
  130. package/types/FloatType.js +9 -9
  131. package/types/IntegerType.d.ts +3 -3
  132. package/types/IntegerType.js +9 -9
  133. package/types/IntervalType.d.ts +4 -4
  134. package/types/IntervalType.js +12 -12
  135. package/types/JsonType.d.ts +8 -8
  136. package/types/JsonType.js +32 -32
  137. package/types/MediumIntType.d.ts +1 -1
  138. package/types/MediumIntType.js +3 -3
  139. package/types/SmallIntType.d.ts +3 -3
  140. package/types/SmallIntType.js +9 -9
  141. package/types/StringType.d.ts +4 -4
  142. package/types/StringType.js +12 -12
  143. package/types/TextType.d.ts +3 -3
  144. package/types/TextType.js +9 -9
  145. package/types/TimeType.d.ts +5 -5
  146. package/types/TimeType.js +17 -17
  147. package/types/TinyIntType.d.ts +3 -3
  148. package/types/TinyIntType.js +10 -10
  149. package/types/Type.d.ts +79 -83
  150. package/types/Type.js +82 -82
  151. package/types/Uint8ArrayType.d.ts +4 -4
  152. package/types/Uint8ArrayType.js +21 -21
  153. package/types/UnknownType.d.ts +4 -4
  154. package/types/UnknownType.js +12 -12
  155. package/types/UuidType.d.ts +5 -5
  156. package/types/UuidType.js +19 -19
  157. package/types/index.d.ts +49 -75
  158. package/types/index.js +26 -52
  159. package/typings.d.ts +737 -1250
  160. package/typings.js +231 -244
  161. package/unit-of-work/ChangeSet.d.ts +26 -26
  162. package/unit-of-work/ChangeSet.js +56 -56
  163. package/unit-of-work/ChangeSetComputer.d.ts +12 -12
  164. package/unit-of-work/ChangeSetComputer.js +170 -178
  165. package/unit-of-work/ChangeSetPersister.d.ts +44 -63
  166. package/unit-of-work/ChangeSetPersister.js +421 -442
  167. package/unit-of-work/CommitOrderCalculator.d.ts +40 -40
  168. package/unit-of-work/CommitOrderCalculator.js +88 -89
  169. package/unit-of-work/IdentityMap.d.ts +31 -31
  170. package/unit-of-work/IdentityMap.js +105 -105
  171. package/unit-of-work/UnitOfWork.d.ts +141 -181
  172. package/unit-of-work/UnitOfWork.js +1183 -1200
  173. package/utils/AbstractMigrator.d.ts +91 -111
  174. package/utils/AbstractMigrator.js +275 -275
  175. package/utils/AbstractSchemaGenerator.d.ts +34 -43
  176. package/utils/AbstractSchemaGenerator.js +122 -121
  177. package/utils/AsyncContext.d.ts +3 -3
  178. package/utils/AsyncContext.js +35 -34
  179. package/utils/Configuration.d.ts +808 -852
  180. package/utils/Configuration.js +344 -359
  181. package/utils/Cursor.d.ts +22 -40
  182. package/utils/Cursor.js +127 -135
  183. package/utils/DataloaderUtils.d.ts +43 -58
  184. package/utils/DataloaderUtils.js +198 -203
  185. package/utils/EntityComparator.d.ts +81 -98
  186. package/utils/EntityComparator.js +732 -828
  187. package/utils/NullHighlighter.d.ts +1 -1
  188. package/utils/NullHighlighter.js +3 -3
  189. package/utils/QueryHelper.d.ts +51 -79
  190. package/utils/QueryHelper.js +361 -372
  191. package/utils/RawQueryFragment.d.ts +34 -50
  192. package/utils/RawQueryFragment.js +105 -107
  193. package/utils/RequestContext.d.ts +32 -32
  194. package/utils/RequestContext.js +53 -52
  195. package/utils/TransactionContext.d.ts +16 -16
  196. package/utils/TransactionContext.js +27 -27
  197. package/utils/TransactionManager.d.ts +58 -58
  198. package/utils/TransactionManager.js +197 -199
  199. package/utils/Utils.d.ts +145 -204
  200. package/utils/Utils.js +812 -812
  201. package/utils/clone.js +113 -104
  202. package/utils/env-vars.js +88 -90
  203. package/utils/fs-utils.d.ts +15 -15
  204. package/utils/fs-utils.js +181 -180
  205. package/utils/upsert-utils.d.ts +5 -20
  206. package/utils/upsert-utils.js +116 -114
@@ -4,231 +4,229 @@ import { ReferenceKind } from '../enums.js';
4
4
  import { SerializationContext } from './SerializationContext.js';
5
5
  import { isRaw } from '../utils/RawQueryFragment.js';
6
6
  function isVisible(meta, propName, ignoreFields = []) {
7
- const prop = meta.properties[propName];
8
- const visible = prop && !prop.hidden;
9
- const prefixed = prop && !prop.primary && !prop.accessor && propName.startsWith('_'); // ignore prefixed properties, if it's not a PK
10
- return visible && !prefixed && !ignoreFields.includes(propName);
7
+ const prop = meta.properties[propName];
8
+ const visible = prop && !prop.hidden;
9
+ const prefixed = prop && !prop.primary && !prop.accessor && propName.startsWith('_'); // ignore prefixed properties, if it's not a PK
10
+ return visible && !prefixed && !ignoreFields.includes(propName);
11
11
  }
12
12
  /** Converts entity instances to plain objects via `toObject()`, respecting populate hints, hidden fields, and serialization context. */
13
13
  export class EntityTransformer {
14
- /** Converts an entity to a plain object, respecting populate hints, hidden fields, and custom serializers. */
15
- static toObject(entity, ignoreFields = [], raw = false) {
16
- if (!Array.isArray(ignoreFields)) {
17
- ignoreFields = [];
18
- }
19
- const wrapped = helper(entity);
20
- let contextCreated = false;
21
- if (!wrapped) {
22
- return entity;
23
- }
24
- if (!wrapped.__serializationContext.root) {
25
- const root = new SerializationContext(
26
- wrapped.__serializationContext.populate,
27
- wrapped.__serializationContext.fields,
28
- wrapped.__serializationContext.exclude,
29
- );
30
- SerializationContext.propagate(root, entity, isVisible);
31
- contextCreated = true;
32
- }
33
- const root = wrapped.__serializationContext.root;
34
- const meta = wrapped.__meta;
35
- const ret = {};
36
- const props = new Set();
37
- if (meta.serializedPrimaryKey && !meta.compositePK) {
38
- props.add(meta.serializedPrimaryKey);
39
- } else {
40
- meta.primaryKeys.forEach(pk => props.add(pk));
41
- }
42
- if (wrapped.isInitialized() || !wrapped.hasPrimaryKey()) {
43
- const entityKeys = new Set(Object.keys(entity));
44
- for (const prop of meta.props) {
45
- if (entityKeys.has(prop.name) || (prop.getter && prop.accessor === prop.name)) {
46
- props.add(prop.name);
47
- }
48
- }
49
- for (const key of entityKeys) {
50
- if (!meta.properties[key]) {
51
- props.add(key);
52
- }
53
- }
54
- }
55
- const visited = root.visited.has(entity);
56
- const includePrimaryKeys = wrapped.__config.get('serialization').includePrimaryKeys;
57
- if (!visited) {
58
- root.visited.add(entity);
59
- }
60
- for (const prop of props) {
61
- const visible = raw ? meta.properties[prop] : isVisible(meta, prop, ignoreFields);
62
- if (!visible) {
63
- continue;
64
- }
65
- const populated = root.isMarkedAsPopulated(meta.class, prop);
66
- if (!raw) {
67
- const partiallyLoaded = root.isPartiallyLoaded(meta.class, prop);
68
- const isPrimary = includePrimaryKeys && meta.properties[prop].primary;
69
- if (!partiallyLoaded && !populated && !isPrimary) {
70
- continue;
71
- }
72
- if (root.isExcluded(meta.class, prop) && !populated) {
73
- continue;
74
- }
75
- }
76
- const cycle = root.visit(meta.class, prop);
77
- if (cycle && visited) {
78
- continue;
79
- }
80
- const val = EntityTransformer.processProperty(prop, entity, raw, populated);
81
- if (!cycle) {
82
- root.leave(meta.class, prop);
83
- }
84
- if (isRaw(val)) {
85
- throw new Error(`Trying to serialize raw SQL fragment: '${val.sql}'`);
86
- }
87
- if (typeof val === 'undefined') {
88
- continue;
89
- }
90
- ret[this.propertyName(meta, prop, raw)] = val;
91
- }
92
- if (!wrapped.isInitialized() && wrapped.hasPrimaryKey()) {
93
- return ret;
94
- }
95
- for (const prop of meta.getterProps) {
96
- // decorated get methods
97
- if (prop.getterName != null) {
98
- const visible = !prop.hidden && entity[prop.getterName] instanceof Function;
99
- const populated = root.isMarkedAsPopulated(meta.class, prop.name);
100
- if (visible) {
101
- ret[this.propertyName(meta, prop.name, raw)] = this.processProperty(prop.getterName, entity, raw, populated);
102
- }
103
- } else {
104
- // decorated getters
105
- const visible = !prop.hidden && typeof entity[prop.name] !== 'undefined';
106
- const populated = root.isMarkedAsPopulated(meta.class, prop.name);
107
- if (visible) {
108
- ret[this.propertyName(meta, prop.name, raw)] = this.processProperty(prop.name, entity, raw, populated);
109
- }
110
- }
111
- }
112
- if (contextCreated) {
113
- root.close();
114
- }
115
- return ret;
116
- }
117
- static propertyName(meta, prop, raw) {
118
- if (raw) {
119
- return prop;
120
- }
121
- if (meta.properties[prop].serializedName) {
122
- return meta.properties[prop].serializedName;
123
- }
124
- if (meta.properties[prop].primary && meta.serializedPrimaryKey) {
125
- return meta.serializedPrimaryKey;
126
- }
127
- return prop;
128
- }
129
- static processProperty(prop, entity, raw, populated) {
130
- const wrapped = helper(entity);
131
- const property = wrapped.__meta.properties[prop] ?? { name: prop };
132
- const serializer = property?.serializer;
133
- const value = entity[prop];
134
- // getter method
135
- if (entity[prop] instanceof Function) {
136
- const returnValue = entity[prop]();
137
- if (serializer && !raw) {
138
- return serializer(returnValue);
139
- }
140
- return returnValue;
141
- }
142
- if (serializer && !raw) {
143
- return serializer(value);
144
- }
145
- if (Utils.isCollection(value)) {
146
- return EntityTransformer.processCollection(property, entity, raw, populated);
147
- }
148
- if (Utils.isEntity(value, true)) {
149
- return EntityTransformer.processEntity(property, entity, wrapped.__platform, raw, populated);
150
- }
151
- if (Utils.isScalarReference(value)) {
152
- return value.unwrap();
153
- }
154
- if (property.kind === ReferenceKind.EMBEDDED) {
155
- if (Array.isArray(value)) {
156
- return value.map(item => {
157
- const wrapped = item && helper(item);
158
- return wrapped ? wrapped.toJSON() : item;
159
- });
160
- }
161
- const wrapped = value && helper(value);
162
- return wrapped ? wrapped.toJSON() : value;
163
- }
164
- const customType = property?.customType;
165
- if (customType) {
166
- return customType.toJSON(value, wrapped.__platform);
167
- }
168
- if (property?.primary) {
169
- return wrapped.__platform.normalizePrimaryKey(value);
170
- }
171
- return value;
172
- }
173
- static processEntity(prop, entity, platform, raw, populated) {
174
- const child = entity[prop.name];
175
- const wrapped = helper(child);
176
- const meta = wrapped.__meta;
177
- const visible = meta.primaryKeys.filter(prop => isVisible(meta, prop));
178
- if (raw && wrapped.isInitialized() && child !== entity) {
179
- return wrapped.toPOJO();
180
- }
181
- function isPopulated() {
182
- if (wrapped.__populated != null) {
183
- return wrapped.__populated;
184
- }
185
- if (populated) {
186
- return true;
187
- }
188
- return !wrapped.__managed;
189
- }
190
- if (wrapped.isInitialized() && isPopulated() && child !== entity) {
191
- return wrap(child).toJSON();
192
- }
193
- let pk = wrapped.getPrimaryKey();
194
- if (prop.customType) {
195
- pk = prop.customType.toJSON(pk, wrapped.__platform);
196
- }
197
- if (wrapped.__config.get('serialization').forceObject) {
198
- return Utils.primaryKeyToObject(meta, pk, visible);
199
- }
200
- if (Utils.isPlainObject(pk)) {
201
- const pruned = Utils.primaryKeyToObject(meta, pk, visible);
202
- if (visible.length === 1) {
203
- return platform.normalizePrimaryKey(pruned[visible[0]]);
204
- }
205
- return pruned;
206
- }
207
- return platform.normalizePrimaryKey(pk);
208
- }
209
- static processCollection(prop, entity, raw, populated) {
210
- const col = entity[prop.name];
211
- if (raw && col.isInitialized(true)) {
212
- return col.map(item => helper(item).toPOJO());
213
- }
214
- if (col.shouldPopulate(populated)) {
215
- return col.toArray();
14
+ /** Converts an entity to a plain object, respecting populate hints, hidden fields, and custom serializers. */
15
+ static toObject(entity, ignoreFields = [], raw = false) {
16
+ if (!Array.isArray(ignoreFields)) {
17
+ ignoreFields = [];
18
+ }
19
+ const wrapped = helper(entity);
20
+ let contextCreated = false;
21
+ if (!wrapped) {
22
+ return entity;
23
+ }
24
+ if (!wrapped.__serializationContext.root) {
25
+ const root = new SerializationContext(wrapped.__serializationContext.populate, wrapped.__serializationContext.fields, wrapped.__serializationContext.exclude);
26
+ SerializationContext.propagate(root, entity, isVisible);
27
+ contextCreated = true;
28
+ }
29
+ const root = wrapped.__serializationContext.root;
30
+ const meta = wrapped.__meta;
31
+ const ret = {};
32
+ const props = new Set();
33
+ if (meta.serializedPrimaryKey && !meta.compositePK) {
34
+ props.add(meta.serializedPrimaryKey);
35
+ }
36
+ else {
37
+ meta.primaryKeys.forEach(pk => props.add(pk));
38
+ }
39
+ if (wrapped.isInitialized() || !wrapped.hasPrimaryKey()) {
40
+ const entityKeys = new Set(Object.keys(entity));
41
+ for (const prop of meta.props) {
42
+ if (entityKeys.has(prop.name) || (prop.getter && prop.accessor === prop.name)) {
43
+ props.add(prop.name);
44
+ }
45
+ }
46
+ for (const key of entityKeys) {
47
+ if (!meta.properties[key]) {
48
+ props.add(key);
49
+ }
50
+ }
51
+ }
52
+ const visited = root.visited.has(entity);
53
+ const includePrimaryKeys = wrapped.__config.get('serialization').includePrimaryKeys;
54
+ if (!visited) {
55
+ root.visited.add(entity);
56
+ }
57
+ for (const prop of props) {
58
+ const visible = raw ? meta.properties[prop] : isVisible(meta, prop, ignoreFields);
59
+ if (!visible) {
60
+ continue;
61
+ }
62
+ const populated = root.isMarkedAsPopulated(meta.class, prop);
63
+ if (!raw) {
64
+ const partiallyLoaded = root.isPartiallyLoaded(meta.class, prop);
65
+ const isPrimary = includePrimaryKeys && meta.properties[prop].primary;
66
+ if (!partiallyLoaded && !populated && !isPrimary) {
67
+ continue;
68
+ }
69
+ if (root.isExcluded(meta.class, prop) && !populated) {
70
+ continue;
71
+ }
72
+ }
73
+ const cycle = root.visit(meta.class, prop);
74
+ if (cycle && visited) {
75
+ continue;
76
+ }
77
+ const val = EntityTransformer.processProperty(prop, entity, raw, populated);
78
+ if (!cycle) {
79
+ root.leave(meta.class, prop);
80
+ }
81
+ if (isRaw(val)) {
82
+ throw new Error(`Trying to serialize raw SQL fragment: '${val.sql}'`);
83
+ }
84
+ if (typeof val === 'undefined') {
85
+ continue;
86
+ }
87
+ ret[this.propertyName(meta, prop, raw)] = val;
88
+ }
89
+ if (!wrapped.isInitialized() && wrapped.hasPrimaryKey()) {
90
+ return ret;
91
+ }
92
+ for (const prop of meta.getterProps) {
93
+ // decorated get methods
94
+ if (prop.getterName != null) {
95
+ const visible = !prop.hidden && entity[prop.getterName] instanceof Function;
96
+ const populated = root.isMarkedAsPopulated(meta.class, prop.name);
97
+ if (visible) {
98
+ ret[this.propertyName(meta, prop.name, raw)] = this.processProperty(prop.getterName, entity, raw, populated);
99
+ }
100
+ }
101
+ else {
102
+ // decorated getters
103
+ const visible = !prop.hidden && typeof entity[prop.name] !== 'undefined';
104
+ const populated = root.isMarkedAsPopulated(meta.class, prop.name);
105
+ if (visible) {
106
+ ret[this.propertyName(meta, prop.name, raw)] = this.processProperty(prop.name, entity, raw, populated);
107
+ }
108
+ }
109
+ }
110
+ if (contextCreated) {
111
+ root.close();
112
+ }
113
+ return ret;
216
114
  }
217
- if (col.isInitialized()) {
218
- const wrapped = helper(entity);
219
- const forceObject = wrapped.__config.get('serialization').forceObject;
220
- return col.map(item => {
221
- const wrapped = helper(item);
222
- const pk = wrapped.getPrimaryKey();
115
+ static propertyName(meta, prop, raw) {
116
+ if (raw) {
117
+ return prop;
118
+ }
119
+ if (meta.properties[prop].serializedName) {
120
+ return meta.properties[prop].serializedName;
121
+ }
122
+ if (meta.properties[prop].primary && meta.serializedPrimaryKey) {
123
+ return meta.serializedPrimaryKey;
124
+ }
125
+ return prop;
126
+ }
127
+ static processProperty(prop, entity, raw, populated) {
128
+ const wrapped = helper(entity);
129
+ const property = wrapped.__meta.properties[prop] ?? { name: prop };
130
+ const serializer = property?.serializer;
131
+ const value = entity[prop];
132
+ // getter method
133
+ if (entity[prop] instanceof Function) {
134
+ const returnValue = entity[prop]();
135
+ if (serializer && !raw) {
136
+ return serializer(returnValue);
137
+ }
138
+ return returnValue;
139
+ }
140
+ if (serializer && !raw) {
141
+ return serializer(value);
142
+ }
143
+ if (Utils.isCollection(value)) {
144
+ return EntityTransformer.processCollection(property, entity, raw, populated);
145
+ }
146
+ if (Utils.isEntity(value, true)) {
147
+ return EntityTransformer.processEntity(property, entity, wrapped.__platform, raw, populated);
148
+ }
149
+ if (Utils.isScalarReference(value)) {
150
+ return value.unwrap();
151
+ }
152
+ if (property.kind === ReferenceKind.EMBEDDED) {
153
+ if (Array.isArray(value)) {
154
+ return value.map(item => {
155
+ const wrapped = item && helper(item);
156
+ return wrapped ? wrapped.toJSON() : item;
157
+ });
158
+ }
159
+ const wrapped = value && helper(value);
160
+ return wrapped ? wrapped.toJSON() : value;
161
+ }
162
+ const customType = property?.customType;
163
+ if (customType) {
164
+ return customType.toJSON(value, wrapped.__platform);
165
+ }
166
+ if (property?.primary) {
167
+ return wrapped.__platform.normalizePrimaryKey(value);
168
+ }
169
+ return value;
170
+ }
171
+ static processEntity(prop, entity, platform, raw, populated) {
172
+ const child = entity[prop.name];
173
+ const wrapped = helper(child);
174
+ const meta = wrapped.__meta;
175
+ const visible = meta.primaryKeys.filter(prop => isVisible(meta, prop));
176
+ if (raw && wrapped.isInitialized() && child !== entity) {
177
+ return wrapped.toPOJO();
178
+ }
179
+ function isPopulated() {
180
+ if (wrapped.__populated != null) {
181
+ return wrapped.__populated;
182
+ }
183
+ if (populated) {
184
+ return true;
185
+ }
186
+ return !wrapped.__managed;
187
+ }
188
+ if (wrapped.isInitialized() && isPopulated() && child !== entity) {
189
+ return wrap(child).toJSON();
190
+ }
191
+ let pk = wrapped.getPrimaryKey();
223
192
  if (prop.customType) {
224
- return prop.customType.toJSON(pk, wrapped.__platform);
193
+ pk = prop.customType.toJSON(pk, wrapped.__platform);
194
+ }
195
+ if (wrapped.__config.get('serialization').forceObject) {
196
+ return Utils.primaryKeyToObject(meta, pk, visible);
197
+ }
198
+ if (Utils.isPlainObject(pk)) {
199
+ const pruned = Utils.primaryKeyToObject(meta, pk, visible);
200
+ if (visible.length === 1) {
201
+ return platform.normalizePrimaryKey(pruned[visible[0]]);
202
+ }
203
+ return pruned;
204
+ }
205
+ return platform.normalizePrimaryKey(pk);
206
+ }
207
+ static processCollection(prop, entity, raw, populated) {
208
+ const col = entity[prop.name];
209
+ if (raw && col.isInitialized(true)) {
210
+ return col.map(item => helper(item).toPOJO());
211
+ }
212
+ if (col.shouldPopulate(populated)) {
213
+ return col.toArray();
225
214
  }
226
- if (forceObject) {
227
- return Utils.primaryKeyToObject(wrapped.__meta, pk);
215
+ if (col.isInitialized()) {
216
+ const wrapped = helper(entity);
217
+ const forceObject = wrapped.__config.get('serialization').forceObject;
218
+ return col.map(item => {
219
+ const wrapped = helper(item);
220
+ const pk = wrapped.getPrimaryKey();
221
+ if (prop.customType) {
222
+ return prop.customType.toJSON(pk, wrapped.__platform);
223
+ }
224
+ if (forceObject) {
225
+ return Utils.primaryKeyToObject(wrapped.__meta, pk);
226
+ }
227
+ return pk;
228
+ });
228
229
  }
229
- return pk;
230
- });
230
+ return undefined;
231
231
  }
232
- return undefined;
233
- }
234
232
  }
@@ -5,31 +5,27 @@ import type { AnyEntity, EntityMetadata, EntityName, PopulateOptions } from '../
5
5
  * are defined in populate hint). If not, we proceed and call `leave` afterwards.
6
6
  */
7
7
  export declare class SerializationContext<T extends object> {
8
- #private;
9
- readonly path: [EntityName, string][];
10
- readonly visited: Set<AnyEntity>;
11
- constructor(populate?: PopulateOptions<T>[], fields?: Set<string>, exclude?: readonly string[]);
12
- /**
13
- * Returns true when there is a cycle detected.
14
- */
15
- visit(entityName: EntityName, prop: string): boolean;
16
- /** Removes the last entry from the visit path after processing a property. */
17
- leave(entityName: EntityName, prop: string): void;
18
- /** Cleans up the serialization context by removing root references from all tracked entities. */
19
- close(): void;
20
- /**
21
- * When initializing new context, we need to propagate it to the whole entity graph recursively.
22
- */
23
- static propagate(
24
- root: SerializationContext<any>,
25
- entity: AnyEntity,
26
- isVisible: (meta: EntityMetadata, prop: string) => boolean,
27
- ): void;
28
- /** Checks whether a property is explicitly listed in the populate hints for the current path. */
29
- isMarkedAsPopulated(entityName: EntityName, prop: string): boolean;
30
- /** Checks whether a property is excluded from serialization via the exclude list. */
31
- isExcluded(entityName: EntityName, prop: string): boolean;
32
- /** Checks whether a property is included in the partial fields selection for the current path. */
33
- isPartiallyLoaded(entityName: EntityName, prop: string): boolean;
34
- private register;
8
+ #private;
9
+ readonly path: [EntityName, string][];
10
+ readonly visited: Set<AnyEntity>;
11
+ constructor(populate?: PopulateOptions<T>[], fields?: Set<string>, exclude?: readonly string[]);
12
+ /**
13
+ * Returns true when there is a cycle detected.
14
+ */
15
+ visit(entityName: EntityName, prop: string): boolean;
16
+ /** Removes the last entry from the visit path after processing a property. */
17
+ leave(entityName: EntityName, prop: string): void;
18
+ /** Cleans up the serialization context by removing root references from all tracked entities. */
19
+ close(): void;
20
+ /**
21
+ * When initializing new context, we need to propagate it to the whole entity graph recursively.
22
+ */
23
+ static propagate(root: SerializationContext<any>, entity: AnyEntity, isVisible: (meta: EntityMetadata, prop: string) => boolean): void;
24
+ /** Checks whether a property is explicitly listed in the populate hints for the current path. */
25
+ isMarkedAsPopulated(entityName: EntityName, prop: string): boolean;
26
+ /** Checks whether a property is excluded from serialization via the exclude list. */
27
+ isExcluded(entityName: EntityName, prop: string): boolean;
28
+ /** Checks whether a property is included in the partial fields selection for the current path. */
29
+ isPartiallyLoaded(entityName: EntityName, prop: string): boolean;
30
+ private register;
35
31
  }