Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

mongodb

mongodb28.7mApache-2.06.12.0TypeScript support: included

The official MongoDB driver for Node.js

mongodb, driver, official

readme

MongoDB Node.js Driver

The official MongoDB driver for Node.js.

Upgrading to version 6? Take a look at our upgrade guide here!

Site Link
Documentation www.mongodb.com/docs/drivers/node
API Docs mongodb.github.io/node-mongodb-native
npm package www.npmjs.com/package/mongodb
MongoDB www.mongodb.com
MongoDB University learn.mongodb.com
MongoDB Developer Center www.mongodb.com/developer
Stack Overflow stackoverflow.com
Source Code github.com/mongodb/node-mongodb-native
Upgrade to v6 etc/notes/CHANGES_6.0.0.md
Contributing CONTRIBUTING.md
Changelog HISTORY.md

Release Integrity

Releases are created automatically and signed using the Node team's GPG key. This applies to the git tag as well as all release packages provided as part of a GitHub release. To verify the provided packages, download the key and import it using gpg:

gpg --import node-driver.asc

The GitHub release contains a detached signature file for the NPM package (named mongodb-X.Y.Z.tgz.sig).

The following command returns the link npm package.

npm view mongodb@vX.Y.Z dist.tarball

Using the result of the above command, a curl command can return the official npm package for the release.

To verify the integrity of the downloaded package, run the following command:

gpg --verify mongodb-X.Y.Z.tgz.sig mongodb-X.Y.Z.tgz

[!Note] No verification is done when using npm to install the package. The contents of the Github tarball and npm's tarball are identical.

Bugs / Feature Requests

Think you’ve found a bug? Want to see a new feature in node-mongodb-native? Please open a case in our issue management tool, JIRA:

  • Create an account and login jira.mongodb.org.
  • Navigate to the NODE project jira.mongodb.org/browse/NODE.
  • Click Create Issue - Please provide as much information as possible about the issue type and how to reproduce it.

Bug reports in JIRA for all driver projects (i.e. NODE, PYTHON, CSHARP, JAVA) and the Core Server (i.e. SERVER) project are public.

Support / Feedback

For issues with, questions about, or feedback for the Node.js driver, please look into our support channels. Please do not email any of the driver developers directly with issues or questions - you're more likely to get an answer on the MongoDB Community Forums.

Change Log

Change history can be found in HISTORY.md.

Compatibility

The driver currently supports 3.6+ servers.

** 3.6 support is deprecated and support will be removed in a future version **

For exhaustive server and runtime version compatibility matrices, please refer to the following links:

Component Support Matrix

The following table describes add-on component version compatibility for the Node.js driver. Only packages with versions in these supported ranges are stable when used in combination.

Component `mongodb@3.x` `mongodb@4.x` `mongodb@5.x` mongodb@<6.12 mongodb@>=6.12
bson ^1.0.0 ^4.0.0 ^5.0.0 ^6.0.0 ^6.0.0
bson-ext ^1.0.0 || ^2.0.0 ^4.0.0 N/A N/A N/A
kerberos ^1.0.0 ^1.0.0 || ^2.0.0 ^1.0.0 || ^2.0.0 ^2.0.1 ^2.0.1
mongodb-client-encryption ^1.0.0 ^1.0.0 || ^2.0.0 ^2.3.0 ^6.0.0 ^6.0.0
mongodb-legacy N/A ^4.0.0 ^5.0.0 ^6.0.0 ^6.0.0
@mongodb-js/zstd N/A ^1.0.0 ^1.0.0 ^1.1.0 ^1.1.0 || ^2.0.0

Typescript Version

We recommend using the latest version of typescript, however we currently ensure the driver's public types compile against `typescript@4.4.0`. This is the lowest typescript version guaranteed to work with our driver: older versions may or may not work - use at your own risk. Since typescript does not restrict breaking changes to major versions, we consider this support best effort. If you run into any unexpected compiler failures against our supported TypeScript versions, please let us know by filing an issue on our JIRA.

Additionally, our Typescript types are compatible with the ECMAScript standard for our minimum supported Node version. Currently, our Typescript targets es2021.

Installation

The recommended way to get started using the Node.js 5.x driver is by using the npm (Node Package Manager) to install the dependency in your project.

After you've created your own project using npm init, you can run:

npm install mongodb
# or ...
yarn add mongodb

This will download the MongoDB driver and add a dependency entry in your package.json file.

If you are a Typescript user, you will need the Node.js type definitions to use the driver's definitions:

npm install -D @types/node

Driver Extensions

The MongoDB driver can optionally be enhanced by the following feature packages:

Maintained by MongoDB:

Some of these packages include native C++ extensions. Consult the trouble shooting guide here if you run into compilation issues.

Third party:

Quick Start

This guide will show you how to set up a simple application using Node.js and MongoDB. Its scope is only how to set up the driver and perform the simple CRUD operations. For more in-depth coverage, see the official documentation.

Create the package.json file

First, create a directory where your application will live.

mkdir myProject
cd myProject

Enter the following command and answer the questions to create the initial structure for your new project:

npm init -y

Next, install the driver as a dependency.

npm install mongodb

Start a MongoDB Server

For complete MongoDB installation instructions, see the manual.

  1. Download the right MongoDB version from MongoDB
  2. Create a database directory (in this case under /data).
  3. Install and start a mongod process.
mongod --dbpath=/data

You should see the mongod process start up and print some status information.

Connect to MongoDB

Create a new app.js file and add the following code to try out some basic CRUD operations using the MongoDB driver.

Add code to connect to the server and the database myProject:

NOTE: Resolving DNS Connection issues

Node.js 18 changed the default DNS resolution ordering from always prioritizing IPv4 to the ordering returned by the DNS provider. In some environments, this can result in localhost resolving to an IPv6 address instead of IPv4 and a consequent failure to connect to the server.

This can be resolved by:

  • specifying the IP address family using the MongoClient family option (MongoClient(<uri>, { family: 4 } ))
  • launching mongod or mongos with the ipv6 flag enabled (--ipv6 mongod option documentation)
  • using a host of 127.0.0.1 in place of localhost
  • specifying the DNS resolution ordering with the --dns-resolution-order Node.js command line argument (e.g. node --dns-resolution-order=ipv4first)
const { MongoClient } = require('mongodb');
// or as an es module:
// import { MongoClient } from 'mongodb'

// Connection URL
const url = 'mongodb://localhost:27017';
const client = new MongoClient(url);

// Database Name
const dbName = 'myProject';

async function main() {
  // Use connect method to connect to the server
  await client.connect();
  console.log('Connected successfully to server');
  const db = client.db(dbName);
  const collection = db.collection('documents');

  // the following code examples can be pasted here...

  return 'done.';
}

main()
  .then(console.log)
  .catch(console.error)
  .finally(() => client.close());

Run your app from the command line with:

node app.js

The application should print Connected successfully to server to the console.

Insert a Document

Add to app.js the following function which uses the insertMany method to add three documents to the documents collection.

const insertResult = await collection.insertMany([{ a: 1 }, { a: 2 }, { a: 3 }]);
console.log('Inserted documents =>', insertResult);

The insertMany command returns an object with information about the insert operations.

Find All Documents

Add a query that returns all the documents.

const findResult = await collection.find({}).toArray();
console.log('Found documents =>', findResult);

This query returns all the documents in the documents collection. If you add this below the insertMany example, you'll see the documents you've inserted.

Find Documents with a Query Filter

Add a query filter to find only documents which meet the query criteria.

const filteredDocs = await collection.find({ a: 3 }).toArray();
console.log('Found documents filtered by { a: 3 } =>', filteredDocs);

Only the documents which match 'a' : 3 should be returned.

Update a document

The following operation updates a document in the documents collection.

const updateResult = await collection.updateOne({ a: 3 }, { $set: { b: 1 } });
console.log('Updated documents =>', updateResult);

The method updates the first document where the field a** is equal to **3 by adding a new field b** to the document set to **1. updateResult contains information about whether there was a matching document to update or not.

Remove a document

Remove the document where the field a** is equal to **3.

const deleteResult = await collection.deleteMany({ a: 3 });
console.log('Deleted documents =>', deleteResult);

Index a Collection

Indexes can improve your application's performance. The following function creates an index on the a** field in the **documents collection.

const indexName = await collection.createIndex({ a: 1 });
console.log('index name =', indexName);

For more detailed information, see the indexing strategies page.

Error Handling

If you need to filter certain errors from our driver, we have a helpful tree of errors described in etc/notes/errors.md.

It is our recommendation to use instanceof checks on errors and to avoid relying on parsing error.message and error.name strings in your code. We guarantee instanceof checks will pass according to semver guidelines, but errors may be sub-classed or their messages may change at any time, even patch releases, as we see fit to increase the helpfulness of the errors.

Any new errors we add to the driver will directly extend an existing error class and no existing error will be moved to a different parent class outside of a major release. This means instanceof will always be able to accurately capture the errors that our driver throws.

const client = new MongoClient(url);
await client.connect();
const collection = client.db().collection('collection');

try {
  await collection.insertOne({ _id: 1 });
  await collection.insertOne({ _id: 1 }); // duplicate key error
} catch (error) {
  if (error instanceof MongoServerError) {
    console.log(`Error worth logging: ${error}`); // special case for some reason
  }
  throw error; // still want to crash
}

Nightly releases

If you need to test with a change from the latest main branch, our mongodb npm package has nightly versions released under the nightly tag.

npm install mongodb@nightly

Nightly versions are published regardless of testing outcome. This means there could be semantic breakages or partially implemented features. The nightly build is not suitable for production use.

Next Steps

License

Apache 2.0

© 2012-present MongoDB Contributors \ © 2009-2012 Christian Amor Kvalheim

changelog

Changelog

All notable changes to this project will be documented in this file. See standard-version for commit guidelines.

6.12.0 (2024-12-10)

Features

