@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
@@ -2,85 +2,96 @@ import type { EntityManager } from '../EntityManager.js';
2
2
  import type { EntityData, EntityDTO, EntityProperty, FromEntityType, IsSubset, MergeSelected } from '../typings.js';
3
3
  /** Handles assigning data to entities, resolving relations, and propagating changes. */
4
4
  export declare class EntityAssigner {
5
- /** Assigns the given data to the entity, resolving relations and handling custom types. */
6
- static assign<Entity extends object, Naked extends FromEntityType<Entity> = FromEntityType<Entity>, Convert extends boolean = false, Data extends EntityData<Naked, Convert> | Partial<EntityDTO<Naked>> = EntityData<Naked, Convert> | Partial<EntityDTO<Naked>>>(entity: Entity, data: Data & IsSubset<EntityData<Naked, Convert>, Data>, options?: AssignOptions<Convert>): MergeSelected<Entity, Naked, keyof Data & string>;
7
- private static assignProperty;
8
- /**
9
- * auto-wire 1:1 inverse side with owner as in no-sql drivers it can't be joined
10
- * also makes sure the link is bidirectional when creating new entities from nested structures
11
- * @internal
12
- */
13
- static autoWireOneToOne<T extends object, O extends object>(prop: EntityProperty<O, T>, entity: O): void;
14
- private static validateEM;
15
- private static assignReference;
16
- private static assignCollection;
17
- private static assignEmbeddable;
18
- private static createCollectionItem;
5
+ /** Assigns the given data to the entity, resolving relations and handling custom types. */
6
+ static assign<
7
+ Entity extends object,
8
+ Naked extends FromEntityType<Entity> = FromEntityType<Entity>,
9
+ Convert extends boolean = false,
10
+ Data extends EntityData<Naked, Convert> | Partial<EntityDTO<Naked>> =
11
+ | EntityData<Naked, Convert>
12
+ | Partial<EntityDTO<Naked>>,
13
+ >(
14
+ entity: Entity,
15
+ data: Data & IsSubset<EntityData<Naked, Convert>, Data>,
16
+ options?: AssignOptions<Convert>,
17
+ ): MergeSelected<Entity, Naked, keyof Data & string>;
18
+ private static assignProperty;
19
+ /**
20
+ * auto-wire 1:1 inverse side with owner as in no-sql drivers it can't be joined
21
+ * also makes sure the link is bidirectional when creating new entities from nested structures
22
+ * @internal
23
+ */
24
+ static autoWireOneToOne<T extends object, O extends object>(prop: EntityProperty<O, T>, entity: O): void;
25
+ private static validateEM;
26
+ private static assignReference;
27
+ private static assignCollection;
28
+ private static assignEmbeddable;
29
+ private static createCollectionItem;
19
30
  }
20
31
  export declare const assign: typeof EntityAssigner.assign;
21
32
  /** Options controlling how data is assigned to an entity via `assign()`. */
