@mikro-orm/core 7.0.10-dev.5 → 7.0.10-dev.7

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.
@@ -39,11 +39,6 @@ export class EntityHelper {
39
39
  // toJSON can be overridden
40
40
  Object.defineProperty(prototype, 'toJSON', {
41
41
  value: function (...args) {
42
- // Guard against being called on the prototype itself (e.g. by serializers
43
- // walking the object graph and calling toJSON on prototype objects)
44
- if (this === prototype) {
45
- return {};
46
- }
47
42
  return EntityTransformer.toObject(this, ...args);
48
43
  },
49
44
  writable: true,
@@ -51,6 +46,22 @@ export class EntityHelper {
51
46
  enumerable: false,
52
47
  });
53
48
  }
49
+ // Walkers / serializers reaching the prototype directly invoke its methods and
50
+ // accessors with `this === prototype`. Wrap each so that case is a no-op rather
51
+ // than throwing (when a user `@Property({ persist: false })` getter dereferences
52
+ // unhydrated instance state) or installing state on the prototype itself (#7151).
53
+ for (const name of Object.getOwnPropertyNames(prototype)) {
54
+ const desc = Object.getOwnPropertyDescriptor(prototype, name);
55
+ const fn = desc.get ?? desc.value;
56
+ if (name === 'constructor' || typeof fn !== 'function' || fn.__guarded) {
57
+ continue;
58
+ }
59
+ const guarded = function (...args) {
60
+ return this === prototype ? undefined : fn.apply(this, args);
61
+ };
62
+ guarded.__guarded = true;
63
+ Object.defineProperty(prototype, name, desc.get ? { ...desc, get: guarded } : { ...desc, value: guarded });
64
+ }
54
65
  }
55
66
  /**
56
67
  * As a performance optimization, we create entity state methods lazily. We first add
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@mikro-orm/core",
3
- "version": "7.0.10-dev.5",
3
+ "version": "7.0.10-dev.7",
4
4
  "description": "TypeScript ORM for Node.js based on Data Mapper, Unit of Work and Identity Map patterns. Supports MongoDB, MySQL, PostgreSQL and SQLite databases as well as usage with vanilla JavaScript.",
5
5
  "keywords": [
6
6
  "data-mapper",
@@ -1188,20 +1188,21 @@ export class UnitOfWork {
1188
1188
  }
1189
1189
  getCommitOrder() {
1190
1190
  const calc = new CommitOrderCalculator();
1191
- const set = new Set();
1191
+ // keyed by `_id` so we return the SAME instances as the change set groups (GH #7511)
1192
+ const metaById = new Map();
1192
1193
  this.#changeSets.forEach(cs => {
1193
1194
  if (cs.meta.inheritanceType === 'tpt') {
1194
- set.add(cs.meta);
1195
+ metaById.set(cs.meta._id, cs.meta);
1195
1196
  for (const parentCs of cs.tptChangeSets ?? []) {
1196
- set.add(parentCs.meta);
1197
+ metaById.set(parentCs.meta._id, parentCs.meta);
1197
1198
  }
1198
1199
  }
1199
1200
  else {
1200
- set.add(cs.rootMeta);
1201
+ metaById.set(cs.rootMeta._id, cs.rootMeta);
1201
1202
  }
1202
1203
  });
1203
- set.forEach(meta => calc.addNode(meta._id));
1204
- for (const meta of set) {
1204
+ metaById.forEach(meta => calc.addNode(meta._id));
1205
+ for (const meta of metaById.values()) {
1205
1206
  for (const prop of meta.relations) {
1206
1207
  if (prop.polymorphTargets) {
1207
1208
  for (const targetMeta of prop.polymorphTargets) {
@@ -1213,11 +1214,11 @@ export class UnitOfWork {
1213
1214
  }
1214
1215
  }
1215
1216
  // For TPT, parent table must be inserted BEFORE child tables
1216
- if (meta.inheritanceType === 'tpt' && meta.tptParent && set.has(meta.tptParent)) {
1217
+ if (meta.inheritanceType === 'tpt' && meta.tptParent && metaById.has(meta.tptParent._id)) {
1217
1218
  calc.addDependency(meta.tptParent._id, meta._id, 1);
1218
1219
  }
1219
1220
  }
1220
- return calc.sort().map(id => this.#metadata.getById(id));
1221
+ return calc.sort().map(id => metaById.get(id));
1221
1222
  }
1222
1223
  resetTransaction(oldTx) {
1223
1224
  if (oldTx) {
package/utils/Utils.js CHANGED
@@ -132,7 +132,7 @@ export function parseJsonSafe(value) {
132
132
  /** Collection of general-purpose utility methods used throughout the ORM. */
133
133
  export class Utils {
134
134
  static PK_SEPARATOR = '~~~';
135
- static #ORM_VERSION = '7.0.10-dev.5';
135
+ static #ORM_VERSION = '7.0.10-dev.7';
136
136
  /**
137
137
  * Checks if the argument is instance of `Object`. Returns false for arrays.
138
138
  */
package/utils/fs-utils.js CHANGED
@@ -14,10 +14,11 @@ export const fs = {
14
14
  if (tinyGlobby) {
15
15
  globSync = (patterns, options) => {
16
16
  patterns = Utils.asArray(patterns).map(p => p.replace(/\\/g, '/'));
17
- if (options?.cwd) {
18
- options = { ...options, cwd: options.cwd.replace(/\\/g, '/') };
19
- }
20
- return tinyGlobby.globSync(patterns, { ...options, expandDirectories: false });
17
+ // never forward `cwd: undefined` — tinyglobby >= 0.2.16 calls `path.resolve(undefined)` and throws
18
+ return tinyGlobby.globSync(patterns, {
19
+ expandDirectories: false,
20
+ ...(options?.cwd && { cwd: options.cwd.replace(/\\/g, '/') }),
21
+ });
21
22
  };
22
23
  }
23
24
  },