From 25ef87026bca935b00d30ad943ddd28784f801e8 Mon Sep 17 00:00:00 2001 From: Anna Henningsen Date: Fri, 22 Jan 2021 21:18:33 +0100 Subject: [PATCH] fix: restore `createAutoEncrypter()` functionality (#2710) Corrects the import name of the AutoEncrypter class. Passes through client constructor options to CSFLE lib. NODE-3042 --- src/connection_string.ts | 2 +- src/operations/connect.ts | 17 +++++++++++------ 2 files changed, 12 insertions(+), 7 deletions(-) diff --git a/src/connection_string.ts b/src/connection_string.ts index 125a5a107b..81d68a66fb 100644 --- a/src/connection_string.ts +++ b/src/connection_string.ts @@ -418,7 +418,7 @@ export function parseOptions( checkTLSOptions(mongoOptions); if (mongoClient && options.autoEncryption) { - mongoOptions.autoEncrypter = createAutoEncrypter(mongoClient); + mongoOptions.autoEncrypter = createAutoEncrypter(mongoClient, options); } if (options.promiseLibrary) PromiseProvider.set(options.promiseLibrary); diff --git a/src/operations/connect.ts b/src/operations/connect.ts index dd27abb9ec..da701abf7e 100644 --- a/src/operations/connect.ts +++ b/src/operations/connect.ts @@ -4,7 +4,7 @@ import { resolveSRVRecord } from '../connection_string'; import { emitDeprecationWarning, Callback } from '../utils'; import { CMAP_EVENT_NAMES } from '../cmap/events'; import * as BSON from '../bson'; -import type { MongoClient, MongoOptions } from '../mongo_client'; +import type { MongoClient, MongoOptions, MongoClientOptions } from '../mongo_client'; import { Connection } from '../cmap/connection'; import { Server } from '../sdam/server'; import type { AutoEncrypter } from '../deps'; @@ -114,8 +114,11 @@ function registerDeprecatedEventNotifiers(client: MongoClient) { * returns undefined if CSFLE is not enabled. * @throws if optional 'mongodb-client-encryption' dependency missing */ -export function createAutoEncrypter(client: MongoClient): AutoEncrypter | undefined { - if (!client.options.autoEncryption) { +export function createAutoEncrypter( + client: MongoClient, + options: MongoClientOptions +): AutoEncrypter | undefined { + if (!options.autoEncryption) { return; } try { @@ -135,10 +138,12 @@ export function createAutoEncrypter(client: MongoClient): AutoEncrypter | undefi 'Please make sure you are loading the correct version of `mongodb-client-encryption`' ); } - // eslint-disable-next-line @typescript-eslint/no-var-requires - const { AutoEncrypterClass } = mongodbClientEncryption.extension(require('../../lib/index')); + const { AutoEncrypter: AutoEncrypterClass } = mongodbClientEncryption.extension( + // eslint-disable-next-line @typescript-eslint/no-var-requires + require('../../lib/index') + ); - const mongoCryptOptions = Object.assign({ bson: BSON }, client.options.autoEncryption); + const mongoCryptOptions = Object.assign({ bson: BSON }, options.autoEncryption); return new AutoEncrypterClass(client, mongoCryptOptions); }