Update dependency mongodb to ^3.7.3
This MR contains the following updates:
Package | Change | Age | Adoption | Passing | Confidence |
---|---|---|---|---|---|
mongodb | ^3.1.13 -> ^3.7.3 |
Release Notes
mongodb/node-mongodb-native
v3.7.3
The MongoDB Node.js team is pleased to announce version 3.7.3 of the mongodb package!
What's Changed
- fix(NODE-3515): do proper opTime merging in bulk results by @durran in https://github.com/mongodb/node-mongodb-native/pull/3011
Full Changelog: https://github.com/mongodb/node-mongodb-native/compare/v3.7.2...v3.7.3
Documentation
- Reference: https://docs.mongodb.com/drivers/node
- API: https://mongodb.github.io/node-mongodb-native/3.7
- Changelog: https://github.com/mongodb/node-mongodb-native/blob/3.7/HISTORY.md
We invite you to try the mongodb library immediately, and report any issues to the NODE project.
v3.7.2
The MongoDB Node.js team is pleased to announce version 3.7.2 of the mongodb package!
Release Highlights
This release contains a fix for optional require of dependencies on yarn berry.
Bug Fixes
Documentation
- Reference: https://docs.mongodb.com/drivers/node
- API: https://mongodb.github.io/node-mongodb-native/3.7
- Changelog: https://github.com/mongodb/node-mongodb-native/blob/3.7/HISTORY.md
We invite you to try the mongodb library immediately, and report any issues to the NODE project.
v3.7.1
The MongoDB Node.js team is pleased to announce version 3.7.1 of the mongodb package!
Release Highlights
This release contains an internal improvement that makes our monitor utilize the new hello handshake for monitoring when available.
Features
Documentation
- Reference: https://docs.mongodb.com/drivers/node
- API: https://mongodb.github.io/node-mongodb-native/3.7
- Changelog: https://github.com/mongodb/node-mongodb-native/blob/3.7/HISTORY.md
We invite you to try the mongodb library immediately, and report any issues to the NODE project.
v3.7.0
The MongoDB Node.js team is pleased to announce version 3.7.0 of the mongodb package!
Release Highlights
Versioned API
Versioned API is a new feature in MongoDB 5.0 that allows user-selectable API versions, subsets of MongoDB server semantics, to be declared on a client. During communication with a server, clients with a declared API version will force the server to behave in a manner compatible with the API version. Declaring an API version on a client can be used to ensure consistent responses from a server, providing long term API stability for an application. The declared API version is applied to all commands run through the client, including those sent through the generic RunCommand helper. Specifying versioned API options in the command document AND declaring an API version on the client is not supported and will lead to undefined behavior.
Declare an API version on a client
// Declare API version "1" for the client
client = new MongoClient(uri, { serverApi: { version: '1' } });
cursor = client.db('database').collection('coll').find(...);
Strict mode
Declaring a strict
API version will cause the MongoDB server to reject all commands that are not part of the declared API version. This includes command options and aggregation pipeline stages. For example, the following find
call would fail because the tailable
option is not part of version 1:
// Declare API version "1" for the client, with strict on
client = new MongoClient(uri, { serverApi: { version: '1', strict: true } });
// Fails with an error
cursor = client.db('database').collection('coll').find({ ... }, { tailable: true });
Deprecation Errors
The deprecationErrors
option can be used to enable command failures when using functionality that is deprecated from version 1. Note that at the time of this writing, no deprecations in version 1 exist.
// Declare API version "1" for the client, with deprecationErrors on
client = new MongoClient(uri, { serverApi: { version: '1', deprecationErrors: true } });
// Note: since API version "1" is the initial version, there are no deprecated commands to provide as an example yet.
Features
Bug Fixes
- NODE-3377: driver should allow arbitrary explain levels (#2961) (96c8ab4)
- NODE-3463: pass explain error through to callback (#2949) (e5975af)
Documentation
- Reference: https://docs.mongodb.com/drivers/node/current/
- API: https://mongodb.github.io/node-mongodb-native/3.7/api/
- Changelog: https://github.com/mongodb/node-mongodb-native/blob/v3.7.0/HISTORY.md
We invite you to try the mongodb library immediately, and report any issues to the NODE project.
v3.6.12
The MongoDB Node.js team is pleased to announce version 3.6.12 of the mongodb package!
Bug Fixes
- NODE-3487: check for nullish aws mechanism property (#2957) (5902b4c)
- NODE-3528: add support for snappy v7 (#2947) (54f5c2d)
Documentation
- Reference: https://docs.mongodb.com/drivers/node/current/
- API: https://mongodb.github.io/node-mongodb-native/3.6/api/
- Changelog: https://github.com/mongodb/node-mongodb-native/blob/v3.6.12/HISTORY.md
We invite you to try the mongodb library immediately, and report any issues to the NODE project.
v3.6.11
The MongoDB Node.js team is pleased to announce version 3.6.11 of the mongodb package!
Release Highlights
This patch addresses a few bugs listed below. Notably, we fixed an issue with the way we imported one of our optional dependencies that blocked webpack bundling.
If you are a webpack user you will still get warnings for our optional dependencies (if you don't use them). You can hush the warnings by adding this option to your webpack config:
{
// ...
externals: [
'mongodb-client-encryption',
'aws4',
'saslprep',
'kerberos',
'snappy',
'bson-ext',
],
// ...
}
It is important to note that this will leave the imports in place and not pull in the code to your bundle. If you later do adopt using these dependencies you'll want to revert the relevant setting.
Bug Fixes
- NODE-1843: bulk operations ignoring provided sessions (#2898) (9244b17)
- NODE-3199: unable to bundle driver due to uncaught require (#2903) (60efe9d)
Documentation
- Reference: https://docs.mongodb.com/drivers/node/current/
- API: http://mongodb.github.io/node-mongodb-native/3.6/api
- Changelog: https://github.com/mongodb/node-mongodb-native/blob/3.6/HISTORY.md
We invite you to try the mongodb package immediately, and report any issues to the NODE project.
v3.6.10
The MongoDB Node.js team is pleased to announce version 3.6.10 of the mongodb package!
Release Highlights
This patch addresses a few bugs listed below. Notably the bsonRegExp
option is now respected by the underlying BSON library, you can use this to decode regular expressions that contain syntax not permitted in native JS RegExp objects. Take a look at this example:
await collection.insertOne({ a: new BSONRegExp('(?-i)AA_') })
await collection.findOne({ a: new BSONRegExp('(?-i)AA_') }, { bsonRegExp: true })
// { _id: ObjectId, a: BSONRegExp { pattern: '(?-i)AA_', options: '' } }
Also there was an issue with Cursor.forEach
where user defined forEach callbacks that throw errors incorrectly handled catching errors. Take a look at the comments in this example:
collection.find({}).forEach(doc => {
if(doc.bad) throw new Error('bad document!');
}).catch(error => {
// now this is called! and error is `bad document!`
})
// before this fix the `bad document!` error would be thrown synchronously
// and have to be caught with try catch out here
Bug Fixes
- NODE-2035: Exceptions thrown from awaited cursor forEach do not propagate (#2852) (a917dfa)
- NODE-3150: added bsonRegExp option for v3.6 (#2843) (e4a9a57)
- NODE-3358: Command monitoring objects hold internal state references (#2858) (750760c)
- NODE-3380: perform retryable write checks against server (#2861) (621677a)
- NODE-3397: report more helpful error with unsupported authMechanism in initial handshake (#2876) (3ce148d)
Documentation
- Reference: https://docs.mongodb.com/drivers/node/current/
- API: http://mongodb.github.io/node-mongodb-native/3.6/api
- Changelog: https://github.com/mongodb/node-mongodb-native/blob/3.6/HISTORY.md
We invite you to try the mongodb package immediately, and report any issues to the NODE project.
v3.6.9
The MongoDB Node.js team is pleased to announce version 3.6.9 of the driver!
Release Highlights
This release fixes a major performance bug in bulk write operations, which was inadvertently introduced by an incomplete code change in the previous release. The bug resulted in redundant array iterations and caused exponential increases in bulk operation completion times. Thank you Jan Schwalbe for bringing this to our attention!
Bug Fixes
- NODE-3309: remove redundant iteration of bulk write result (#2815) (fac9610)
- NODE-3234: fix url parsing for a mongodb+srv url that has commas in the database name (#2789) (58c4e69)
Documentation
- Reference: https://docs.mongodb.com/drivers/node/current/
- API: http://mongodb.github.io/node-mongodb-native/3.6/api
- Changelog: https://github.com/mongodb/node-mongodb-native/blob/3.6/HISTORY.md
We invite you to try the mongodb package immediately, and report any issues to the NODE project.
v3.6.8
The MongoDB Node.js team is pleased to announce version 3.6.8 of the mongodb package!
Release Highlights
Thanks to the quick adoption of the previous new patch by the mongoose package (https://github.com/Automattic/mongoose/pull/10265) a small bug was identified when connections to mongodb would timeout causing unnecessary clean up operations to run. Thank you @vkarpov15!
Bug Fixes
Documentation
- Reference: https://docs.mongodb.com/drivers/node/current/
- API: http://mongodb.github.io/node-mongodb-native/3.6/api
- Changelog: https://github.com/mongodb/node-mongodb-native/blob/3.6/HISTORY.md
We invite you to try the mongodb package immediately, and report any issues to the NODE project.
v3.6.7
The MongoDB Node.js team is pleased to announce version 3.6.7 of the driver
Release Highlights
This patch addresses a number of bug fixes. Notably, there was an interesting javascript related issue with sorting documents. It only impacts users using numerical keys in their documents.
> { a: 'asc', [23]: 'asc' }
{ [23]: 'asc', a: 'asc' } // numbers come first
In javascript, numerical keys are always iterated first when looping over the keys of an object followed by the chronological specification of each string key. This effectively changes the ordering of a sort document sent to mongodb. However our driver does accept sort specification in a variety of ways and one way to avoid this problem is passing an array of tuples:
[['a', 'asc'], ['23', 'asc']]
This ensures that mongodb is sent the 'a'
key as the first sort key and '23'
as the second.
Bug Fixes
- NODE-3159: removing incorrect apm docs (#2793) (971259a)
- NODE-3173: Preserve sort key order for numeric string keys (#2790) (730f43a)
- NODE-3176: handle errors from MessageStream (#2774) (f1afcc4)
- NODE-3192: check clusterTime is defined before access (#2806) (6ceace6)
- NODE-3252: state transistion from DISCONNECTED (#2807) (5d8f649)
- NODE-3219: topology no longer causes close event (#2791) (16e7064)
- invalid case on writeconcern makes skip check fail (#2773) (b1363c2)
Documentation
- Reference: http://mongodb.github.io/node-mongodb-native/3.6
- API: http://mongodb.github.io/node-mongodb-native/3.6/api
- Changelog: https://github.com/mongodb/node-mongodb-native/blob/3.6/HISTORY.md
We invite you to try the driver immediately, and report any issues to the NODE project.
Thanks very much to all the community members who contributed to this release!
v3.6.6
The MongoDB Node.js team is pleased to announce version 3.6.6 of the driver
Release Highlights
This patch addresses a number of bugs listed below.
Most notably, for client side encryption users upgrading to this version of the driver along with the new version of mongodb-client-encryption@1.2.3 will alleviate the potential deadlock case if your connection pool was fully utilized. There will now be an internal MongoClient that will be used for metadata look ups (e.g, listCollections
) when the pool size is under certain constraints. The events generated from this client are forwarded to the client instance you initialize so it is possible to monitor all events.
Bug
- [NODE-2995] - Sharing a MongoClient for metadata lookup can lead to deadlock in drivers using automatic encryption
- [NODE-3050] - Infinite loop on Windows due to a bug in require_optional package
- [NODE-3120] - TypeError: Cannot read property 'roundTripTime' of undefined
- [NODE-3122] - Pipelining an upload stream of GridFSBucket never finishes on Node v14
- [NODE-3129] - Collection () .. .setReadPreference() not routing query to secondaries
- [NODE-3133] - autoEncryption produces serverHeartbeatFailed - with MongoError typemismatch
Improvement
- [NODE-3070] - Define error handling behavior of writeErrors and writeConcernError on Mongos
Documentation
- Reference: http://mongodb.github.io/node-mongodb-native/3.6
- API: http://mongodb.github.io/node-mongodb-native/3.6/api
- Changelog: https://github.com/mongodb/node-mongodb-native/blob/3.6/HISTORY.md
We invite you to try the driver immediately, and report any issues to the NODE project.
Thanks very much to all the community members who contributed to this release!
v3.6.5
The MongoDB Node.js team is pleased to announce version 3.6.5 of the driver!
Notable Fixes
In this patch there is a fix surrounding an issue some users were encountering in serverless environments when using the Unified Topology. If the nodejs process went unused for a great amount of time there was an intermittent issue that would cause startSession
to fail, however, issuing a dummy read request would resolve the problem. The session support check is now done after server selection meaning the driver has the most up to date information about the MongoDB deployment before utilizing sessions. We encourage any user's that implemented workarounds to updated their driver and make use of this fix.
In addition, the previous release of our driver added a warning about an upcoming change in the v4 version of the driver about how users can specify their write concern options. We've updated the driver to use nodejs's process.emitWarning
API in nearly all cases where the driver prints something out, as well as limit most warning messages to only be printed once.
Bug
- session support detection spec compliance (#2732) (9baec71)
- [NODE-3100] - startSession fails intermittently on servers that support sessions
- [NODE-3066] - Accessing non-existent property 'MongoError' of module exports inside circular dependency
- [NODE-3114] - Incorrect warning: Top-level use of w, wtimeout, j, and fsync is deprecated
- [NODE-3119] - Node 14.5.4, mongo 3.6.4 Circular warnings
v3.6.4
MongoDB Driver v3.6.4
The MongoDB Node.js team is pleased to announce version 3.6.4 of the driver
Release Highlights
Explain Support
The full set of $explain verbosity settings are now supported:
queryPlanner
queryPlannerExtended
executionStats
allPlansExecution
In the following commands:
-
aggregate()
(MDB 3.0+) -
find()
(MDB 3.0+) -
remove()
(MDB 3.0+) -
update()
(MDB 3.0+) -
distinct()
(MDB 3.2+) -
findAndModify()
(MDB 3.2+) -
mapReduce()
(MDB 4.4+)
You can get a lot of insight into the performance of a query or optimization using these fine grained reports. To learn more about how to use explain read here.
Direct Connection Issue Revert
We removed automatic direct connection for the unified topology in the 3.6.3 release of the driver. This change was preparatory for the 4.0 version of the driver, where we'll always perform automatic discovery. To avoid making this kind of change in a patch release, this version restores automatic direct connection when connecting to a single host using the unified topology without a specified replicaSet and without directConnection: false, in line with previous 3.6 releases.
NOTE: In the next major version the
unifiedTopology
is the only Topology and it is required to either specify areplicaSet
name or enabledirectConnection
in order to connect to single nodes in a replica set.
Support Azure and GCP keystores in FLE
There are no functional changes to the driver to support using Azure and GCP keystores but a new mongodb-client-encryption release (v1.2.0) can be found here which prominently features support for these key stores.
Documentation
- Reference: http://mongodb.github.io/node-mongodb-native/3.6
- API: http://mongodb.github.io/node-mongodb-native/3.6/api
- Changelog: https://github.com/mongodb/node-mongodb-native/blob/3.6/HISTORY.md
We invite you to try the driver immediately, and report any issues to the NODE project.
Thanks very much to all the community members who contributed to this release!
Release Notes
Bug
- [NODE-2355] - GridFSBucketWriteStream doesn't implement stream.Writable properly
- [NODE-2828] - noCursorTimeout does not seem to for find()
- [NODE-2874] - Setting connectionTimeoutMS to 0 will result in a disconnection every heartbeatFrequencyMS
- [NODE-2876] - Race condition when resetting server monitor
- [NODE-2916] - Legacy topology hangs with unlimited socket timeout
- [NODE-2945] - ignoreUndefined not works on findOneAndUpdate when { upsert: true }
- [NODE-2965] - MongoClient.readPreference returns "primary" ignoring readPref from connection string
- [NODE-2966] - Unified topology: server selection fails when trying to connect to a remote replica set with a member whose 'host' attribute resolves to 'localhost'
- [NODE-2977] - Query parameters with path in connection string not working on windows
- [NODE-2986] - MongoError: pool destroyed
Features
- [NODE-2762] - Comprehensive Support for Explain
- [NODE-2852] - Add explain support to non-cursor commands
- [NODE-2853] - Add explain support to cursor-based commands
Improvement
- [NODE-1726] - Deprecate Topology events in
Db
- [NODE-2825] - Support Azure and GCP keystores in FLE
- [NODE-2880] - Improve stack traces in the session leak checker
- [NODE-2895] - Update AggregateCursor "unwind" method to match the native driver
- [NODE-2995] - Sharing a MongoClient for metadata lookup can lead to deadlock in drivers using automatic encryption
v3.6.3
The MongoDB Node.js team is pleased to announce version 3.6.3 of the driver
Release Highlights
MongoError: not master
when running createIndex
A regression introduced in v3.6.2 meant that createIndex
operations would not be executed with a fixed
primary read preference. This resulted in the driver selecting any server for the operation, which would
fail if a non-primary was selected.
Performance issues on AWS Lambda
The driver periodically monitors members of the replicaset for changes in the topology, but ensures that
the "monitoring thread" is never woken sooner than 500ms. Measuring this elapsed time depends on a
stable clock, which is not available to us in some virtualized environments like AWS Lambda. The result
was that periodically operations would think there were no available servers, and the driver would force
a wait of heartbeatFrequencyMS
(10s by default) before reaching out to servers again for a new
monitoring check. The internal async interval timer has been improved to account for these environments
GSSAPI AuthProvider reuses single kerberos client
A regression introduced in v3.6.0 forced the driver to reuse a single kerberos client for all
authentication attempts. This would result in incomplete authentication flows, and occaisionally even
a crash in the kerberos
module. The driver has been reverted to creating a kerberos client per
authentication attempt.
Performance regression due to use of setImmediate
A change introduced in v3.6.1 switched all our usage of process.nextTick
in the connection pool with
setImmediate
per Node.js core recommendation. This was observed to introduce noticeable latency when the event loop
was experiencing pressure, so the change was reverted for this release pending further investigation.
Community Contributions
- @jswangjunsheng submitted a fix for a rare scenario when wait queue members time out before connection establishment
- @through-a-haze submitted a fix for incorrect construction of an X509 authentication message
-
@andreialecu helped us indicate peer optional dependencies in our
package.json
for stricter package managers (pnpm, yarn2)
Documentation
Reference: http://mongodb.github.io/node-mongodb-native/3.6/ API: http://mongodb.github.io/node-mongodb-native/3.6/api/ Changelog: https://github.com/mongodb/node-mongodb-native/blob/3.6/HISTORY.md
We invite you to try the driver immediately, and report any issues to the NODE project.
Thanks very much to all the community members who contributed to this release!
Release Notes
Bug
- [NODE-2172] - Change stream breaks on disconnection when there39;s something piped into it.
- [NODE-2784] - MongoError: Not Master when running createIndex in 3.6.0
- [NODE-2807] - MongoClient.readPreference always returns primary
- [NODE-2827] - Connecting to single mongos makes driver think it is connected to a standalone
- [NODE-2829] - MongoDB Driver 3.6+ Performance issues on AWS Lambda
- [NODE-2835] - Remove default timeout for read operations
- [NODE-2859] - GSSAPI AuthProvider causing crashes in Compass
- [NODE-2861] - Performance Regression for usage of mongodb connections (queries, inserts, ...)
- [NODE-2865] - Connections can be leaked if wait queue members are cancelled
- [NODE-2869] - Invalid assignment of X509 username makes authentication impossible
Improvement
- [NODE-2834] - Remove deprecation of AggregationCursor#geoNear
- [NODE-2867] - Use peerDependenciesMeta field to mark peer optional dependencies
v3.6.2
The MongoDB Node.js team is pleased to announce version 3.6.2 of the driver
Release Highlights
bl
dependency due to CVE-2020-8244
Updated See this link for more details: https://github.com/advisories/GHSA-pp7h-53gx-mx7r
Connection pool wait queue processing is too greedy
The logic for processing the wait queue in our connection pool ran the risk of
starving the event loop. Calls to process the wait queue are now wrapped in a
setImmediate
to prevent starvation
Documentation
Reference: http://mongodb.github.io/node-mongodb-native/3.6/ API: http://mongodb.github.io/node-mongodb-native/3.6/api/ Changelog: https://github.com/mongodb/node-mongodb-native/blob/3.6/HISTORY.md
We invite you to try the driver immediately, and report any issues to the NODE project.
Thanks very much to all the community members who contributed to this release!
Release Notes
Bug
- [NODE-2798] - Update version of dependency "bl" due to vulnerability
- [NODE-2803] - Connection pool wait queue processing is too greedy
v3.6.1
The MongoDB Node.js team is pleased to announce version 3.6.1 of the driver
Release Highlights
Kerberos
A bug in introducing the new CMAP Connection
prevented some users from properly authenticating with the kerberos
module.
createIndex
Index options are not respected with The logic for building the createIndex
command was changed in v3.6.0 to use an allowlist rather than a blocklist, but omitted a number of index types in that list. This release reintroduces all supported index types to the allowlist.
createCollection
Remove strict mode for Since v3.6.0 createCollection
will no longer returned a cached Collection
instance if a collection already exists in the database, rather it will return a server error stating that the collection already exists. This is the same behavior provided by the strict
option for createCollection
, so that option has been removed from documentation.
Documentation
Reference: http://mongodb.github.io/node-mongodb-native/3.6/ API: http://mongodb.github.io/node-mongodb-native/3.6/api/ Changelog: https://github.com/mongodb/node-mongodb-native/blob/3.6/HISTORY.md
We invite you to try the driver immediately, and report any issues to the NODE project.
Thanks very much to all the community members who contributed to this release!
Release Notes
Bug
- [NODE-2731] - CMAP Connection type does not provide host/port properties
- [NODE-2755] - "language_override" option support for text index is broken
Improvement
- [NODE-2730] - Move MongoAuthProcess into the driver source tree
- [NODE-2746] - Strict mode for `createCollection` should be removed
v3.6.0
The MongoDB Node.js team is pleased to announce version 3.6.0 of the driver
NOTE: This version begins our official support for MongoDB 4.4
Release Highlights
Streaming topology changes
MongoDB drivers maintain a local view of the topology they are connected to, and ensure the accuracy of that view by polling connected nodes on average every ~10s. In MongoDB 4.4, drivers are now able to receive push notifications about topology updates, effectively reducing the time for client recovery in failover scenarios to the time it takes for the server to make the election and report the outcome.
This feature is enabled by default when connecting to MongoDB 4.4, no changes are needed for user code.
Authentication
MONGODB-AWS authentication mechanism
The MONGODB-AWS authentication mechanism uses your Amazon Web Services Identity and Access Management (AWS IAM) credentials to authenticate users on MongoDB 4.4+. Please read more about this new authentication mechanism in our documentation.
Performance improvements
There were two projects to transparently improve performance of authentication in MongoDB 4.4:
-
A driver can now include the first
saslStart
command in its initial handshake with server. This so-called "speculative authentication" allows us to reduce one roundtrip to the server for authentication a connection. This feature is only support for X.509, SCRAM-SHA-1 and SCRAM-SHA-256 (default) authentication mechanisms. -
The SCRAM conversation between driver and server can now skip one of it's empty exchanges which also serves to reduce the roundtrips during a SCRAM authentication.
OCSP stapling testing
OCSP stapling greatly improves performance when using LetsEncrypt certificates, removing the need for an external request to LetsEncrypt servers for each authentication attempt. No additional changes were required to support OCSP stapling in the driver, but extensive testing was added to verify that the feature works as expected.
Db.prototype.createCollection
Changes in behavior of The createCollection
helper used to internally run a listCollections
command in order to see if a collection already existed before running the command. If it determined a collection with the same name existed, it would skip running the command and return an instance of Collection
. This behavior was changed in v3.6.0 to avoid potentially serious bugs, specifically that the driver was not considering options passed into createCollection
as part of the collection equality check. Imagine the following scenario:
const client = new MongoClient('...');
await client.connect();
await client.db('foo').collection('bar').insert({ importantField: 'llamas' });
await client.db('foo').createCollection('bar', {
validator: { $jsonSchema: {
bsonType: 'object',
required: ['importantField'],
properties: { name: { bsonType: 'boolean' } }
}
});
The createCollection
call which defines a JSON schema validator would be completely bypassed because of the existence of bar
, which was implicitly created in the first command. Our policy is strictly adhere to semver, but in rare cases like this where we feel there is potential for a data corrupting bug, we make breaking behavioral changes to protect the user.
Documentation
Reference: http://mongodb.github.io/node-mongodb-native/3.6/ API: http://mongodb.github.io/node-mongodb-native/3.6/api/ Changelog: https://github.com/mongodb/node-mongodb-native/blob/3.6/HISTORY.md
We invite you to try the driver immediately, and report any issues to the NODE project.
Thanks very much to all the community members who contributed to this release!
Release Notes
Epic
- [NODE-2450] - Node MongoDB 4.4 Support
New Feature
- [NODE-2434] - Reduce Client Time To Recovery On Topology Changes
- [NODE-2288] - MONGODB-AWS Support
- [NODE-2289] - Support for allowDiskUse on find operations
- [NODE-2290] - Allow passing hint to findAndModify update and replace operations
- [NODE-2291] - Improve testing around default writeConcern
- [NODE-2295] - Collection and index creation in multi-doc txns
- [NODE-2427] - OCSP Support
- [NODE-2487] - Support speculative authentication attempts in isMaster
- [NODE-2301] - Support shorter SCRAM conversation
- [NODE-2269] - Add support for validate command "background" option
Improvement
- [NODE-2175] - Avoid using readConcern snapshot in sharded transaction tests
- [NODE-2176] - Resync bson-corpus array.json to fix duplicate test names
- [NODE-2393] - Change uri_options/auth-options spec test to enable conditional tests
- [NODE-2394] - Verify max set version and max election id on topologies in SDAM spec tests
- [NODE-2422] - Validate that mongocryptd is not spawned if bypassAutoEncryption=true
- [NODE-2430] - Raise error if hint specified for unacknowledged update using OP_MSG or OP_UPDATE
- [NODE-2431] - Reduce floating point precision required of extended json implementations
- [NODE-2432] - Clarify behavior when "me" field doesn39;t match any values in "hosts" array
- [NODE-2477] - Allow hinting the delete command
- [NODE-2504] - Add SDAM test for incompatible server becoming compatible
- [NODE-2506] - Ensure that the WriteConcernError "errInfo" object is propagated
- [NODE-2538] - Add RetryableWriteError error labels to retryable transaction tests
- [NODE-2546] - Deprecate geoHaystack and geoSearch
- [NODE-2559] - Reduce race conditions in SDAM error handling
- [NODE-2560] - Make 39;reIndex39; a standalone-only command
- [NODE-2564] - Clarify how a driver must handle wrong set name in single topology
- [NODE-2569] - 39;CommitQuorum39; option support for 39;createIndexes’ command on MongoDB 4.4
- [NODE-2576] - Raise error when hint option is provided on unacknowledged writes against any server version
- [NODE-2592] - Update documentation for Text Search
- [NODE-2594] - Do not add the RetryableWriteError label to errors that occur during a write within a transaction (excepting commitTransaction and abortTransaction)
- [NODE-2622] - allowDiskUse option for find should be documented as only being supported in 4.4+
- [NODE-2627] - Reduce default keepalive time to align with Azure defaults
- [NODE-2659] - Drivers should retry replSetStepDown after "Unable to acquire X lock" error
- [NODE-2661] - Define behavior of connectTimeoutMS=0 with streaming protocol
- [NODE-2675] - Test that ElectionInProgress is not resumed
- [NODE-2682] - Treat CursorNotFound as a resumable change stream error
- [NODE-2150] - Bump wire protocol version for 4.4
- [NODE-2379] - Expand use of error labels for RetryableWrites
- [NODE-2423] - Deprecate oplogReplay find command option from CRUD spec
- [NODE-2426] - Make ExceededTimeLimit retryable writes error
- [NODE-2429] - GridFS index checking should support indexes created in the shell
- [NODE-2433] - Lift restriction on authSource without credentials
- [NODE-2452] - Unify behavior around configuration for replica set discovery
- [NODE-2510] - Driver support for server Hedged Reads
- [NODE-2516] - Update comment in Transactions withTxn examples for the manual.
- [NODE-2557] - Remove replicaset from tests that perform reIndex command
Bug
- [NODE-2416] - Confusing documentation for collection.aggregate collation option
- [NODE-2502] - replaceOne example in test/examples/update_documents.js incorrect
- [NODE-2537] - createCollection helper should not run listIndexes outside of strict mode
- [NODE-2567] - Fix qs dependency for older node
- [NODE-2616] - SDAM test typo "compatible"
- [NODE-2623] - Gridfs doesn39;t allow to catch exception with length that exceeds file size
- [NODE-2660] - Throw an error if bulk update documents don39;t contain update operator expressions
- [NODE-2711] - Monitoring should not be immediately scheduled on streaming failure
v3.5.11
The MongoDB Node.js team is pleased to announce version 3.5.11 of the driver
Release Highlights
Kerberos
A bug in introducing the new CMAP Connection
prevented some users from properly
authenticating with the kerberos
module.
bl
dependency due to CVE-2020-8244
Updated See this link for more details: https://github.com/advisories/GHSA-pp7h-53gx-mx7r
Documentation
Reference: http://mongodb.github.io/node-mongodb-native/3.5/ API: http://mongodb.github.io/node-mongodb-native/3.5/api/ Changelog: https://github.com/mongodb/node-mongodb-native/blob/3.5/HISTORY.md
We invite you to try the driver immediately, and report any issues to the NODE project.
Thanks very much to all the community members who contributed to this release!
Release Notes
Bug
- [NODE-2731] - CMAP Connection type does not provide host/port properties
- [NODE-2798] - Update version of dependency "bl" due to vulnerability
v3.5.10
The MongoDB Node.js team is pleased to announce version 3.5.10 of the driver
NOTE: This will be the final release in the 3.5.x branch, please consider upgrading to 3.6.0
Release Highlights
TypeError: Cannot read property 'documents' of null
@adrian-gierakowski helped us identify a bug with our ChangeStreamCursor, specifically when the cursor
was complete it would not return a valid document but instead a null
value.
Command helper not respecting server selection specification rules
The server selection specification indicates that the "runCommand" helper should act
as a read operation for the purposes of server selection, and that it should use a default read
preference of "primary" which can only be overridden by the helper itself. The driver had a bug
where it would inherit the read preference from its "parent" type (Collection
, Db
, MongoClient
)
which is at odds with the specified behavior.
mongodb+srv
invalid IPv6 support
Due to a bug in how we referred to ipv6 addresses internal to the driver, if a mongodb+srv
connection string was provided with an ipv6 address the driver would never be able to connect
and would result in a the following error RangeError: Maximum call stack size exceeded
.
maxStalenessSeconds
not accepted when provided via options
There was a bug in our connection string and MongoClient
options parsing where a value provided
for maxStalenessSeconds
would not end up being reflected in the ReadPreference
used internal
to the driver.
Sessions are prohibited with unacknowledged writes
MongoDB can provide no guarantees around unacknowledged writes when used within a session. The
driver will now silently remove the lsid
field from all writes issued with { w: 0 }
, and
will return an error in these situations in the upcoming 4.0 major release.
Documentation
Reference: http://mongodb.github.io/node-mongodb-native/3.5/ API: http://mongodb.github.io/node-mongodb-native/3.5/api/ Changelog: https://github.com/mongodb/node-mongodb-native/blob/3.5/HISTORY.md
We invite you to try the driver immediately, and report any issues to the NODE project.
Thanks very much to all the community members who contributed to this release!
Release Notes
Bug
- [NODE-2626] - initialising change stream results in: TypeError: Cannot read property 39;documents39; of null
- [NODE-2649] - Driver 3.5.x with useUnifiedTopology sends admin commands to secondary
- [NODE-2671] - ipv6 is not supported when using dns service discovering
- [NODE-2678] - ReadPreference.fromOptions doesn39;t pull "maxStalenessSeconds" from options
Improvement
- [NODE-1341] - Prohibit using unacknowledged writes with explicit sessions
v3.5.9
The MongoDB Node.js team is pleased to announce version 3.5.9 of the driver
Release Highlights
Use duration of handshake if no previous roundTripTime exists
The default roundTripTime
of a ServerDescription
is -1, which means if that value is used we can potentially calculate a negative roundTripTime
. Instead, if no previous roundTripTime
exists, we use the duration of the initial handshake.
the options [maxIdleTimeMS] is not supported
A number of new options were added when the CMAP compliant connection pool was introduced in 3.5.x. Unfortunately, these options were not documented properly. Now they are mentioned in the MongoClient
documentation, with a notice that they are only supported with the unified topology.
TypeError: Reduce of empty array with no initial value
A fix in 3.5.8 which ensured proper filtering of servers during server selection exposed an issue in max staleness calculations when the topology type is ReplicaSetNoPrimary
and no servers are currently known. In order to estimate an upper bound of max staleness when there is no primary, the most stale known server is known to compare the others to - if there are no known servers, you can't reduce the array!
Server monitoring is prevented under heavy request load
In certain very high load fail-over scenarios the driver is unable to reschedule a monitoring check in order to update its view of the topology for retryability. This would result in a high number of failed operations, as they were unable to determine a new viable server.
Documentation
Reference: http://mongodb.github.io/node-mongodb-native/3.5/ API: http://mongodb.github.io/node-mongodb-native/3.5/api/ Changelog: https://github.com/mongodb/node-mongodb-native/blob/3.5/HISTORY.md
We invite you to try the driver immediately, and report any issues to the NODE project.
Thanks very much to all the community members who contributed to this release!
Release Notes
Bug
- [NODE-2637] - connection pool options support for MongoClient
- [NODE-2641] - maxStalenessReducer fails on empty set of servers
- [NODE-2643] - Server monitoring is prevented under heavy request load
- [NODE-2652] - Use duration of initial handshake if no roundTripTime value exists for server
Improvement
- [NODE-2651] - Use consistent means of measuring time
v3.5.8
The MongoDB Node.js team is pleased to announce version 3.5.8 of the driver
Release Highlights
Fixes for NEAREST latency window calculation
@adityapatadia helped uncover an issue with our server selection logic which filtered out servers after evaluating whether they were in the latency window. This meant that non-viable servers were considered during the window calculation and would render certain viable servers unviable.
BulkWriteError writeErrors
property
@vkarpov15 submitted a patch to always include writeErrors
on a BulkWriteError
.
We have logic to set the message
of BulkWriteError
to the message of the first
error encountered if there is only one error. Unfortunately, this logic removed
the writeErrors
field when doing that, so users could be faced with an error
which conditionally changed shape.
Memory leak in timed out wait queue members
@dead-horse identified a memory leak in the new connection pool where wait queue members which timed out might be left in the queue indefinitely under sufficient load. The fix here was to ensure that all wait queue members are flushed during wait queue processing before evaluating whether there were available sockets to process new requests.
Implicit sessions cleanup improvements
Once @dead-horse was able to patch the connection pool memory leak, they also identified a edge case where implicit sessions could be leaked in a very specific error condition. The logic to release implicit sessions was simplified, preventing this from happening in the future
Unordered bulk writes continue-on-error
A bug introduced last summer prevented unordered bulk write operations from continuing after the first write error - one of the most important features of being an unordered operation. We now properly support this feature again.
journal
in connection string is ignored
@nknighter filed a report that the journal
option was ignored when provided
via the connection string. The paramater j
was supported both through the
connection string and explicit added to MongoClient
options, but the official
documentation for connection strings support a journal
option.
Documentation
Reference: http://mongodb.github.io/node-mongodb-native/3.5/ API: http://mongodb.github.io/node-mongodb-native/3.5/api/ Changelog: https://github.com/mongodb/node-mongodb-native/blob/3.5/HISTORY.md
We invite you to try the driver immediately, and report any issues to the NODE project.
Thanks very much to all the community members who contributed to this release!
Release Notes
Bug
- [NODE-2407] - UnifiedTopology + near read makes application crash with timeout error when one of replica server is down
- [NODE-2413] - The node process enters an infinite loop at the pool and causes OOM
- [NODE-2442] - journal=true is ignored in connection string
- [NODE-2548] - Change streams do not resume from errors
- [NODE-2565] - Change stream should not check for NonResumableChangeStreamError label
- [NODE-2619] - Unordered bulk write aborts on first encountered error
- [NODE-2625] - BulkWriteError should always have a writeErrors field
Task
- [NODE-2478] - Use white list for change stream resumability
- [NODE-2598] - Change stream close refactor
- [NODE-2605] - Refactor shared test helpers to improve usability
Improvement
- [NODE-2522] - Remove ElectionInProgress (216) from ResumableChangeStreamError
- [NODE-2571] - Don39;t use admin database for FLE tests
- [NODE-2630] - Simplify code path for ending implicit sessions in cursors
v3.5.7
The MongoDB Node.js team is pleased to announce version 3.5.7 of the driver
Release Highlights
Warning: Accessing non-existent property 'count' of module exports inside circular dependency
Work earlier this year left some dead code in our operations code, resulting in this warning message reported by multiple users. While we still have a few cycles in our codebase yet, this will quiet Node.js 14's circular dependency warnings.
Sessions are only acquired when operations are executed
Drivers use an implicit session for all operations where an explicit session is not provided. A subtle bug was introduced when session support was implemented where implicit sessions were created and assigned to operations even if they were about to sit in a queue waiting for execution. This results in the driver creating many sessions rather than reusing pooled ones. The fix is to ensure a session is only checked out of the pool when the operation is about to be written to a server.
Thanks very much to all the community members who contributed to this release!
Release Notes
Bug
- [NODE-2536] - Circular dependency in Node.js 14 nightly
- [NODE-2552] - Server session creation grows unbounded with every operation call
Improvement
- [NODE-2534] - Document options supported by the unified topology
- [NODE-2560] - Make 39;reIndex39; a standalone-only command
v3.5.6
The MongoDB Node.js team is pleased to announce version 3.5.6 of the driver
Release Highlights
map
when cursor used as a stream
Regression in @dobesv helped identify a regression where a map function would be applied twice if defined on a cursor, and that cursor was used to stream data.
TypeError: Cannot read property 'code' of undefined
User @linus-hologram originally reported an issue with a TypeError when the lambda
passed to the withTransaction
helper rejected with a null
value. @vkarpov15
submitted the fix.
readPreferenceTags
interpreted as an array
A bug was fixed where readPreferenceTags
with a single value in the connection
string was not properly interpreted as an array of tags. This prevented the
Use Analytics Nodes to Isolate Workload guidance from working
correctly.
Cannot set property 'isDirty' of null
User @sean-daley reported seeing this in an AWS Lambda environment, but has proven to be somewhat of a heisenbug. We are rolling out a fix here that ensures sessions (implicit or not) are not used after they have been explicitly ended.
Thanks very much to all the community members who contributed to this release!
Release Notes
Bug
- [NODE-2503] - Cursor ReadStream applies map function twice
- [NODE-2515] - TypeError when transaction is rejected with empty reason
- [NODE-2541] - readPreferenceTags are not interpreted as an array
- [NODE-2545] - Cannot set property 39;isDirty39; of null
- [NODE-2549] - Unknown topology should return empty array for server selection with read preference
v3.5.5
The MongoDB Node.js team is pleased to announce version 3.5.5 of the driver
Release Highlights
hasNext
when using a cursor with a limit
Regression in @peterbroadhurst helped point out a regression introduced in v3.5.4 where using hasNext
on a cusor with a limit would not return the full set of results.
Ignored topology updates cause servers to fall out of latency window
A change introduced across all MongoDB drivers, and in particular v3.5.0 of the Node.js
driver, attempted to prevent needless duplicate topologyDescriptionChanged
topology events
by introducing a ServerDescription
equality operator. Since equality does not take the
lastUpdateTime
and lastWriteDate
fields of an ismaster into account, the driver could
eventually consider servers non-suitable for server selection, since they would fall out
of the latency window.
All updates are considered viable for topology updates now, and only event emission is
gated by ServerDescription
equality.
Memory leaks with Node.js v12+
The legacy topology types (in particular if you were connected to a replic set) used a
custom Timeout
class to wrap a timer. Unfortunately, the class depended on an undocumented,
private variable _called
, which was removed in Node.js v12. This would lead to the driver
thinking the timeout never occurred, and therefore never releasing the object for garbage
collection. We recommend users of the legacy topology types immediately update to this
version of the driver, or use the Unified Topology which is unaffected by this bug.
TypeError: Cannot read property 'Symbol(cancelled)' of undefined
@erfanium and @Paic helped us identify an issue in rare failover events where multiple
requests to process the server selection queue would result in an attempted property
access of an undefined
variable.
promiseLibrary
not respected by newly introduced maybePromise
helper
@tobyealden pointed out that an internal refactor to use a helper to optionally
return a Promise
for top level API methods was not, in fact, using a custom
promise library if one was provided!
Thanks very much to all the community members who contributed to this release!
Release Notes
Bug
- [NODE-2460] - Memory Leak with ReplSet and NodeJS v12
- [NODE-2472] - TypeError on server available with useUnifiedTopology: true
- [NODE-2474] - Server_Description update with lastUpdateTime / lastWriteDate fields is ignored in topology
- [NODE-2480] - TypeError after reconnecting
- [NODE-2483] - Regression using hasNext on cursor with limit
- [NODE-2490] - promiseLibrary option is not honoured
v3.5.4
Bug Fixes
- cmap: don't run min connection thread if no minimum specified (2d1b713)
- sdam: use ObjectId comparison to track maxElectionId (a1e0849)
- topology: ensure selection wait queue is always processed (bf701d6)
-
topology: enter
STATE_CLOSING
before draining waitQueue (494dffb) - don't consume first document when calling
hasNext
on cursor (bb359a1)
Features
- add utility helper for returning promises or using callbacks (ac9e4c9)
v3.5.3
Bug Fixes
- message-stream: support multiple inbound message packets (8388443)
- server: non-timeout network errors transition to Unknown state (fa4b01b)
Features
- connection: support exhaust behavior at the transport level (9ccf268)
v3.5.2
Bug Fixes
- properly handle err messages in MongoDB 2.6 servers (0f4ab38)
- topology: always emit SDAM unrecoverable errors (57f158f)
v3.5.1
Bug Fixes
- cmap: accept all node TLS options as pool options (5995d1d)
- cmap: error wait queue members on failed connection creation (d13b153)
-
connect: listen to
secureConnect
for tls connections (f8bdb8d) - transactions: use options helper to resolve read preference (9698a76)
-
uri_parser: TLS uri variants imply
ssl=true
(c8d182e)
v3.5.0
Bug Fixes
- copy
ssl
option to pool connection options (563ced6) - destroy connections marked as closed on checkIn / checkOut (2bd17a6)
- ensure sync errors are thrown, and don't callback twice (cca5b49)
- ignore connection errors during pool destruction (b8805dc)
- not all message payloads are arrays of Buffer (e4df5f4)
- recover on network error during initial connect (a13dc68)
- remove servers with me mismatch in
updateRsFromPrimary
(95a772e) - report the correct platform in client metadata (35d0274)
- reschedule monitoring before emitting heartbeat events (7fcbeb5)
- socket timeout for handshake should be
connectTimeoutMS
(c83af9a) - timed out streams should be destroyed on
timeout
event (5319ff9) - use remote address for stream identifier (f13c20b)
- used weighted RTT calculation for server selection (d446be5)
- execute-operation: don't swallow synchronous errors (0a2d4e9)
- gridfs: make a copy of chunk before writing to server (b4ec5b8)
Features
- add a
withConnection
helper to the connection pool (d59dced) - include
connectionId
for APM with new CMAP connection pool (9bd360c) - integrate CMAP connection pool into unified topology (9dd3939)
- introduce
MongoServerSelectionError
(0cf7ec9) - introduce a class for tracking stream specific attributes (f6bf82c)
- introduce a new
Monitor
type for server monitoring (2bfe2a1) - relay all CMAP events to MongoClient (1aea4de)
- support socket timeouts on a per-connection level (93e8ad0)
3.4.1 (2019-12-19)
Bug Fixes
- bulk: use original indexes as map for current op index (20800ac)
- always check for network errors during SCRAM conversation (e46a70e)
v3.4.1
Bug Fixes
- bulk: use original indexes as map for current op index (20800ac)
- always check for network errors during SCRAM conversation (e46a70e)
v3.4.0
Bug Fixes
- bulk: use operation index from input to report operation error (f713b13)
- command: only add TransientTransactionError label when in a transaction (478d714)
- compression: recalculate opcode after determine OP_COMMRESSED (022f51b)
- connect: connect with family 0 instead of family 4 (db07366)
- connection: timed out connections should not be half closed (850f4f5)
-
cursor: call
initialize
after session support check (e50c51a) - encryption: autoEncryption must error on mongodb < 4.2 (c274615)
- encryption: do not attempt to merge autoEncryption options (e27fdf9)
- encryption: encryption uses smaller batch size (cb78e69)
- encryption: respect bypassAutoEncryption (e927499)
- encryption: respect user bson options when using autoEncryption (cb7a3f7)
- add calculated duration to server as
roundTripTime
(cb107a8) - mongodb+srv: respect overriding SRV-provided properties (ea83360)
- pool: flush workItems after next tick to avoid dupe selection (3ec49e5)
-
pool: support a
drain
event for use with unified topology (da931ea) - scram: verify server digest, ensuring mutual authentication (806cd62)
-
srv-poller: always provide a valid number for
intervalMS
(afb125f) - topology: correct logic for checking for sessions support (8d157c8)
- topology: don't drain iteration timers on server selection (fed6a57)
Features
- add
MessageStream
for streamed wire protocol messaging (8c44044) - introduce a modern
Connection
replacement for CMAP (7890e48) - support connection establishment cancellation (2014b7b)
- support driver info for drivers wrapping the node driver (1b6670b)
3.3.5 (2019-11-26)
Bug Fixes
- bulk: use operation index from input to report operation error (08ee53e)
- command: only add TransientTransactionError label when in a transaction (8bab074)
- connect: connect with family 0 instead of family 4 (7a41279)
-
cursor: call
initialize
after session support check (3b076b3) - mongodb+srv: respect overriding SRV-provided properties (5ed4c07)
-
pool: support a
drain
event for use with unified topology (3471c28) - topology: correct logic for checking for sessions support (2d976bd)
- topology: don't drain iteration timers on server selection (261f1e5)
Features
- support driver info for drivers wrapping the node driver (d85c4a8)
3.3.4 (2019-11-11)
Bug Fixes
- close: the unified topology emits a close event on close now (ee0db01)
- connect: prevent multiple callbacks in error scenarios (5f6a787)
- monitoring: incorrect states used to determine rescheduling (ec1e04c)
- pool: don't reset a pool if we'not already connected (32316e4)
-
pool: only transition to
DISCONNECTED
if reconnect enabled (43d461e) - replset: don't leak servers failing to connect (f209160)
-
replset: use correct
topologyId
for event emission (19549ff) -
sdam:
minHeartbeatIntervalMS
=>minHeartbeatFrequencyMS
(af9fb45) -
sdam: don't emit
close
every time a child server closes (818055a) - sdam: don't lose servers when they fail monitoring (8a534bb)
- sdam: don't remove unknown servers in topology updates (1147ebf)
- sdam: ignore server errors when closing/closed (49d7235)
- server: don't emit error in connect if closing/closed (62ada2a)
- server: ensure state is transitioned to closed on connect fail (a471707)
-
topology: report unified topology as
nodejs
(d126665) - topology: set max listeners to infinity for db event relay (edb1335)
Features
- sdam_viz: add new tool for visualizing driver sdam changes (738189a)
- sdam_viz: support legacy topologies in sdam_viz tool (1a5537e)
-
update-hints: add support for
hint
to all update methods (720f5e5)
3.3.3 (2019-10-16)
Bug Fixes
- change_stream: emit 'close' event if reconnecting failed (f24c084)
- ChangeStream: remove startAtOperationTime once we have resumeToken (362afd8)
- connect: Switch new Buffer(size) -> Buffer.alloc(size) (da90c3a)
- MongoClient: only check own properties for valid options (9cde4b9)
- mongos: disconnect proxies which are not mongos instances (ee53983)
- mongos: force close servers during reconnect flow (186263f)
- monitoring: correct spelling mistake for heartbeat event (21aa117)
- replset: correct server leak on initial connect (da39d1e)
- replset: destroy primary before removing from replsetstate (45ac09a)
- replset: destroy servers that are removed during SDAM flow (9ea0190)
- saslprep: add in missing saslprep dependency (41f1165)
- topology: don't early abort server selection on network errors (2b6a359)
- topology: don't emit server closed event on network error (194dcf0)
- topology: include all BSON types in ctor for bson-ext support (aa4c832)
-
topology: respect the
force
parameter for topology close (d6e8936)
Features
- Update: add the ability to specify a pipeline to an update command (#2017) (44a4110)
- urlParser: default useNewUrlParser to true (52d76e3)
3.2.7 (2019-06-04)
Bug Fixes
- core: updating core to version 3.2.7 (2f91466)
- findOneAndReplace: throw error if atomic operators provided for findOneAndReplace (6a860a3)
3.3.2 (2019-08-28)
Bug Fixes
- change-stream: default to server default batch size (b3ae4c5)
- execute-operation: return promise on session support check (a976c14)
-
gridfs-stream: ensure
close
is emitted after last chunk (ae94cb9)
3.3.1 (2019-08-23)
Bug Fixes
- find: respect client-level provided read preference (fec4f15)
- correct inverted defaults for unified topology (cf598e1)
v3.3.5
Bug Fixes
- bulk: use operation index from input to report operation error (08ee53e)
- command: only add TransientTransactionError label when in a transaction (8bab074)
- connect: connect with family 0 instead of family 4 (7a41279)
-
cursor: call
initialize
after session support check (3b076b3) - mongodb+srv: respect overriding SRV-provided properties (5ed4c07)
-
pool: support a
drain
event for use with unified topology (3471c28) - topology: correct logic for checking for sessions support (2d976bd)
- topology: don't drain iteration timers on server selection (261f1e5)
Features
- support driver info for drivers wrapping the node driver (d85c4a8)
v3.3.4
Bug Fixes
- close: the unified topology emits a close event on close now (ee0db01)
- connect: prevent multiple callbacks in error scenarios (5f6a787)
- monitoring: incorrect states used to determine rescheduling (ec1e04c)
- pool: don't reset a pool if we'not already connected (32316e4)
-
pool: only transition to
DISCONNECTED
if reconnect enabled (43d461e) - replset: don't leak servers failing to connect (f209160)
-
replset: use correct
topologyId
for event emission (19549ff) -
sdam:
minHeartbeatIntervalMS
=>minHeartbeatFrequencyMS
(af9fb45) -
sdam: don't emit
close
every time a child server closes (818055a) - sdam: don't lose servers when they fail monitoring (8a534bb)
- sdam: don't remove unknown servers in topology updates (1147ebf)
- sdam: ignore server errors when closing/closed (49d7235)
- server: don't emit error in connect if closing/closed (62ada2a)
- server: ensure state is transitioned to closed on connect fail (a471707)
-
topology: report unified topology as
nodejs
(d126665) - topology: set max listeners to infinity for db event relay (edb1335)
Features
- sdam_viz: add new tool for visualizing driver sdam changes (738189a)
- sdam_viz: support legacy topologies in sdam_viz tool (1a5537e)
-
update-hints: add support for
hint
to all update methods (720f5e5)
v3.3.3
Bug Fixes
- change_stream: emit 'close' event if reconnecting failed (f24c084)
- ChangeStream: remove startAtOperationTime once we have resumeToken (362afd8)
- connect: Switch new Buffer(size) -> Buffer.alloc(size) (da90c3a)
- MongoClient: only check own properties for valid options (9cde4b9)
- mongos: disconnect proxies which are not mongos instances (ee53983)
- mongos: force close servers during reconnect flow (186263f)
- monitoring: correct spelling mistake for heartbeat event (21aa117)
- replset: correct server leak on initial connect (da39d1e)
- replset: destroy primary before removing from replsetstate (45ac09a)
- replset: destroy servers that are removed during SDAM flow (9ea0190)
- saslprep: add in missing saslprep dependency (41f1165)
- topology: don't early abort server selection on network errors (2b6a359)
- topology: don't emit server closed event on network error (194dcf0)
- topology: include all BSON types in ctor for bson-ext support (aa4c832)
-
topology: respect the
force
parameter for topology close (d6e8936)
Features
- Update: add the ability to specify a pipeline to an update command (#2017) (44a4110)
- urlParser: default useNewUrlParser to true (52d76e3)
v3.3.2
Bug Fixes
- change-stream: default to server default batch size (b3ae4c5)
- execute-operation: return promise on session support check (a976c14)
-
gridfs-stream: ensure
close
is emitted after last chunk (ae94cb9)
v3.3.1
Bug Fixes
- find: respect client-level provided read preference (fec4f15)
- correct inverted defaults for unified topology (cf598e1)
v3.3.0
Bug Fixes
- aggregate-operation: move type assertions to constructor (25b27ff)
- autoEncryption: tear down mongocryptd client when main client closes (fe2f57e)
- autoEncryption: use new url parser for autoEncryption client (d3670c2)
- Bulk: change BulkWriteError message to first item from writeErrors (#2013) (6bcf1e4)
- change_stream: emit 'close' event if reconnecting failed (41aba90)
- change_stream: emit close event after cursor is closed during error (c2d80b2)
- change-streams: don't copy irrelevant resume options (f190072)
- changestream: removes all event listeners on close (30eeeb5)
- ChangeStream: remove startAtOperationTime once we have resumeToken (8d27e6e)
- ClientSessions: initialize clientOptions and cluster time (b95d64e)
- connect: don't treat 'connect' as an error event (170a011)
- connect: fixed syntax issue in connect error handler (ff7166d)
- connections_stepdown_tests: use correct version of mongo for tests (ce2c9af)
- createCollection: Db.createCollection should pass readConcern to new collection (#2026) (6145d4b)
- cursor: do not truncate an existing Long (317055b), closes mongodb-js/mongodb-core#441
-
distinct: return full response if
full
option was specified (95a7d05) - MongoClient: allow Object.prototype items as db names (dc6fc37)
- MongoClient: only check own properties for valid options (c9dc717)
- OpMsg: cap requestIds at 0x7fffffff (c0e87d5)
- read-operations: send sessions on all read operations (4d45c8a)
- ReadPreference: improve ReadPreference error message and remove irrelevant sharding test (dd34ce4)
- ReadPreference: only allow valid ReadPreference modes (06bbef2)
- replset: correct legacy max staleness calculation (2eab8aa)
- replset: introduce a fixed-time server selection loop (cf53299)
- server: emit "first connect" error if initial connect fails due to ECONNREFUSED (#2016) (5a7b15b)
- serverSelection: make sure to pass session to serverSelection (eb5cc6b)
- sessions: ensure an error is thrown when attempting sharded transactions (3a1fdc1)
- topology: add new error for retryWrites on MMAPv1 (392f5a6)
- don't check non-unified topologies for session support check (2bccd3f)
- maintain internal database name on collection rename (884d46f)
- only check for transaction state if session exists (360975a)
- preserve aggregate explain support for legacy servers (032b204)
- read concern only supported for
mapReduce
without inline (51a36f3) - reintroduce support for 2.6 listIndexes (c3bfc05)
- return
executeOperation
for explain, if promise is desired (b4a7ad7) - validate atomic operations in all update methods (88bb77e)
- transactions: fix error message for attempting sharded (eb5dfc9)
- transactions: fix sharded transaction error logic (083e18a)
Features
- Aggregate: support ReadConcern in aggregates with $out (21cdcf0)
- AutoEncryption: improve error message for missing mongodb-client-encryption (583f29f)
- ChangeStream: adds new resume functionality to ChangeStreams (9ec9b8f)
- ChangeStreamCursor: introduce new cursor type for change streams (8813eb0)
- cryptdConnectionString: makes mongocryptd uri configurable (#2049) (a487be4)
- eachAsync: dedupe async iteration with a common helper (c296f3a)
- execute-operation: allow execution with server selection (36bc1fd)
- pool: add support for resetting the connection pool (2d1ff40)
- sessions: track dirty state of sessions, drop after use (f61df16)
- add concept of
data-bearing
type toServerDescription
(852e14f) - transaction: allow applications to set maxTimeMS for commitTransaction (b3948aa)
- Update: add the ability to specify a pipeline to an update command (#2017) (dc1387e)
- add
known
,data-bearing
filters toTopologyDescription
(d0ccb56) - perform selection before cursor operation execution if needed (808cf37)
- perform selection before operation execution if needed (1a25876)
- support explain operations in
CommandOperationV2
(86f5ba5) - support operations passed to a
Cursor
or subclass (b78bb89)
3.2.7 (2019-06-04)
Bug Fixes
- core: updating core to version 3.2.7 (2f91466)
- findOneAndReplace: throw error if atomic operators provided for findOneAndReplace (6a860a3)
3.2.6 (2019-05-24)
3.2.5 (2019-05-17)
Bug Fixes
- core: updating core to 3.2.5 (a2766c1)
3.2.4 (2019-05-08)
Bug Fixes
- aggregation: fix field name typo (4235d04)
- async: rewrote asyncGenerator in node < 10 syntax (49c8cef)
- BulkOp: run unordered bulk ops in serial (f548bd7)
- bulkWrite: fix issue with bulkWrite continuing w/ callback (2a4a42c)
-
docs: correctly document that default for
sslValidate
is false (1f8e7fa) - gridfs-stream: honor chunk size (9eeb114)
- unified-topology: only clone pool size if provided (8dc2416)
Features
- update to mongodb-core v3.2.3 (1c5357a)
- core: update to mongodb-core v3.2.4 (2059260)
- lib: implement executeOperationV2 (67d4edf)
3.2.3 (2019-04-05)
Bug Fixes
- aggregation: fix field name typo (4235d04)
- async: rewrote asyncGenerator in node < 10 syntax (49c8cef)
- bulkWrite: fix issue with bulkWrite continuing w/ callback (2a4a42c)
-
docs: correctly document that default for
sslValidate
is false (1f8e7fa)
Features
- update to mongodb-core v3.2.3 (1c5357a)
3.2.2 (2019-03-22)
Bug Fixes
- asyncIterator: stronger guard against importing async generator (e0826fb)
Features
- update to mongodb-core v3.2.2 (868cfc3)
3.2.1 (2019-03-21)
Features
- core: update to mongodb-core v3.2.1 (30b0100)
v3.2.7
Bug Fixes
- core: updating core to version 3.2.7 (2f91466)
- findOneAndReplace: throw error if atomic operators provided for findOneAndReplace (6a860a3)
v3.2.6
3.2.6 (2019-05-24)
v3.2.5
Bug Fixes
- core: updating core to 3.2.5 (a2766c1)
v3.2.4
Bug Fixes
- aggregation: fix field name typo (4235d04)
- async: rewrote asyncGenerator in node < 10 syntax (49c8cef)
- BulkOp: run unordered bulk ops in serial (f548bd7)
- bulkWrite: fix issue with bulkWrite continuing w/ callback (2a4a42c)
-
docs: correctly document that default for
sslValidate
is false (1f8e7fa) - gridfs-stream: honor chunk size (9eeb114)
- unified-topology: only clone pool size if provided (8dc2416)
Features
- update to mongodb-core v3.2.3 (1c5357a)
- core: update to mongodb-core v3.2.4 (2059260)
- lib: implement executeOperationV2 (67d4edf)
v3.2.3
Bug Fixes
- aggregation: fix field name typo (4235d04)
- async: rewrote asyncGenerator in node < 10 syntax (49c8cef)
- bulkWrite: fix issue with bulkWrite continuing w/ callback (2a4a42c)
-
docs: correctly document that default for
sslValidate
is false (1f8e7fa)
Features
- update to mongodb-core v3.2.3 (1c5357a)
v3.2.2
Bug Fixes
- asyncIterator: stronger guard against importing async generator (e0826fb)
Features
- update to mongodb-core v3.2.2 (868cfc3)
v3.2.1
Features
- core: update to mongodb-core v3.2.1 (30b0100)
Configuration
-
If you want to rebase/retry this MR, check this box
This MR has been generated by Renovate Bot.