From fe54b3e196523dc68df6208b01ccc8f7f76498b9 Mon Sep 17 00:00:00 2001 From: Nico Francois Date: Wed, 31 Jan 2024 09:23:30 +0100 Subject: [PATCH] fix: replace Symbol with a private 'buffer' property in ObjectId to avoid errors when mixing cjs and mjs --- src/objectid.ts | 18 +++++++++--------- test/node/object_id.test.ts | 3 +-- 2 files changed, 10 insertions(+), 11 deletions(-) diff --git a/src/objectid.ts b/src/objectid.ts index a1a46f4e..b448f61b 100644 --- a/src/objectid.ts +++ b/src/objectid.ts @@ -21,8 +21,6 @@ export interface ObjectIdExtended { $oid: string; } -const kId = Symbol('id'); - /** * A class representation of the BSON ObjectId type. * @public @@ -39,7 +37,7 @@ export class ObjectId extends BSONValue { static cacheHexString: boolean; /** ObjectId Bytes @internal */ - private [kId]!: Uint8Array; + private buffer!: Uint8Array; /** ObjectId hexString cache @internal */ private __id?: string; @@ -108,13 +106,13 @@ export class ObjectId extends BSONValue { if (workingId == null || typeof workingId === 'number') { // The most common use case (blank id, new objectId instance) // Generate a new id - this[kId] = ObjectId.generate(typeof workingId === 'number' ? workingId : undefined); + this.buffer = ObjectId.generate(typeof workingId === 'number' ? workingId : undefined); } else if (ArrayBuffer.isView(workingId) && workingId.byteLength === 12) { // If intstanceof matches we can escape calling ensure buffer in Node.js environments - this[kId] = ByteUtils.toLocalBufferType(workingId); + this.buffer = ByteUtils.toLocalBufferType(workingId); } else if (typeof workingId === 'string') { if (workingId.length === 24 && checkForHexRegExp.test(workingId)) { - this[kId] = ByteUtils.fromHex(workingId); + this.buffer = ByteUtils.fromHex(workingId); } else { throw new BSONError( 'input must be a 24 character hex string, 12 byte Uint8Array, or an integer' @@ -134,11 +132,11 @@ export class ObjectId extends BSONValue { * @readonly */ get id(): Uint8Array { - return this[kId]; + return this.buffer; } set id(value: Uint8Array) { - this[kId] = value; + this.buffer = value; if (ObjectId.cacheHexString) { this.__id = ByteUtils.toHex(value); } @@ -240,7 +238,9 @@ export class ObjectId extends BSONValue { } if (ObjectId.is(otherId)) { - return this[kId][11] === otherId[kId][11] && ByteUtils.equals(this[kId], otherId[kId]); + return ( + this.buffer[11] === otherId.buffer[11] && ByteUtils.equals(this.buffer, otherId.buffer) + ); } if (typeof otherId === 'string') { diff --git a/test/node/object_id.test.ts b/test/node/object_id.test.ts index d49f3bb5..2af8b132 100644 --- a/test/node/object_id.test.ts +++ b/test/node/object_id.test.ts @@ -3,7 +3,6 @@ import { BSON, BSONError, EJSON, ObjectId } from '../register-bson'; import * as util from 'util'; import { expect } from 'chai'; import { bufferFromHexArray } from './tools/utils'; -import { getSymbolFrom } from './tools/utils'; import { isBufferOrUint8Array } from './tools/utils'; describe('ObjectId', function () { @@ -376,7 +375,7 @@ describe('ObjectId', function () { */ const oidString = '6b61666665656b6c61746368'; const oid = new ObjectId(oidString); - const oidKId = getSymbolFrom(oid, 'id'); + const oidKId = 'buffer'; it('should return false for an undefined otherId', () => { // otherId === undefined || otherId === null expect(oid.equals(null)).to.be.false;