@mikro-orm/core 7.0.0-dev.6 → 7.0.0-dev.61

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 (123) hide show
  1. package/EntityManager.d.ts +85 -32
  2. package/EntityManager.js +281 -178
  3. package/MikroORM.d.ts +8 -8
  4. package/MikroORM.js +31 -74
  5. package/README.md +3 -2
  6. package/cache/FileCacheAdapter.d.ts +2 -1
  7. package/cache/FileCacheAdapter.js +5 -4
  8. package/connections/Connection.d.ts +11 -7
  9. package/connections/Connection.js +16 -13
  10. package/decorators/Embeddable.d.ts +2 -0
  11. package/decorators/Embedded.d.ts +5 -11
  12. package/decorators/Entity.d.ts +20 -3
  13. package/decorators/Indexed.d.ts +2 -2
  14. package/decorators/ManyToMany.d.ts +2 -0
  15. package/decorators/ManyToOne.d.ts +4 -0
  16. package/decorators/OneToOne.d.ts +4 -0
  17. package/decorators/Property.d.ts +53 -9
  18. package/decorators/Transactional.d.ts +3 -1
  19. package/decorators/Transactional.js +6 -3
  20. package/decorators/index.d.ts +1 -1
  21. package/drivers/DatabaseDriver.d.ts +11 -5
  22. package/drivers/DatabaseDriver.js +13 -4
  23. package/drivers/IDatabaseDriver.d.ts +29 -5
  24. package/entity/ArrayCollection.d.ts +6 -4
  25. package/entity/ArrayCollection.js +27 -12
  26. package/entity/BaseEntity.d.ts +0 -1
  27. package/entity/BaseEntity.js +0 -3
  28. package/entity/Collection.d.ts +3 -4
  29. package/entity/Collection.js +34 -17
  30. package/entity/EntityAssigner.d.ts +1 -1
  31. package/entity/EntityAssigner.js +9 -1
  32. package/entity/EntityFactory.d.ts +7 -0
  33. package/entity/EntityFactory.js +63 -40
  34. package/entity/EntityHelper.js +26 -9
  35. package/entity/EntityLoader.d.ts +5 -4
  36. package/entity/EntityLoader.js +69 -36
  37. package/entity/EntityRepository.d.ts +1 -1
  38. package/entity/EntityValidator.js +2 -2
  39. package/entity/Reference.d.ts +9 -7
  40. package/entity/Reference.js +32 -5
  41. package/entity/WrappedEntity.d.ts +0 -2
  42. package/entity/WrappedEntity.js +1 -5
  43. package/entity/defineEntity.d.ts +555 -0
  44. package/entity/defineEntity.js +529 -0
  45. package/entity/index.d.ts +2 -0
  46. package/entity/index.js +2 -0
  47. package/entity/utils.d.ts +7 -0
  48. package/entity/utils.js +15 -3
  49. package/enums.d.ts +18 -5
  50. package/enums.js +13 -0
  51. package/errors.d.ts +6 -1
  52. package/errors.js +14 -4
  53. package/events/EventSubscriber.d.ts +3 -1
  54. package/hydration/ObjectHydrator.d.ts +4 -4
  55. package/hydration/ObjectHydrator.js +35 -24
  56. package/index.d.ts +2 -1
  57. package/index.js +1 -1
  58. package/logging/DefaultLogger.d.ts +1 -1
  59. package/logging/SimpleLogger.d.ts +1 -1
  60. package/metadata/EntitySchema.d.ts +8 -4
  61. package/metadata/EntitySchema.js +41 -23
  62. package/metadata/MetadataDiscovery.d.ts +5 -7
  63. package/metadata/MetadataDiscovery.js +151 -159
  64. package/metadata/MetadataStorage.js +1 -1
  65. package/metadata/MetadataValidator.js +4 -3
  66. package/metadata/discover-entities.d.ts +5 -0
  67. package/metadata/discover-entities.js +39 -0
  68. package/naming-strategy/AbstractNamingStrategy.d.ts +5 -1
  69. package/naming-strategy/AbstractNamingStrategy.js +7 -1
  70. package/naming-strategy/NamingStrategy.d.ts +11 -1
  71. package/package.json +14 -8
  72. package/platforms/Platform.d.ts +5 -8
  73. package/platforms/Platform.js +4 -17
  74. package/serialization/EntitySerializer.d.ts +2 -0
  75. package/serialization/EntitySerializer.js +29 -11
  76. package/serialization/EntityTransformer.js +22 -12
  77. package/serialization/SerializationContext.js +14 -11
  78. package/types/BigIntType.d.ts +9 -6
  79. package/types/BigIntType.js +3 -0
  80. package/types/BlobType.d.ts +0 -1
  81. package/types/BlobType.js +0 -3
  82. package/types/BooleanType.d.ts +2 -1
  83. package/types/BooleanType.js +3 -0
  84. package/types/DecimalType.d.ts +6 -4
  85. package/types/DecimalType.js +1 -1
  86. package/types/DoubleType.js +1 -1
  87. package/types/JsonType.d.ts +1 -1
  88. package/types/JsonType.js +7 -2
  89. package/types/Type.d.ts +2 -1
  90. package/types/Type.js +1 -1
  91. package/types/Uint8ArrayType.d.ts +0 -1
  92. package/types/Uint8ArrayType.js +0 -3
  93. package/types/index.d.ts +1 -1
  94. package/typings.d.ts +95 -52
  95. package/typings.js +31 -31
  96. package/unit-of-work/ChangeSetComputer.js +8 -3
  97. package/unit-of-work/ChangeSetPersister.d.ts +4 -2
  98. package/unit-of-work/ChangeSetPersister.js +37 -16
  99. package/unit-of-work/UnitOfWork.d.ts +8 -1
  100. package/unit-of-work/UnitOfWork.js +110 -53
  101. package/utils/AbstractSchemaGenerator.js +3 -1
  102. package/utils/Configuration.d.ts +201 -184
  103. package/utils/Configuration.js +143 -151
  104. package/utils/ConfigurationLoader.d.ts +9 -22
  105. package/utils/ConfigurationLoader.js +53 -76
  106. package/utils/Cursor.d.ts +3 -3
  107. package/utils/Cursor.js +3 -0
  108. package/utils/DataloaderUtils.d.ts +15 -5
  109. package/utils/DataloaderUtils.js +53 -7
  110. package/utils/EntityComparator.d.ts +8 -4
  111. package/utils/EntityComparator.js +105 -58
  112. package/utils/QueryHelper.d.ts +9 -1
  113. package/utils/QueryHelper.js +66 -5
  114. package/utils/RawQueryFragment.d.ts +36 -4
  115. package/utils/RawQueryFragment.js +34 -13
  116. package/utils/TransactionManager.d.ts +65 -0
  117. package/utils/TransactionManager.js +223 -0
  118. package/utils/Utils.d.ts +16 -31
  119. package/utils/Utils.js +129 -107
  120. package/utils/index.d.ts +1 -0
  121. package/utils/index.js +1 -0
  122. package/utils/upsert-utils.d.ts +7 -2
  123. package/utils/upsert-utils.js +52 -1
