@mikro-orm/core 7.0.2 → 7.0.3-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 (205) hide show
  1. package/EntityManager.d.ts +583 -883
  2. package/EntityManager.js +1869 -1897
  3. package/MikroORM.d.ts +74 -103
  4. package/MikroORM.js +179 -178
  5. package/cache/CacheAdapter.d.ts +36 -36
  6. package/cache/FileCacheAdapter.d.ts +24 -30
  7. package/cache/FileCacheAdapter.js +78 -80
  8. package/cache/GeneratedCacheAdapter.d.ts +20 -18
  9. package/cache/GeneratedCacheAdapter.js +30 -30
  10. package/cache/MemoryCacheAdapter.d.ts +20 -18
  11. package/cache/MemoryCacheAdapter.js +36 -35
  12. package/cache/NullCacheAdapter.d.ts +16 -16
  13. package/cache/NullCacheAdapter.js +24 -24
  14. package/connections/Connection.d.ts +84 -95
  15. package/connections/Connection.js +168 -165
  16. package/drivers/DatabaseDriver.d.ts +80 -186
  17. package/drivers/DatabaseDriver.js +443 -450
  18. package/drivers/IDatabaseDriver.d.ts +301 -440
  19. package/entity/BaseEntity.d.ts +83 -120
  20. package/entity/BaseEntity.js +43 -43
  21. package/entity/Collection.d.ts +179 -212
  22. package/entity/Collection.js +721 -727
  23. package/entity/EntityAssigner.d.ts +77 -88
  24. package/entity/EntityAssigner.js +230 -231
  25. package/entity/EntityFactory.d.ts +54 -66
  26. package/entity/EntityFactory.js +383 -425
  27. package/entity/EntityHelper.d.ts +22 -34
  28. package/entity/EntityHelper.js +267 -280
  29. package/entity/EntityIdentifier.d.ts +4 -4
  30. package/entity/EntityIdentifier.js +10 -10
  31. package/entity/EntityLoader.d.ts +73 -103
  32. package/entity/EntityLoader.js +723 -753
  33. package/entity/EntityRepository.d.ts +201 -316
  34. package/entity/EntityRepository.js +213 -213
  35. package/entity/PolymorphicRef.d.ts +5 -5
  36. package/entity/PolymorphicRef.js +10 -10
  37. package/entity/Reference.d.ts +82 -126
  38. package/entity/Reference.js +274 -278
  39. package/entity/WrappedEntity.d.ts +72 -115
  40. package/entity/WrappedEntity.js +166 -168
  41. package/entity/defineEntity.d.ts +614 -1280
  42. package/entity/defineEntity.js +511 -520
  43. package/entity/utils.d.ts +3 -13
  44. package/entity/utils.js +73 -71
  45. package/entity/validators.js +43 -43
  46. package/entity/wrap.js +8 -8
  47. package/enums.d.ts +253 -258
  48. package/enums.js +252 -251
  49. package/errors.d.ts +72 -114
  50. package/errors.js +253 -350
  51. package/events/EventManager.d.ts +14 -26
  52. package/events/EventManager.js +77 -79
  53. package/events/EventSubscriber.d.ts +29 -29
  54. package/events/TransactionEventBroadcaster.d.ts +8 -15
  55. package/events/TransactionEventBroadcaster.js +14 -14
  56. package/exceptions.d.ts +40 -23
  57. package/exceptions.js +52 -35
  58. package/hydration/Hydrator.d.ts +17 -42
  59. package/hydration/Hydrator.js +43 -43
  60. package/hydration/ObjectHydrator.d.ts +17 -50
  61. package/hydration/ObjectHydrator.js +416 -479
  62. package/index.d.ts +2 -116
  63. package/index.js +1 -10
  64. package/logging/DefaultLogger.d.ts +32 -34
  65. package/logging/DefaultLogger.js +86 -86
  66. package/logging/Logger.d.ts +41 -41
  67. package/logging/SimpleLogger.d.ts +11 -13
  68. package/logging/SimpleLogger.js +22 -22
  69. package/logging/colors.d.ts +6 -6
  70. package/logging/colors.js +10 -11
  71. package/logging/inspect.js +7 -7
  72. package/metadata/EntitySchema.d.ts +127 -211
  73. package/metadata/EntitySchema.js +398 -397
  74. package/metadata/MetadataDiscovery.d.ts +114 -114
  75. package/metadata/MetadataDiscovery.js +1863 -1947
  76. package/metadata/MetadataProvider.d.ts +21 -24
  77. package/metadata/MetadataProvider.js +84 -82
  78. package/metadata/MetadataStorage.d.ts +32 -38
  79. package/metadata/MetadataStorage.js +118 -118
  80. package/metadata/MetadataValidator.d.ts +39 -39
  81. package/metadata/MetadataValidator.js +338 -381
  82. package/metadata/discover-entities.d.ts +2 -5
  83. package/metadata/discover-entities.js +27 -27
  84. package/metadata/types.d.ts +531 -615
  85. package/naming-strategy/AbstractNamingStrategy.d.ts +39 -54
  86. package/naming-strategy/AbstractNamingStrategy.js +85 -90
  87. package/naming-strategy/EntityCaseNamingStrategy.d.ts +6 -6
  88. package/naming-strategy/EntityCaseNamingStrategy.js +22 -22
  89. package/naming-strategy/MongoNamingStrategy.d.ts +6 -6
  90. package/naming-strategy/MongoNamingStrategy.js +18 -18
  91. package/naming-strategy/NamingStrategy.d.ts +99 -109
  92. package/naming-strategy/UnderscoreNamingStrategy.d.ts +7 -7
  93. package/naming-strategy/UnderscoreNamingStrategy.js +21 -21
  94. package/not-supported.js +4 -7
  95. package/package.json +1 -1
  96. package/platforms/ExceptionConverter.d.ts +1 -1
  97. package/platforms/ExceptionConverter.js +4 -4
  98. package/platforms/Platform.d.ts +299 -308
  99. package/platforms/Platform.js +636 -659
  100. package/serialization/EntitySerializer.d.ts +26 -48
  101. package/serialization/EntitySerializer.js +218 -224
  102. package/serialization/EntityTransformer.d.ts +6 -10
  103. package/serialization/EntityTransformer.js +217 -219
  104. package/serialization/SerializationContext.d.ts +23 -27
  105. package/serialization/SerializationContext.js +105 -105
  106. package/types/ArrayType.d.ts +8 -8
  107. package/types/ArrayType.js +33 -33
  108. package/types/BigIntType.d.ts +10 -17
  109. package/types/BigIntType.js +37 -37
  110. package/types/BlobType.d.ts +3 -3
  111. package/types/BlobType.js +13 -13
  112. package/types/BooleanType.d.ts +4 -4
  113. package/types/BooleanType.js +12 -12
  114. package/types/CharacterType.d.ts +2 -2
  115. package/types/CharacterType.js +6 -6
  116. package/types/DateTimeType.d.ts +5 -5
  117. package/types/DateTimeType.js +15 -15
  118. package/types/DateType.d.ts +5 -5
  119. package/types/DateType.js +15 -15
  120. package/types/DecimalType.d.ts +7 -7
  121. package/types/DecimalType.js +26 -26
  122. package/types/DoubleType.d.ts +3 -3
  123. package/types/DoubleType.js +12 -12
  124. package/types/EnumArrayType.d.ts +5 -5
  125. package/types/EnumArrayType.js +24 -24
  126. package/types/EnumType.d.ts +3 -3
  127. package/types/EnumType.js +11 -11
  128. package/types/FloatType.d.ts +3 -3
  129. package/types/FloatType.js +9 -9
  130. package/types/IntegerType.d.ts +3 -3
  131. package/types/IntegerType.js +9 -9
  132. package/types/IntervalType.d.ts +4 -4
  133. package/types/IntervalType.js +12 -12
  134. package/types/JsonType.d.ts +8 -8
  135. package/types/JsonType.js +32 -32
  136. package/types/MediumIntType.d.ts +1 -1
  137. package/types/MediumIntType.js +3 -3
  138. package/types/SmallIntType.d.ts +3 -3
  139. package/types/SmallIntType.js +9 -9
  140. package/types/StringType.d.ts +4 -4
  141. package/types/StringType.js +12 -12
  142. package/types/TextType.d.ts +3 -3
  143. package/types/TextType.js +9 -9
  144. package/types/TimeType.d.ts +5 -5
  145. package/types/TimeType.js +17 -17
  146. package/types/TinyIntType.d.ts +3 -3
  147. package/types/TinyIntType.js +10 -10
  148. package/types/Type.d.ts +79 -83
  149. package/types/Type.js +82 -82
  150. package/types/Uint8ArrayType.d.ts +4 -4
  151. package/types/Uint8ArrayType.js +21 -21
  152. package/types/UnknownType.d.ts +4 -4
  153. package/types/UnknownType.js +12 -12
  154. package/types/UuidType.d.ts +5 -5
  155. package/types/UuidType.js +19 -19
  156. package/types/index.d.ts +49 -75
  157. package/types/index.js +26 -52
  158. package/typings.d.ts +729 -1211
  159. package/typings.js +231 -244
  160. package/unit-of-work/ChangeSet.d.ts +26 -26
  161. package/unit-of-work/ChangeSet.js +56 -56
  162. package/unit-of-work/ChangeSetComputer.d.ts +12 -12
  163. package/unit-of-work/ChangeSetComputer.js +170 -178
  164. package/unit-of-work/ChangeSetPersister.d.ts +44 -63
  165. package/unit-of-work/ChangeSetPersister.js +421 -442
  166. package/unit-of-work/CommitOrderCalculator.d.ts +40 -40
  167. package/unit-of-work/CommitOrderCalculator.js +88 -89
  168. package/unit-of-work/IdentityMap.d.ts +31 -31
  169. package/unit-of-work/IdentityMap.js +105 -105
  170. package/unit-of-work/UnitOfWork.d.ts +141 -181
  171. package/unit-of-work/UnitOfWork.js +1183 -1200
  172. package/utils/AbstractMigrator.d.ts +91 -111
  173. package/utils/AbstractMigrator.js +275 -275
  174. package/utils/AbstractSchemaGenerator.d.ts +34 -43
  175. package/utils/AbstractSchemaGenerator.js +122 -121
  176. package/utils/AsyncContext.d.ts +3 -3
  177. package/utils/AsyncContext.js +35 -34
  178. package/utils/Configuration.d.ts +808 -852
  179. package/utils/Configuration.js +344 -359
  180. package/utils/Cursor.d.ts +22 -40
  181. package/utils/Cursor.js +127 -135
  182. package/utils/DataloaderUtils.d.ts +43 -58
  183. package/utils/DataloaderUtils.js +198 -203
  184. package/utils/EntityComparator.d.ts +81 -98
  185. package/utils/EntityComparator.js +728 -824
  186. package/utils/NullHighlighter.d.ts +1 -1
  187. package/utils/NullHighlighter.js +3 -3
  188. package/utils/QueryHelper.d.ts +51 -79
  189. package/utils/QueryHelper.js +361 -372
  190. package/utils/RawQueryFragment.d.ts +34 -50
  191. package/utils/RawQueryFragment.js +105 -107
  192. package/utils/RequestContext.d.ts +32 -32
  193. package/utils/RequestContext.js +53 -52
  194. package/utils/TransactionContext.d.ts +16 -16
  195. package/utils/TransactionContext.js +27 -27
  196. package/utils/TransactionManager.d.ts +58 -58
  197. package/utils/TransactionManager.js +197 -199
  198. package/utils/Utils.d.ts +145 -204
  199. package/utils/Utils.js +813 -814
  200. package/utils/clone.js +113 -104
  201. package/utils/env-vars.js +88 -90
  202. package/utils/fs-utils.d.ts +15 -15
  203. package/utils/fs-utils.js +181 -180
  204. package/utils/upsert-utils.d.ts +5 -20
  205. package/utils/upsert-utils.js +116 -114