Bug Fixes

  • NODE-6583: upgrade to BSON v6.10.1 to remove internal unbounded type cache (#4338) (249c279)
  • NODE-6600: set object mode correctly for message chunking in SizedMessageTransform (#4345) (5558573)
  • NODE-6602: only wrap errors from SOCKS in network errors (#4347) (ed83f36)

6.11.0 (2024-11-22)

Features

  • NODE-5682: set maxTimeMS on commands and preempt I/O (#4174) (e4e6a5e)
  • NODE-5844: add iscryptd to ServerDescription (#4239) (c39d443)
  • NODE-6069: OIDC k8s machine workflow (#4270) (82c931c)
  • NODE-6090: Implement CSOT logic for connection checkout and server selection (bd8a9f4)
  • NODE-6231: Add CSOT behaviour for retryable reads and writes (#4186) (2ffd5eb)
  • NODE-6274: add CSOT support to bulkWrite (#4250) (c5a9ae5)
  • NODE-6275: Add CSOT support to GridFS (#4246) (3cb8187)
  • NODE-6304: add CSOT support for non-tailable cursors (#4195) (131f6ed)
  • NODE-6305: Add CSOT support to tailable cursors (#4218) (2398fc6)
  • NODE-6312: add error transformation for server timeouts (#4192) (c2c0cb9)
  • NODE-6313: add CSOT support to sessions and transactions (#4199) (5f1102f)
  • NODE-6387: Add CSOT support to change streams (#4256) (4588ff2)
  • NODE-6389: add support for timeoutMS in StateMachine.execute() (#4243) (c55f965)
  • NODE-6390: Add timeoutMS support to auto encryption (#4265) (55e08e7)
  • NODE-6391: Add timeoutMS support to explicit encryption (#4269) (f745b99)
  • NODE-6392: add timeoutMS support to ClientEncryption helpers part 1 (#4281) (e86f11e)
  • NODE-6403: add CSOT support to client bulk write (#4261) (365d63b)
  • NODE-6421: add support for timeoutMS to explain helpers (#4268) (5b2629b)
  • NODE-6446: deprecate legacy timeout options (#4279) (c28608b)
  • NODE-6551: update bson to 6.10.0 (#4329) (adb15fe)

Bug Fixes

  • NODE-6374: MongoOperationTimeoutError inherits MongoRuntimeError (#4237) (9fb896a)
  • NODE-6412: read stale response from previously timed out connection (#4273) (fd8f3bd)
  • NODE-6454: use timeoutcontext for state machine execute() cursor options (#4291) (5dd8ee5)
  • NODE-6469: pool is cleared before connection checkin on error (#4296) (06a2e2c)
  • NODE-6523: deleteMany in gridfs passes timeoutMS to predicate, not options (#4319) (1965ed5)

Performance Improvements

  • NODE-6525: remove setPrototype and defineProperty from hot path (#4321) (48ed47e)

6.10.0 (2024-10-21)

Features

  • NODE-5838: remove support for server 3.6 (#4182) (7b71e1f)
  • NODE-6060: set fire-and-forget protocol when writeConcern is w: 0 (#4219) (643a875)
  • NODE-6289: allow valid srv hostnames with less than 3 parts (#4197) (3d5bd51)
  • NODE-6329: client bulk write happy path (#4206) (3d3da40)
  • NODE-6337: implement client bulk write batching (#4248) (d56e235)
  • NODE-6338: implement client bulk write error handling (#4262) (8def42d)
  • NODE-6342: support maxTimeMS for explain commands (#4207) (20396e1)
  • NODE-6350: add typescript support to client bulkWrite API (#4257) (30c61f2)
  • NODE-6409: new errors for unacknowledged bulk writes (#4276) (7fde8dd)
  • NODE-6419: deprecate explain options API for find and aggregate (#4271) (a473de9)

Bug Fixes

  • NODE-6394: data events missed while awaiting drain (#4249) (3f9d243)
  • NODE-6418: change stream resumes infinitely after failed aggregates (#4267) (6ecf198)
  • NODE-6436: only force majority write concern on commitTransaction retry (#4284) (a7d1d43)

6.9.0 (2024-09-12)

Features

  • NODE-5459: add durations to connection pool events (#4166) (7295695)
  • NODE-5614: add support for explicit resource management (#4177) (b3f3987)
  • NODE-5754: allow auto select family options (#4185) (54efb7d)
  • NODE-5908: support range v2 (#4141) (de253a7)
  • NODE-6225: add property ownership check before referencing mongocryptdSpawnPath and mongocryptdSpawnArgs (#4151) (f48f8d3)
  • NODE-6244: Bump max supported wire version and server version (#4163) (45bc098)
  • NODE-6252: insertMany and bulkWrite permit readonly arrays (#4175) (4b219d3)
  • NODE-6278: deprecate 3.6 servers (#4178) (35d8840)
  • NODE-6309: Mark range API as stable (#4190) (f53e9d9)
  • NODE-6327: new client bulk write types and builders (#4205) (6d65ae7)
  • NODE-6365: pass through allowPartialTrustChain TLS flag (#4228) (d6c147d)

Bug Fixes

  • NODE-5720: on pre-4.4 sharded servers, the node driver uses error.writeConcern.code to determine retryability (#4155) (b26c328)
  • NODE-6241: allow Binary as local kms provider key for auto encryption (#4165) (d85f827)
  • NODE-6259: replace dynamically assigned length property with a static getter (#4173) (320dde0)
  • NODE-6276: preserve top level error code MongoWriteConcernError (#4183) (e902584)
  • NODE-6284: make sparsity and trimFactor optional (#4189) (8622545)
  • NODE-6355: respect utf8 validation options when iterating cursors (#4214) (8bfe187)
  • NODE-6362: cache cursor deserialization options across deserialize calls (#4221) (833eaa4)
  • NODE-6367: enable mixed use of iteration APIs (#4231) (08912c8)

Performance Improvements

  • NODE-5906: optimize toArray to use batches (#4171) (5565d50)

6.8.0 (2024-06-27)

Features

  • NODE-5718: add ReadConcernMajorityNotAvailableYet to retryable errors (#4154) (4f32dec)
  • NODE-5801: allow multiple providers providers per type (#4137) (4d209ce)
  • NODE-5853: support delegated KMIP data key option (#4129) (aa429f8)
  • NODE-6136: parse cursor responses on demand (#4112) (3ed6a2a)
  • NODE-6157: add signature to github releases (#4119) (f38c5fe)

Bug Fixes

  • NODE-5801: use more specific key typing for multiple KMS provider support (#4146) (465ffd9)
  • NODE-6085: add TS support for KMIP data key options (#4128) (f790cc1)
  • NODE-6241: allow Binary as local KMS provider key (#4160) (fb724eb)
  • NODE-6242: close becomes true after calling close when documents still remain (#4161) (e3d70c3)

6.7.0 (2024-05-29)

Features

  • NODE-5464: OIDC machine and callback workflow (#3912) (2ba8434)

Bug Fixes

  • NODE-6165: useBigInt64 causes compareTopologyVersion to throw (#4109) (21b729b)

6.6.2 (2024-05-15)

Bug Fixes

  • NODE-6171: RTT set to zero when serverMonitoringMode=stream (#4110) (7a7ec5b)

6.6.1 (2024-05-06)

Bug Fixes

  • NODE-6151: MongoClient connect does not keep Node.js running (#4101) (7e0d9e6)

6.6.0 (2024-05-02)

Features

  • NODE-3639: add a general stage to the aggregation pipeline builder (#4079) (8fca1aa)
  • NODE-5678: add options parsing support for timeoutMS and defaultTimeoutMS (#4068) (ddd1e81)
  • NODE-5762: include cause and package name for all MongoMissingDependencyErrors (#4067) (62ea94b)
  • NODE-5825: add minRoundTripTime to ServerDescription and change roundTripTime to a moving average (#4059) (0e3d6ea)
  • NODE-5919: support new type option in create search index helpers (#4060) (3598c23)
  • NODE-6020: upgrade BSON to ^6.5.0 (#4035) (8ab2055)

Bug Fixes

  • NODE-3681: Typescript error in Collection.findOneAndModify UpdateFilter $currentDate (#4047) (a8670a7)
  • NODE-5530: make topology descriptions JSON stringifiable (#4070) (3a0e011)
  • NODE-5745: ignore Read/Write Concern in Atlas Search Index Helpers (#4042) (67d7bab)
  • NODE-5925: driver throws error when non-read operation in a transaction has a ReadPreferenceMode other than 'primary' (#4075) (39fc198)
  • NODE-5971: attach v to createIndexes command when version is specified (#4043) (1879a04)
  • NODE-5999: Change TopologyDescription.error type to MongoError (#4028) (30432e8)
  • NODE-6019: indexExists always returns false when full is set to true (#4034) (0ebc1ac)
  • NODE-6029: update types for collection listing indexes (#4072) (232bf3c)
  • NODE-6051: only provide expected allowed keys to libmongocrypt after fetching aws kms credentials (#4057) (c604e74)
  • NODE-6066: ClusterTime.signature can be undefined (#4069) (ce55ca9)

Performance Improvements

  • NODE-6127: move error construction into setTimeout callback (#4094) (6abc074)

6.5.0 (2024-03-11)

Features

  • NODE-5968: container and Kubernetes awareness in client metadata (#4005) (28b7040)
  • NODE-5988: Provide access to raw results doc on MongoServerError (#4016) (c023242)
  • NODE-6008: deprecate CloseOptions interface (#4030) (f6cd8d9)

Bug Fixes

  • NODE-5636: generate _ids using pkFactory in bulk write operations (#4025) (fbb5059)
  • NODE-5981: read preference not applied to commands properly (#4010) (937c9c8)
  • NODE-5985: throw Nodejs' certificate expired error when TLS fails to connect instead of CERT_HAS_EXPIRED (#4014) (057c223)
  • NODE-5993: memory leak in the Connection class (#4022) (69de253)

Performance Improvements

  • NODE-5986: parallelize SRV/TXT resolution (#4012) (eab8f23)

6.4.0 (2024-02-29)

Features

  • NODE-3449: Add serverConnectionId to Command Monitoring Spec (735f7aa)
  • NODE-3470: retry selects another mongos (#3963) (84959ee)
  • NODE-3689: require hello command for connection handshake to use OP_MSG disallowing OP_QUERY (#3938) (ce7df0f)
  • NODE-4686: Add log messages to CLAM (#3955) (e3bfa30)
  • NODE-4687: Add logging to server selection (#3946) (7f3ce0b)
  • NODE-4719: add SDAM Logging Spec (#3940) (a3c0298)
  • NODE-4847: Add config error handling to logging (#3970) (8f7bb59)
  • NODE-5717: make ExceededTimeLimit retryable reads error (#3947) (106ab09)
  • NODE-5885: upgrade BSON to ^6.3.0 (#3983) (9401d09)
  • NODE-5939: Implement 6.x: cache the AWS credentials provider in the MONGODB-AWS auth logic (#3991) (e0a37e5)
  • NODE-5978: upgrade BSON to ^6.4.0 (#4007) (90f2f70)

Bug Fixes

  • NODE-5127: implement reject kmsRequest on server close (#3964) (568e05f)
  • NODE-5609: node driver omits base64 padding in sasl-continue command (#3975) (b7d28d3)
  • NODE-5765: change type for countDocuments (#3932) (22cae0f)
  • NODE-5791: type error with $addToSet in bulkWrite (#3953) (b93d405)
  • NODE-5818: Add feature flagging to server selection logging (#3974) (55203ef)
  • NODE-5839: support for multibyte code-points in stringifyWithMaxLen (#3979) (aed1cf0)
  • NODE-5840: heartbeat duration includes socket creation (#3973) (a42039b)
  • NODE-5901: propagate errors to transformed stream in cursor (#3985) (ecfc615)
  • NODE-5944: make AWS session token optional (#4002) (f26de76)

Performance Improvements

  • NODE-5771: improve new connection (#3948) (a4776cf)
  • NODE-5854: Conditional logger instantiation and precompute willLog perf fix (#3984) (a63fbc2)
  • NODE-5928: consolidate signal use and abort promise wrap (#3992) (38742c2)

6.3.0 (2023-11-15)

Features

  • NODE-3881: require hello command + OP_MSG when 'loadBalanced=True' (#3907) (fd58eec)
  • NODE-4849: Add Typescript support for log path in client options (#3886) (f495abb)
  • NODE-4878: Add remaining log configurable client options (#3908) (54adc9f)
  • NODE-5197: add server monitoring mode (#3899) (ae4c94a)
  • NODE-5452: Logging Cosmos Document DB Info Message (#3902) (bb5fa43)
  • NODE-5590: deprecate GridFS fields (#3905) (d2225da)

Bug Fixes

  • NODE-4863: do not use RetryableWriteError for non-server errors (#3914) (08c9fb4)
  • NODE-5709: bump mongodb-connection-string-url to 3.0.0 (#3909) (1c3dc02)
  • NODE-5749: RTTPinger always sends legacy hello (#3921) (ebbfb8a)

6.2.0 (2023-10-19)

Features

Bug Fixes

  • NODE-5496: remove client-side collection and database name check validation (#3873) (98550c6)
  • NODE-5628: bulkWriteResult.insertedIds does not filter out _ids that are not actually inserted (#3867) (09f2a67)
  • NODE-5706: make findOne() close implicit session to avoid memory leak (#3897) (995d138)

6.1.0 (2023-09-14)

Features

Bug Fixes

  • NODE-5551: set AWS region from environment variable for STSClient (#3831) (e9a5079)
  • NODE-5588: recursive calls to next cause memory leak (#3841) (9a8fdb2)

6.0.0 (2023-08-28)

⚠ BREAKING CHANGES

  • NODE-5584: adopt bson v6 and mongodb-client-encryption v6 (#3845)
  • NODE-5484: mark MongoError for internal use and remove Node14 cause assignment logic (#3800)
  • NODE-4788: use implementer Writable methods for GridFSBucketWriteStream (#3808)
  • NODE-4986: remove callbacks from ClientEncryption encrypt, decrypt, and createDataKey (#3797)
  • NODE-5490: bump kerberos compatibility to ^2.0.1 (#3798)
  • NODE-3568: ensure includeResultsMetadata is false by default (#3786)
  • NODE-3989: only accept true and false for boolean options (#3791)
  • NODE-5233: prevent session from one client from being used on another (#3790)
  • NODE-5444: emit deprecation warning for useNewUrlParser and useUnifiedTopology (#3792)
  • NODE-5470: convert remaining FLE to TS and drop support for onKMSProvidersRefresh (#3787)
  • NODE-5508: remove EvalOperation and EvalOptions (#3795)
  • NODE-3920: validate options are not repeated in connection string (#3788)
  • NODE-3924: read tls files async (#3776)
  • NODE-5430: make AutoEncrypter and MongoClient.autoEncrypter internal (#3789)
  • NODE-4961: remove command result from commit and abort transaction APIs (#3784)
  • NODE-2014: return executor result from withSession and withTransaction (#3783)
  • NODE-5409: allow socks to be installed optionally (#3782)
  • NODE-4796: remove addUser and collection.stats APIs (#3781)
  • NODE-4936: remove unsupported options from db.command and admin.command (#3775)
  • NODE-5228: remove unneeded fields from ConnectionPoolCreatedEvent.options (#3772)
  • NODE-5190: remove deprecated keep alive options (#3771)
  • NODE-5186: remove duplicate BulkWriteResult accessors (#3766)
  • NODE-5376: remove deprecated ssl options (#3755)
  • NODE-5415: bump minimum Node.js version to v16.20.1 (#3760)

Features

  • NODE-2014: return executor result from withSession and withTransaction (#3783) (65aa288)
  • NODE-3568: ensure includeResultsMetadata is false by default (#3786) (fee8d3e)
  • NODE-3920: validate options are not repeated in connection string (#3788) (11631a2)
  • NODE-3924: read tls files async (#3776) (68adaf1)
  • NODE-3989: only accept true and false for boolean options (#3791) (e2e36cc)
  • NODE-4796: remove addUser and collection.stats APIs (#3781) (e79ac9d)
  • NODE-4961: remove command result from commit and abort transaction APIs (#3784) (71c5936)
  • NODE-4986: remove callbacks from ClientEncryption encrypt, decrypt, and createDataKey (#3797) (51a573f)
  • NODE-5186: remove duplicate BulkWriteResult accessors (#3766) (8693987)
  • NODE-5190: remove deprecated keep alive options (#3771) (7ade907)
  • NODE-5233: prevent session from one client from being used on another (#3790) (9268b35)
  • NODE-5376: remove deprecated ssl options (#3755) (ee56c8e)
  • NODE-5396: add mongodb-js/saslprep as a required dependency (#3815) (bd031fc)
  • NODE-5409: allow socks to be installed optionally (#3782) (787bdbf)
  • NODE-5415: bump minimum Node.js version to v16.20.1 (#3760) (de158b2)
  • NODE-5430: make AutoEncrypter and MongoClient.autoEncrypter internal (#3789) (b16ef9e)
  • NODE-5444: emit deprecation warning for useNewUrlParser and useUnifiedTopology (#3792) (c08060d)
  • NODE-5470: convert remaining FLE to TS and drop support for onKMSProvidersRefresh (#3787) (844aa52)
  • NODE-5484: mark MongoError for internal use and remove Node14 cause assignment logic (#3800) (a17b0af)
  • NODE-5490: bump kerberos compatibility to ^2.0.1 (#3798) (1044be1)
  • NODE-5508: remove EvalOperation and EvalOptions (#3795) (225cb81)
  • NODE-5566: add ability to provide CRL file via tlsCRLFile (#3834) (33c86c9)
  • NODE-5584: adopt bson v6 and mongodb-client-encryption v6 (#3845) (7bef363)

Bug Fixes

  • NODE-4788: use implementer Writable methods for GridFSBucketWriteStream (#3808) (7955610)
  • NODE-4936: remove unsupported options from db.command and admin.command (#3775) (52cd649)
  • NODE-5228: remove unneeded fields from ConnectionPoolCreatedEvent.options (#3772) (7a91714)
  • NODE-5412: drop aws sdk version to match node18 runtime (#3809) (1e96e49)
  • NODE-5548: ensure that tlsCertificateKeyFile maps to cert and key (#3819) (a0955bd)
  • NODE-5592: withTransaction return type (#3846) (05d2725)

5.7.0 (2023-07-06)

Features

Bug Fixes

  • NODE-4977: load snappy lazily (#3726) (865e658)
  • NODE-5102: listDatabases nameOnly setting is sent as NaN (#3742) (b97132e)
  • NODE-5289: prevent scram auth from throwing TypeError if saslprep is not a function (#3727) (e006347)
  • NODE-5374: do not apply cursor transform in Cursor.hasNext (#3746) (0668cd8)

5.6.0 (2023-06-01)

Features

Bug Fixes

  • NODE-5249: remove strict flag from create collection options (#3677) (be8faaf)
  • NODE-5296: construct error messages for AggregateErrors in Node16+ (#3682) (e03178e)

5.5.0 (2023-05-11)

Features

  • NODE-4720: Add log messages to CMAP spec (#3645) (b27f385)
  • NODE-5004: dont create or drop ecc collections (#3660) (2264fbb)

Bug Fixes

  • NODE-5260: AWS Lambda metadata detection logic is too permissive (#3663) (d74d3f9)

5.4.0 (2023-05-04)

Features

  • NODE-4814: implement remaining severity logging methods (#3629) (d7a8079)
  • NODE-4815: stringify and truncate BSON documents in log messages (#3635) (d6bd1d1)
  • NODE-4970: deprecate collStats collection helper (#3638) (325c4bc)
  • NODE-5166: bump max wire version for 7.0 (#3659) (561229b)
  • NODE-5191: OIDC Auth Updates (#3637) (c52a4ed)
  • NODE-5207: deprecate unsupported runCommand options and add spec tests (#3643) (d6d76b4)

Bug Fixes

  • NODE-5213: ChangeStream.tryNext() should return TChange type (#3649) (3b58ca1)

5.3.0 (2023-04-18)

Features

  • NODE-4696: add FaaS env information to client metadata (#3626) (0424080)
  • NODE-4774: deprecate cursor forEach (#3622) (8d76a71)
  • NODE-4791: deprecate duplicate bulk methods (#3623) (2839e95)
  • NODE-4795: deprecate addUser helper (#3624) (53a0aae)
  • NODE-5169: Implement emergency logger (#3610) (d502eb0)
  • NODE-5188: add alternative runtime detection to client metadata (#3636) (2a26de3)
  • NODE-5189: deprecate tcp keepalive options (#3621) (cc7c75a)

Bug Fixes

  • NODE-5042: relax SRV record validation to account for a dot suffix (#3633) (ad15881)
  • NODE-5171: allow upsertedId to be null in UpdateResult (#3631) (4b5be21)
  • NODE-5201: prevent warning when default value for deprecation option is used (#3646) (e7f6e4e)

5.2.0 (2023-04-04)

Features

  • NODE-5035: enable OIDC authentication (#3577) (35879f6)
  • NODE-5036: reauthenticate OIDC and retry (#3589) (a41846d)
  • NODE-5077: automatic Azure kms credential refresh (#3599) (8e87e5c)

Bug Fixes

  • NODE-3998: metadata duplication in handshake (#3615) (6d894d6)
  • NODE-4518: error message with invalid authMechanism is provided (#undefined) (1a16b7e)
  • NODE-4854: set timeout on write and reset on message (#3582) (4a7b5ec)
  • NODE-5106: prevent multiple mongo client connect()s from leaking topology (#3596) (eb836bb)
  • NODE-5126: find operations fail when passed an ObjectId as filter (#3604) (2647b61)

5.1.0 (2023-02-23)

Features

  • NODE-3445: add support for AssumeRoleWithWebIdentity in aws authentication (#3556) (e8a30b1)
  • NODE-4877: Add support for useBigInt64 (#3519) (917668c)
  • NODE-5034: support OIDC auth options (#3557) (20a4fec)
  • NODE-5050: support GCP automatic credential fetch for CSFLE (#3574) (722a4a6)

Bug Fixes

  • NODE-5044: Write Concern 0 Must Not Affect Read Operations (#3541) (#3575) (10146a4)
  • NODE-5052: prevent cursor and changestream close logic from running more than once (#3562) (71d0d79)
  • NODE-5064: consolidate connection cleanup logic and ensure socket is always closed (#3572) (e544d88)

5.0.1 (2023-02-07)

Bug Fixes

  • NODE-5027: revert "ensure that MessageStream is destroyed when connections are destroyed" (#3552) (2d178d0)

5.0.0 (2023-01-31)

⚠ BREAKING CHANGES

  • NODE-5016: compile ts with target es2020 (#3545)

Features

  • NODE-5016: compile ts with target es2020 (#3545) (def266a)

Bug Fixes

  • NODE-4998: use ipv4 in socks5 tests for node 18 (#3538) (425dbe0)

5.0.0-alpha.0 (2023-01-24)

⚠ BREAKING CHANGES

  • NODE-4522: remove callback support (#3499)
  • NODE-4817: remove legacy logger (#3518)
  • NODE-4867: adopt BSON v5 (#3490)
  • NODE-4738: remove dot notation support by default (#3520)
  • NODE-4950: remove bson-ext import (#3523)
  • NODE-4756: ok 1 with write concern failure event changes (#3525)
  • NODE-4034: make internal bulk result private (#3515)
  • NODE-4751: drop support for client encryption < 2.3.0 (#3521)
  • NODE-4684: remove collection insert, update, remove methods (#3500)
  • NODE-4924: remove mapReduce collection helper (#3511)
  • NODE-4925: remove deprecated options and types (#3513)
  • NODE-3818: remove slaveOk options (#3503)
  • NODE-3695: remove lastop and optime from bulk result (#3504)
  • NODE-3489: remove cursor close options (#3505)
  • NODE-4598: close cursor on early loop break (#3502)
  • NODE-3482: remove unref (#3494)
  • NODE-4521: remove custom promise library support (#3498)
  • NODE-4898: aws credential providers now optional peerDependency (#3497)
  • NODE-4436: update minimum supported node version (#3496)
  • NODE-4899: support only snappy 7 or later (#3491)

Features

  • NODE-3482: remove unref (#3494) (556812f)
  • NODE-3489: remove cursor close options (#3505) (88c03a1)
  • NODE-3695: remove lastop and optime from bulk result (#3504) (8900d40)
  • NODE-3818: remove slaveOk options (#3503) (2e28009)
  • NODE-4034: make internal bulk result private (#3515) (ebac1f5)
  • NODE-4436: update minimum supported node version (#3496) (cca5362)
  • NODE-4509: send 1 with hello commands (#3508) (cc8ea1d)
  • NODE-4521: remove custom promise library support (#3498) (af36ebb)
  • NODE-4522: remove callback support (#3499) (52853ff)
  • NODE-4598: close cursor on early loop break (#3502) (30c0aee)
  • NODE-4684: remove collection insert, update, remove methods (#3500) (14427d1)
  • NODE-4738: remove dot notation support by default (#3520) (26145df)
  • NODE-4751: drop support for client encryption < 2.3.0 (#3521) (3dae6da)
  • NODE-4756: ok 1 with write concern failure event changes (#3525) (fee783c)
  • NODE-4767: Change abstract cursor return type (#3531) (410ef30)
  • NODE-4817: remove legacy logger (#3518) (28c7cdd)
  • NODE-4867: adopt BSON v5 (#3490) (b850868)
  • NODE-4898: aws credential providers now optional peerDependency (#3497) (b9e4c7c)
  • NODE-4899: support only snappy 7 or later (#3491) (21db1a9)
  • NODE-4924: remove mapReduce collection helper (#3511) (10d757a)
  • NODE-4925: remove deprecated options and types (#3513) (8f8ea45)
  • NODE-4950: remove bson-ext import (#3523) (1470115)

4.13.0 (2022-12-19)

Features

  • NODE-4691: interrupt in-flight operations on heartbeat failure (#3457) (e641bd4)
  • NODE-4810: define the new Logger (#3475) (6ef11d7)

Bug Fixes

  • NODE-4447: disable causal consistency in implicit sessions (#3479) (6566fb5)
  • NODE-4834: ensure that MessageStream is destroyed when connections are destroyed (#3482) (8338bae)

4.12.1 (2022-11-23)

Bug Fixes

4.12.0 (2022-11-16)

Features

Bug Fixes

  • NODE-4609: allow mapping to falsey non-null values in cursors (#3452) (1bf6ef1)
  • NODE-4735: fix change stream consecutive resumabilty (#3453) (89b27e9)
  • NODE-4753: remove erroneous deprecation of geoNear (#3465) (199dcaf)
  • NODE-4783: handle orphaned operation descriptions (#3463) (4c9b4d8)

4.11.0 (2022-10-19)

Features

  • NODE-3255: add minPoolSizeCheckIntervalMS option to connection pool (#3429) (5f34ad0)
  • NODE-3651: add hashed index type (#3432) (f6b56a1)
  • NODE-3875: support recursive schema types (#3433) (26bce4a)
  • NODE-4503: throw original error when server attaches NoWritesPerformed label (#3441) (a7dab96)
  • NODE-4650: handle handshake errors with SDAM (#3426) (cbe7533)
  • NODE-4721: add aws-sdk as optional dependency (#3446) (b879cb5)

Bug Fixes

  • NODE-3712,NODE-4546: electionId should be ordered before setVersion (#3174) (ca51fec)
  • NODE-3921: error on invalid TLS option combinations (#3405) (1a550df)
  • NODE-4186: accept ReadPreferenceLike in TransactionOptions type (#3425) (dc62bcb)
  • NODE-4475: make interrupted message more specific (#3437) (5f37cb6)
  • NODE-4608: prevent parallel monitor checks (#3404) (78bcfe4)
  • NODE-4647: improve error message (#3409) (0d3c02e)
  • NODE-4649: use SDAM handling for errors from min pool size population (#3424) (ef3b55d)

4.10.0 (2022-09-19)

Features

  • NODE-4385: add cmap pool pausing functionality (#3321) (335ee55)
  • NODE-4484: add experimental support for disambiguatedPaths in change stream documents (#3365) (846365a)
  • NODE-4519: deprecate promiseLibrary and PromiseProvider (#3403) (5c322b6)
  • NODE-4547: mark all callback APIs as deprecated (#3388) (a983f14)
  • NODE-4607: add exports needed by legacy client (#3396) (972f760)
  • NODE-4634: add support for bulk FindOperators.hint() (#3408) (8758890)

Bug Fixes

  • NODE-3144: pool clear event ordering and retryability tests (#3407) (bdc0d67)
  • NODE-3986: unskip MONGODB-AWS test (#3397) (5676f81)
  • NODE-4557: randomize servers when there are only 2 eligible servers (#3390) (ddcfa49)
  • NODE-4583: revert nested union type support (#3383) (7f94f0a)
  • NODE-4591: only set loadBalanced on handshake when explicitly set (#3386) (57e9f2d)
  • NODE-4621: ipv6 address handling in HostAddress (#3410) (5eb3978)
  • NODE-4639: allow PromiseProvider to be null (#3412) (d29b3d9)

4.9.0 (2022-08-18)

Features

  • NODE-3517: improve index spec handling and type definitions (#3315) (0754bf9)
  • NODE-4336: deprecate old write concern options and add missing writeConcern to MongoClientOptions (#3340) (d2b6ad8)
  • NODE-4548: export ChangeStream class from top-level (#3357) (48f295a)

Bug Fixes

  • NODE-4159,NODE-4512: remove servers with incorrect setName from topology and fix unix socket parsing (#3348) (00dcf2d)
  • NODE-4273: pass 'comment' option through to distinct command (#3339) (753ecfe)
  • NODE-4413: set maxTimeMS on getMores when maxAwaitTimeMS is specified (#3319) (dcbfd6e)
  • NODE-4429: select server sync for endSessions during close (#3363) (5086ead)
  • NODE-4467: Add back support for oplogReplay option as deprecated (#3337) (6c69b7d)
  • NODE-4496: counter values incorrecly compared when instance of Long (#3342) (d29eb8c)
  • NODE-4513: type for nested objects in query & update (#3349) (ec1a68f)
  • NODE-4533: session support error message and unified test runner (#3355) (6a0e502)
  • NODE-4555: export BSON internally (#3367) (4ce6e4c)

4.8.1 (2022-07-26)

Bug Fixes

  • NODE-4423: better type support for nested objects in query & update (#3328) (05e007b)
  • NODE-4425: webpack optional import of FLE issue (#3324) (5ab2b05)
  • NODE-4444: use Node.js clear timers (#3327) (c5cfe21)

4.8.0 (2022-07-13)

Features

  • NODE-4078: allow comment with estimated doc count (#3301) (bed1fe3)
  • NODE-4267: support nested fields in type completion for UpdateFilter (#3259) (1a9a44c)
  • NODE-4294: mark queryable encryption options beta (#3300) (4c07bbb)
  • NODE-4301: remove shared lib experimental tags (#3298) (3976783)

Bug Fixes

  • NODE-4125: change stream resumability (#3289) (aa5f97e)
  • NODE-4262: make startSession work without a connection (#3286) (89ad7c3)
  • sync showExpandedEvents spec tests (#3288) (cfe18f9)

4.7.0 (2022-06-06)

Features

  • NODE-1837: add zstd compression option (#3237) (1261432)
  • NODE-2993: implement maxConnecting (#3255) (c9d3816)
  • NODE-3750: make maxConnecting configurable (#3261) (ee41447)
  • NODE-3938: Add support for pre/post images in change streams (#3250) (981465c)
  • NODE-4079: estimated document count uses count (#3244) (a752e75)
  • NODE-4081: fix and deprecate change stream resume options (#3270) (47adfb3)
  • NODE-4139: streaming protocol message changes (#3256) (4b9ad77)
  • NODE-4192: make MongoClient.connect optional (#3232) (a2359e4)
  • NODE-4196: add support for showExpandedEvents in change streams (#3254) (9c1782e)
  • NODE-4229: bump maxWireVersion to 17 (#3265) (d13cec2)

Bug Fixes

  • NODE-4103: respect BSON options when creating change streams (#3247) (b2798d9)
  • NODE-4108: improve return type for withTransaction() (#3236) (48e0e6e)
  • NODE-4254: allow csfle to be dynamically required (#3260) (cd6b5a0)
  • NODE-4281: ensure that the driver always uses Node.js timers (#3275) (4501a1c)

4.6.0 (2022-05-11)

Features

  • NODE-4185: Allow opting out of disk use on cursor builder (#3230) (d216725)
  • NODE-4189: Add support for clustered collections (#3229) (79a917b)

Bug Fixes

  • NODE-3565: Improve error message for insertMany with partially empty array (#3221) (0ef2516)
  • NODE-4232: stream() also returns generic AsyncIterable (ed4ba58)

4.6.0-alpha.0 (2022-05-04)

Features

  • NODE-2992: consider server load during server selection (#3219) (35eeba3)
  • NODE-4059: ChangeStreamDocument not fully typed to specification (#3191) (8b24212)
  • NODE-4136: revise FLE shared library typings for spec changes (#3206) (6e2e27f)
  • NODE-4202: add FLE 2 behavior for create/drop collection (#3218) (6d3947b)

Bug Fixes

  • NODE-3688: make handshake errors retryable (#3165) (3f8765a)
  • NODE-3833: return early on end if gridfs upload stream is already ended (#3223) (c27e844)
  • NODE-3928: don't throw error in Response constructor (#3199) (441fc63)
  • NODE-4031: options parsing for array options (#3193) (4b2e3d1)
  • NODE-4133: array field NestedPaths return type (#3184) (c46c984)
  • NODE-4156: remove comment from commands pre-4.4 (#3195) (4e6dccd)
  • NODE-4188: default localThresholdMS to 15ms (#3207) (5e730ff)
  • NODE-4208: add aws http request timeout handler (#3225) (829d7be)

4.5.0 (2022-04-04)

Features

  • NODE-3697: reduce serverSession allocation (#3171) (5132bc9)
  • NODE-3699: add support for comment field (#3167) (4e2f9bf)
  • NODE-4014: Add let option to bulk write operations (#3160) (6f633d1)
  • NODE-4085: add typings for csfle shared library option support (#3179) (d2897ab)

Bug Fixes

  • NODE-3769: retryable writes are not compliant with specification (#3144) (ff26b12)
  • NODE-3810: delay timeout errors by one event loop tick (#3180) (0ed7cbf)
  • NODE-4069: remove 'default' from options for fullDocument field in change stream options (#3169) (799689e)
  • NODE-4074: ensure getTopology doesn't throw synchronously (#3172) (329f081)
  • NODE-4129: constrain watch type parameter to extend ChangeStream type parameter (#3183) (43ba9fc)

4.4.1 (2022-03-03)

Features

  • NODE-3866: Add let option to ReplaceOptions for replaceOne operation (#3148) (f76635a)

Bug Fixes

  • NODE-3521: update session support checks (#3151) (aaa453d)
  • NODE-3948: Add error code to MongoSystemError (#3149) (446da95)

4.4.0 (2022-02-17)

Features

  • NODE-2938: add service host mechanism property (#3130) (46d5821)
  • NODE-2939: add new hostname canonicalization opts (#3131) (d0390d0)
  • NODE-3351: use hostname canonicalization (#3122) (f5c76f3)
  • NODE-3777: add csfle kmip support (#3070) (44bbd6e)
  • NODE-3867: deprecate cursor count and update v4 docs (#3127) (a48d7e2)

Bug Fixes

  • fix csfle imports (#3142) (541e939)
  • NODE-3621: fixed type of documentKey property on ChangeStreamDocument (#3118) (c63a21b)
  • NODE-3795: unexpected No auth provider for DEFAULT defined error (#3092) (fb38a56)
  • NODE-3813: unexpected type conversion of read preference tags (#3138) (3e7b894)
  • NODE-3878: use legacy count operation on collection.count (#3126) (12c6835)
  • NODE-3917: Throw an error when directConnection is set with multiple hosts (#3143) (b192493)

4.3.1 (2022-01-18)

Bug Fixes

  • NODE-3792: remove offensive language throughout the codebase (#3091) (8e2b0cc)
  • NODE-3852,NODE-3854,NODE-3856: Misc typescript fixes for 4.3.1 (#3102) (dd5195a)

4.3.0 (2022-01-06)

Features

  • NODE-3589: support dot-notation attributes in Filter (#2972) (76fff97)
  • NODE-3633: add Socks5 support (#3041) (451627a)
  • NODE-3784: Add enableUtf8Validation option (#3074) (4f56409)
  • NODE-3793: Remove offensive language from code and tests (#3082) (91a67e0)

Bug Fixes

  • gridfs: make GridFSBucketWriteStream.prototype.end() return this for compat with @types/node@17.0.6 (#3088) (7bb9e37)
  • NODE-2899: sort and correct circular imports (#3072) (48cc729)
  • NODE-3675: SRV option bug correctly defaults authSource to $external (#3079) (30f2a2d)
  • NODE-3803: Fix _id typing on collection create operations (#3077) (f1979db)

4.2.2 (2021-12-13)

Bug Fixes

  • NODE-3705: ReadPreference.fromOptions omitting hedge and maxStalenessSeconds when readPreference is a string (#3060) (b9fbac5)
  • NODE-3711: retry txn end on retryable write (#3045) (7b00d0f)
  • NODE-3765: make replacement for replaceOne operations without _id (#3040) (e07e564)
  • stricter protocol check in connection string (#3078) (bc05671)

4.2.1 (2021-11-30)

Bug Fixes

  • NODE-2370: correct a return type of hasNext() (#3058) (b6a63df)
  • NODE-3627: Enable flexible BSON validation for server error key containing invalid utf-8 (#3054) (7a507f0)
  • NODE-3648: run get more ops through server selection (#3030) (268e211)
  • NODE-3767: don't delete dbName if authSource is provided (#3055) (0a830e2)
  • NODE-3770: Filter type uses WithId on the schema (#3053) (307d623)

4.2.0 (2021-11-17)

Features

  • NODE-3083: support aggregate writes on secondaries (#3022) (f696909)
  • NODE-3446: deprecate mapReduce command (#3036) (b6c73bf)
  • NODE-3467: implement srvMaxHosts, srvServiceName options (#3031) (1f8b539)
  • NODE-3469,NODE-3615,NODE-3507: update min and max wire versions (#3014) (2a78d5a)
  • NODE-3691: make time series options granularity type strict (#3005) (98017f9)
  • NODE-3692: make change stream events typing more generic (#3034) (d5ae78e)
  • NODE-3728: Allow to pass authorizedCollections option to the db.listCollections method (#3021) (e1234a7)
  • NODE-3729: add withId to default return type for collection.find and collection.findOne (#3039) (52520aa)

Bug Fixes

  • NODE-3116: reschedule unreliable async interval first (#3006) (33886a7)
  • NODE-3344: allow setting defaultTransactionOptions with POJO rather than ReadConcern instance (#3032) (53b3164)
  • NODE-3515: do proper opTime merging in bulk results (#3012) (43300c3)
  • NODE-3668: compile error with OptionalId on TS 4.5 beta (#3004) (ee7f095)
  • NODE-3726: add optional option overloads of Db's createCollection function (#3019) (c3149e1)
  • NODE-3727: add overloads for BulkOperationBase's execute function (#3018) (216d194)

4.1.3 (2021-10-05)

Bug Fixes

  • NODE-3609: correct listDatabases return type (#2986) (a8e9938)
  • NODE-3624: Incorrect default aggregation generic type (#2987) (440517e)

4.1.2 (2021-09-14)

Bug Fixes

  • NODE-3434: errInfo should be exposed on bulk write (#2977) (6b3c161)
  • NODE-3467: allow object type for aggregate out helper (#2971) (cd603e8)
  • NODE-3487: check for nullish aws mechanism property (#2951) (78ec0dd)
  • NODE-3559: incorrect GridFS stream type (#2981) (3915ea8)
  • NODE-3567: correct typing on aggregation out helper (#2967) (a299a0b)
  • NODE-3574: reintroduce ObjectID export (#2965) (2291119)
  • NODE-3585: MongoClientOptions#compressors has incorrect type (#2976) (f1b896d)
  • NODE-3591: tlsCertificateKeyFile option does not default cert (#2979) (6d42267)
  • NODE-3599: incorrect indexes return type (#2980) (122b9f3)

4.1.1 (2021-08-24)

Bug Fixes

  • NODE-3454: projection types are too narrow (#2924) (48d6da9)
  • NODE-3468: remove generic overrides from find (#2935) (74bd7bd)
  • NODE-3511: deprecate fullResponse and remove associated buggy code paths (#2943) (dfc39d1)
  • NODE-3528: add support for snappy 7 (#2939) (0f7f300)
  • NODE-3546: revert findOne not found result type to null (#2945) (1c576e9)

4.1.0 (2021-08-03)

Features

  • NODE-2843: implement sessions advanceClusterTime method (#2920) (1fd0244)
  • NODE-3011: Load Balancer Support (#2909) (c554a7a)

Bug Fixes

  • NODE-2883: Aggregate Operation should not require parent parameter (#2918) (dc6e2d6)
  • NODE-3058: accept null or undefined anywhere we permit nullish values (#2921) (b42a1b4)
  • NODE-3441: fix typings for createIndexes (#2915) (f87f376)
  • NODE-3442: AsyncIterator has incorrect return type (#2916) (4a10389)
  • NODE-3452: readonly filters not permitted by typings (#2927) (ce51e78)
  • NODE-3510: omit incorrect | void in declaration of Promise overload of rename() (#2922) (58c1e84)
  • NODE-3513: default command monitoring to off (#2926) (3c60245)

4.0.1 (2021-07-20)

Features

  • NODE-3419: define MongoRuntimeError children (#2893) (eadeb01)

Bug Fixes

  • NODE-3199: unable to bundle driver due to uncaught require (#2904) (9e48bbd)
  • NODE-3393: snapshot time not applied if distinct executed first (#2908) (7aa3008)
  • NODE-3417: allow calling db() before MongoClient is connected (#2889) (51ea86d)

4.0.0 (2021-07-13)

Features

  • NODE-3095: add timeseries options to db.createCollection (#2878) (c145c91)
  • NODE-3392: enable snapshot reads on secondaries (#2897) (523e05c)
  • NODE-3403: define MongoRuntimeError children (#2894) (cb0db49)
  • NODE-3410: added MongoRuntimeError (#2892) (ee903cb)

Bug Fixes

  • NODE-1797: error when ChangeStream used as iterator and emitter concurrently (#2871) (e0b3afe)
  • NODE-1843: bulk operations ignoring provided sessions (#2868) (70810d1)
  • NODE-3063: fix custom csfle test script (#2884) (d73c80c)
  • NODE-3279: use "hello" for monitoring if supported (#2895) (5a8842a)
  • NODE-3386: listCollections result type definition (#2866) (c12979a)
  • NODE-3413: accept tls=false in mongodb+srv connection strings (#2886) (526c73f)
  • NODE-3416: make change stream generic default to Document (#2882) (3d490dc)
  • NODE-3430: watch method types on MongoClient and Db (#2900) (17cc291)

4.0.0-beta.6 (2021-07-01)

⚠ BREAKING CHANGES

  • NODE-3291: Standardize error representation in the driver (#2824)
  • NODE-3272: emit correct event type when SRV Polling (#2825)
  • remove strict/callback mode from Db.collection helper (#2817)

Features

  • NODE-2751: add arrayFilters builder to bulk FindOperators (#2820) (d099622)
  • NODE-3274: add type hinting for UpdateFilter (#2842) (05035eb)
  • NODE-3325: support 'let' option for aggregate command (#2828) (e38838e)
  • NODE-3331: offer downleveled types for legacy typescript versions (#2859) (27cf1d2)
  • NODE-3333: support 'let' option for CRUD commands (#2829) (0d91da1)

Bug Fixes

  • NODE-1502: command monitoring objects hold internal state references (#2832) (a2887db)
  • NODE-2026: SERVICE_REALM kerberos mechanism property not attached (#2865) (5caa354)
  • NODE-2035: exceptions thrown from awaited cursor forEach do not propagate (#2835) (ac49df6)
  • NODE-2905: support SERVICE_NAME authentication mechanism property (#2857) (dfb91b8)
  • NODE-2944: Reintroduce bson-ext support (#2823) (8eb0081)
  • NODE-3150: allow retrieving PCRE-style RegExp (ca9e2dc)
  • NODE-3272: emit correct event type when SRV Polling (#2825) (579119f)
  • NODE-3305: beforeHandshake flag is always true (#2854) (079bd6c)
  • NODE-3311: InsertOneOptions extends CommandOperationOptions (#2816) (734b481)
  • NODE-3335: do not validate explain verbosity in client (#2834) (1a57ba8)
  • NODE-3343: allow overriding result document after projection applied (#2856) (988f9c8)
  • NODE-3356: update redaction logic for command monitoring events (#2849) (536e5ff)
  • NODE-3291: Standardize error representation in the driver (#2824) (9608c6a)
  • remove strict/callback mode from Db.collection helper (#2817) (53abfe7)

4.0.0-beta.5 (2021-05-26)

Bug Fixes

  • NODE-3183,NODE-3249: bring versioned API impl up to date (#2814) (cd3b73a)
  • NODE-3245: mark symbols as internal remove from type definitions (#2810) (0b636ba)
  • NODE-3275: Fix enum type export naming and serverApi validation (#2809) (661511d)

4.0.0-beta.4 (2021-05-18)

⚠ BREAKING CHANGES

  • NODE-1812: replace returnOriginal with returnDocument option (#2803)
  • NODE-3157: update find and modify interfaces for 4.0 (#2799)
  • NODE-2978: remove deprecated bulk ops (#2794)

Features

Bug Fixes

  • NODE-2995: Add shared metadata MongoClient (#2772) (9073d54)
  • NODE-3074: update estimated document count for v1 api (#2764) (146791c)
  • NODE-3109: prevent servername from being an IP (#2771) (27089be)
  • NODE-3166: allowInvalidHostnames and allowInvalidCertificates flags are ignored (#2784) (a769cf8)
  • NODE-3174: Preserve sort key order for numeric string keys (#2788) (440de41)
  • NODE-3176: handle errors from MessageStream (#2780) (76b110e)
  • NODE-3194: Ignore undefined and null options in MongoClient constructor (#2800) (8bb92f9)
  • NODE-3197: revert setImmediate in waitQueue (#2802) (6c0dfef)
  • NODE-3206: Make distinct use any[] type instead of Document[] (#2795) (b45e3b3)
  • sdam: topology no longer causes close event (#2792) (6cd982f)
  • NODE-1812: replace returnOriginal with returnDocument option (#2803) (1cdc8a8)
  • NODE-2978: remove deprecated bulk ops (#2794) (c3a1839)
  • NODE-3157: update find and modify interfaces for 4.0 (#2799) (29512da)

4.0.0-beta.3 (2021-04-06)

Features

Bug Fixes

  • always close gridfs upload stream on finish (#2759) (1c6f544)
  • don't auto destroy read stream for Node 14 (d4e297e)
  • move session support check to operation layer (#2750) (c19f296)
  • remove existing session from cloned cursors (30ccd86)
  • NODE-3071: Ignore error message if error code is defined (#2770) (d4cc936)
  • NODE-3152: ensure AWS environment variables are applied properly (#2756) (341a602)

4.0.0-beta.2 (2021-03-16)

⚠ BREAKING CHANGES

  • remove deprecated items (#2740)
  • remove enums in favor of const objects (#2741)

Bug Fixes

  • add FLE AWS sessionToken TypeScript definitions (#2737) (f4698b5)
  • remove catch for synchronous socket errors and remove validation on nodejs option (#2746) (a516903)
  • session support detection spec compliance [PORT: 4.0] (#2733) (1615be0)

4.0.0-beta.1 (2021-02-02)

Bug Fixes

  • find: correctly translate timeout option into noCursorTimeout (#2708) (16a22c4)
  • Compatibility with mongodb-client-encryption (#2713) (d08ddb9)
  • restore createAutoEncrypter() functionality (#2710) (25ef870)
  • Support bson property on Topology class (#2721) (00b1374)
  • Use getters to sync BulkWriteResult wrappers (#2716) (c94b54a)
  • operations: avoid hardcoding checkKeys for insert operations (#2726) (5ce9b25)
  • operations: make every CollationOptions property optional except locale (#2727) (8a678e9)
  • WriteConcern: avoid throwing error when options is null (#2714) (ea142bc)

4.0.0-beta.0 (2021-01-19)

⚠ BREAKING CHANGES

  • Clarify empty BulkOperation error message (#2697)
  • db: suppress Db events (#2251)
  • Integrate MongoOptions parser into driver (#2680)
  • bulk: add collation to FindOperators (#2679)
  • remove top-level write concern options (#2642)
  • CreateIndexOp returns string, CreateIndexesOp returns array (#2666)
  • conform CRUD result types to specification (#2651)
  • remove deprecated Collection.group helper
  • Options object precedence over URI options (#2691)
  • adds async iterator for custom promises
  • format sort in cursor and in sort builder (#2573)
  • remove Cursor#transformStream
  • remove deprecated find options
  • pull CursorStream out of Cursor
  • remove deprecated GridFS API
  • only store topology on MongoClient (#2594)

Features

  • add withReadConcern builder to AbstractCursor (#2645) (0cca729)
  • add an internal tryNext method (#2638) (43c94b6)
  • add commitQuorum option to createIndexes command (168a952)
  • add explain support for cursor commands (#2622) (bb1e081)
  • add explain support for non-cursor commands (#2599) (4472308)
  • add MONGODB-AWS as a supported auth mechanism (7f3cfba)
  • Add MongoOption builder logic (#2623) (cb9ee9e)
  • Add MongoOptions interface (#2616) (54c456b)
  • add types for the result of bulk initialize methods (#2654) (3e5ff57)
  • adds "hidden" option when creating indexes (ee8ca1a)
  • adds async iterator for custom promises (16d6572)
  • allow hinting the delete command (95fedf4)
  • bump wire protocol version for 4.4 (6d3f313)
  • convert the entire codebase to TypeScript (272bc18)
  • deprecate oplogReplay for find commands (24155e7)
  • directConnection adds unify behavior for replica set discovery (#2349) (34c9195)
  • expand use of error labels for retryable writes (c775a4a)
  • implements promise provider (e5b762c)
  • Integrate MongoOptions parser into driver (#2680) (b1bdb06)
  • introduce AbstractCursor and its concrete subclasses (#2619) (a2d78b2)
  • introduce an interruptable async interval timer (21cbabd)
  • introduce BufferPool to replace BufferList (#2669) (3c56efc)
  • introduce typescript migration pipeline (f40cffc)
  • Options object precedence over URI options (#2691) (85d8d09)
  • reintroduce clone and rewind for cursors (#2647) (a5154fb)
  • remove parallelCollectionScan helper (9dee21f)
  • remove Cursor#transformStream (a54be7a)
  • remove legacy topology types (6aa2434)
  • remove reIndex (6b510a6)
  • remove the collection save method (d5bb496)
  • remove top-level write concern options (#2642) (6914e87)
  • support allowDiskUse for find commands (dbc0b37)
  • support creating collections and indexes in transactions (917f2b0)
  • bulk: add collation to FindOperators (#2679) (a41d503)
  • support hedged reads (2b7b936)
  • support passing a hint to findOneAndReplace/findOneAndUpdate (faee15b)
  • support shorter SCRAM conversations (6b9ff05)
  • db: remove createCollection strict mode (bb13764)
  • FindCursor: fluent builder for allowDiskUse option (#2678) (d442aac)
  • geoHaystackSearch: remove geoHaystackSearch (5a1b61c)
  • support speculative authentication in scram-sha and x509 (f71f09b)
  • support the streaming protocol for topology updates (7e9c5bc)
  • use error labels for retryable writes in legacy topologies (fefc165)

Bug Fixes

  • add all accessor tags to exported symbols (#2649) (55534c9)
  • allow client connect after close (#2581) (1aecf96)
  • allow client re-connect after close (#2615) (9a176ef)
  • allow event loop to process during wait queue processing (#2541) (7bbc783)
  • always clear cancelled wait queue members during processing (7e942ba)
  • always include writeErrors on a BulkWriteError instance (0759a0e)
  • apply bson options for bulk operations (#2601) (e01cafd)
  • assert update/replace atomic requirements in bulk operations (911c25d)
  • awaitable isMaster timeout must respect connectTimeoutMS (#2650) (8d44cc2)
  • change prepublishOnly npm script to prepare (95440fb)
  • Change socket timeout default to 0 (#2564) (7ed6dbf)
  • clarify handle wrong set name single topology (93cd8b3)
  • connection leak if wait queue member cancelled (#2563) (4018a1e)
  • correct legacy require paths (f96a97f)
  • correct typeof check in checkSupportedServer (#2690) (421fe6e)
  • correctly re-establishes pipe destinations (#2592) (7d023a6)
  • correctly use template string for connection string error message (b4d89ea)
  • createCollection only uses listCollections in strict mode (ccccbc8)
  • db.command to not inherit options from parent (8f6c247)
  • don't depend on private node api for Timeout wrapper (e6dc1f4)
  • don't immediately schedule monitoring after streaming failure (7a3b99b)
  • don't reset monitor if we aren't streaming topology changes (2f23dd7)
  • don't try to calculate sMax if there are no viable servers (dd24cee)
  • ensure implicit sessions are ended consistently (1a443e7)
  • enumerate function override call signatures (#2687) (2492dd2)
  • error label checking & insertOne where retryWrites is false (d4502aa)
  • filter servers before applying reducers (99b86b3)
  • handle session with unacknowledged write (4aeaedf)
  • hint should raise error on unacknowledged writes (665b352)
  • honor journal=true in connection string (41d291a)
  • ignore ENOTFOUND during TXT record lookup (b1e15a8)
  • ingest WC as a simple object or number for w value (#2695) (f5f9fd4)
  • internal access modifier on symbol properties (#2664) (f6d9b81)
  • ipv6 is not supported when using dns service discovery (3cc53cb)
  • make MongoBulkWriteError conform to CRUD spec (#2621) (7aa3567)
  • make the owner property of ClientSessionOptions optional (#2656) (d811a01)
  • make tryNext and Batch public (#2675) (634ae4f)
  • min and max take Document parameters, not numbers (#2657) (698533f)
  • move kerberos client setup from prepare to auth (#2655) (93ef9e8)
  • npm script check:test failure on ubuntu (addb4f5)
  • only consider MongoError subclasses for retryability (265fe40)
  • only force server id generation if requested (#2653) (577d6eb)
  • only use ServerDescription equality to prevent event emission (ddf151d)
  • pass optional promise lib to maybePromise (52be01f)
  • pass options into commandSupportsReadConcern (e855c83)
  • permit waking async interval with unreliable clock (#2551) (a2c113f)
  • prevent bulk operations from being executed multiple times (#2658) (bb883f7)
  • reduce default keepalive time to align with Azure defaults (ffc0f55)
  • remove check for NonResumableChangeStreamError label (7cf669d)
  • remove circular dependency warnings on node 14 (f32fa15)
  • removed geoNear deprecation (a3408e6)
  • revert BSON Map export removal (#2704) (2b74387)
  • SASL signature consists of the string representation of the payload (#2529) (e7d2693)
  • single readPreferenceTags should be parsed as an array (98e879d)
  • store name of collection for more informative error messages (979d41e)
  • support write concern provided as string in fromOptions (637f428)
  • tests using lib prohibited (#2625) (5e04fff)
  • ChangeStream: handle null changes (9db8369)
  • ChangeStream: make CursorNotFound error resumable (3d8ac55)
  • ChangeStream: should resume from errors when iterating (7a8a533)
  • ChangeStream: whitelist change stream resumable errors (f4bf912), closes #17 #18
  • ClientSession: correct toBSON TypeScript signature (#2686) (cc4b9e0)
  • writes within transactions are not retryable (08fd347)
  • cursor: transforms should only be applied once to documents (a52a860)
  • throw an error if allowDiskUse is used on MongoDB < 3.2 (ebeae56)
  • typings for readConcern (4f9d4ce)
  • unordered bulk write should attempt to execute all batches (fa07519)
  • use async interruptable interval for server monitoring (d792806)
  • sdam: use ObjectId comparison to track maxElectionId (db991d6)
  • use options for readPreference in client (800e71e)
  • use properly camel cased form of mapReduce for command (c1ed2c1)
  • use require instead of readFileSync for driver.version (#2652) (e7a42bb)
  • GridFS: emit error on bad options (21b8ae9)
  • GridFS: emit error on bad options (e11e573)
  • user roles take single string & DDL readPreference tests (98162c3)
  • warning message fix should not check for topology existence (f7094b2)
  • db: suppress Db events (#2251) (eed1131)
  • Clarify empty BulkOperation error message (#2697) (34f488d)
  • conform CRUD result types to specification (#2651) (0135e9e)
  • CreateIndexOp returns string, CreateIndexesOp returns array (#2666) (e12c485)
  • format sort in cursor and in sort builder (#2573) (8aad134)
  • only store topology on MongoClient (#2594) (33fa6b2)
  • pull CursorStream out of Cursor (054838f)
  • remove deprecated Collection.group helper (cf5c865)
  • remove deprecated find options (0e6375a)
  • remove deprecated GridFS API (bee0aa2)

3.5.4 (2020-02-25)

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)

3.5.3 (2020-02-12)

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)

3.5.2 (2020-01-20)

Bug Fixes

  • properly handle err messages in MongoDB 2.6 servers (0f4ab38)
  • topology: always emit SDAM unrecoverable errors (57f158f)

3.5.1 (2020-01-17)

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)

3.5.0 (2020-01-14)

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)

3.4.0 (2019-12-10)

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_COMPRESSED (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)

3.3.0 (2019-08-13)

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 to ServerDescription (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 to TopologyDescription (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)

3.2.0 (2019-03-21)

Bug Fixes

  • aggregate: do not send batchSize for aggregation with $out (ddb8d90)
  • bulkWrite: always count undefined values in bson size for bulk (436d340)
  • db_ops: rename db to add user on (79931af)
  • mongo_client_ops: only skip authentication if no authMechanism is specified (3b6957d)
  • mongo-client: ensure close callback is called with client (f39e881)

Features

  • core: pin to mongodb-core v3.2.0 (22af15a)
  • Cursor: adds support for AsyncIterator in cursors (b972c1e)
  • db: add database-level aggregation (b629b21)
  • mongo-client: remove deprecated logout and print warning (542859d)
  • topology-base: support passing callbacks to close method (7c111e0)
  • transactions: support pinning mongos for sharded txns (3886127)
  • unified-sdam: backport unified SDAM to master for v3.2.0 (79f33ca)

3.1.13 (2019-01-23)

Bug Fixes

  • restore ability to webpack by removing makeLazyLoader (050267d)
  • bulk: honor ignoreUndefined in initializeUnorderedBulkOp (e806be4)
  • changeStream: properly handle changeStream event mid-close (#1902) (5ad9fa9)
  • db_ops: ensure we async resolve errors in createCollection (210c71d)

3.1.12 (2019-01-16)

Features

  • core: update to mongodb-core v3.1.11 (9bef6e7)

3.1.11 (2019-01-15)

Bug Fixes

  • bulk: fix error propagation in empty bulk.execute (a3adb3f)
  • bulk: make sure that any error in bulk write is propagated (bedc2d2)
  • bulk: properly calculate batch size for bulk writes (aafe71b)
  • operations: do not call require in a hot path (ff82ff4)

3.1.10 (2018-11-16)

Bug Fixes

  • auth: remember to default to admin database (c7dec28)

Features

  • core: update to mongodb-core v3.1.9 (bd3355b)

3.1.9 (2018-11-06)

Bug Fixes

  • db: move db constants to other file to avoid circular ref (#1858) (239036f)
  • estimated-document-count: support options other than maxTimeMs (36c3c7d)

Features

  • core: update to mongodb-core v3.1.8 (80d7c79)

3.1.8 (2018-10-10)

Bug Fixes

  • connect: use reported default databse from new uri parser (811f8f8)

Features

  • core: update to mongodb-core v3.1.7 (dbfc905)

3.1.7 (2018-10-09)

Features

  • core: update mongodb-core to v3.1.6 (61b054e)

3.1.6 (2018-09-15)

Features

  • core: update to core v3.1.5 (c5f823d)

3.1.5 (2018-09-14)

Bug Fixes

  • cursor: allow $meta based sort when passing an array to sort() (f93a8c3)
  • utils: only set retryWrites to true for valid operations (3b725ef)

Features

  • core: bump core to v3.1.4 (805d58a)

3.1.4 (2018-08-25)

Bug Fixes

  • buffer: use safe-buffer polyfill to maintain compatibility (327da95)
  • change-stream: properly support resumablity in stream mode (c43a34b)
  • connect: correct replacement of topology on connect callback (918a1e0)
  • cursor: remove deprecated notice on forEach (a474158)
  • url-parser: bail early on validation when using domain socket (3cb3da3)

Features

  • client-ops: allow bypassing creation of topologies on connect (fe39b93)
  • core: update mongodb-core to 3.1.3 (a029047)
  • test: use connection strings for all calls to newClient (1dac18f)

3.1.3 (2018-08-13)

Features

  • core: update to mongodb-core 3.1.2 (337cb79)

3.1.2 (2018-08-13)

Bug Fixes

  • aggregate: support user-provided batchSize (ad10dee)
  • buffer: replace deprecated Buffer constructor (759dd85)
  • bulk: fixing retryable writes for mass-change ops (0604036)
  • bulk: handle MongoWriteConcernErrors (12ff392)
  • change_stream: do not check isGetMore if error[mongoErrorContextSymbol] is undefined (#1720) (844c2c8)
  • change-stream: fix change stream resuming with promises (3063f00)
  • client-ops: return transform map to map rather than function (cfb7d83)
  • collection: correctly shallow clone passed in options (7727700)
  • collection: countDocuments throws error when query doesn't match docs (09c7d8e)
  • collection: depend on resolveReadPreference for inheritance (a649e35)
  • collection: ensure findAndModify always use readPreference primary (86344f4)
  • collection: isCapped returns false instead of undefined (b8471f1)
  • collection: only send bypassDocumentValidation if true (fdb828b)
  • count-documents: return callback on error case (fca1185)
  • cursor: cursor count with collation fix (71879c3)
  • cursor: cursor hasNext returns false when exhausted (184b817)
  • cursor: cursor.count not respecting parent readPreference (5a9fdf0)
  • cursor: set readPreference for cursor.count (13d776f)
  • db: don't send session down to createIndex command (559c195)
  • db: throw readable error when creating _id with background: true (b3ff3ed)
  • db_ops: call collection.find() with correct parameters (#1795) (36e92f1)
  • db_ops: fix two incorrectly named variables (15dc808)
  • findOneAndUpdate: ensure that update documents contain atomic operators (eb68074)
  • index: export MongoNetworkError (98ab29e)
  • mongo_client: translate options for connectWithUrl (78f6977)
  • mongo-client: pass arguments to ctor when new keyword is used (d6c3417)
  • mongos: bubble up close events after the first one (#1713) (3e91d77), closes Automattic/mongoose#6249 #1685
  • parallelCollectionScan: do not use implicit sessions on cursors (2de470a)
  • retryWrites: fixes more bulk ops to not use retryWrites (69e5254)
  • server: remove unnecessary print statement (2bcbc12)
  • teardown: properly destroy a topology when initial connect fails (b8d2f1d)
  • topology-base: sending endSessions is always skipped now (a276cbe)
  • txns: omit writeConcern when in a transaction (b88c938)
  • utils: restructure inheritance rules for read preferences (6a7dac1)

Features

  • auth: add support for SCRAM-SHA-256 (f53195d)
  • changeStream: Adding new 4.0 ChangeStream features (2cb4894)
  • changeStream: allow resuming on getMore errors (4ba5adc)
  • changeStream: expanding changeStream resumable errors (49fbafd)
  • ChangeStream: update default startAtOperationTime (50a9f65)
  • collection: add colleciton level document mapping/unmapping (d03335e)
  • collection: Implement new count API (a5240ae)
  • Collection: warn if callback is not function in find and findOne (cddaba0)
  • core: bump core dependency to v3.1.0 (4937240)
  • cursor: new cursor.transformStream method (397fcd2)
  • deprecation: create deprecation function (4f907a0)
  • deprecation: wrap deprecated functions (a5d0f1d)
  • GridFS: add option to disable md5 in file upload (704a88e)
  • listCollections: add support for nameOnly option (d2d0367)
  • parallelCollectionScan: does not allow user to pass a session (4da9e03)
  • read-preference: add transaction to inheritance rules (18ca41d)
  • read-preference: unify means of read preference resolution (#1738) (2995e11)
  • urlParser: use core URL parser (c1c5d8d)
  • withSession: add top level helper for session lifetime (9976b86)

Reverts

3.1.1 (2018-07-05)

Bug Fixes

  • client-ops: return transform map to map rather than function (b8b4bfa)
  • collection: correctly shallow clone passed in options (2e6c4fa)
  • collection: countDocuments throws error when query doesn't match docs (4e83556)
  • server: remove unnecessary print statement (20e11b3)

3.1.0 (2018-06-27)

Bug Fixes

  • aggregate: support user-provided batchSize (ad10dee)
  • bulk: fixing retryable writes for mass-change ops (0604036)
  • bulk: handle MongoWriteConcernErrors (12ff392)
  • change_stream: do not check isGetMore if error[mongoErrorContextSymbol] is undefined (#1720) (844c2c8)
  • change-stream: fix change stream resuming with promises (3063f00)
  • collection: depend on resolveReadPreference for inheritance (a649e35)
  • collection: only send bypassDocumentValidation if true (fdb828b)
  • cursor: cursor count with collation fix (71879c3)
  • cursor: cursor hasNext returns false when exhausted (184b817)
  • cursor: cursor.count not respecting parent readPreference (5a9fdf0)
  • db: don't send session down to createIndex command (559c195)
  • db: throw readable error when creating _id with background: true (b3ff3ed)
  • findOneAndUpdate: ensure that update documents contain atomic operators (eb68074)
  • index: export MongoNetworkError (98ab29e)
  • mongo-client: pass arguments to ctor when new keyword is used (d6c3417)
  • mongos: bubble up close events after the first one (#1713) (3e91d77), closes Automattic/mongoose#6249 #1685
  • parallelCollectionScan: do not use implicit sessions on cursors (2de470a)
  • retryWrites: fixes more bulk ops to not use retryWrites (69e5254)
  • topology-base: sending endSessions is always skipped now (a276cbe)
  • txns: omit writeConcern when in a transaction (b88c938)
  • utils: restructure inheritance rules for read preferences (6a7dac1)

Features

  • auth: add support for SCRAM-SHA-256 (f53195d)
  • changeStream: Adding new 4.0 ChangeStream features (2cb4894)
  • changeStream: allow resuming on getMore errors (4ba5adc)
  • changeStream: expanding changeStream resumable errors (49fbafd)
  • ChangeStream: update default startAtOperationTime (50a9f65)
  • collection: add colleciton level document mapping/unmapping (d03335e)
  • collection: Implement new count API (a5240ae)
  • Collection: warn if callback is not function in find and findOne (cddaba0)
  • core: bump core dependency to v3.1.0 (855bfdb)
  • cursor: new cursor.transformStream method (397fcd2)
  • GridFS: add option to disable md5 in file upload (704a88e)
  • listCollections: add support for nameOnly option (d2d0367)
  • parallelCollectionScan: does not allow user to pass a session (4da9e03)
  • read-preference: add transaction to inheritance rules (18ca41d)
  • read-preference: unify means of read preference resolution (#1738) (2995e11)
  • urlParser: use core URL parser (c1c5d8d)
  • withSession: add top level helper for session lifetime (9976b86)

Reverts

3.0.6 (2018-04-09)

Bug Fixes

  • db: ensure dropDatabase always uses primary read preference (e62e5c9)
  • driverBench: driverBench has default options object now (c557817)

Features

  • command-monitoring: support enabling command monitoring (5903680)
  • core: update to mongodb-core v3.0.6 (cfdd0ae)
  • driverBench: Implementing DriverBench (d10fbad)

3.0.5 (2018-03-23)

Bug Fixes

  • AggregationCursor: adding session tracking to AggregationCursor (baca5b7)
  • Collection: fix session leak in parallelCollectonScan (3331ec9)
  • comments: adding fixes for PR comments (ee110ac)
  • url_parser: support a default database on mongodb+srv uris (6d39b2a)

Features

  • sessions: adding implicit cursor session support (a81245b)

3.0.4 (2018-03-05)

Bug Fixes

  • collection: fix error when calling remove with no args (#1657) (4c9b0f8)
  • executeOperation: don't mutate options passed to commands (934a43a)
  • jsdoc: mark db.collection callback as optional + typo fix (#1658) (c519b9b)
  • sessions: move active session tracking to topology base (#1665) (b1f296f)
  • utils: fixes executeOperation to clean up sessions (04e6ef6)

Features

  • default-db: use dbName from uri if none provided (23b1938)
  • mongodb-core: update to mongodb-core 3.0.4 (1fdbaa5)

3.0.3 (2018-02-23)

Bug Fixes

  • collection: fix error when calling remove with no args (#1657) (4c9b0f8)
  • executeOperation: don't mutate options passed to commands (934a43a)
  • jsdoc: mark db.collection callback as optional + typo fix (#1658) (c519b9b)
  • sessions: move active session tracking to topology base (#1665) (b1f296f)

3.0.2 (2018-01-29)

Bug Fixes

  • collection: ensure dynamic require of db is wrapped in parentheses (efa78f0)
  • db: only callback with MongoError NODE-1293 (#1652) (45bc722)
  • topology base: allow more than 10 event listeners (#1630) (d9fb750)
  • url parser: preserve auth creds when composing conn string (#1640) (eddca5e)

Features

  • bulk: forward 'checkKeys' option for ordered and unordered bulk operations (421a6b2)
  • collection: expose dbName property of collection (6fd05c1)

3.0.1 (2017-12-24)

  • update mongodb-core to 3.0.1

3.0.0 (2017-12-24)

Bug Fixes

  • aggregate: remove support for inline results for aggregate (#1620) (84457ec)
  • topologies: unify topologies connect API (#1615) (0fb4658)

Features

  • keepAlive: make keepAlive options consistent (#1612) (f608f44)

BREAKING CHANGES

  • topologies: Function signature for .connect method on replset and mongos has changed. You shouldn't have been using this anyway, but if you were, you only should pass options and callback.

Part of NODE-1089

  • keepAlive: option keepAlive is now split into boolean keepAlive and number keepAliveInitialDelay

Fixes NODE-998

3.0.0-rc0 (2017-12-05)

Bug Fixes

  • aggregation: ensure that the cursor key is always present (f16f314)
  • apm: give users access to raw server responses (88b206b)
  • apm: only rebuilt cursor if reply is non-null (96052c8)
  • apm: rebuild lost cursor info on pre-OP_QUERY responses (4242d49)
  • bulk-unordered: add check for ignoreUndefined (f38641a)
  • change stream examples: use timeouts, cleanup (c5fec5f)
  • change-streams: ensure a majority read concern on initial agg (23011e9)
  • changeStreams: fixing node4 issue with util.inherits (#1587) (168bb3d)
  • collection: allow { upsert: 1 } for findOneAndUpdate() and update() (5bcedd6)
  • collection: allow passing noCursorTimeout as an option to find() (e9c4ffc)
  • collection: make the parameters of findOne very explicit (3054f1a)
  • cursor: hasNext should propagate errors when using callback (6339625)
  • cursor: close readable on null response for dead cursor (6aca2c5)
  • dns txt records: check options are set (e5caf4f)
  • docs: Represent each valid option in docs in both places (fde6e5d)
  • grid-store: add missing callback (66a9a05)
  • grid-store: move into callback scope (b53f65f)
  • GridFS: fix TypeError: doc.data.length is not a function (#1570) (22a4628)
  • list-collections: ensure default of primary ReadPreference (4a0cfeb)
  • mongo client: close client before calling done (c828aab)
  • mongo client: do not connect if url parse error (cd10084)
  • mongo client: send error to cb (eafc9e2)
  • mongo-client: move to inside of callback (68b0fca)
  • mongo-client: options should not be passed to connect (474ac65)
  • tests: migrate 2.x tests to 3.x (3a5232a)
  • updateOne/updateMany: ensure that update documents contain atomic operators (8b4255a)
  • url parser: add check for options as cb (52b6039)
  • url parser: compare srv address and parent domains (daa186d)
  • url parser: compare string from first period on (9e5d77e)
  • url parser: default to ssl true for mongodb+srv (0fbca4b)
  • url parser: error when multiple hostnames used (c1aa681)
  • url parser: keep original uri options and default to ssl true (e876a72)
  • url parser: log instead of throw error for unsupported url options (155de2d)
  • url parser: make sure uri has 3 parts (aa9871b)
  • url parser: only 1 txt record allowed with 2 possible options (d9f4218)
  • url parser: only check for multiple hostnames with srv protocol (5542bcc)
  • url parser: remove .only from test (642e39e)
  • url parser: return callback (6096afc)
  • url parser: support single text record with multiple strings (356fa57)
  • url parser: try catch bug, not actually returning from try loop (758892b)
  • url parser: use warn instead of info (40ed27d)
  • url-parser: remove comment, send error to cb (d44420b)

Features

  • aggregate: support hit field for aggregate command (aa7da15)
  • aggregation: adds support for comment in aggregation command (#1571) (4ac475c)
  • aggregation: fail aggregation on explain + readConcern/writeConcern (e0ca1b4)
  • causal-consistency: support afterClusterTime in readConcern (a9097f7)
  • change-streams: add support for change streams (c02d25c)
  • collection: updating find API (f26362d)
  • execute-operation: implementation for common op execution (67c344f)
  • listDatabases: add support for nameOnly option to listDatabases (eb79b5a)
  • maxTimeMS: adding maxTimeMS option to createIndexes and dropIndexes (90d4a63)
  • mongo-client: implement MongoClient.prototype.startSession (bce5adf)
  • retryable-writes: add support for retryWrites cs option (2321870)
  • sessions: MongoClient will now track sessions and release (6829f47)
  • sessions: support passing sessions via objects in all methods (a531f05)
  • shared: add helper utilities for assertion and suite setup (b6cc34e)
  • ssl: adds missing ssl options ssl options for ciphers and ecdhCurve (441b7b1)
  • test-shared: add notEqual assertion (41d93fd)
  • test-shared: add strictEqual assertion method (cad8e19)
  • topologies: expose underlaying `logicalSessionTimeoutMinutes' (1609a37)
  • url parser: better error message for slash in hostname (457bc29)

BREAKING CHANGES

  • aggregation: If you use aggregation, and try to use the explain flag while you have a readConcern or writeConcern, your query will fail
  • collection: find and findOne no longer support the fields parameter. You can achieve the same results as the fields parameter by either using Cursor.prototype.project, or by passing the projection property in on the options object. Additionally, find does not support individual options like skip and limit as positional parameters. You must pass in these parameters in the options object

3.0.0 2017-??-??

  • NODE-1043 URI-escaping authentication and hostname details in connection string

2.2.31 2017-08-08

  • update mongodb-core to 2.2.15
  • allow auth option in MongoClient.connect
  • remove duplicate option promoteLongs from MongoClient's connect
  • bulk operations should not throw an error on empty batch

2.2.30 2017-07-07

  • Update mongodb-core to 2.2.14
  • MongoClient
    • add appname to list of valid option names
    • added test for passing appname as option
  • NODE-1052 ensure user options are applied while parsing connection string uris

2.2.29 2017-06-19

  • Update mongodb-core to 2.1.13
    • NODE-1039 ensure we force destroy server instances, forcing queue to be flushed.
    • Use actual server type in standalone SDAM events.
  • Allow multiple map calls (Issue #1521, https://github.com/Robbilie).
  • Clone insertMany options before mutating (Issue #1522, https://github.com/vkarpov15).
  • NODE-1034 Fix GridStore issue caused by Node 8.0.0 breaking backward compatible fs.read API.
  • NODE-1026, use operator instead of skip function in order to avoid useless fetch stage.

2.2.28 2017-06-02

  • Update mongodb-core to 2.1.12
    • NODE-1019 Set keepAlive to 300 seconds or 1/2 of socketTimeout if socketTimeout < keepAlive.
    • Minor fix to report the correct state on error.
    • NODE-1020 'family' was added to options to provide high priority for ipv6 addresses (Issue #1518, https://github.com/firej).
    • Fix require_optional loading of bson-ext.
    • Ensure no errors are thrown by replset if topology is destroyed before it finished connecting.
    • NODE-999 SDAM fixes for Mongos and single Server event emitting.
    • NODE-1014 Set socketTimeout to default to 360 seconds.
    • NODE-1019 Set keepAlive to 300 seconds or 1/2 of socketTimeout if socketTimeout < keepAlive.
  • Just handle Collection name errors distinctly from general callback errors avoiding double callbacks in Db.collection.
  • NODE-999 SDAM fixes for Mongos and single Server event emitting.
  • NODE-1000 Added guard condition for upload.js checkDone function in case of race condition caused by late arriving chunk write.

2.2.27 2017-05-22

  • Updated mongodb-core to 2.1.11
    • NODE-987 Clear out old intervalIds on when calling topologyMonitor.
    • NODE-987 Moved filtering to pingServer method and added test case.
    • Check for connection destroyed just before writing out and flush out operations correctly if it is (Issue #179, https://github.com/jmholzinger).
    • NODE-989 Refactored Replicaset monitoring to correcly monitor newly added servers, Also extracted setTimeout and setInterval to use custom wrappers Timeout and Interval.
  • NODE-985 Deprecated Db.authenticate and Admin.authenticate and moved auth methods into authenticate.js to ensure MongoClient.connect does not print deprecation warnings.
  • NODE-988 Merged readConcern and hint correctly on collection(...).find(...).count()
  • Fix passing the readConcern option to MongoClient.connect (Issue #1514, https://github.com/bausmeier).
  • NODE-996 Propegate all events up to a MongoClient instance.
  • Allow saving doc with null _id (Issue #1517, https://github.com/vkarpov15).
  • NODE-993 Expose hasNext for command cursor and add docs for both CommandCursor and Aggregation Cursor.

2.2.26 2017-04-18

  • Updated mongodb-core to 2.1.10
    • NODE-981 delegate auth to replset/mongos if inTopology is set.
    • NODE-978 Wrap connection.end in try/catch for node 0.10.x issue causing exceptions to be thrown, Also surfaced getConnection for mongos and replset.
    • Remove dynamic require (Issue #175, https://github.com/tellnes).
    • NODE-696 Handle interrupted error for createIndexes.
    • Fixed isse when user is executing find command using Server.command and it get interpreted as a wire protcol message, #172.
    • NODE-966 promoteValues not being promoted correctly to getMore.
    • Merged in fix for flushing out monitoring operations.
  • NODE-983 Add cursorId to aggregate and listCollections commands (Issue, #1510).
  • Mark group and profilingInfo as deprecated methods
  • NODE-956 DOCS Examples.
  • Update readable-stream to version 2.2.7.
  • NODE-978 Added test case to uncover connection.end issue for node 0.10.x.
  • NODE-972 Fix(db): don't remove database name if collectionName == dbName (Issue, #1502)
  • Fixed merging of writeConcerns on db.collection method.
  • NODE-970 mix in readPreference for strict mode listCollections callback.
  • NODE-966 added testcase for promoteValues being applied to getMore commands.
  • NODE-962 Merge in ignoreUndefined from collection level for find/findOne.
  • Remove multi option from updateMany tests/docs (Issue #1499, https://github.com/spratt).
  • NODE-963 Correctly handle cursor.count when using APM.

2.2.25 2017-03-17

  • Don't rely on global toString() for checking if object (Issue #1494, https://github.com/vkarpov15).
  • Remove obsolete option uri_decode_auth (Issue #1488, https://github.com/kamagatos).
  • NODE-936 Correctly translate ReadPreference to CoreReadPreference for mongos queries.
  • Exposed BSONRegExp type.
  • NODE-950 push correct index for INSERT ops (https://github.com/mbroadst).
  • NODE-951 Added support for sslCRL option and added a test case for it.
  • NODE-953 Made batchSize issue general at cursor level.
  • NODE-954 Remove write concern from reindex helper as it will not be supported in 3.6.
  • Updated mongodb-core to 2.1.9.
    • Return lastIsMaster correctly when connecting with secondaryOnlyConnectionAllowed is set to true and only a secondary is available in replica state.
    • Clone options when passed to wireProtocol handler to avoid intermittent modifications causing errors.
    • Ensure SSL error propegates better for Replset connections when there is a SSL validation error.
    • NODE-957 Fixed issue where < batchSize not causing cursor to be closed on execution of first batch.
    • NODE-958 Store reconnectConnection on pool object to allow destroy to close immediately.

2.2.24 2017-02-14

  • NODE-935, NODE-931 Make MongoClient strict options validation optional and instead print annoying console.warn entries.

2.2.23 2017-02-13

  • Updated mongodb-core to 2.1.8.
    • NODE-925 ensure we reschedule operations while pool is < poolSize while pool is growing and there are no connections with not currently performing work.
    • NODE-927 fixes issue where authentication was performed against arbiter instances.
    • NODE-915 Normalize all host names to avoid comparison issues.
    • Fixed issue where pool.destroy would never finish due to a single operation not being executed and keeping it open.
  • NODE-931 Validates all the options for MongoClient.connect and fixes missing connection settings.
  • NODE-929 Update SSL tutorial to correctly reflect the non-need for server/mongos/replset subobjects
  • Fix sensitive command check (Issue #1473, https://github.com/Annoraaq)

2.2.22 2017-01-24

  • Updated mongodb-core to 2.1.7.
    • NODE-919 ReplicaSet connection does not close immediately (Issue #156).
    • NODE-901 Fixed bug when normalizing host names.
    • NODE-909 Fixed readPreference issue caused by direct connection to primary.
    • NODE-910 Fixed issue when bufferMaxEntries == 0 and read preference set to nearest.
  • Add missing unref implementations for replset, mongos (Issue #1455, https://github.com/zbjornson)

2.2.21 2017-01-13

  • Updated mongodb-core to 2.1.6.
    • NODE-908 Keep auth contexts in replset and mongos topology to ensure correct application of authentication credentials when primary is first server to be detected causing an immediate connect event to happen.

2.2.20 2017-01-11

  • Updated mongodb-core to 2.1.5 to include bson 1.0.4 and bson-ext 1.0.4 due to Buffer.from being broken in early node 4.x versions.

2.2.19 2017-01-03

  • Corrupted Npm release fix.

2.2.18 2017-01-03

  • Updated mongodb-core to 2.1.4 to fix bson ObjectId toString issue with utils.inspect messing with toString parameters in node 6.

2.2.17 2017-01-02

  • updated createCollection doc options and linked to create command.
  • Updated mongodb-core to 2.1.3.
    • Monitoring operations are re-scheduled in pool if it cannot find a connection that does not already have scheduled work on it, this is to avoid the monitoring socket timeout being applied to any existing operations on the socket due to pipelining
    • Moved replicaset monitoring away from serial mode and to parallel mode.
    • updated bson and bson-ext dependencies to 1.0.2.

2.2.16 2016-12-13

  • NODE-899 reversed upsertedId change to bring back old behavior.

2.2.15 2016-12-10

  • Updated mongodb-core to 2.1.2.
    • Delay topologyMonitoring on successful attemptReconnect as no need to run a full scan immediately.
    • Emit reconnect event in primary joining when in connected status for a replicaset (Fixes mongoose reconnect issue).

2.2.14 2016-12-08

  • Updated mongodb-core to 2.1.1.
  • NODE-892 Passthrough options.readPreference to mongodb-core ReplSet instance.

2.2.13 2016-12-05

  • Updated mongodb-core to 2.1.0.
  • NODE-889 Fixed issue where legacy killcursor wire protocol messages would not be sent when APM is enabled.
  • Expose parserType as property on topology objects.

2.2.12 2016-11-29

  • Updated mongodb-core to 2.0.14.
    • Updated bson library to 0.5.7.
    • Dont leak connection.workItems elments when killCursor is called (Issue #150, https://github.com/mdlavin).
    • Remove unnecessary errors formatting (Issue #149, https://github.com/akryvomaz).
    • Only check isConnected against availableConnections (Issue #142).
    • NODE-838 Provide better error message on failed to connect on first retry for Mongos topology.
    • Set default servername to host is not passed through for sni.
    • Made monitoring happen on exclusive connection and using connectionTimeout to handle the wait time before failure (Issue #148).
    • NODE-859 Make minimum value of maxStalenessSeconds 90 seconds.
    • NODE-852 Fix Kerberos module deprecations on linux and windows and release new kerberos version.
    • NODE-850 Update Max Staleness implementation.
    • NODE-849 username no longer required for MONGODB-X509 auth.
    • NODE-848 BSON Regex flags must be alphabetically ordered.
    • NODE-846 Create notice for all third party libraries.
    • NODE-843 Executing bulk operations overwrites write concern parameter.
    • NODE-842 Re-sync SDAM and SDAM Monitoring tests from Specs repo.
    • NODE-840 Resync CRUD spec tests.
    • Unescapable while(true) loop (Issue #152).
  • NODE-864 close event not emits during network issues using single server topology.
  • Introduced maxStalenessSeconds.
  • NODE-840 Added CRUD specification test cases and fix minor issues with upserts reporting matchedCount > 0.
  • Don't ignore Db-level authSource when using auth method. (https://github.com/donaldguy).

2.2.11 2016-10-21

  • Updated mongodb-core to 2.0.13.
  • Updated bson library to 0.5.6.
    • Included cyclic dependency detection
  • Fix typo in serverHeartbeatFailed event name (Issue #1418, https://github.com/jakesjews).
  • NODE-824, readPreference "nearest" does not work when specified at collection level.
  • NODE-822, GridFSBucketWriteStream end method does not handle optional parameters.
  • NODE-823, GridFSBucketWriteStream end: callback is invoked with invalid parameters.
  • NODE-829, Using Start/End offset option in GridFSBucketReadStream doesn't return the right sized buffer.

2.2.10 2016-09-15

  • Updated mongodb-core to 2.0.12.
  • fix debug logging message not printing server name.
  • fixed application metadata being sent by wrong ismaster.
  • NODE-812 Fixed mongos stall due to proxy monitoring ismaster failure causing reconnect.
  • NODE-818 Replicaset timeouts in initial connect sequence can "no primary found".
  • Updated bson library to 0.5.5.
  • Added DBPointer up conversion to DBRef.
  • MongoDB 3.4-RC Pass appname through MongoClient.connect uri or options to allow metadata to be passed.
  • MongoDB 3.4-RC Pass collation options on update, findOne, find, createIndex, aggregate.
  • MongoDB 3.4-RC Allow write concerns to be passed to all supporting server commands.
  • MongoDB 3.4-RC Allow passing of servername as SSL options to support SNI.

2.2.9 2016-08-29

  • Updated mongodb-core to 2.0.11.
  • NODE-803, Fixed issue in how the latency window is calculated for Mongos topology causing issues for single proxy connections.
  • Avoid timeout in attemptReconnect causing multiple attemptReconnect attempts to happen (Issue #134, https://github.com/dead-horse).
  • Ensure promoteBuffers is propegated in same fashion as promoteValues and promoteLongs.
  • Don't treat ObjectId as object for mapReduce scope (Issue #1397, https://github.com/vkarpov15).

2.2.8 2016-08-23

  • Updated mongodb-core to 2.0.10.
  • Added promoteValues flag (default to true) to allow user to specify they only want wrapped BSON values back instead of promotion to native types.
  • Do not close mongos proxy connection on failed ismaster check in ha process (Issue #130).

2.2.7 2016-08-19

  • If only a single mongos is provided in the seedlist, fix issue where it would be assigned as single standalone server instead of mongos topology (Issue #130).
  • Updated mongodb-core to 2.0.9.
  • Allow promoteLongs to be passed in through Response.parse method and overrides default set on the connection.
  • NODE-798 Driver hangs on count command in replica set with one member.
  • Allow promoteLongs to be passed in through Response.parse method and overrides default set on the connection.
  • Allow passing in servername for TLS connections for SNI support.

2.2.6 2016-08-16

  • Updated mongodb-core to 2.0.8.
  • Allow execution of store operations independent of having both a primary and secondary available (Issue #123).
  • Fixed command execution issue for mongos to ensure buffering of commands when no mongos available.
  • Allow passing in an array of tags to ReadPreference constructor (Issue #1382, https://github.com/vkarpov15)
  • Added hashed connection names and fullResult.
  • Updated bson library to 0.5.3.
  • Enable maxTimeMS in count, distinct, findAndModify.

2.2.5 2016-07-28

  • Updated mongodb-core to 2.0.7.
  • Allow primary to be returned when secondaryPreferred is passed (Issue #117, https://github.com/dhendo).
  • Added better warnings when passing in illegal seed list members to a Mongos topology.
  • Minor attemptReconnect bug that would cause multiple attemptReconnect to run in parallel.
  • Fix wrong opType passed to disconnectHandler.add (Issue #121, https://github.com/adrian-gierakowski)
  • Implemented domain backward comp support enabled via domainsEnabled options on Server/ReplSet/Mongos and MongoClient.connect.

2.2.4 2016-07-19

  • NPM corrupted upload fix.

2.2.3 2016-07-19

  • Updated mongodb-core to 2.0.6.
  • Destroy connection on socket timeout due to newer node versions not closing the socket.

2.2.2 2016-07-15

  • Updated mongodb-core to 2.0.5.
  • Minor fixes to handle faster MongoClient connectivity from the driver, allowing single server instances to detect if they are a proxy.
  • Added numberOfConsecutiveTimeouts to pool that will destroy the pool if the number of consecutive timeouts > reconnectTries.
  • Print warning if seedlist servers host name does not match the one provided in it's ismaster.me field for Replicaset members.
  • Fix issue where Replicaset connection would not succeeed if there the replicaset was a single primary server setup.

2.2.1 2016-07-11

  • Updated mongodb-core to 2.0.4.
  • handle situation where user is providing seedlist names that do not match host list. fix allows for a single full discovery connection sweep before erroring out.
  • NODE-747 Polyfill for Object.assign for 0.12.x or 0.10.x.
  • NODE-746 Improves replicaset errors for wrong setName.

2.2.0 2016-07-05

  • Updated mongodb-core to 2.0.3.
  • Moved all authentication and handling of growing/shrinking of pool connections into actual pool.
  • All authentication methods now handle both auth/reauthenticate and logout events.
  • Introduced logout method to get rid of onAll option for logout command.
  • Updated bson to 0.5.0 that includes Decimal128 support.
  • Fixed logger error serialization issue.
  • Documentation fixes.
  • Implemented Server Selection Specification test suite.
  • Added warning level to logger.
  • Added warning message when sockeTimeout < haInterval for Replset/Mongos.
  • Mongos emits close event on no proxies available or when reconnect attempt fails.
  • Replset emits close event when no servers available or when attemptReconnect fails to reconnect.
  • Don't throw in auth methods but return error in callback.

2.1.21 2016-05-30

  • Updated mongodb-core to 1.3.21.
  • Pool gets stuck if a connection marked for immediateRelease times out (Issue #99, https://github.com/nbrachet).
  • Make authentication process retry up to authenticationRetries at authenticationRetryIntervalMS interval.
  • Made ismaster replicaset calls operate with connectTimeout or monitorSocketTimeout to lower impact of big socketTimeouts on monitoring performance.
  • Make sure connections mark as "immediateRelease" don't linger the inUserConnections list. Otherwise, after that connection times out, getAll() incorrectly returns more connections than are effectively present, causing the pool to not get restarted by reconnectServer. (Issue #99, https://github.com/nbrachet).
  • Make cursor getMore or killCursor correctly trigger pool reconnect to single server if pool has not been destroyed.
  • Make ismaster monitoring for single server connection default to avoid user confusion due to change in behavior.

2.1.20 2016-05-25

  • Refactored MongoClient options handling to simplify the logic, unifying it.
  • NODE-707 Implemented openUploadStreamWithId on GridFS to allow for custom fileIds so users are able to customize shard key and shard distribution.
  • NODE-710 Allow setting driver loggerLevel and logger function from MongoClient options.
  • Updated mongodb-core to 1.3.20.
  • Minor fix for SSL errors on connection attempts, minor fix to reconnect handler for the server.
  • Don't write to socket before having registered the callback for commands, work around for windows issuing error events twice on node.js when socket gets destroyed by firewall.
  • Fix minor issue where connectingServers would not be removed correctly causing single server connections to not auto-reconnect.

2.1.19 2016-05-17

  • Handle situation where a server connection in a replicaset sometimes fails to be destroyed properly due to being in the middle of authentication when the destroy method is called on the replicaset causing it to be orphaned and never collected.
  • Ensure replicaset topology destroy is never called by SDAM.
  • Ensure all paths are correctly returned on inspectServer in replset.
  • Updated mongodb-core to 1.3.19 to fix minor connectivity issue on quick open/close of MongoClient connections on auth enabled mongodb Replicasets.

2.1.18 2016-04-27

  • Updated mongodb-core to 1.3.18 to fix Node 6.0 issues.

2.1.17 2016-04-26

  • Updated mongodb-core to 1.3.16 to work around issue with early versions of node 0.10.x due to missing unref method on ClearText streams.
  • INT-1308: Allow listIndexes to inherit readPreference from Collection or DB.
  • Fix timeout issue using new flags #1361.
  • Updated mongodb-core to 1.3.17.
  • Better handling of unique createIndex error.
  • Emit error only if db instance has an error listener.
  • DEFAULT authMechanism; don't throw error if explicitly set by user.

2.1.16 2016-04-06

  • Updated mongodb-core to 1.3.16.

2.1.15 2016-04-06

  • Updated mongodb-core to 1.3.15.
  • Set ssl, sslValidate etc to mongosOptions on url_parser (Issue #1352, https://github.com/rubenstolk).
  • NODE-687 Fixed issue where a server object failed to be destroyed if the replicaset state did not update successfully. This could leave active connections accumulating over time.
  • Fixed some situations where all connections are flushed due to a single connection in the connection pool closing.

2.1.14 2016-03-29

  • Updated mongodb-core to 1.3.13.
  • Handle missing cursor on getMore when going through a mongos proxy by pinning to socket connection and not server.

2.1.13 2016-03-29

  • Updated mongodb-core to 1.3.12.

2.1.12 2016-03-29

  • Updated mongodb-core to 1.3.11.
  • Mongos setting acceptableLatencyMS exposed to control the latency women for mongos selection.
  • Mongos pickProxies fall back to closest mongos if no proxies meet latency window specified.
  • isConnected method for mongos uses same selection code as getServer.
  • Exceptions in cursor getServer trapped and correctly delegated to high level handler.

2.1.11 2016-03-23

  • Updated mongodb-core to 1.3.10.
  • Introducing simplified connections settings.

2.1.10 2016-03-21

  • Updated mongodb-core to 1.3.9.
  • Fixing issue that prevented mapReduce stats from being resolved (Issue #1351, https://github.com/davidgtonge)
  • Forwards SDAM monitoring events from mongodb-core.

2.1.9 2016-03-16

  • Updated mongodb-core to 1.3.7 to fix intermittent race condition that causes some users to experience big amounts of socket connections.
  • Makde bson parser in ordered/unordered bulk be directly from mongodb-core to avoid intermittent null error on mongoose.

2.1.8 2016-03-14

  • Updated mongodb-core to 1.3.5.
  • NODE-660 TypeError: Cannot read property 'noRelease' of undefined.
  • Harden MessageHandler in server.js to avoid issues where we cannot find a callback for an operation.
  • Ensure RequestId can never be larger than Max Number integer size.
  • NODE-661 typo in url_parser.js resulting in replSetServerOptions is not defined when connecting over ssl.
  • Confusing error with invalid partial index filter (Issue #1341, https://github.com/vkarpov15).
  • NODE-669 Should only error out promise for bulkWrite when error is a driver level error not a write error or write concern error.
  • NODE-662 shallow copy options on methods that are not currently doing it to avoid passed in options mutiation.
  • NODE-663 added lookup helper on aggregation cursor.
  • NODE-585 Result object specified incorrectly for findAndModify?.
  • NODE-666 harden validation for findAndModify CRUD methods.

2.1.7 2016-02-09

  • NODE-656 fixed corner case where cursor count command could be left without a connection available.
  • NODE-658 Work around issue that bufferMaxEntries:-1 for js gets interpreted wrongly due to double nature of Javascript numbers.
  • Fix: GridFS always returns the oldest version due to incorrect field name (Issue #1338, https://github.com/mdebruijne).
  • NODE-655 GridFS stream support for cancelling upload streams and download streams (Issue #1339, https://github.com/vkarpov15).
  • NODE-657 insertOne don`t return promise in some cases.
  • Added destroy alias for abort function on GridFSBucketWriteStream.

2.1.6 2016-02-05

  • Updated mongodb-core to 1.3.1.

2.1.5 2016-02-04

  • Updated mongodb-core to 1.3.0.
  • Added raw support for the command function on topologies.
  • Fixed issue where raw results that fell on batchSize boundaries failed (Issue #72)
  • Copy over all the properties to the callback returned from bindToDomain, (Issue #72)
  • Added connection hash id to be able to reference connection host/name without leaking it outside of driver.
  • NODE-638, Cannot authenticate database user with utf-8 password.
  • Refactored pool to be worker queue based, minimizing the impact a slow query have on throughput as long as # slow queries < # connections in the pool.
  • Pool now grows and shrinks correctly depending on demand not causing a full pool reconnect.
  • Improvements in monitoring of a Replicaset where in certain situations the inquiry process could get exited.
  • Switched to using Array.push instead of concat for use cases of a lot of documents.
  • Fixed issue where re-authentication could loose the credentials if whole Replicaset disconnected at once.
  • Added peer optional dependencies support using require_optional module.
  • Bug is listCollections for collection names that start with db name (Issue #1333, https://github.com/flyingfisher)
  • Emit error before closing stream (Issue #1335, https://github.com/eagleeye)

2.1.4 2016-01-12

2.1.3 2016-01-04

  • Updated mongodb-core to 1.2.31.
  • Allow connection to secondary if primaryPreferred or secondaryPreferred (Issue #70, https://github.com/leichter)

2.1.2 2015-12-23

  • Updated mongodb-core to 1.2.30.
  • Pool allocates size + 1 connections when using replicasets, reserving additional pool connection for monitoring exclusively.
  • Fixes bug when all replicaset members are down, that would cause it to fail to reconnect using the originally provided seedlist.

2.1.1 2015-12-13

  • Surfaced checkServerIdentity options for MongoClient, Server, ReplSet and Mongos to allow for control of the checkServerIdentity method available in Node.s 0.12.x or higher.
  • Added readPreference support to listCollections and listIndexes helpers.
  • Updated mongodb-core to 1.2.28.

2.1.0 2015-12-06

2.0.53 2015-12-23

  • Updated mongodb-core to 1.2.30.
  • Pool allocates size + 1 connections when using replicasets, reserving additional pool connection for monitoring exclusively.
  • Fixes bug when all replicaset members are down, that would cause it to fail to reconnect using the originally provided seedlist.

2.0.52 2015-12-14

  • removed remove from Gridstore.close.

2.0.51 2015-12-13

  • Surfaced checkServerIdentity options for MongoClient, Server, ReplSet and Mongos to allow for control of the checkServerIdentity method available in Node.s 0.12.x or higher.
  • Added readPreference support to listCollections and listIndexes helpers.
  • Updated mongodb-core to 1.2.28.

2.0.50 2015-12-06

  • Updated mongodb-core to 1.2.26.

2.0.49 2015-11-20

  • Updated mongodb-core to 1.2.24 with several fixes.
    • Fix Automattic/mongoose#3481; flush callbacks on error, (Issue #57, https://github.com/vkarpov15).
    • $explain query for wire protocol 2.6 and 2.4 does not set number of returned documents to -1 but to 0.
    • ismaster runs against admin.$cmd instead of system.$cmd.
    • Fixes to handle getMore command errors for MongoDB 3.2
    • Allows the process to properly close upon a Db.close() call on the replica set by shutting down the haTimer and closing arbiter connections.

2.0.48 2015-11-07

  • GridFS no longer performs any deletes when writing a brand new file that does not have any previous <db>.fs.chunks or <db>.fs.files documents.
  • Updated mongodb-core to 1.2.21.
  • Hardened the checking for replicaset equality checks.
  • OpReplay flag correctly set on Wire protocol query.
  • Mongos load balancing added, introduced localThresholdMS to control the feature.
  • Kerberos now a peerDependency, making it not install it by default in Node 5.0 or higher.

2.0.47 2015-10-28

  • Updated mongodb-core to 1.2.20.
  • Fixed bug in arbiter connection capping code.
  • NODE-599 correctly handle arrays of server tags in order of priority.
  • Fix for 2.6 wire protocol handler related to readPreference handling.
  • Added maxAwaitTimeMS support for 3.2 getMore to allow for custom timeouts on tailable cursors.
  • Make CoreCursor check for $err before saying that 'next' succeeded (Issue #53, https://github.com/vkarpov15).

2.0.46 2015-10-15

  • Updated mongodb-core to 1.2.19.
  • NODE-578 Order of sort fields is lost for numeric field names.
  • Expose BSON Map (ES6 Map or polyfill).
  • Minor fixes for APM support to pass extended APM test suite.

2.0.45 2015-09-30

  • NODE-566 Fix issue with rewind on capped collections causing cursor state to be reset on connection loss.

2.0.44 2015-09-28

  • Bug fixes for APM upconverting of legacy INSERT/UPDATE/REMOVE wire protocol messages.
  • NODE-562, fixed issue where a Replicaset MongoDB URI with a single seed and replSet name set would cause a single direct connection instead of topology discovery.
  • Updated mongodb-core to 1.2.14.
  • NODE-563 Introduced options.ignoreUndefined for db class and MongoClient db options, made serialize undefined to null default again but allowing for overrides on insert/update/delete operations.
  • Use handleCallback if result is an error for count queries. (Issue #1298, https://github.com/agclever)
  • Rewind cursor to correctly force reconnect on capped collections when first query comes back empty.
  • NODE-571 added code 59 to legacy server errors when SCRAM-SHA-1 mechanism fails.
  • NODE-572 Remove examples that use the second parameter to find().

2.0.43 2015-09-14

  • Propagate timeout event correctly to db instances.
  • Application Monitoring API (APM) implemented.
  • NOT providing replSet name in MongoClient connection URI will force single server connection. Fixes issue where it was impossible to directly connect to a replicaset member server.
  • Updated mongodb-core to 1.2.12.
  • NODE-541 Initial Support "read committed" isolation level where "committed" means confimed by the voting majority of a replica set.
  • GridStore doesn't share readPreference setting from connection string. (Issue #1295, https://github.com/zhangyaoxing)
  • fixed forceServerObjectId calls (Issue #1292, https://github.com/d-mon-)
  • Pass promise library through to DB function (Issue #1294, https://github.com/RovingCodeMonkey)

2.0.42 2015-08-18

  • Added test case to exercise all non-crud methods on mongos topologies, fixed numberOfConnectedServers on mongos topology instance.

2.0.41 2015-08-14

  • Added missing Mongos.prototype.parserType function.
  • Updated mongodb-core to 1.2.10.

2.0.40 2015-07-14

  • Updated mongodb-core to 1.2.9 for 2.4 wire protocol error handler fix.
  • NODE-525 Reset connectionTimeout after it's overwritten by tls.connect.
  • NODE-518 connectTimeoutMS is doubled in 2.0.39.
  • NODE-506 Ensures that errors from bulk unordered and ordered are instanceof Error (Issue #1282, https://github.com/owenallenaz).
  • NODE-526 Unique index not throwing duplicate key error.
  • NODE-528 Ignore undefined fields in Collection.find().
  • NODE-527 The API example for collection.createIndex shows Db.createIndex functionality.

2.0.39 2015-07-14

  • Updated mongodb-core to 1.2.6 for NODE-505.

2.0.38 2015-07-14

  • NODE-505 Query fails to find records that have a 'result' property with an array value.

2.0.37 2015-07-14

  • NODE-504 Collection * Default options when using promiseLibrary.
  • NODE-500 Accidental repeat of hostname in seed list multiplies total connections persistently.
  • Updated mongodb-core to 1.2.5 to fix NODE-492.

2.0.36 2015-07-07

  • Fully promisified allowing the use of ES6 generators and libraries like co. Also allows for BYOP (Bring your own promises).
  • NODE-493 updated mongodb-core to 1.2.4 to ensure we cannot DDOS the mongod or mongos process on large connection pool sizes.

2.0.35 2015-06-17

  • Upgraded to mongodb-core 1.2.2 including removing warnings when C++ bson parser is not available and a fix for SCRAM authentication.

2.0.34 2015-06-17

  • Upgraded to mongodb-core 1.2.1 speeding up serialization and removing the need for the c++ bson extension.
  • NODE-486 fixed issue related to limit and skip when calling toArray in 2.0 driver.
  • NODE-483 throw error if capabilities of topology is queries before topology has performed connection setup.
  • NODE-482 fixed issue where MongoClient.connect would incorrectly identify a replset seed list server as a non replicaset member.
  • NODE-487 fixed issue where killcursor command was not being sent correctly on limit and skip queries.

2.0.33 2015-05-20

  • Bumped mongodb-core to 1.1.32.

2.0.32 2015-05-19

  • NODE-463 db.close immediately executes its callback.
  • Don't only emit server close event once (Issue #1276, https://github.com/vkarpov15).
  • NODE-464 Updated mongodb-core to 1.1.31 that uses a single socket connection to arbiters and hidden servers as well as emitting all event correctly.

2.0.31 2015-05-08

  • NODE-461 Tripping on error "no chunks found for file, possibly corrupt" when there is no error.

2.0.30 2015-05-07

  • NODE-460 fix; don't set authMechanism for user in db.authenticate() to avoid mongoose authentication issue.

2.0.29 2015-05-07

  • NODE-444 Possible memory leak, too many listeners added.
  • NODE-459 Auth failure using Node 0.8.28, MongoDB 3.0.2 & mongodb-node-native 1.4.35.
  • Bumped mongodb-core to 1.1.26.

2.0.28 2015-04-24

  • Bumped mongodb-core to 1.1.25
  • Added Cursor.prototype.setCursorOption to allow for setting node specific cursor options for tailable cursors.
  • NODE-430 Cursor.count() opts argument masked by var opts = {}
  • NODE-406 Implemented Cursor.prototype.map function tapping into MongoClient cursor transforms.
  • NODE-438 replaceOne is not returning the result.ops property as described in the docs.
  • NODE-433 _read, pipe and write all open gridstore automatically if not open.
  • NODE-426 ensure drain event is emitted after write function returns, fixes intermittent issues in writing files to gridstore.
  • NODE-440 GridStoreStream._read() doesn't check GridStore.read() error.
  • Always use readPreference = primary for findAndModify command (ignore passed in read preferences) (Issue #1274, https://github.com/vkarpov15).
  • Minor fix in GridStore.exists for dealing with regular expressions searches.

2.0.27 2015-04-07

  • NODE-410 Correctly handle issue with pause/resume in Node 0.10.x that causes exceptions when using the Node 0.12.0 style streams.

2.0.26 2015-04-07

2.0.25 2015-03-26

  • Upgraded mongodb-core to 1.1.21, making the C++ bson code an optional dependency to the bson module.

2.0.24 2015-03-24

  • NODE-395 Socket Not Closing, db.close called before full set finished initalizing leading to server connections in progress not being closed properly.
  • Upgraded mongodb-core to 1.1.20.

2.0.23 2015-03-21

  • NODE-380 Correctly return MongoError from toError method.
  • Fixed issue where addCursorFlag was not correctly setting the flag on the command for mongodb-core.
  • NODE-388 Changed length from method to property on order.js/unordered.js bulk operations.
  • Upgraded mongodb-core to 1.1.19.

2.0.22 2015-03-16

  • NODE-377, fixed issue where tags would correctly be checked on secondary and nearest to filter out eligible server candidates.
  • Upgraded mongodb-core to 1.1.17.

2.0.21 2015-03-06

  • Upgraded mongodb-core to 1.1.16 making sslValidate default to true to force validation on connection unless overriden by the user.

2.0.20 2015-03-04

  • Updated mongodb-core 1.1.15 to relax pickserver method.

2.0.19 2015-03-03

2.0.18 2015-02-27

  • Bumped mongodb-core 1.1.14 to ensure passives are correctly added as secondaries.

2.0.17 2015-02-27

  • NODE-336 Added length function to ordered and unordered bulk operations to be able know the amount of current operations in bulk.
  • Bumped mongodb-core 1.1.13 to ensure passives are correctly added as secondaries.

2.0.16 2015-02-16

  • listCollection now returns filtered result correctly removing db name for 2.6 or earlier servers.
  • Bumped mongodb-core 1.1.12 to correctly work for node 0.12.0 and io.js.
  • Add ability to get collection name from cursor (Issue #1253, https://github.com/vkarpov15)

2.0.15 2015-02-02

  • Unified behavior of listCollections results so 3.0 and pre 3.0 return same type of results.
  • Bumped mongodb-core to 1.1.11 to support per document tranforms in cursors as well as relaxing the setName requirement.
  • NODE-360 Aggregation cursor and command correctly passing down the maxTimeMS property.
  • Added ~1.0 mongodb-tools module for test running.
  • Remove the required setName for replicaset connections, if not set it will pick the first setName returned.

2.0.14 2015-01-21

  • Fixed some MongoClient.connect options pass through issues and added test coverage.
  • Bumped mongodb-core to 1.1.9 including fixes for io.js

2.0.13 2015-01-09

  • Bumped mongodb-core to 1.1.8.
  • Optimized query path for performance, moving Object.defineProperty outside of constructors.

2.0.12 2014-12-22

  • Minor fixes to listCollections to ensure correct querying of a collection when using a string.

2.0.11 2014-12-19

  • listCollections filters out index namespaces on < 2.8 correctly
  • Bumped mongo-client to 1.1.7

2.0.10 2014-12-18

  • NODE-328 fixed db.open return when no callback available issue and added test.
  • NODE-327 Refactored listCollections to return cursor to support 2.8.
  • NODE-327 Added listIndexes method and refactored internal methods to use the new command helper.
  • NODE-335 Cannot create index for nested objects fixed by relaxing key checking for createIndex helper.
  • Enable setting of connectTimeoutMS (Issue #1235, https://github.com/vkarpov15)
  • Bumped mongo-client to 1.1.6

2.0.9 2014-12-01

  • Bumped mongodb-core to 1.1.3 fixing global leaked variables and introducing strict across all classes.
  • All classes are now strict (Issue #1233)
  • NODE-324 Refactored insert/update/remove and all other crud opts to rely on internal methods to avoid any recursion.
  • Fixed recursion issues in debug logging due to JSON.stringify()
  • Documentation fixes (Issue #1232, https://github.com/wsmoak)
  • Fix writeConcern in Db.prototype.ensureIndex (Issue #1231, https://github.com/Qard)

2.0.8 2014-11-28

  • NODE-322 Finished up prototype refactoring of Db class.
  • NODE-322 Exposed Cursor in index.js for New Relic.

2.0.7 2014-11-20

  • Bumped mongodb-core to 1.1.2 fixing a UTF8 encoding issue for collection names.
  • NODE-318 collection.update error while setting a function with serializeFunctions option.
  • Documentation fixes.

2.0.6 2014-11-14

  • Refactored code to be prototype based instead of privileged methods.
  • Bumped mongodb-core to 1.1.1 to take advantage of the prototype based refactorings.
  • Implemented missing aspects of the CRUD specification.
  • Fixed documentation issues.
  • Fixed global leak REFERENCE_BY_ID in gridfs grid_store (Issue #1225, https://github.com/j)
  • Fix LearnBoost/mongoose#2313: don't let user accidentally clobber geoNear params (Issue #1223, https://github.com/vkarpov15)

2.0.5 2014-10-29

  • Minor fixes to documentation and generation of documentation.
  • NODE-306 (No results in aggregation cursor when collection name contains a dot), Merged code for cursor and aggregation cursor.

2.0.4 2014-10-23

  • Allow for single replicaset seed list with no setName specified (Issue #1220, https://github.com/imaman)
  • Made each rewind on each call allowing for re-using the cursor.
  • Fixed issue where incorrect iterations would happen on each for extensive batchSizes.
  • NODE-301 specifying maxTimeMS on find causes all fields to be omitted from result.

2.0.3 2014-10-14

  • NODE-297 Aggregate Broken for case of pipeline with no options.

2.0.2 2014-10-08

  • Bumped mongodb-core to 1.0.2.
  • Fixed bson module dependency issue by relying on the mongodb-core one.
  • Use findOne instead of find followed by nextObject (Issue #1216, https://github.com/sergeyksv)

2.0.1 2014-10-07

  • Dependency fix

2.0.0 2014-10-07

  • First release of 2.0 driver

2.0.0-alpha2 2014-10-02

  • CRUD API (insertOne, insertMany, updateOne, updateMany, removeOne, removeMany, bulkWrite, findOneAndDelete, findOneAndUpdate, findOneAndReplace)
  • Cluster Management Spec compatible.

2.0.0-alpha1 2014-09-08

  • Insert method allows only up 1000 pr batch for legacy as well as 2.6 mode
  • Streaming behavior is 0.10.x or higher with backwards compatibility using readable-stream npm package
  • Gridfs stream only available through .stream() method due to overlapping names on Gridstore object and streams in 0.10.x and higher of node
  • remove third result on update and remove and return the whole result document instead (getting rid of the weird 3 result parameters)
    • Might break some application
  • Returns the actual mongodb-core result instead of just the number of records changed for insert/update/remove
  • MongoClient only has the connect method (no ability instantiate with Server, ReplSet or similar)
  • Removed Grid class
  • GridStore only supports w+ for metadata updates, no appending to file as it's not thread safe and can cause corruption of the data
    • seek will fail if attempt to use with w or w+
    • write will fail if attempted with w+ or r
    • w+ only works for updating metadata on a file
  • Cursor toArray and each resets and re-runs the cursor
  • FindAndModify returns whole result document instead of just value
  • Extend cursor to allow for setting all the options via methods instead of dealing with the current messed up find
  • Removed db.dereference method
  • Removed db.cursorInfo method
  • Removed db.stats method
  • Removed db.collectionNames not needed anymore as it's just a specialized case of listCollections
  • Removed db.collectionInfo removed due to not being compatible with new storage engines in 2.8 as they need to use the listCollections command due to system collections not working for namespaces.
  • Added db.listCollections to replace several methods above

1.4.10 2014-09-04

  • Fixed BSON and Kerberos compilation issues
  • Bumped BSON to ~0.2 always installing latest BSON 0.2.x series
  • Fixed Kerberos and bumped to 0.0.4

1.4.9 2014-08-26

  • Check _bsonType for Binary (Issue #1202, https://github.com/mchapman)
  • Remove duplicate Cursor constructor (Issue #1201, https://github.com/KenPowers)
  • Added missing parameter in the documentation (Issue #1199, https://github.com/wpjunior)
  • Documented third parameter on the update callback(Issue #1196, https://github.com/gabmontes)
  • NODE-240 Operations on SSL connection hang on node 0.11.x
  • NODE-235 writeResult is not being passed on when error occurs in insert
  • NODE-229 Allow count to work with query hints
  • NODE-233 collection.save() does not support fullResult
  • NODE-244 Should parseError also emit a disconnected event?
  • NODE-246 Cursors are inefficiently constructed and consequently cannot be promisified.
  • NODE-248 Crash with X509 auth
  • NODE-252 Uncaught Exception in Base.__executeAllServerSpecificErrorCallbacks
  • Bumped BSON parser to 0.2.12

1.4.8 2014-08-01

  • NODE-205 correctly emit authenticate event
  • NODE-210 ensure no undefined connection error when checking server state
  • NODE-212 correctly inherit socketTimeoutMS from replicaset when HA process adds new servers or reconnects to existing ones
  • NODE-220 don't throw error if ensureIndex errors out in Gridstore
  • Updated bson to 0.2.11 to ensure correct toBSON behavior when returning non object in nested classes
  • Fixed test running filters
  • Wrap debug log in a call to format (Issue #1187, https://github.com/andyroyle)
  • False option values should not trigger w:1 (Issue #1186, https://github.com/jsdevel)
  • Fix aggregatestream.close(Issue #1194, https://github.com/jonathanong)
  • Fixed parsing issue for w:0 in url parser when in connection string
  • Modified collection.geoNear to support a geoJSON point or legacy coordinate pair (Issue #1198, https://github.com/mmacmillan)

1.4.7 2014-06-18

  • Make callbacks to be executed in right domain when server comes back up (Issue #1184, https://github.com/anton-kotenko)
  • Fix issue where currentOp query against mongos would fail due to mongos passing through $readPreference field to mongod (CS-X)

1.4.6 2014-06-12

1.4.5 2014-05-21

  • Added fullResult flag to insert/update/remove which will pass raw result document back. Document contents will vary depending on the server version the driver is talking to. No attempt is made to coerce a joint response.
  • Fix to avoid MongoClient.connect hanging during auth when secondaries building indexes pre 2.6.
  • return the destination stream in GridStore.pipe (Issue #1176, https://github.com/iamdoron)

1.4.4 2014-05-13

  • Bumped BSON version to use the NaN 1.0 package, fixed strict comparison issue for ObjectID
  • Removed leaking global variable (Issue #1174, https://github.com/dainis)
  • MongoClient respects connectTimeoutMS for initial discovery process (NODE-185)
  • Fix bug with return messages larger than 16MB but smaller than max BSON Message Size (NODE-184)

1.4.3 2014-05-01

1.4.2 2014-04-15

1.4.1 2014-04-09

  • Correctly emit joined event when primary change
  • Add _id to documents correctly when using bulk operations

1.4.0 2014-04-03

  • All node exceptions will no longer be caught if on('error') is defined
  • Added X509 auth support
  • Fix for MongoClient connection timeout issue (NODE-97)
  • Pass through error messages from parseError instead of just text (Issue #1125)
  • Close db connection on error (Issue #1128, https://github.com/benighted)
  • Fixed documentation generation
  • Added aggregation cursor for 2.6 and emulated cursor for pre 2.6 (uses stream2)
  • New Bulk API implementation using write commands for 2.6 and down converts for pre 2.6
  • Insert/Update/Remove using new write commands when available
  • Added support for new roles based API's in 2.6 for addUser/removeUser
  • Added bufferMaxEntries to start failing if the buffer hits the specified number of entries
  • Upgraded BSON parser to version 0.2.7 to work with < 0.11.10 C++ API changes
  • Support for OP_LOG_REPLAY flag (NODE-94)
  • Fixes for SSL HA ping and discovery.
  • Uses createIndexes if available for ensureIndex/createIndex
  • Added parallelCollectionScan method to collection returning CommandCursor instances for cursors
  • Made CommandCursor behave as Readable stream.
  • Only Db honors readPreference settings, removed Server.js legacy readPreference settings due to user confusion.
  • Reconnect event emitted by ReplSet/Mongos/Server after reconnect and before replaying of buffered operations.
  • GridFS buildMongoObject returns error on illegal md5 (NODE-157, https://github.com/iantocristian)
  • Default GridFS chunk size changed to (255 * 1024) bytes to optimize for collections defaulting to power of 2 sizes on 2.6.
  • Refactored commands to all go through command function ensuring consistent command execution.
  • Fixed issues where readPreferences where not correctly passed to mongos.
  • Catch error == null and make err detection more prominent (NODE-130)
  • Allow reads from arbiter for single server connection (NODE-117)
  • Handle error coming back with no documents (NODE-130)
  • Correctly use close parameter in Gridstore.write() (NODE-125)
  • Throw an error on a bulk find with no selector (NODE-129, https://github.com/vkarpov15)
  • Use a shallow copy of options in find() (NODE-124, https://github.com/vkarpov15)
  • Fix statistical strategy (NODE-158, https://github.com/vkarpov15)
  • GridFS off-by-one bug in lastChunkNumber() causes uncaught throw and data loss (Issue #1154, https://github.com/vsivsi)
  • GridStore drops passed aliases option, always results in null value in GridFS files (Issue #1152, https://github.com/vsivsi)
  • Remove superfluous connect object copying in index.js (Issue #1145, https://github.com/thomseddon)
  • Do not return false when the connection buffer is still empty (Issue #1143, https://github.com/eknkc)
  • Check ReadPreference object on ReplSet.canRead (Issue #1142, https://github.com/eknkc)
  • Fix unpack error on _executeQueryCommand (Issue #1141, https://github.com/eknkc)
  • Close db on failed connect so node can exit (Issue #1128, https://github.com/benighted)
  • Fix global leak with writeconcern (Issue #1126, https://github.com/shanejonas)

1.3.19 2013-08-21

  • Correctly rethrowing errors after change from event emission to callbacks, compatibility with 0.10.X domains without breaking 0.8.X support.
  • Small fix to return the entire findAndModify result as the third parameter (Issue #1068)
  • No removal of "close" event handlers on server reconnect, emits "reconnect" event when reconnection happens. Reconnect Only applies for single server connections as of now as semantics for ReplSet and Mongos is not clear (Issue #1056)

1.3.18 2013-08-10

  • Fixed issue when throwing exceptions in MongoClient.connect/Db.open (Issue #1057)
  • Fixed an issue where _events is not cleaned up correctly causing a slow steady memory leak.

1.3.17 2013-08-07

  • Ignore return commands that have no registered callback
  • Made collection.count not use the db.command function
  • Fix throw exception on ping command (Issue #1055)

1.3.16 2013-08-02

  • Fixes connection issue where lots of connections would happen if a server is in recovery mode during connection (Issue #1050, NODE-50, NODE-51)
  • Bug in unlink mulit filename (Issue #1054)

1.3.15 2013-08-01

  • Memory leak issue due to node Issue #4390 where _events[id] is set to undefined instead of deleted leading to leaks in the Event Emitter over time

1.3.14 2013-08-01

  • Fixed issue with checkKeys where it would error on X.X

1.3.13 2013-07-31

  • Added override for checkKeys on insert/update (Warning will expose you to injection attacks) (Issue #1046)
  • BSON size checking now done pre serialization (Issue #1037)
  • Added isConnected returns false when no connection Pool exists (Issue #1043)
  • Unified command handling to ensure same handling (Issue #1041, #1042)
  • Correctly emit "open" and "fullsetup" across all Db's associated with Mongos, ReplSet or Server (Issue #1040)
  • Correctly handles bug in authentication when attempting to connect to a recovering node in a replicaset.
  • Correctly remove recovering servers from available servers in replicaset. Piggybacks on the ping command.
  • Removed findAndModify chaining to be compliant with behavior in other official drivers and to fix a known mongos issue.
  • Fixed issue with Kerberos authentication on Windows for re-authentication.
  • Fixed Mongos failover behavior to correctly throw out old servers.
  • Ensure stored queries/write ops are executed correctly after connection timeout
  • Added promoteLongs option for to allow for overriding the promotion of Longs to Numbers and return the actual Long.

1.3.12 2013-07-19

  • Fixed issue where timeouts sometimes would behave wrongly (Issue #1032)
  • Fixed bug with callback third parameter on some commands (Issue #1033)
  • Fixed possible issue where killcursor command might leave hanging functions
  • Fixed issue where Mongos was not correctly removing dead servers from the pool of eligable servers
  • Throw error if dbName or collection name contains null character (at command level and at collection level)
  • Updated bson parser to 0.2.1 with security fix and non-promotion of Long values to javascript Numbers (once a long always a long)

1.3.11 2013-07-04

  • Fixed errors on geoNear and geoSearch (Issue #1024, https://github.com/ebensing)
  • Add driver version to export (Issue #1021, https://github.com/aheckmann)
  • Add text to readpreference obedient commands (Issue #1019)
  • Drivers should check the query failure bit even on getmore response (Issue #1018)
  • Map reduce has incorrect expectations of 'inline' value for 'out' option (Issue #1016, https://github.com/rcotter)
  • Support SASL PLAIN authentication (Issue #1009)
  • Ability to use different Service Name on the driver for Kerberos Authentication (Issue #1008)
  • Remove unnecessary octal literal to allow the code to run in strict mode (Issue #1005, https://github.com/jamesallardice)
  • Proper handling of recovering nodes (when they go into recovery and when they return from recovery, Issue #1027)

1.3.10 2013-06-17

  • Guard against possible undefined in server::canCheckoutWriter (Issue #992, https://github.com/willyaranda)
  • Fixed some duplicate test names (Issue #993, https://github.com/kawanet)
  • Introduced write and read concerns for GridFS (Issue #996)
  • Fixed commands not correctly respecting Collection level read preference (Issue #995, #999)
  • Fixed issue with pool size on replicaset connections (Issue #1000)
  • Execute all query commands on master switch (Issue #1002, https://github.com/fogaztuc)

1.3.9 2013-06-05

  • Fixed memory leak when findAndModify errors out on w>1 and chained callbacks not properly cleaned up.

1.3.8 2013-05-31

  • Fixed issue with socket death on windows where it emits error event instead of close event (Issue #987)
  • Emit authenticate event on db after authenticate method has finished on db instance (Issue #984)
  • Allows creation of MongoClient and do new MongoClient().connect(..). Emits open event when connection correct allowing for apps to react on event.

1.3.7 2013-05-29

  • After reconnect, tailable getMores go on inconsistent connections (Issue #981, #982, https://github.com/glasser)
  • Updated Bson to 0.1.9 to fix ARM support (Issue #985)

1.3.6 2013-05-21

  • Fixed issue where single server reconnect attempt would throw due to missing options variable (Issue #979)
  • Fixed issue where difference in ismaster server name and seed list caused connections issues, (Issue #976)

1.3.5 2013-05-14

  • Fixed issue where HA for replicaset would pick the same broken connection when attempting to ping the replicaset causing the replicaset to never recover.

1.3.4 2013-05-14

  • Fixed bug where options not correctly passed in for uri parser (Issue #973, https://github.com/supershabam)
  • Fixed bug when passing a named index hint (Issue #974)

1.3.3 2013-05-09

  • Fixed auto-reconnect issue with single server instance.

1.3.2 2013-05-08

  • Fixes for an issue where replicaset would be pronounced dead when high priority primary caused double elections.

1.3.1 2013-05-06

  • Fix for replicaset consisting of primary/secondary/arbiter with priority applied failing to reconnect properly
  • Applied auth before server instance is set as connected when single server connection
  • Throw error if array of documents passed to save method

1.3.0 2013-04-25

  • Whole High availability handling for Replicaset, Server and Mongos connections refactored to ensure better handling of failover cases.
  • Fixed issue where findAndModify would not correctly skip issuing of chained getLastError (Issue #941)
  • Fixed throw error issue on errors with findAndModify during write out operation (Issue #939, https://github.com/autopulated)
  • Gridstore.prototype.writeFile now returns gridstore object correctly (Issue #938)
  • Kerberos support is now an optional module that allows for use of GSSAPI authentication using MongoDB Subscriber edition
  • Fixed issue where cursor.toArray could blow the stack on node 0.10.X (#950)

1.2.14 2013-03-14

  • Refactored test suite to speed up running of replicaset tests
  • Fix of async error handling when error happens in callback (Issue #909, https://github.com/medikoo)
  • Corrected a slaveOk setting issue (Issue #906, #905)
  • Fixed HA issue where ping's would not go to correct server on HA server connection failure.
  • Uses setImmediate if on 0.10 otherwise nextTick for cursor stream
  • Fixed race condition in Cursor stream (NODE-31)
  • Fixed issues related to node 0.10 and process.nextTick now correctly using setImmediate where needed on node 0.10
  • Added support for maxMessageSizeBytes if available (DRIVERS-1)
  • Added support for authSource (2.4) to MongoClient URL and db.authenticate method (DRIVER-69/NODE-34)
  • Fixed issue in GridStore seek and GridStore read to correctly work on multiple seeks (Issue #895)

1.2.13 2013-02-22

  • Allow strategy 'none' for repliaset if no strategy wanted (will default to round robin selection of servers on a set readPreference)
  • Fixed missing MongoErrors on some cursor methods (Issue #882)
  • Correctly returning a null for the db instance on MongoClient.connect when auth fails (Issue #890)
  • Added dropTarget option support for renameCollection/rename (Issue #891, help from https://github.com/jbottigliero)
  • Fixed issue where connection using MongoClient.connect would fail if first server did not exist (Issue #885)

1.2.12 2013-02-13

  • Added limit/skip options to Collection.count (Issue #870)
  • Added applySkipLimit option to Cursor.count (Issue #870)
  • Enabled ping strategy as default for Replicaset if none specified (Issue #876)
  • Should correctly pick nearest server for SECONDARY/SECONDARY_PREFERRED/NEAREST (Issue #878)

1.2.11 2013-01-29

  • Added fixes for handling type 2 binary due to PHP driver (Issue #864)
  • Moved callBackStore to Base class to have single unified store (Issue #866)
  • Ping strategy now reuses sockets unless they are closed by the server to avoid overhead

1.2.10 2013-01-25

  • Merged in SSL support for 2.4 supporting certificate validation and presenting certificates to the server.
  • Only open a new HA socket when previous one dead (Issue #859, #857)
  • Minor fixes

1.2.9 2013-01-15

  • Fixed bug in SSL support for MongoClient/Db.connect when discovering servers (Issue #849)
  • Connection string with no db specified should default to admin db (Issue #848)
  • Support port passed as string to Server class (Issue #844)
  • Removed noOpen support for MongoClient/Db.connect as auto discovery of servers for Mongod/Mongos makes it not possible (Issue #842)
  • Included toError wrapper code moved to utils.js file (Issue #839, #840)
  • Rewrote cursor handling to avoid process.nextTick using trampoline instead to avoid stack overflow, speedup about 40%

1.2.8 2013-01-07

  • Accept function in a Map Reduce scope object not only a function string (Issue #826, https://github.com/aheckmann)
  • Typo in db.authenticate caused a check (for provided connection) to return false, causing a connection AND onAll=true to be passed into __executeQueryCommand downstream (Issue #831, https://github.com/m4tty)
  • Allow gridfs objects to use non ObjectID ids (Issue #825, https://github.com/nailgun)
  • Removed the double wrap, by not passing an Error object to the wrap function (Issue #832, https://github.com/m4tty)
  • Fix connection leak (gh-827) for HA replicaset health checks (Issue #833, https://github.com/aheckmann)
  • Modified findOne to use nextObject instead of toArray avoiding a nextTick operation (Issue #836)
  • Fixes for cursor stream to avoid multiple getmore issues when one in progress (Issue #818)
  • Fixes .open replaying all backed up commands correctly if called after operations performed, (Issue #829 and #823)

1.2.7 2012-12-23

  • Rolled back batches as they hang in certain situations
  • Fixes for NODE-25, keep reading from secondaries when primary goes down

1.2.6 2012-12-21

1.2.5 2012-12-12

  • Fixed ssl regression, added more test coverage (Issue #800)
  • Added better error reporting to the Db.connect if no valid serverConfig setup found (Issue #798)

1.2.4 2012-12-11

  • Fix to ensure authentication is correctly applied across all secondaries when using MongoClient.

1.2.3 2012-12-10

  • Fix for new replicaset members correctly authenticating when being added (Issue #791, https://github.com/m4tty)
  • Fixed seek issue in gridstore when using stream (Issue #790)

1.2.2 2012-12-03

  • Fix for journal write concern not correctly being passed under some circumstances.
  • Fixed correct behavior and re-auth for servers that get stepped down (Issue #779).

1.2.1 2012-11-30

  • Fix for double callback on insert with w:0 specified (Issue #783)
  • Small cleanup of urlparser.

1.2.0 2012-11-27

  • Honor connectTimeoutMS option for replicasets (Issue #750, https://github.com/aheckmann)
  • Fix ping strategy regression (Issue #738, https://github.com/aheckmann)
  • Small cleanup of code (Issue #753, https://github.com/sokra/node-mongodb-native)
  • Fixed index declaration using objects/arrays from other contexts (Issue #755, https://github.com/sokra/node-mongodb-native)
  • Intermittent (and rare) null callback exception when using ReplicaSets (Issue #752)
  • Force correct setting of read_secondary based on the read preference (Issue #741)
  • If using read preferences with secondaries queries will not fail if primary is down (Issue #744)
  • noOpen connection for Db.connect removed as not compatible with autodetection of Mongo type
  • Mongos connection with auth not working (Issue #737)
  • Use the connect method directly from the require. require('mongodb')("mongodb://localhost:27017/db")
  • new MongoClient introduced as the point of connecting to MongoDB's instead of the Db
    • open/close/db/connect methods implemented
  • Implemented common URL connection format using MongoClient.connect allowing for simialar interface across all drivers.
  • Fixed a bug with aggregation helper not properly accepting readPreference

1.1.11 2012-10-10

  • Removed strict mode and introduced normal handling of safe at DB level.

1.1.10 2012-10-08

1.1.9 2012-10-05

  • Updated bson to 0.1.5 to fix build problem on sunos/windows.

1.1.8 2012-10-01

  • Fixed db.eval to correctly handle system.js global javascript functions (Issue #709)
  • Cleanup of non-closing connections (Issue #706)
  • More cleanup of connections under replicaset (Issue #707, https://github.com/elbert3)
  • Set keepalive on as default, override if not needed
  • Cleanup of jsbon install to correctly build without install.js script (https://github.com/shtylman)
  • Added domain socket support new Server("/tmp/mongodb.sock") style

1.1.7 2012-09-10

  • Protect against starting PingStrategy being called more than once (Issue #694, https://github.com/aheckmann)
  • Make PingStrategy interval configurable (was 1 second, relaxed to 5) (Issue #693, https://github.com/aheckmann)
  • Made PingStrategy api more consistant, callback to start/stop methods are optional (Issue #693, https://github.com/aheckmann)
  • Proper stopping of strategy on replicaset stop
  • Throw error when gridstore file is not found in read mode (Issue #702, https://github.com/jbrumwell)
  • Cursor stream resume now using nextTick to avoid duplicated records (Issue #696)

1.1.6 2012-09-01

1.1.5 2012-08-29

  • Fix for eval on replicaset Issue #684
  • Use helpful error msg when native parser not compiled (Issue #685, https://github.com/aheckmann)
  • Arbiter connect hotfix (Issue #681, https://github.com/fengmk2)
  • Upgraded bson parser to 0.1.2 using gyp, deprecated support for node 0.4.X
  • Added name parameter to createIndex/ensureIndex to be able to override index names larger than 128 bytes
  • Added exhaust option for find for feature completion (not recommended for normal use)
  • Added tailableRetryInterval to find for tailable cursors to allow to control getMore retry time interval
  • Fixes for read preferences when using MongoS to correctly handle no read preference set when iterating over a cursor (Issue #686)

1.1.4 2012-08-12

  • Added Mongos connection type with a fallback list for mongos proxies, supports ha (on by default) and will attempt to reconnect to failed proxies.
  • Documents can now have a toBSON method that lets the user control the serialization behavior for documents being saved.
  • Gridstore instance object now works as a readstream or writestream (thanks to code from Aaron heckmann (https://github.com/aheckmann/gridfs-stream)).
  • Fix gridfs readstream (Issue #607, https://github.com/tedeh).
  • Added disableDriverBSONSizeCheck property to Server.js for people who wish to push the inserts to the limit (Issue #609).
  • Fixed bug where collection.group keyf given as Code is processed as a regular object (Issue #608, https://github.com/rrusso2007).
  • Case mismatch between driver's ObjectID and mongo's ObjectId, allow both (Issue #618).
  • Cleanup map reduce (Issue #614, https://github.com/aheckmann).
  • Add proper error handling to gridfs (Issue #615, https://github.com/aheckmann).
  • Ensure cursor is using same connection for all operations to avoid potential jump of servers when using replicasets.
  • Date identification handled correctly in bson js parser when running in vm context.
  • Documentation updates
  • GridStore filename not set on read (Issue #621)
  • Optimizations on the C++ bson parser to fix a potential memory leak and avoid non-needed calls
  • Added support for awaitdata for tailable cursors (Issue #624)
  • Implementing read preference setting at collection and cursor level
    • collection.find().setReadPreference(Server.SECONDARY_PREFERRED)
    • db.collection("some", {readPreference:Server.SECONDARY})
  • Replicaset now returns when the master is discovered on db.open and lets the rest of the connections happen asynchronous.
    • ReplSet/ReplSetServers emits "fullsetup" when all servers have been connected to
  • Prevent callback from executing more than once in getMore function (Issue #631, https://github.com/shankar0306)
  • Corrupt bson messages now errors out to all callbacks and closes up connections correctly, Issue #634
  • Replica set member status update when primary changes bug (Issue #635, https://github.com/alinsilvian)
  • Fixed auth to work better when multiple connections are involved.
  • Default connection pool size increased to 5 connections.
  • Fixes for the ReadStream class to work properly with 0.8 of Node.js
  • Added explain function support to aggregation helper
  • Added socketTimeoutMS and connectTimeoutMS to socket options for repl_set.js and server.js
  • Fixed addUser to correctly handle changes in 2.2 for getLastError authentication required
  • Added index to gridstore chunks on file_id (Issue #649, https://github.com/jacobbubu)
  • Fixed Always emit db events (Issue #657)
  • Close event not correctly resets DB openCalled variable to allow reconnect
  • Added open event on connection established for replicaset, mongos and server
  • Much faster BSON C++ parser thanks to Lucasfilm Singapore.
  • Refactoring of replicaset connection logic to simplify the code.
  • Add options.connectArbiter to decide connect arbiters or not (Issue #675)
  • Minor optimization for findAndModify when not using j,w or fsync for safe

1.0.2 2012-05-15

  • Reconnect functionality for replicaset fix for mongodb 2.0.5

1.0.1 2012-05-12

  • Passing back getLastError object as 3rd parameter on findAndModify command.
  • Fixed a bunch of performance regressions in objectId and cursor.
  • Fixed issue #600 allowing for single document delete to be passed in remove command.

1.0.0 2012-04-25

  • Fixes to handling of failover on server error
  • Only emits error messages if there are error listeners to avoid uncaught events
  • Server.isConnected using the server state variable not the connection pool state

0.9.9.8 2012-04-12

  • _id=0 is being turned into an ObjectID (Issue #551)
  • fix for error in GridStore write method (Issue #559)
  • Fix for reading a GridStore from arbitrary, non-chunk aligned offsets, added test (Issue #563, https://github.com/subroutine)
  • Modified limitRequest to allow negative limits to pass through to Mongo, added test (Issue #561)
  • Corrupt GridFS files when chunkSize < fileSize, fixed concurrency issue (Issue #555)
  • Handle dead tailable cursors (Issue #568, https://github.com/aheckmann)
  • Connection pools handles closing themselves down and clearing the state
  • Check bson size of documents against maxBsonSize and throw client error instead of server error, (Issue #553)
  • Returning update status document at the end of the callback for updates, (Issue #569)
  • Refactor use of Arguments object to gain performance (Issue #574, https://github.com/AaronAsAChimp)

0.9.9.7 2012-03-16

  • Stats not returned from map reduce with inline results (Issue #542)
  • Re-enable testing of whether or not the callback is called in the multi-chunk seek, fix small GridStore bug (Issue #543, https://github.com/pgebheim)
  • Streaming large files from GridFS causes truncation (Issue #540)
  • Make callback type checks agnostic to V8 context boundaries (Issue #545)
  • Correctly throw error if an attempt is made to execute an insert/update/remove/createIndex/ensureIndex with safe enabled and no callback
  • Db.open throws if the application attemps to call open again without calling close first

0.9.9.6 2012-03-12

  • BSON parser is externalized in it's own repository, currently using git master
  • Fixes for Replicaset connectivity issue (Issue #537)
  • Fixed issues with node 0.4.X vs 0.6.X (Issue #534)
  • Removed SimpleEmitter and replaced with standard EventEmitter
  • GridStore.seek fails to change chunks and call callback when in read mode (Issue #532)

0.9.9.5 2012-03-07

0.9.9.4 2012-02-26

  • bugfix for findAndModify: Error: corrupt bson message < 5 bytes long (Issue #519)

0.9.9.3 2012-02-23

  • document: save callback arguments are both undefined, (Issue #518)
  • Native BSON parser install error with npm, (Issue #517)

0.9.9.2 2012-02-17

  • Improved detection of Buffers using Buffer.isBuffer instead of instanceof.
  • Added wrap error around db.dropDatabase to catch all errors (Issue #512)
  • Added aggregate helper to collection, only for MongoDB >= 2.1

0.9.9.1 2012-02-15

  • Better handling of safe when using some commands such as createIndex, ensureIndex, addUser, removeUser, createCollection.
  • Mapreduce now throws error if out parameter is not specified.

0.9.9 2012-02-13

  • Added createFromTime method on ObjectID to allow for queries against _id more easily using the timestamp.
  • Db.close(true) now makes connection unusable as it's been force closed by app.
  • Fixed mapReduce and group functions to correctly send slaveOk on queries.
  • Fixes for find method to correctly work with find(query, fields, callback) (Issue #506).
  • A fix for connection error handling when using the SSL on MongoDB.

0.9.8-7 2012-02-06

  • Simplified findOne to use the find command instead of the custom code (Issue #498).
  • BSON JS parser not also checks for _bsonType variable in case BSON object is in weird scope (Issue #495).

0.9.8-6 2012-02-04

  • Removed the check for replicaset change code as it will never work with node.js.

0.9.8-5 2012-02-02

  • Added geoNear command to Collection.
  • Added geoHaystackSearch command to Collection.
  • Added indexes command to collection to retrieve the indexes on a Collection.
  • Added stats command to collection to retrieve the statistics on a Collection.
  • Added listDatabases command to admin object to allow retrieval of all available dbs.
  • Changed createCreateIndexCommand to work better with options.
  • Fixed dereference method on Db class to correctly dereference Db reference objects.
  • Moved connect object onto Db class(Db.connect) as well as keeping backward compatibility.
  • Removed writeBuffer method from gridstore, write handles switching automatically now.
  • Changed readBuffer to read on Gridstore, Gridstore now only supports Binary Buffers no Strings anymore.
  • Moved Long class to bson directory.

0.9.8-4 2012-01-28

  • Added reIndex command to collection and db level.
  • Added support for $returnKey, $maxScan, $min, $max, $showDiskLoc, $comment to cursor and find/findOne methods.
  • Added dropDups and v option to createIndex and ensureIndex.
  • Added isCapped method to Collection.
  • Added indexExists method to Collection.
  • Added findAndRemove method to Collection.
  • Fixed bug for replicaset connection when no active servers in the set.
  • Fixed bug for replicaset connections when errors occur during connection.
  • Merged in patch for BSON Number handling from Lee Salzman, did some small fixes and added test coverage.

0.9.8-3 2012-01-21

  • Workaround for issue with Object.defineProperty (Issue #484)
  • ObjectID generation with date does not set rest of fields to zero (Issue #482)

0.9.8-2 2012-01-20

  • Fixed a missing this in the ReplSetServers constructor.

0.9.8-1 2012-01-17

  • FindAndModify bug fix for duplicate errors (Issue #481)

0.9.8 2012-01-17

  • Replicasets now correctly adjusts to live changes in the replicaset configuration on the servers, reconnecting correctly.
    • Set the interval for checking for changes setting the replicaSetCheckInterval property when creating the ReplSetServers instance or on db.serverConfig.replicaSetCheckInterval. (default 1000 miliseconds)
  • Fixes formattedOrderClause in collection.js to accept a plain hash as a parameter (Issue #469) https://github.com/tedeh
  • Removed duplicate code for formattedOrderClause and moved to utils module
  • Pass in poolSize for ReplSetServers to set default poolSize for new replicaset members
  • Bug fix for BSON JS deserializer. Isolating the eval functions in separate functions to avoid V8 deoptimizations
  • Correct handling of illegal BSON messages during deserialization
  • Fixed Infinite loop when reading GridFs file with no chunks (Issue #471)
  • Correctly update existing user password when using addUser (Issue #470)

0.9.7.3-5 2012-01-04

  • Fix for RegExp serialization for 0.4.X where typeof /regexp/ == 'function' vs in 0.6.X typeof /regexp/ == 'object'
  • Don't allow keepAlive and setNoDelay for 0.4.X as it throws errors

0.9.7.3-4 2012-01-04

  • Chased down potential memory leak on findAndModify, Issue #467 (node.js removeAllListeners leaves the key in the _events object, node.js bug on eventlistener?, leads to extremely slow memory leak on listener object)
  • Sanity checks for GridFS performance with benchmark added

0.9.7.3-3 2012-01-04

  • Bug fixes for performance issues going form 0.9.6.X to 0.9.7.X on linux
  • BSON bug fixes for performance

0.9.7.3-2 2012-01-02

  • Fixed up documentation to reflect the preferred way of instantiating bson types
  • GC bug fix for JS bson parser to avoid stop-and-go GC collection

0.9.7.3-1 2012-01-02

  • Fix to make db.bson_serializer and db.bson_deserializer work as it did previously

0.9.7.3 2011-12-30

  • Moved BSON_BINARY_SUBTYPE_DEFAULT from BSON object to Binary object and removed the BSON_BINARY_ prefixes
  • Removed Native BSON types, C++ parser uses JS types (faster due to cost of crossing the JS-C++ barrier for each call)
  • Added build fix for 0.4.X branch of Node.js where GetOwnPropertyNames is not defined in v8
  • Fix for wire protocol parser for corner situation where the message is larger than the maximum socket buffer in node.js (Issue #464, #461, #447)
  • Connection pool status set to connected on poolReady, isConnected returns false on anything but connected status (Issue #455)

0.9.7.2-5 2011-12-22

0.9.7.2-4 2011-12-21

  • Refactoring of callback code to work around performance regression on linux
  • Fixed group function to correctly use the command mode as default

0.9.7.2-3 2011-12-18

  • Fixed error handling for findAndModify while still working for mongodb 1.8.6 (Issue #450).
  • Allow for force send query to primary, pass option (read:'primary') on find command.
    • find({a:1}, {read:'primary'}).toArray(function(err, items) {});

0.9.7.2-2 2011-12-16

  • Fixes infinite streamRecords QueryFailure fix when using Mongos (Issue #442)

0.9.7.2-1 2011-12-16

  • ~10% perf improvement for ObjectId#toHexString (Issue #448, https://github.com/aheckmann)
  • Only using process.nextTick on errors emitted on callbacks not on all parsing, reduces number of ticks in the driver
  • Changed parsing off bson messages to use process.nextTick to do bson parsing in batches if the message is over 10K as to yield more time to the event look increasing concurrency on big mongoreply messages with multiple documents

0.9.7.2 2011-12-15

  • Added SSL support for future version of mongodb (VERY VERY EXPERIMENTAL)
    • pass in the ssl:true option to the server or replicaset server config to enable
    • a bug either in mongodb or node.js does not allow for more than 1 connection pr db instance (poolSize:1).
  • Added getTimestamp() method to objectID that returns a date object
  • Added finalize function to collection.group
    • function group (keys, condition, initial, reduce, finalize, command, callback)
  • Reaper no longer using setTimeout to handle reaping. Triggering is done in the general flow leading to predictable behavior.
    • reaperInterval, set interval for reaper (default 10000 miliseconds)
    • reaperTimeout, set timeout for calls (default 30000 miliseconds)
    • reaper, enable/disable reaper (default false)
  • Work around for issues with findAndModify during high concurrency load, insure that the behavior is the same across the 1.8.X branch and 2.X branch of MongoDb
  • Reworked multiple db's sharing same connection pool to behave correctly on error, timeout and close
  • EnsureIndex command can be executed without a callback (Issue #438)
  • Eval function no accepts options including nolock (Issue #432)
    • eval(code, parameters, options, callback) (where options = {nolock:true})

0.9.7.1-4 2011-11-27

  • Replaced install.sh with install.js to install correctly on all supported os's

0.9.7.1-3 2011-11-27

0.9.7.1-2 2011-11-27

  • Set statistical selection strategy as default for secondary choice.

0.9.7.1-1 2011-11-27

  • Better handling of single server reconnect (fixes some bugs)
  • Better test coverage of single server failure
  • Correct handling of callbacks on replicaset servers when firewall dropping packets, correct reconnect

0.9.7.1 2011-11-24

  • Better handling of dead server for single server instances
  • FindOne and find treats selector == null as {}, Issue #403
  • Possible to pass in a strategy for the replicaset to pick secondary reader node
    • parameter strategy
      • ping (default), pings the servers and picks the one with the lowest ping time
      • statistical, measures each request and pick the one with the lowest mean and std deviation
  • Set replicaset read preference replicaset.setReadPreference()
    • Server.READ_PRIMARY (use primary server for reads)
    • Server.READ_SECONDARY (from a secondary server (uses the strategy set))
    • tags, {object of tags}
  • Added replay of commands issued to a closed connection when the connection is re-established
  • Fix isConnected and close on unopened connections. Issue #409, fix by (https://github.com/sethml)
  • Moved reaper to db.open instead of constructor (Issue #406)
  • Allows passing through of socket connection settings to Server or ReplSetServer under the option socketOptions
    • timeout = set seconds before connection times out (default 0)
    • noDelay = Disables the Nagle algorithm (default true)
    • keepAlive = Set if keepAlive is used (default 0, which means no keepAlive, set higher than 0 for keepAlive)
    • encoding = ['ascii', 'utf8', or 'base64'] (default null)
  • Fixes for handling of errors during shutdown off a socket connection
  • Correctly applies socket options including timeout
  • Cleanup of test management code to close connections correctly
  • Handle parser errors better, closing down the connection and emitting an error
  • Correctly emit errors from server.js only wrapping errors that are strings

0.9.7 2011-11-10

  • Added priority setting to replicaset manager
  • Added correct handling of passive servers in replicaset
  • Reworked socket code for simpler clearer handling
  • Correct handling of connections in test helpers
  • Added control of retries on failure
    • control with parameters retryMiliSeconds and numberOfRetries when creating a db instance
  • Added reaper that will timeout and cleanup queries that never return
    • control with parameters reaperInterval and reaperTimeout when creating a db instance
  • Refactored test helper classes for replicaset tests
  • Allows raw (no bson parser mode for insert, update, remove, find and findOne)
    • control raw mode passing in option raw:true on the commands
    • will return buffers with the binary bson objects
  • Fixed memory leak in cursor.toArray
  • Fixed bug in command creation for mongodb server with wrong scope of call
  • Added db(dbName) method to db.js to allow for reuse of connections against other databases
  • Serialization of functions in an object is off by default, override with parameter
    • serializeFunctions [true/false] on db level, collection level or individual insert/update/findAndModify
  • Added Long.fromString to c++ class and fixed minor bug in the code (Test case for $gt operator on 64-bit integers, Issue #394)
  • FindOne and find now share same code execution and will work in the same manner, Issue #399
  • Fix for tailable cursors, Issue #384
  • Fix for Cursor rewind broken, Issue #389
  • Allow Gridstore.exist to query using regexp, Issue #387, fix by (https://github.com/kaij)
  • Updated documentation on https://github.com/christkv/node-mongodb-native
  • Fixed toJSON methods across all objects for BSON, Binary return Base64 Encoded data

0.9.6-22 2011-10-15

  • Fixed bug in js bson parser that could cause wrong object size on serialization, Issue #370
  • Fixed bug in findAndModify that did not throw error on replicaset timeout, Issue #373

0.9.6-21 2011-10-05

  • Reworked reconnect code to work correctly
  • Handling errors in different parts of the code to ensure that it does not lock the connection
  • Consistent error handling for Object.createFromHexString for JS and C++

0.9.6-20 2011-10-04

  • Reworked bson.js parser to get rid off Array.shift() due to it allocating new memory for each call. Speedup varies between 5-15% depending on doc
  • Reworked bson.cc to throw error when trying to serialize js bson types
  • Added MinKey, MaxKey and Double support for JS and C++ parser
  • Reworked socket handling code to emit errors on unparsable messages
  • Added logger option for Db class, lets you pass in a function in the shape {

      log : function(message, object) {},
      error : function(errorMessage, errorObject) {},
      debug : function(debugMessage, object) {},

    }

    Usage is new Db(new Server(..), {logger: loggerInstance})

0.9.6-19 2011-09-29

  • Fixing compatibility issues between C++ bson parser and js parser
  • Added Symbol support to C++ parser
  • Fixed socket handling bug for seldom misaligned message from mongodb
  • Correctly handles serialization of functions using the C++ bson parser

0.9.6-18 2011-09-22

  • Fixed bug in waitForConnection that would lead to 100% cpu usage, Issue #352

0.9.6-17 2011-09-21

  • Fixed broken exception test causing bamboo to hang
  • Handling correctly command+lastError when both return results as in findAndModify, Issue #351

0.9.6-16 2011-09-14

  • Fixing a bunch of issues with compatibility with MongoDB 2.0.X branch. Some fairly big changes in behavior from 1.8.X to 2.0.X on the server.
  • Error Connection MongoDB V2.0.0 with Auth=true, Issue #348

0.9.6-15 2011-09-09

  • Fixed issue where pools would not be correctly cleaned up after an error, Issue #345
  • Fixed authentication issue with secondary servers in Replicaset, Issue #334
  • Duplicate replica-set servers when omitting port, Issue #341
  • Fixing findAndModify to correctly work with Replicasets ensuring proper error handling, Issue #336
  • Merged in code from (https://github.com/aheckmann) that checks for global variable leaks

0.9.6-14 2011-09-05

0.9.6-13 2011-08-24

  • Db names correctly error checked for illegal characters

0.9.6-12 2011-08-24

  • Nasty bug in GridFS if you changed the default chunk size
  • Fixed error handling bug in findOne

0.9.6-11 2011-08-23

  • Timeout option not correctly making it to the cursor, Issue #320, Fix from (https://github.com/year2013)
  • Fixes for memory leaks when using buffers and C++ parser
  • Fixes to make tests pass on 0.5.X
  • Cleanup of bson.js to remove duplicated code paths
  • Fix for errors occurring in ensureIndex, Issue #326
  • Removing require.paths to make tests work with the 0.5.X branch

0.9.6-10 2011-08-11

  • Specific type Double for capped collections (https://github.com/mbostock), Issue #312
  • Decorating Errors with all all object info from Mongo (https://github.com/laurie71), Issue #308
  • Implementing fixes for mongodb 1.9.1 and higher to make tests pass
  • Admin validateCollection now takes an options argument for you to pass in full option
  • Implemented keepGoing parameter for mongodb 1.9.1 or higher, Issue #310
  • Added test for read_secondary count issue, merged in fix from (https://github.com/year2013), Issue #317

0.9.6-9

  • Bug fix for bson parsing the key '':'' correctly without crashing

0.9.6-8

  • Changed to using node.js crypto library MD5 digest
  • Connect method support documented mongodb: syntax by (https://github.com/sethml)
  • Support Symbol type for BSON, serializes to it's own type Symbol, Issue #302, #288
  • Code object without scope serializing to correct BSON type
  • Lot's of fixes to avoid double callbacks (https://github.com/aheckmann) Issue #304
  • Long deserializes as Number for values in the range -2^53 to 2^53, Issue #305 (https://github.com/sethml)
  • Fixed C++ parser to reflect JS parser handling of long deserialization
  • Bson small optimizations

0.9.6-7 2011-07-13

  • JS Bson deserialization bug #287

0.9.6-6 2011-07-12

  • FindAndModify not returning error message as other methods Issue #277
  • Added test coverage for $push, $pushAll and $inc atomic operations
  • Correct Error handling for non 12/24 bit ids on Pure JS ObjectID class Issue #276
  • Fixed terrible deserialization bug in js bson code #285
  • Fix by andrewjstone to avoid throwing errors when this.primary not defined

0.9.6-5 2011-07-06

  • Rewritten BSON js parser now faster than the C parser on my core2duo laptop
  • Added option full to indexInformation to get all index info Issue #265
  • Passing in ObjectID for new Gridstore works correctly Issue #272

0.9.6-4 2011-07-01

  • Added test and bug fix for insert/update/remove without callback supplied

0.9.6-3 2011-07-01

  • Added simple grid class called Grid with put, get, delete methods
  • Fixed writeBuffer/readBuffer methods on GridStore so they work correctly
  • Automatic handling of buffers when using write method on GridStore
  • GridStore now accepts a ObjectID instead of file name for write and read methods
  • GridStore.list accepts id option to return of file ids instead of filenames
  • GridStore close method returns document for the file allowing user to reference _id field

0.9.6-2 2011-06-30

  • Fixes for reconnect logic for server object (replays auth correctly)
  • More testcases for auth
  • Fixes in error handling for replicaset
  • Fixed bug with safe parameter that would fail to execute safe when passing w or wtimeout
  • Fixed slaveOk bug for findOne method
  • Implemented auth support for replicaset and test cases
  • Fixed error when not passing in rs_name

0.9.6-1 2011-06-25

  • Fixes for test to run properly using c++ bson parser
  • Fixes for dbref in native parser (correctly handles ref without db component)
  • Connection fixes for replicasets to avoid runtime conditions in cygwin (https://github.com/vincentcr)
  • Fixes for timestamp in js bson parser (distinct timestamp type now)

0.9.6 2011-06-21

0.9.5-1 2011-06-21

  • Extracted Timestamp as separate class for bson js parser to avoid instanceof problems
  • Fixed driver strict mode issue

0.9.5 2011-06-20

  • Replicaset support (failover and reading from secondary servers)
  • Removed ServerPair and ServerCluster
  • Added connection pool functionality
  • Fixed serious bug in C++ bson parser where bytes > 127 would generate 2 byte sequences
  • Allows for forcing the server to assign ObjectID's using the option {forceServerObjectId: true}

0.6.8

  • Removed multiple message concept from bson
  • Changed db.open(db) to be db.open(err, db)

0.1 2010-01-30

  • Initial release support of driver using native node.js interface
  • Supports gridfs specification
  • Supports admin functionality