@@ -8,7 +8,6 @@ export class RawQueryFragment {
8
8
  static #storage = new AsyncLocalStorage();
9
9
  static #index = 0n;
10
10
  static cloneRegistry;
11
- #assigned = false;
12
11
  #used = 0;
13
12
  #key;
14
13
  constructor(sql, params = []) {
@@ -17,11 +16,6 @@ export class RawQueryFragment {
17
16
  this.#key = `[raw]: ${this.sql} (#${RawQueryFragment.#index++})`;
18
17
  }
19
18
  as(alias) {
20
- // TODO: to be removed in v7
21
- /* istanbul ignore next */
22
- if (alias.startsWith('`') || alias.startsWith('"')) {
23
- return new RawQueryFragment(`${this.sql} as ${alias}`, this.params);
24
- }
25
19
  return new RawQueryFragment(`${this.sql} as ??`, [...this.params, alias]);
26
20
  }
27
21
  valueOf() {
@@ -35,13 +29,6 @@ export class RawQueryFragment {
35
29
  this.#used++;
36
30
  return this.#key;
37
31
  }
38
- /** @internal */
39
- assign() {
40
- if (this.#assigned) {
41
- throw new Error(`Cannot reassign already used RawQueryFragment: '${this.sql}'`);
42
- }
43
- this.#assigned = true;
44
- }
45
32
  clone() {
46
33
  RawQueryFragment.cloneRegistry?.add(this.#key);
47
34
  return new RawQueryFragment(this.sql, this.params);
@@ -147,6 +134,24 @@ export const ALIAS_REPLACEMENT_RE = '\\[::alias::\\]';
147
134
  * ```ts
148
135
  * @Filter({ name: 'long', cond: () => ({ [raw('length(perex)')]: { $gt: 10000 } }) })
149
136
  * ```
137
+ *
138
+ * The `raw` helper can be used within indexes and uniques to write database-agnostic SQL expressions. In that case, you can use `'??'` to tag your database identifiers (table name, column names, index name, ...) inside your expression, and pass those identifiers as a second parameter to the `raw` helper. Internally, those will automatically be quoted according to the database in use:
139
+ *
140
+ * ```ts
141
+ * // On postgres, will produce: create index "index custom_idx_on_name" on "library.author" ("country")
142
+ * // On mysql, will produce: create index `index custom_idx_on_name` on `library.author` (`country`)
143
+ * @Index({ name: 'custom_idx_on_name', expression: (table, columns) => raw(`create index ?? on ?? (??)`, ['custom_idx_on_name', table, columns.name]) })
144
+ * @Entity({ schema: 'library' })
145
+ * export class Author { ... }
146
+ * ```
147
+ *
148
+ * You can also use the `quote` tag function to write database-agnostic SQL expressions. The end-result is the same as using the `raw` function regarding database identifiers quoting, only to have a more elegant expression syntax:
149
+ *
150
+ * ```ts
151
+ * @Index({ name: 'custom_idx_on_name', expression: (table, columns) => quote`create index ${'custom_idx_on_name'} on ${table} (${columns.name})` })
152
+ * @Entity({ schema: 'library' })
153
+ * export class Author { ... }
154
+ * ```
150
155
  */
151
156
  export function raw(sql, params) {
152
157
  if (sql instanceof RawQueryFragment) {
@@ -205,3 +210,19 @@ sql.ref = (...keys) => raw('??', [keys.join('.')]);
205
210
  sql.now = (length) => raw('current_timestamp' + (length == null ? '' : `(${length})`));
206
211
  sql.lower = (key) => createSqlFunction('lower', key);
207
212
  sql.upper = (key) => createSqlFunction('upper', key);
213
+ /**
214
+ * Tag function providing quoting of db identifiers (table name, columns names, index names, ...).
215
+ *
216
+ * Within the template literal on which the tag function is applied, all placeholders are considered to be database identifiers, and will thus be quoted as so according to the database in use.
217
+ *
218
+ * ```ts
219
+ * // On postgres, will produce: create index "index custom_idx_on_name" on "library.author" ("name")
220
+ * // On mysql, will produce: create index `index custom_idx_on_name` on `library.author` (`name`)
221
+ * @Index({ name: 'custom_idx_on_name', expression: (table, columns) => quote`create index ${'custom_idx_on_name'} on ${table} (${columns.name})` })
222
+ * @Entity({ schema: 'library' })
223
+ * export class Author { ... }
224
+ * ```
225
+ */
226
+ export function quote(expParts, ...values) {
227
+ return raw(expParts.join('??'), values);
228
+ }
@@ -0,0 +1,65 @@
1
+ import type { EntityManager } from '../EntityManager.js';
2
+ import { type TransactionOptions } from '../enums.js';
3
+ /**
4
+ * Manages transaction lifecycle and propagation for EntityManager.
5
+ */
6
+ export declare class TransactionManager {
7
+ private readonly em;
8
+ constructor(em: EntityManager);
9
+ /**
10
+ * Main entry point for handling transactional operations with propagation support.
11
+ */
12
+ handle<T>(cb: (em: EntityManager) => T | Promise<T>, options?: TransactionOptions): Promise<T>;
13
+ /**
14
+ * Executes the callback with the specified propagation type.
15
+ */
16
+ private executeWithPropagation;
17
+ /**
18
+ * Suspends the current transaction and returns the suspended resources.
19
+ */
20
+ private suspendTransaction;
21
+ /**
22
+ * Resumes a previously suspended transaction.
23
+ */
24
+ private resumeTransaction;
25
+ /**
26
+ * Executes operation without transaction context.
27
+ */
28
+ private executeWithoutTransaction;
29
+ /**
30
+ * Creates new independent transaction, suspending any existing one.
31
+ */
32
+ private executeWithNewTransaction;
33
+ /**
34
+ * Creates new transaction context.
35
+ */
36
+ private createNewTransaction;
37
+ /**
38
+ * Executes nested transaction with savepoint.
39
+ */
40
+ private executeNestedTransaction;
41
+ /**
42
+ * Creates a fork of the EntityManager with the given options.
43
+ */
44
+ private createFork;
45
+ /**
46
+ * Determines if changes should be propagated to the upper context.
47
+ */
48
+ private shouldPropagateToUpperContext;
49
+ /**
50
+ * Merges entities from fork to parent EntityManager.
51
+ */
52
+ private mergeEntitiesToParent;
53
+ /**
54
+ * Registers a deletion handler to unset entity identities after flush.
55
+ */
56
+ private registerDeletionHandler;
57
+ /**
58
+ * Processes transaction execution.
59
+ */
60
+ private processTransaction;
61
+ /**
62
+ * Executes transaction workflow with entity synchronization.
63
+ */
64
+ private executeTransactionFlow;
65
+ }
@@ -0,0 +1,223 @@
1
+ import { ReferenceKind, TransactionPropagation } from '../enums.js';
2
+ import { TransactionEventBroadcaster } from '../events/TransactionEventBroadcaster.js';
3
+ import { TransactionContext } from '../utils/TransactionContext.js';
4
+ import { ChangeSetType } from '../unit-of-work/ChangeSet.js';
5
+ import { TransactionStateError } from '../errors.js';
6
+ import { helper } from '../entity/wrap.js';
7
+ /**
8
+ * Manages transaction lifecycle and propagation for EntityManager.
9
+ */
10
+ export class TransactionManager {
11
+ em;
12
+ constructor(em) {
13
+ this.em = em;
14
+ }
15
+ /**
16
+ * Main entry point for handling transactional operations with propagation support.
17
+ */
18
+ async handle(cb, options = {}) {
19
+ const em = this.em.getContext(false);
20
+ options.propagation ??= TransactionPropagation.NESTED;
21
+ options.ctx ??= em.getTransactionContext();
22
+ const hasExistingTransaction = !!em.getTransactionContext();
23
+ return this.executeWithPropagation(options.propagation, em, cb, options, hasExistingTransaction);
24
+ }
25
+ /**
26
+ * Executes the callback with the specified propagation type.
27
+ */
28
+ async executeWithPropagation(propagation, em, cb, options, hasExistingTransaction) {
29
+ switch (propagation) {
30
+ case TransactionPropagation.NOT_SUPPORTED:
31
+ return this.executeWithoutTransaction(em, cb, options);
32
+ case TransactionPropagation.REQUIRES_NEW:
33
+ return this.executeWithNewTransaction(em, cb, options, hasExistingTransaction);
34
+ case TransactionPropagation.REQUIRED:
35
+ if (hasExistingTransaction) {
36
+ return cb(em);
37
+ }
38
+ return this.createNewTransaction(em, cb, options);
39
+ case TransactionPropagation.NESTED:
40
+ if (hasExistingTransaction) {
41
+ return this.executeNestedTransaction(em, cb, options);
42
+ }
43
+ return this.createNewTransaction(em, cb, options);
44
+ case TransactionPropagation.SUPPORTS:
45
+ if (hasExistingTransaction) {
46
+ return cb(em);
47
+ }
48
+ return this.executeWithoutTransaction(em, cb, options);
49
+ case TransactionPropagation.MANDATORY:
50
+ if (!hasExistingTransaction) {
51
+ throw TransactionStateError.requiredTransactionNotFound(propagation);
52
+ }
53
+ return cb(em);
54
+ case TransactionPropagation.NEVER:
55
+ if (hasExistingTransaction) {
56
+ throw TransactionStateError.transactionNotAllowed(propagation);
57
+ }
58
+ return this.executeWithoutTransaction(em, cb, options);
59
+ default:
60
+ throw TransactionStateError.invalidPropagation(propagation);
61
+ }
62
+ }
63
+ /**
64
+ * Suspends the current transaction and returns the suspended resources.
65
+ */
66
+ suspendTransaction(em) {
67
+ const suspended = em.getTransactionContext();
68
+ em.resetTransactionContext();
69
+ return suspended;
70
+ }
71
+ /**
72
+ * Resumes a previously suspended transaction.
73
+ */
74
+ resumeTransaction(em, suspended) {
75
+ if (suspended != null) {
76
+ em.setTransactionContext(suspended);
77
+ }
78
+ }
79
+ /**
80
+ * Executes operation without transaction context.
81
+ */
82
+ async executeWithoutTransaction(em, cb, options) {
83
+ const suspended = this.suspendTransaction(em);
84
+ const fork = this.createFork(em, { ...options, disableTransactions: true });
85
+ const propagateToUpperContext = this.shouldPropagateToUpperContext(em);
86
+ try {
87
+ return await this.executeTransactionFlow(fork, cb, propagateToUpperContext, em);
88
+ }
89
+ finally {
90
+ this.resumeTransaction(em, suspended);
91
+ }
92
+ }
93
+ /**
94
+ * Creates new independent transaction, suspending any existing one.
95
+ */
96
+ async executeWithNewTransaction(em, cb, options, hasExistingTransaction) {
97
+ const fork = this.createFork(em, options);
98
+ let suspended = null;
99
+ // Suspend existing transaction if present
100
+ if (hasExistingTransaction) {
101
+ suspended = this.suspendTransaction(em);
102
+ }
103
+ const newOptions = { ...options, ctx: undefined };
104
+ try {
105
+ return await this.processTransaction(em, fork, cb, newOptions);
106
+ }
107
+ finally {
108
+ if (suspended != null) {
109
+ this.resumeTransaction(em, suspended);
110
+ }
111
+ }
112
+ }
113
+ /**
114
+ * Creates new transaction context.
115
+ */
116
+ async createNewTransaction(em, cb, options) {
117
+ const fork = this.createFork(em, options);
118
+ return this.processTransaction(em, fork, cb, options);
119
+ }
120
+ /**
121
+ * Executes nested transaction with savepoint.
122
+ */
123
+ async executeNestedTransaction(em, cb, options) {
124
+ const fork = this.createFork(em, options);
125
+ // Pass existing context to create savepoint
126
+ const nestedOptions = { ...options, ctx: em.getTransactionContext() };
127
+ return this.processTransaction(em, fork, cb, nestedOptions);
128
+ }
129
+ /**
130
+ * Creates a fork of the EntityManager with the given options.
131
+ */
132
+ createFork(em, options) {
133
+ return em.fork({
134
+ clear: options.clear ?? false,
135
+ flushMode: options.flushMode,
136
+ cloneEventManager: true,
137
+ disableTransactions: options.ignoreNestedTransactions,
138
+ loggerContext: options.loggerContext,
139
+ });
140
+ }
141
+ /**
142
+ * Determines if changes should be propagated to the upper context.
143
+ */
144
+ shouldPropagateToUpperContext(em) {
145
+ return !em.global || this.em.config.get('allowGlobalContext');
146
+ }
147
+ /**
148
+ * Merges entities from fork to parent EntityManager.
149
+ */
150
+ mergeEntitiesToParent(fork, parent) {
151
+ const parentUoW = parent.getUnitOfWork(false);
152
+ // perf: if parent is empty, we can just move all entities from the fork to skip the `em.merge` overhead
153
+ if (parentUoW.getIdentityMap().keys().length === 0) {
154
+ for (const entity of fork.getUnitOfWork(false).getIdentityMap()) {
155
+ parentUoW.getIdentityMap().store(entity);
156
+ helper(entity).__em = parent;
157
+ }
158
+ return;
159
+ }
160
+ for (const entity of fork.getUnitOfWork(false).getIdentityMap()) {
161
+ const wrapped = helper(entity);
162
+ const meta = wrapped.__meta;
163
+ // eslint-disable-next-line dot-notation
164
+ const parentEntity = parentUoW.getById(meta.className, wrapped.getPrimaryKey(), parent['_schema'], true);
165
+ if (parentEntity && parentEntity !== entity) {
166
+ const parentWrapped = helper(parentEntity);
167
+ parentWrapped.__data = wrapped.__data;
168
+ parentWrapped.__originalEntityData = wrapped.__originalEntityData;
169
+ for (const prop of meta.hydrateProps) {
170
+ if (prop.kind === ReferenceKind.SCALAR) {
171
+ parentEntity[prop.name] = entity[prop.name];
172
+ }
173
+ }
174
+ }
175
+ else {
176
+ parentUoW.merge(entity, new Set([entity]));
177
+ }
178
+ }
179
+ }
180
+ /**
181
+ * Registers a deletion handler to unset entity identities after flush.
182
+ */
183
+ registerDeletionHandler(fork, parent) {
184
+ fork.getEventManager().registerSubscriber({
185
+ afterFlush: (args) => {
186
+ const deletionChangeSets = args.uow.getChangeSets()
187
+ .filter(cs => cs.type === ChangeSetType.DELETE || cs.type === ChangeSetType.DELETE_EARLY);
188
+ for (const cs of deletionChangeSets) {
189
+ parent.getUnitOfWork(false).unsetIdentity(cs.entity);
190
+ }
191
+ },
192
+ });
193
+ }
194
+ /**
195
+ * Processes transaction execution.
196
+ */
197
+ async processTransaction(em, fork, cb, options) {
198
+ const propagateToUpperContext = this.shouldPropagateToUpperContext(em);
199
+ const eventBroadcaster = new TransactionEventBroadcaster(fork, undefined);
200
+ return TransactionContext.create(fork, () => fork.getConnection().transactional(async (trx) => {
201
+ fork.setTransactionContext(trx);
202
+ return this.executeTransactionFlow(fork, cb, propagateToUpperContext, em);
203
+ }, { ...options, eventBroadcaster }));
204
+ }
205
+ /**
206
+ * Executes transaction workflow with entity synchronization.
207
+ */
208
+ async executeTransactionFlow(fork, cb, propagateToUpperContext, parentEm) {
209
+ if (!propagateToUpperContext) {
210
+ const ret = await cb(fork);
211
+ await fork.flush();
212
+ return ret;
213
+ }
214
+ // Setup: Register deletion handler before execution
215
+ this.registerDeletionHandler(fork, parentEm);
216
+ // Execute callback and flush
217
+ const ret = await cb(fork);
218
+ await fork.flush();
219
+ // Synchronization: Merge entities back to the parent
220
+ this.mergeEntitiesToParent(fork, parentEm);
221
+ return ret;
222
+ }
223
+ }
package/utils/Utils.d.ts CHANGED
@@ -1,9 +1,7 @@
1
- import { type GlobbyOptions } from 'globby';
2
1
  import type { Dictionary, EntityData, EntityDictionary, EntityKey, EntityMetadata, EntityName, EntityProperty, IMetadataStorage, Primary } from '../typings.js';
3
2
  import type { Collection } from '../entity/Collection.js';
4
3
  import type { Platform } from '../platforms/Platform.js';
5
4
  import type { ScalarReference } from '../entity/Reference.js';
6
- export declare const ObjectBindingPattern: unique symbol;
7
5
  export declare function compareObjects(a: any, b: any): boolean;
8
6
  export declare function compareArrays(a: any[] | string, b: any[] | string): boolean;
9
7
  export declare function compareBooleans(a: unknown, b: unknown): boolean;
@@ -102,26 +100,11 @@ export declare class Utils {
102
100
  */
103
101
  static renameKey<T>(payload: T, from: string | keyof T, to: string): void;
104
102
  /**
105
- * Returns array of functions argument names. Uses `esprima` for source code analysis.
103
+ * Returns array of functions argument names. Uses basic regex for source code analysis, might not work with advanced syntax.
106
104
  */
107
- static tokenize(func: {
105
+ static getConstructorParams(func: {
108
106
  toString(): string;
109
- } | string | {
110
- type: string;
111
- value: string;
112
- }[]): {
113
- type: string;
114
- value: string;
115
- }[];
116
- /**
117
- * Returns array of functions argument names. Uses `esprima` for source code analysis.
118
- */
119
- static getParamNames(func: {
120
- toString(): string;
121
- } | string | {
122
- type: string;
123
- value: string;
124
- }[], methodName?: string): string[];
107
+ }): string[] | undefined;
125
108
  /**
126
109
  * Checks whether the argument looks like primary key (string, number or ObjectId).
127
110
  */
@@ -134,14 +117,14 @@ export declare class Utils {
134
117
  static getCompositeKeyHash<T>(data: EntityData<T>, meta: EntityMetadata<T>, convertCustomTypes?: boolean, platform?: Platform, flat?: boolean): string;
135
118
  static getPrimaryKeyHash(pks: (string | Buffer | Date)[]): string;
136
119
  static splitPrimaryKeys<T extends object>(key: string): EntityKey<T>[];
137
- static getPrimaryKeyValues<T>(entity: T, primaryKeys: string[], allowScalar?: boolean, convertCustomTypes?: boolean): any;
120
+ static getPrimaryKeyValues<T>(entity: T, meta: EntityMetadata<T>, allowScalar?: boolean, convertCustomTypes?: boolean): any;
138
121
  static getPrimaryKeyCond<T>(entity: T, primaryKeys: EntityKey<T>[]): Record<string, Primary<T>> | null;
139
122
  /**
140
123
  * Maps nested FKs from `[1, 2, 3]` to `[1, [2, 3]]`.
141
124
  */
142
125
  static mapFlatCompositePrimaryKey(fk: Primary<any>[], prop: EntityProperty, fieldNames?: string[], idx?: number): Primary<any> | Primary<any>[];
143
126
  static getPrimaryKeyCondFromArray<T extends object>(pks: Primary<T>[], meta: EntityMetadata<T>): Record<string, Primary<T>>;
144
- static getOrderedPrimaryKeys<T>(id: Primary<T> | Record<string, Primary<T>>, meta: EntityMetadata<T>, platform?: Platform, convertCustomTypes?: boolean): Primary<T>[];
127
+ static getOrderedPrimaryKeys<T>(id: Primary<T> | Record<string, Primary<T>>, meta: EntityMetadata<T>, platform?: Platform, convertCustomTypes?: boolean, allowScalar?: boolean): Primary<T>[];
145
128
  /**
146
129
  * Checks whether given object is an entity instance.
147
130
  */
@@ -206,13 +189,14 @@ export declare class Utils {
206
189
  * If either `path` or `baseDir` are `file:` URLs, they are converted to local paths.
207
190
  */
208
191
  static absolutePath(path: string, baseDir?: string): string;
209
- static hash(data: string, length?: number): string;
192
+ static hash(data: string, length?: number, algorithm?: 'md5' | 'sha256'): string;
210
193
  static runIfNotEmpty(clause: () => any, data: any): void;
211
194
  static defaultValue<T extends Dictionary>(prop: T, option: keyof T, defaultValue: any): void;
212
195
  static findDuplicates<T>(items: T[]): T[];
213
196
  static removeDuplicates<T>(items: T[]): T[];
214
197
  static randomInt(min: number, max: number): number;
215
- static pathExists(path: string, options?: GlobbyOptions): Promise<boolean>;
198
+ static glob(input: string | string[], cwd?: string): string[];
199
+ static pathExists(path: string): boolean;
216
200
  /**
217
201
  * Extracts all possible values of a TS enum. Works with both string and numeric enums.
218
202
  */
@@ -230,10 +214,15 @@ export declare class Utils {
230
214
  * @param [from] Location to start the node resolution
231
215
  */
232
216
  static requireFrom<T extends Dictionary>(id: string, from?: string): T;
217
+ /**
218
+ * Resolve path to a module.
219
+ * @param id The module to require
220
+ * @param [from] Location to start the node resolution
221
+ */
222
+ static resolveModulePath(id: string, from?: string): string;
233
223
  static dynamicImport<T = any>(id: string): Promise<T>;
234
224
  static setDynamicImportProvider(provider: (id: string) => Promise<unknown>): void;
235
225
  static ensureDir(path: string): void;
236
- static pathExistsSync(path: string): boolean;
237
226
  static readJSONSync(path: string): Dictionary;
238
227
  static getORMVersion(): string;
239
228
  static createFunction(context: Map<string, any>, code: string): any;
@@ -246,19 +235,15 @@ export declare class Utils {
246
235
  static setPayloadProperty<T>(entity: EntityDictionary<T>, meta: EntityMetadata<T>, prop: EntityProperty<T>, value: unknown, idx: number[]): void;
247
236
  static tryRequire<T extends Dictionary = any>({ module, from, allowError, warning }: {
248
237
  module: string;
249
- warning: string;
238
+ warning?: string;
250
239
  from?: string;
251
240
  allowError?: string;
252
241
  }): T | undefined;
253
242
  static tryImport<T extends Dictionary = any>({ module, warning }: {
254
243
  module: string;
255
- warning: string;
244
+ warning?: string;
256
245
  }): Promise<T | undefined>;
257
246
  static stripRelativePath(str: string): string;
258
- /**
259
- * simple process.argv parser, supports only properties with long names, prefixed with `--`
260
- */
261
- static parseArgs<T extends Dictionary = Dictionary>(): T;
262
247
  static xor(a: boolean, b: boolean): boolean;
263
248
  static keys<T extends object>(obj: T): (keyof T)[];
264
249
  static values<T extends object>(obj: T): T[keyof T][];