@@ -1,17 +1,5 @@
1
1
  import { type Ref } from './Reference.js';
2
- import type {
3
- AutoPath,
4
- EntityData,
5
- EntityDTO,
6
- Loaded,
7
- LoadedReference,
8
- AddEager,
9
- EntityKey,
10
- FromEntityType,
11
- IsSubset,
12
- MergeSelected,
13
- SerializeDTO,
14
- } from '../typings.js';
2
+ import type { AutoPath, EntityData, EntityDTO, Loaded, LoadedReference, AddEager, EntityKey, FromEntityType, IsSubset, MergeSelected, SerializeDTO } from '../typings.js';
15
3
  import { type AssignOptions } from './EntityAssigner.js';
16
4
  import type { EntityLoaderOptions } from './EntityLoader.js';
17
5
  import { type SerializeOptions } from '../serialization/EntitySerializer.js';
@@ -19,111 +7,86 @@ import type { FindOneOptions } from '../drivers/IDatabaseDriver.js';
19
7
  import type { PopulatePath } from '../enums.js';
20
8
  /** Base class for entities providing convenience methods like `assign()`, `toObject()`, and `populate()`. */
21
9
  export declare abstract class BaseEntity {
22
- /** Returns whether the entity has been fully loaded from the database. */
23
- isInitialized(): boolean;
24
- /** Marks the entity as populated or not for serialization purposes. */
25
- populated(populated?: boolean): void;
26
- /** Loads the specified relations on this entity. */
27
- populate<Entity extends this = this, Hint extends string = never, Fields extends string = never>(
28
- populate: AutoPath<Entity, Hint, PopulatePath.ALL>[] | false,
29
- options?: EntityLoaderOptions<Entity, Fields>,
30
- ): Promise<Loaded<Entity, Hint>>;
31
- /** Returns a Reference wrapper for this entity. */
32
- toReference<Entity extends this = this>(): Ref<Entity> & LoadedReference<Loaded<Entity, AddEager<Entity>>>;
33
- /**
34
- * Converts the entity to a plain object representation.
35
- *
36
- * **Note on typing with `Loaded` entities:** When called on a `Loaded<Entity, 'relation'>` type,
37
- * the return type will be `EntityDTO<Entity>` (with relations as primary keys), not
38
- * `EntityDTO<Loaded<Entity, 'relation'>>` (with loaded relations as nested objects).
39
- * This is a TypeScript limitation - the `this` type resolves to the class, not the `Loaded` wrapper.
40
- *
41
- * For correct typing that reflects loaded relations, use `wrap()`:
42
- * ```ts
43
- * const result = await em.find(User, {}, { populate: ['profile'] });
44
- * // Type: EntityDTO<User> (profile is number)
45
- * const obj1 = result[0].toObject();
46
- * // Type: EntityDTO<Loaded<User, 'profile'>> (profile is nested object)
47
- * const obj2 = wrap(result[0]).toObject();
48
- * ```
49
- *
50
- * Runtime values are correct in both cases - only the static types differ.
51
- */
52
- toObject<Entity extends this = this>(): EntityDTO<Entity>;
53
- /**
54
- * Converts the entity to a plain object representation.
55
- *
56
- * **Note on typing with `Loaded` entities:** When called on a `Loaded<Entity, 'relation'>` type,
57
- * the return type will be `EntityDTO<Entity>` (with relations as primary keys), not
58
- * `EntityDTO<Loaded<Entity, 'relation'>>` (with loaded relations as nested objects).
59
- * This is a TypeScript limitation - the `this` type resolves to the class, not the `Loaded` wrapper.
60
- *
61
- * For correct typing that reflects loaded relations, use `wrap()`:
62
- * ```ts
63
- * const result = await em.find(User, {}, { populate: ['profile'] });
64
- * // Type: EntityDTO<User> (profile is number)
65
- * const obj1 = result[0].toObject();
66
- * // Type: EntityDTO<Loaded<User, 'profile'>> (profile is nested object)
67
- * const obj2 = wrap(result[0]).toObject();
68
- * ```
69
- *
70
- * Runtime values are correct in both cases - only the static types differ.
71
- */
72
- toObject<Entity extends this = this>(ignoreFields: never[]): EntityDTO<Entity>;
73
- /**
74
- * Converts the entity to a plain object representation.
75
- *
76
- * **Note on typing with `Loaded` entities:** When called on a `Loaded<Entity, 'relation'>` type,
77
- * the return type will be `EntityDTO<Entity>` (with relations as primary keys), not
78
- * `EntityDTO<Loaded<Entity, 'relation'>>` (with loaded relations as nested objects).
79
- * This is a TypeScript limitation - the `this` type resolves to the class, not the `Loaded` wrapper.
80
- *
81
- * For correct typing that reflects loaded relations, use `wrap()`:
82
- * ```ts
83
- * const result = await em.find(User, {}, { populate: ['profile'] });
84
- * // Type: EntityDTO<User> (profile is number)
85
- * const obj1 = result[0].toObject();
86
- * // Type: EntityDTO<Loaded<User, 'profile'>> (profile is nested object)
87
- * const obj2 = wrap(result[0]).toObject();
88
- * ```
89
- *
90
- * Runtime values are correct in both cases - only the static types differ.
91
- *
92
- * @param ignoreFields - Array of field names to omit from the result.
93
- */
94
- toObject<Entity extends this = this, Ignored extends EntityKey<Entity> = never>(
95
- ignoreFields: Ignored[],
96
- ): Omit<EntityDTO<Entity>, Ignored>;
97
- /** Converts the entity to a plain object, including all properties regardless of serialization rules. */
98
- toPOJO<Entity extends this = this>(): EntityDTO<Entity>;
99
- /** Serializes the entity with control over which relations and fields to include or exclude. */
100
- serialize<
101
- Entity extends this = this,
102
- Naked extends FromEntityType<Entity> = FromEntityType<Entity>,
103
- Hint extends string = never,
104
- Exclude extends string = never,
105
- >(options?: SerializeOptions<Naked, Hint, Exclude>): SerializeDTO<Naked, Hint, Exclude>;
106
- /** Assigns the given data to this entity, updating its properties and relations. */
107
- assign<
108
- Entity extends this,
109
- Naked extends FromEntityType<Entity> = FromEntityType<Entity>,
110
- Convert extends boolean = false,
111
- Data extends EntityData<Naked, Convert> | Partial<EntityDTO<Naked>> =
112
- | EntityData<Naked, Convert>
113
- | Partial<EntityDTO<Naked>>,
114
- >(
115
- data: Data & IsSubset<EntityData<Naked>, Data>,
116
- options?: AssignOptions<Convert>,
117
- ): MergeSelected<Entity, Naked, keyof Data & string>;
118
- /** Initializes (refreshes) the entity by reloading it from the database. Returns null if not found. */
119
- init<
120
- Entity extends this = this,
121
- Hint extends string = never,
122
- Fields extends string = '*',
123
- Excludes extends string = never,
124
- >(options?: FindOneOptions<Entity, Hint, Fields, Excludes>): Promise<Loaded<Entity, Hint, Fields, Excludes> | null>;
125
- /** Returns the database schema this entity belongs to. */
126
- getSchema(): string | undefined;
127
- /** Sets the database schema for this entity. */
128
- setSchema(schema?: string): void;
10
+ /** Returns whether the entity has been fully loaded from the database. */
11
+ isInitialized(): boolean;
12
+ /** Marks the entity as populated or not for serialization purposes. */
13
+ populated(populated?: boolean): void;
14
+ /** Loads the specified relations on this entity. */
15
+ populate<Entity extends this = this, Hint extends string = never, Fields extends string = never>(populate: AutoPath<Entity, Hint, PopulatePath.ALL>[] | false, options?: EntityLoaderOptions<Entity, Fields>): Promise<Loaded<Entity, Hint>>;
16
+ /** Returns a Reference wrapper for this entity. */
17
+ toReference<Entity extends this = this>(): Ref<Entity> & LoadedReference<Loaded<Entity, AddEager<Entity>>>;
18
+ /**
19
+ * Converts the entity to a plain object representation.
20
+ *
21
+ * **Note on typing with `Loaded` entities:** When called on a `Loaded<Entity, 'relation'>` type,
22
+ * the return type will be `EntityDTO<Entity>` (with relations as primary keys), not
23
+ * `EntityDTO<Loaded<Entity, 'relation'>>` (with loaded relations as nested objects).
24
+ * This is a TypeScript limitation - the `this` type resolves to the class, not the `Loaded` wrapper.
25
+ *
26
+ * For correct typing that reflects loaded relations, use `wrap()`:
27
+ * ```ts
28
+ * const result = await em.find(User, {}, { populate: ['profile'] });
29
+ * // Type: EntityDTO<User> (profile is number)
30
+ * const obj1 = result[0].toObject();
31
+ * // Type: EntityDTO<Loaded<User, 'profile'>> (profile is nested object)
32
+ * const obj2 = wrap(result[0]).toObject();
33
+ * ```
34
+ *
35
+ * Runtime values are correct in both cases - only the static types differ.
36
+ */
37
+ toObject<Entity extends this = this>(): EntityDTO<Entity>;
38
+ /**
39
+ * Converts the entity to a plain object representation.
40
+ *
41
+ * **Note on typing with `Loaded` entities:** When called on a `Loaded<Entity, 'relation'>` type,
42
+ * the return type will be `EntityDTO<Entity>` (with relations as primary keys), not
43
+ * `EntityDTO<Loaded<Entity, 'relation'>>` (with loaded relations as nested objects).
44
+ * This is a TypeScript limitation - the `this` type resolves to the class, not the `Loaded` wrapper.
45
+ *
46
+ * For correct typing that reflects loaded relations, use `wrap()`:
47
+ * ```ts
48
+ * const result = await em.find(User, {}, { populate: ['profile'] });
49
+ * // Type: EntityDTO<User> (profile is number)
50
+ * const obj1 = result[0].toObject();
51
+ * // Type: EntityDTO<Loaded<User, 'profile'>> (profile is nested object)
52
+ * const obj2 = wrap(result[0]).toObject();
53
+ * ```
54
+ *
55
+ * Runtime values are correct in both cases - only the static types differ.
56
+ */
57
+ toObject<Entity extends this = this>(ignoreFields: never[]): EntityDTO<Entity>;
58
+ /**
59
+ * Converts the entity to a plain object representation.
60
+ *
61
+ * **Note on typing with `Loaded` entities:** When called on a `Loaded<Entity, 'relation'>` type,
62
+ * the return type will be `EntityDTO<Entity>` (with relations as primary keys), not
63
+ * `EntityDTO<Loaded<Entity, 'relation'>>` (with loaded relations as nested objects).
64
+ * This is a TypeScript limitation - the `this` type resolves to the class, not the `Loaded` wrapper.
65
+ *
66
+ * For correct typing that reflects loaded relations, use `wrap()`:
67
+ * ```ts
68
+ * const result = await em.find(User, {}, { populate: ['profile'] });
69
+ * // Type: EntityDTO<User> (profile is number)
70
+ * const obj1 = result[0].toObject();
71
+ * // Type: EntityDTO<Loaded<User, 'profile'>> (profile is nested object)
72
+ * const obj2 = wrap(result[0]).toObject();
73
+ * ```
74
+ *
75
+ * Runtime values are correct in both cases - only the static types differ.
76
+ *
77
+ * @param ignoreFields - Array of field names to omit from the result.
78
+ */
79
+ toObject<Entity extends this = this, Ignored extends EntityKey<Entity> = never>(ignoreFields: Ignored[]): Omit<EntityDTO<Entity>, Ignored>;
80
+ /** Converts the entity to a plain object, including all properties regardless of serialization rules. */
81
+ toPOJO<Entity extends this = this>(): EntityDTO<Entity>;
82
+ /** Serializes the entity with control over which relations and fields to include or exclude. */
83
+ serialize<Entity extends this = this, Naked extends FromEntityType<Entity> = FromEntityType<Entity>, Hint extends string = never, Exclude extends string = never>(options?: SerializeOptions<Naked, Hint, Exclude>): SerializeDTO<Naked, Hint, Exclude>;
84
+ /** Assigns the given data to this entity, updating its properties and relations. */
85
+ assign<Entity extends this, Naked extends FromEntityType<Entity> = FromEntityType<Entity>, Convert extends boolean = false, Data extends EntityData<Naked, Convert> | Partial<EntityDTO<Naked>> = EntityData<Naked, Convert> | Partial<EntityDTO<Naked>>>(data: Data & IsSubset<EntityData<Naked>, Data>, options?: AssignOptions<Convert>): MergeSelected<Entity, Naked, keyof Data & string>;
86
+ /** Initializes (refreshes) the entity by reloading it from the database. Returns null if not found. */
87
+ init<Entity extends this = this, Hint extends string = never, Fields extends string = '*', Excludes extends string = never>(options?: FindOneOptions<Entity, Hint, Fields, Excludes>): Promise<Loaded<Entity, Hint, Fields, Excludes> | null>;
88
+ /** Returns the database schema this entity belongs to. */
89
+ getSchema(): string | undefined;
90
+ /** Sets the database schema for this entity. */
91
+ setSchema(schema?: string): void;
129
92
  }