22
33
  export interface AssignOptions<Convert extends boolean> {
23
- /**
24
- * Allows disabling processing of nested relations. When disabled, an object payload in place of a relation always
25
- * results in an `INSERT` query. To assign a value of the relation, use the foreign key instead of an object.
26
- * Defaults to `true`.
27
- */
28
- updateNestedEntities?: boolean;
29
- /**
30
- * When assigning to a relation property with object payload and `updateNestedEntities` enabled (default), you can
31
- * control how a payload without a primary key is handled. By default, it is considered as a new object, resulting
32
- * in an `INSERT` query. Use `updateByPrimaryKey: false` to allow assigning the data on an existing relation instead.
33
- * Defaults to `true`.
34
- */
35
- updateByPrimaryKey?: boolean;
36
- /**
37
- * When you have some properties in the payload that are not represented by an entity property mapping, you can skip
38
- * such unknown properties via `onlyProperties: true`. Defaults to `false`.
39
- */
40
- onlyProperties?: boolean;
41
- /**
42
- * With `onlyOwnProperties` enabled, inverse sides of to-many relations are skipped, and payloads of other relations are converted
43
- * to foreign keys. Defaults to `false`.
44
- */
45
- onlyOwnProperties?: boolean;
46
- /**
47
- * With `ignoreUndefined` enabled, `undefined` properties passed in the payload are skipped. Defaults to `false`.
48
- */
49
- ignoreUndefined?: boolean;
50
- /**
51
- * `assign` excepts runtime values for properties using custom types. To be able to assign raw database values, you
52
- * can enable the `convertCustomTypes` option. Defaults to `false`.
53
- */
54
- convertCustomTypes?: Convert;
55
- /**
56
- * When assigning to a JSON property, the value is replaced. Use `mergeObjectProperties: true` to enable deep merging
57
- * of the payload with the existing value. Defaults to `false`.
58
- */
59
- mergeObjectProperties?: boolean;
60
- /**
61
- * When assigning to an embedded property, the values are deeply merged with the existing data.
62
- * Use `mergeEmbeddedProperties: false` to replace them instead. Defaults to `true`.
63
- */
64
- mergeEmbeddedProperties?: boolean;
65
- /**
66
- * When assigning to a relation property, if the value is a POJO and `updateByPrimaryKey` is enabled, we check if
67
- * the target exists in the identity map based on its primary key and call `assign` on it recursively. If there is
68
- * no primary key provided, or the entity is not present in the context, such an entity is considered as new
69
- * (resulting in `INSERT` query), created via `em.create()`. You can use `merge: true` to use `em.merge()` instead,
70
- * which means there won't be any query used for persisting the relation. Defaults to `false`.
71
- */
72
- merge?: boolean;
73
- /**
74
- * When assigning to a to-many relation properties (`Collection`) with `updateNestedEntities` and `updateByPrimaryKey`
75
- * enabled (default), you can use this option to override the relation schema. This is used only when trying to find
76
- * the entity reference in the current context. If it is not found, we create the relation entity using the target
77
- * entity schema. The value is automatically inferred from the target entity.
78
- */
79
- schema?: string;
80
- /**
81
- * When using the static `assign()` helper, you can pass the EntityManager instance explicitly via the `em` option.
82
- * This is only needed when you try to assign a relation property. The value is automatically inferred from the target
83
- * entity when it is managed, or when you use `em.assign()` instead.
84
- */
85
- em?: EntityManager;
34
+ /**
35
+ * Allows disabling processing of nested relations. When disabled, an object payload in place of a relation always
36
+ * results in an `INSERT` query. To assign a value of the relation, use the foreign key instead of an object.
37
+ * Defaults to `true`.
38
+ */
39
+ updateNestedEntities?: boolean;
40
+ /**
41
+ * When assigning to a relation property with object payload and `updateNestedEntities` enabled (default), you can
42
+ * control how a payload without a primary key is handled. By default, it is considered as a new object, resulting
43
+ * in an `INSERT` query. Use `updateByPrimaryKey: false` to allow assigning the data on an existing relation instead.
44
+ * Defaults to `true`.
45
+ */
46
+ updateByPrimaryKey?: boolean;
47
+ /**
48
+ * When you have some properties in the payload that are not represented by an entity property mapping, you can skip
49
+ * such unknown properties via `onlyProperties: true`. Defaults to `false`.
50
+ */
51
+ onlyProperties?: boolean;
52
+ /**
53
+ * With `onlyOwnProperties` enabled, inverse sides of to-many relations are skipped, and payloads of other relations are converted
54
+ * to foreign keys. Defaults to `false`.
55
+ */
56
+ onlyOwnProperties?: boolean;
57
+ /**
58
+ * With `ignoreUndefined` enabled, `undefined` properties passed in the payload are skipped. Defaults to `false`.
59
+ */
60
+ ignoreUndefined?: boolean;
61
+ /**
62
+ * `assign` excepts runtime values for properties using custom types. To be able to assign raw database values, you
63
+ * can enable the `convertCustomTypes` option. Defaults to `false`.
64
+ */
65
+ convertCustomTypes?: Convert;
66
+ /**
67
+ * When assigning to a JSON property, the value is replaced. Use `mergeObjectProperties: true` to enable deep merging
68
+ * of the payload with the existing value. Defaults to `false`.
69
+ */
70
+ mergeObjectProperties?: boolean;
71
+ /**
72
+ * When assigning to an embedded property, the values are deeply merged with the existing data.
73
+ * Use `mergeEmbeddedProperties: false` to replace them instead. Defaults to `true`.
74
+ */
75
+ mergeEmbeddedProperties?: boolean;
76
+ /**
77
+ * When assigning to a relation property, if the value is a POJO and `updateByPrimaryKey` is enabled, we check if
78
+ * the target exists in the identity map based on its primary key and call `assign` on it recursively. If there is
79
+ * no primary key provided, or the entity is not present in the context, such an entity is considered as new
80
+ * (resulting in `INSERT` query), created via `em.create()`. You can use `merge: true` to use `em.merge()` instead,
81
+ * which means there won't be any query used for persisting the relation. Defaults to `false`.
82
+ */
83
+ merge?: boolean;
84
+ /**
85
+ * When assigning to a to-many relation properties (`Collection`) with `updateNestedEntities` and `updateByPrimaryKey`
86
+ * enabled (default), you can use this option to override the relation schema. This is used only when trying to find
87
+ * the entity reference in the current context. If it is not found, we create the relation entity using the target
88
+ * entity schema. The value is automatically inferred from the target entity.
89
+ */
90
+ schema?: string;
91
+ /**
92
+ * When using the static `assign()` helper, you can pass the EntityManager instance explicitly via the `em` option.
93
+ * This is only needed when you try to assign a relation property. The value is automatically inferred from the target
94
+ * entity when it is managed, or when you use `em.assign()` instead.
95
+ */
96
+ em?: EntityManager;
86
97
  }