@mikro-orm/core 7.0.4-dev.8 → 7.0.4

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 +884 -583
  2. package/EntityManager.js +1922 -1895
  3. package/MikroORM.d.ts +103 -74
  4. package/MikroORM.js +178 -179
  5. package/README.md +1 -1
  6. package/cache/CacheAdapter.d.ts +36 -36
  7. package/cache/FileCacheAdapter.d.ts +30 -24
  8. package/cache/FileCacheAdapter.js +80 -78
  9. package/cache/GeneratedCacheAdapter.d.ts +18 -20
  10. package/cache/GeneratedCacheAdapter.js +30 -30
  11. package/cache/MemoryCacheAdapter.d.ts +18 -20
  12. package/cache/MemoryCacheAdapter.js +35 -36
  13. package/cache/NullCacheAdapter.d.ts +16 -16
  14. package/cache/NullCacheAdapter.js +24 -24
  15. package/connections/Connection.d.ts +95 -84
  16. package/connections/Connection.js +165 -168
  17. package/drivers/DatabaseDriver.d.ts +186 -80
  18. package/drivers/DatabaseDriver.js +450 -443
  19. package/drivers/IDatabaseDriver.d.ts +440 -301
  20. package/entity/BaseEntity.d.ts +120 -83
  21. package/entity/BaseEntity.js +43 -43
  22. package/entity/Collection.d.ts +212 -179
  23. package/entity/Collection.js +727 -721
  24. package/entity/EntityAssigner.d.ts +88 -77
  25. package/entity/EntityAssigner.js +231 -230
  26. package/entity/EntityFactory.d.ts +66 -54
  27. package/entity/EntityFactory.js +425 -383
  28. package/entity/EntityHelper.d.ts +34 -22
  29. package/entity/EntityHelper.js +280 -267
  30. package/entity/EntityIdentifier.d.ts +4 -4
  31. package/entity/EntityIdentifier.js +10 -10
  32. package/entity/EntityLoader.d.ts +98 -72
  33. package/entity/EntityLoader.js +753 -723
  34. package/entity/EntityRepository.d.ts +316 -201
  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 +126 -82
  39. package/entity/Reference.js +278 -274
  40. package/entity/WrappedEntity.d.ts +115 -72
  41. package/entity/WrappedEntity.js +168 -166
  42. package/entity/defineEntity.d.ts +1315 -636
  43. package/entity/defineEntity.js +527 -518
  44. package/entity/utils.d.ts +13 -3
  45. package/entity/utils.js +71 -73
  46. package/entity/validators.js +43 -43
  47. package/entity/wrap.js +8 -8
  48. package/enums.d.ts +258 -253
  49. package/enums.js +251 -252
  50. package/errors.d.ts +114 -72
  51. package/errors.js +350 -253
  52. package/events/EventManager.d.ts +26 -14
  53. package/events/EventManager.js +79 -77
  54. package/events/EventSubscriber.d.ts +29 -29
  55. package/events/TransactionEventBroadcaster.d.ts +15 -8
  56. package/events/TransactionEventBroadcaster.js +14 -14
  57. package/exceptions.d.ts +23 -40
  58. package/exceptions.js +35 -52
  59. package/hydration/Hydrator.d.ts +42 -17
  60. package/hydration/Hydrator.js +43 -43
  61. package/hydration/ObjectHydrator.d.ts +50 -17
  62. package/hydration/ObjectHydrator.js +481 -416
  63. package/index.d.ts +116 -2
  64. package/index.js +10 -1
  65. package/logging/DefaultLogger.d.ts +34 -32
  66. package/logging/DefaultLogger.js +86 -86
  67. package/logging/Logger.d.ts +41 -41
  68. package/logging/SimpleLogger.d.ts +13 -11
  69. package/logging/SimpleLogger.js +22 -22
  70. package/logging/colors.d.ts +6 -6
  71. package/logging/colors.js +11 -10
  72. package/logging/inspect.js +7 -7
  73. package/metadata/EntitySchema.d.ts +211 -127
  74. package/metadata/EntitySchema.js +397 -398
  75. package/metadata/MetadataDiscovery.d.ts +114 -114
  76. package/metadata/MetadataDiscovery.js +1951 -1863
  77. package/metadata/MetadataProvider.d.ts +24 -21
  78. package/metadata/MetadataProvider.js +82 -84
  79. package/metadata/MetadataStorage.d.ts +38 -32
  80. package/metadata/MetadataStorage.js +118 -118
  81. package/metadata/MetadataValidator.d.ts +39 -39
  82. package/metadata/MetadataValidator.js +381 -338
  83. package/metadata/discover-entities.d.ts +5 -2
  84. package/metadata/discover-entities.js +35 -27
  85. package/metadata/types.d.ts +615 -531
  86. package/naming-strategy/AbstractNamingStrategy.d.ts +54 -39
  87. package/naming-strategy/AbstractNamingStrategy.js +90 -85
  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 +109 -99
  93. package/naming-strategy/UnderscoreNamingStrategy.d.ts +7 -7
  94. package/naming-strategy/UnderscoreNamingStrategy.js +21 -21
  95. package/not-supported.js +7 -4
  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 +310 -299
  100. package/platforms/Platform.js +663 -636
  101. package/serialization/EntitySerializer.d.ts +49 -26
  102. package/serialization/EntitySerializer.js +224 -218
  103. package/serialization/EntityTransformer.d.ts +10 -6
  104. package/serialization/EntityTransformer.js +219 -217
  105. package/serialization/SerializationContext.d.ts +27 -23
  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 +17 -10
  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 +83 -79
  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 +75 -49
  158. package/types/index.js +52 -26
  159. package/typings.d.ts +1250 -737
  160. package/typings.js +244 -231
  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 +178 -170
  165. package/unit-of-work/ChangeSetPersister.d.ts +63 -44
  166. package/unit-of-work/ChangeSetPersister.js +442 -421
  167. package/unit-of-work/CommitOrderCalculator.d.ts +40 -40
  168. package/unit-of-work/CommitOrderCalculator.js +89 -88
  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 +181 -141
  172. package/unit-of-work/UnitOfWork.js +1200 -1183
  173. package/utils/AbstractMigrator.d.ts +111 -91
  174. package/utils/AbstractMigrator.js +275 -275
  175. package/utils/AbstractSchemaGenerator.d.ts +43 -34
  176. package/utils/AbstractSchemaGenerator.js +121 -122
  177. package/utils/AsyncContext.d.ts +3 -3
  178. package/utils/AsyncContext.js +34 -35
  179. package/utils/Configuration.d.ts +852 -808
  180. package/utils/Configuration.js +359 -344
  181. package/utils/Cursor.d.ts +40 -22
  182. package/utils/Cursor.js +135 -127
  183. package/utils/DataloaderUtils.d.ts +58 -43
  184. package/utils/DataloaderUtils.js +203 -198
  185. package/utils/EntityComparator.d.ts +98 -81
  186. package/utils/EntityComparator.js +828 -728
  187. package/utils/NullHighlighter.d.ts +1 -1
  188. package/utils/NullHighlighter.js +3 -3
  189. package/utils/QueryHelper.d.ts +79 -51
  190. package/utils/QueryHelper.js +372 -361
  191. package/utils/RawQueryFragment.d.ts +50 -34
  192. package/utils/RawQueryFragment.js +107 -105
  193. package/utils/RequestContext.d.ts +32 -32
  194. package/utils/RequestContext.js +52 -53
  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 +199 -197
  199. package/utils/Utils.d.ts +204 -145
  200. package/utils/Utils.js +812 -810
  201. package/utils/clone.js +104 -113
  202. package/utils/env-vars.js +90 -88
  203. package/utils/fs-utils.d.ts +15 -15
  204. package/utils/fs-utils.js +180 -181
  205. package/utils/upsert-utils.d.ts +20 -5
  206. package/utils/upsert-utils.js +114 -116
@@ -4,229 +4,231 @@ 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(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;
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 = [];
114
18
  }
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();
192
- if (prop.customType) {
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);
19
+ const wrapped = helper(entity);
20
+ let contextCreated = false;
21
+ if (!wrapped) {
22
+ return entity;
206
23
  }
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();
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();
216
+ }
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();
223
+ if (prop.customType) {
224
+ return prop.customType.toJSON(pk, wrapped.__platform);
214
225
  }
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
- });
226
+ if (forceObject) {
227
+ return Utils.primaryKeyToObject(wrapped.__meta, pk);
229
228
  }
230
- return undefined;
229
+ return pk;
230
+ });
231
231
  }
232
+ return undefined;
233
+ }
232
234
  }
@@ -5,27 +5,31 @@ 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(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;
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;
31
35
  }