@@ -4,48 +4,48 @@ import { EntitySerializer } from '../serialization/EntitySerializer.js';
4
4
  import { helper } from './wrap.js';
5
5
  /** Base class for entities providing convenience methods like `assign()`, `toObject()`, and `populate()`. */
6
6
  export class BaseEntity {
7
- /** Returns whether the entity has been fully loaded from the database. */
8
- isInitialized() {
9
- return helper(this).__initialized;
10
- }
11
- /** Marks the entity as populated or not for serialization purposes. */
12
- populated(populated = true) {
13
- helper(this).populated(populated);
14
- }
15
- /** Loads the specified relations on this entity. */
16
- async populate(populate, options = {}) {
17
- return helper(this).populate(populate, options);
18
- }
19
- /** Returns a Reference wrapper for this entity. */
20
- toReference() {
21
- return Reference.create(this);
22
- }
23
- toObject(ignoreFields) {
24
- return helper(this).toObject(ignoreFields);
25
- }
26
- /** Converts the entity to a plain object, including all properties regardless of serialization rules. */
27
- toPOJO() {
28
- return helper(this).toPOJO();
29
- }
30
- /** Serializes the entity with control over which relations and fields to include or exclude. */
31
- serialize(options) {
32
- return EntitySerializer.serialize(this, options);
33
- }
34
- /** Assigns the given data to this entity, updating its properties and relations. */
35
- assign(data, options = {}) {
36
- return EntityAssigner.assign(this, data, options);
37
- }
38
- /** Initializes (refreshes) the entity by reloading it from the database. Returns null if not found. */
39
- init(options) {
40
- return helper(this).init(options);
41
- }
42
- /** Returns the database schema this entity belongs to. */
43
- getSchema() {
44
- return helper(this).getSchema();
45
- }
46
- /** Sets the database schema for this entity. */
47
- setSchema(schema) {
48
- helper(this).setSchema(schema);
49
- }
7
+ /** Returns whether the entity has been fully loaded from the database. */
8
+ isInitialized() {
9
+ return helper(this).__initialized;
10
+ }
11
+ /** Marks the entity as populated or not for serialization purposes. */
12
+ populated(populated = true) {
13
+ helper(this).populated(populated);
14
+ }
15
+ /** Loads the specified relations on this entity. */
16
+ async populate(populate, options = {}) {
17
+ return helper(this).populate(populate, options);
18
+ }
19
+ /** Returns a Reference wrapper for this entity. */
20
+ toReference() {
21
+ return Reference.create(this);
22
+ }
23
+ toObject(ignoreFields) {
24
+ return helper(this).toObject(ignoreFields);
25
+ }
26
+ /** Converts the entity to a plain object, including all properties regardless of serialization rules. */
27
+ toPOJO() {
28
+ return helper(this).toPOJO();
29
+ }
30
+ /** Serializes the entity with control over which relations and fields to include or exclude. */
31
+ serialize(options) {
32
+ return EntitySerializer.serialize(this, options);
33
+ }
34
+ /** Assigns the given data to this entity, updating its properties and relations. */
35
+ assign(data, options = {}) {
36
+ return EntityAssigner.assign(this, data, options);
37
+ }
38
+ /** Initializes (refreshes) the entity by reloading it from the database. Returns null if not found. */
39
+ init(options) {
40
+ return helper(this).init(options);
41
+ }
42
+ /** Returns the database schema this entity belongs to. */
43
+ getSchema() {
44
+ return helper(this).getSchema();
45
+ }
46
+ /** Sets the database schema for this entity. */
47
+ setSchema(schema) {
48
+ helper(this).setSchema(schema);
49
+ }
50
50
  }
51
51
  Object.defineProperty(BaseEntity.prototype, '__baseEntity', { value: true, writable: false, enumerable: false });