# Changelog
All notable changes to this project will be documented in this file.
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
## [1.6.0](https://github.com/zookzook/elixir-mongodb-driver/compare/v1.5.6...v1.6.0) (2025-11-22)
### Enhancements
- improved support for zstd compression (OTP 28 `:zstd` with optional `:ezstd` fallback)
### Bug Fixes
* fixed failing test ([b4318bc](https://github.com/zookzook/elixir-mongodb-driver/commit/b4318bc3cd85aefe2bf4f6fb903144cc36eaa3ef))
* pass auth_db to detect auth mech (reported by m-almas) ([da2476e](https://github.com/zookzook/elixir-mongodb-driver/commit/da2476e99e3443b97bdb0a3238ba9a3e6cb17dac))
* the migration will return the error when calling migrate/drop (reported by yagogarea) ([6d06329](https://github.com/zookzook/elixir-mongodb-driver/commit/6d06329de4c5b014457dd7ba439bcefafdea1256))
## [1.5.6](https://github.com/zookzook/elixir-mongodb-driver/compare/v1.5.5...v1.5.6) (2025-08-12)
### Bug Fixes
- explicitly set options override the options from the URL. ([8125d82](https://github.com/zookzook/elixir-mongodb-driver/commit/8125d820e6b7122fdd5772f12f788e38a2bb6d70))
- improved the spec for function `find_one_and_delete` thanks to csrl ([b868998](https://github.com/zookzook/elixir-mongodb-driver/commit/b8689980b738cdafedb84510dfc0220c7fcad55f))
- added support for inline collection thanks to numso [76b20640](https://github.com/zookzook/elixir-mongodb-driver/commit/76b20640f04fa2cc270e331e3aaaeb8fe72f25e6)
## [1.5.5](https://github.com/zookzook/elixir-mongodb-driver/compare/v1.5.4...v1.5.5) (2025-07-07)
### Bug Fixes
- improved the spec of the function to respect nil values (reported by eseres) ([ee333d5](https://github.com/zookzook/elixir-mongodb-driver/commit/ee333d511d17548435829cd733b0f99329cef0ad))
## [1.5.4](https://github.com/zookzook/elixir-mongodb-driver/compare/v1.5.3...v1.5.4) (2025-06-07)
### Bug Fixes
- when decoding an invalid time range the decoder will use max/min values ([f8b4dde](https://github.com/zookzook/elixir-mongodb-driver/commit/f8b4ddeca2b5f738efa9a193432cbde269c85993))
## [1.5.3](https://github.com/zookzook/elixir-mongodb-driver/compare/v1.5.2...v1.5.3) (2025-04-17)
### Bug Fixes
- Fix Object ID decoding logic for uppercase HEX string ([#274](https://github.com/zookzook/elixir-mongodb-driver/issues/274)) ([fa7890b](https://github.com/zookzook/elixir-mongodb-driver/commit/fa7890baca7e8bd60a73b742cb7b53fb2f8fc733))
## [1.5.2](https://github.com/zookzook/elixir-mongodb-driver/compare/v1.5.1...v1.5.2) (2025-02-11)
### Bug Fixes
- improved error handling when using change-streams ([c07c5a1](https://github.com/zookzook/elixir-mongodb-driver/commit/c07c5a1207153fb0e8f2e3a4c2dd3d0c6042acf1))
### Features
- Added support for directConnection setting in connection string (thanks to colacheng)
## [1.5.1](https://github.com/zookzook/elixir-mongodb-driver/compare/v1.5.0...v1.5.1) (2025-02-04)
### Bug Fixes
- **master:** ensure url_parser does not fail on missing txt record ([#261](https://github.com/zookzook/elixir-mongodb-driver/issues/261)) ([e4a3102](https://github.com/zookzook/elixir-mongodb-driver/commit/e4a3102235090ffd966db4f1b4ca81d14413a95d))
## [1.5.0](https://github.com/zookzook/elixir-mongodb-driver/compare/v1.4.1...v1.5.0) (2024-09-20)
### Features
- added support for op_compressed (zlib and zstd) ([cf32c87](https://github.com/zookzook/elixir-mongodb-driver/commit/cf32c8739ef88175a0c914bd2ef96419f13d992f))
### Bug Fixes
- **update/4:** improve Mongo.update/4 function ([#245](https://github.com/zookzook/elixir-mongodb-driver/issues/245)) ([50b511d](https://github.com/zookzook/elixir-mongodb-driver/commit/50b511d01b7ecd3350a3b21110d15fa0fbbb6fb6))
## [1.4.1](https://github.com/zookzook/elixir-mongodb-driver/compare/v1.4.0...v1.4.1) (2024-05-02)
### Bug Fixes
- improved the reconnection workflow ([08d7fbc](https://github.com/zookzook/elixir-mongodb-driver/commit/08d7fbc05bff833de177ae168ca3bb7fa4425572))
## [1.4.0](https://github.com/zookzook/elixir-mongodb-driver/compare/v1.2.1...v1.4.0) (2024-02-10)
### Features
- Compatibility changes to support mongodb_ecto adapter, thanks to https://github.com/brennana
### Miscellaneous Chores
- release 1.2.1 ([0ef1482](https://github.com/zookzook/elixir-mongodb-driver/commit/0ef14829361bde236cfc054d774a3a51d0abea29))
## [1.2.1](https://github.com/zookzook/elixir-mongodb-driver/compare/v1.2.0...v1.2.1) (2023-11-26)
### Bug Fixes
- added support for read preference specified by the URL ([#207](https://github.com/zookzook/elixir-mongodb-driver/issues/207)) ([9e4d569](https://github.com/zookzook/elixir-mongodb-driver/commit/9e4d56957a8bd2605bf50dbe5eea551b4fc2dc40))
- applies the global timeout value to each query ([#215](https://github.com/zookzook/elixir-mongodb-driver/issues/215)) ([64f8ea1](https://github.com/zookzook/elixir-mongodb-driver/commit/64f8ea16ed47fb724e5fca6d70ef99f3ecef0f51))
- handle read preferences without tags ([50ea98d](https://github.com/zookzook/elixir-mongodb-driver/commit/50ea98db82217bbd9a2f37ad57f6f271b2bff7c2))
- preserve the order of the keys ([#211](https://github.com/zookzook/elixir-mongodb-driver/issues/211)) ([b360d87](https://github.com/zookzook/elixir-mongodb-driver/commit/b360d87ad02383e37ad53dafa036abfb9e2bbc53))
## [1.2.0](https://github.com/zookzook/elixir-mongodb-driver/compare/v1.1.0...v1.2.0) (2023-08-30)
### Features
- Supports passing arrayFilters option through find_one_and_update ([#201](https://github.com/zookzook/elixir-mongodb-driver/issues/201)) ([082878b](https://github.com/zookzook/elixir-mongodb-driver/commit/082878b121ac02fc763cf5be0b6b197abbcbbe9e))
### Bug Fixes
- fixed typo ([e6eff31](https://github.com/zookzook/elixir-mongodb-driver/commit/e6eff31fd1c001074f73aab18d8d88a1cd33005c))
## [1.1.0](https://github.com/zookzook/elixir-mongodb-driver/compare/v1.0.3...v1.1.0) (2023-07-30)
### Features
- add support for Elixir 1.15 ([#195](https://github.com/zookzook/elixir-mongodb-driver/issues/195)) ([f621a62](https://github.com/zookzook/elixir-mongodb-driver/commit/f621a62d5bb825cfd77e8f3024d569f23be0376d))
## [1.0.3](https://github.com/zookzook/elixir-mongodb-driver/compare/v1.0.2...v1.0.3) (2023-05-13)
### Bug Fixes
- check if monitor pid exists before stopping ([6e0c8b2](https://github.com/zookzook/elixir-mongodb-driver/commit/6e0c8b2625d0c424d194a0efcd799177a4c916f1))
### Enhancements
- Add support of errInfo ([#187](https://github.com/zookzook/elixir-mongodb-driver/pull/187))
- add support for the hint option ([#175](https://github.com/zookzook/elixir-mongodb-driver/issues/175)) ([4c817b7](https://github.com/zookzook/elixir-mongodb-driver/commit/4c817b721eb5430dc20eaae754a24d671cb52a62))
- add telemetry start event to fix [#174](https://github.com/zookzook/elixir-mongodb-driver/issues/174) ([e79db9e](https://github.com/zookzook/elixir-mongodb-driver/commit/e79db9e0faedf3b37dcaf8fab6a9aa98dba3b43b))
## [1.0.2](https://github.com/zookzook/elixir-mongodb-driver/compare/v1.0.1...v1.0.2) (2023-01-02)
### Bug Fixes
- deprecated 'use Bitwise' ([#168](https://github.com/zookzook/elixir-mongodb-driver/issues/168)) ([a980d57](https://github.com/zookzook/elixir-mongodb-driver/commit/a980d5782a56a0a8168c5229fe22b7a935c433b3))
- use the basename of the file path ([3a10c56](https://github.com/zookzook/elixir-mongodb-driver/commit/3a10c5604a2cbc5d284a17578280e96c93f61e63))
## [1.0.1](https://github.com/zookzook/elixir-mongodb-driver/compare/v1.0.0...v1.0.1) (2022-12-17)
### Bug Fixes
- replace :code.priv_dir/1 function ([da0fd6c](https://github.com/zookzook/elixir-mongodb-driver/commit/da0fd6cdc777c4d1cb1df0abac98af1f4a37ad11))
## [1.0.0](https://github.com/zookzook/elixir-mongodb-driver/compare/0.9.2...v1.0.0) (2022-11-27)
### Bug Fixes
- add migration ([da65de4](https://github.com/zookzook/elixir-mongodb-driver/commit/da65de4d8fd7cf6a15ac0c42b3022ca1fe743876))
- remove a bug in the hello handshake protocol (thanks to fireproofsocks for reporting) ([59aa841](https://github.com/zookzook/elixir-mongodb-driver/commit/59aa841cc619f77979cc3027c76e918373685723))
- remove derived attributes in the dump function ([c1b60b4](https://github.com/zookzook/elixir-mongodb-driver/commit/c1b60b413329f32d4e0bd52c3988b89b19fe7f5a))
### Enhancements
- improve the dump and load functions ([#154](https://github.com/zookzook/elixir-mongodb-driver/issues/154)) ([e7f2d44](https://github.com/zookzook/elixir-mongodb-driver/commit/e7f2d44a01fa25cd85cb8fd1f935ba5a201fe011))
- use the same timestamps in new/0 function ([0db61da](https://github.com/zookzook/elixir-mongodb-driver/commit/0db61dac03eb2a27d4d47576ed402ad1e6c452f4))
### Miscellaneous Chores
- release 1.0.0 ([64e274a](https://github.com/zookzook/elixir-mongodb-driver/commit/64e274a761dd9e6757d1b506ee3ba4308ac1448f))
## 0.9.3 (2022-10-14)
- Bugfix
- fix a bug in the hello handshake protocol (thanks to fireproofsocks for reporting)
- Enhancements
- add migration
## 0.9.2 (2022-09-24)
- Bugfix
- fix a crash in the streaming hello monitor, if the server sends more than one response at once
- add support for the new hello handshake
- refactor :timeout option (thanks to JD-Robertson for reporting)
- add timestamps macro to the collection module to handle inserted_at and updated_at attributes (thanks to carlosliracl)
## 0.9.1 (2022-05-27)
- Bugfix
- add backward compatible for Elixir < 1.13 (thanks to ja-jimenez)
## 0.9.0 (2022-05-21)
- Enhancements
- add colored log output
- add telemetry support for execution
- add new Repo module (thanks to daskycodes)
- add missing typespecs (thanks to fdie)
- refactor transaction api to support nested transaction
- add `Mongo.rename_collection/3` command
## 0.8.4 (2022-03-09)
- Bugfix
- add missing excludes from dump function (collections)
## 0.8.3 (2022-02-17)
- Bugfix
- fix no function clause matching (thanks to bodbdigr)
## 0.8.2 (2022-02-03)
- Enhancements
- Remove a compiler warning (thanks to a-jimenez )
## 0.8.1 (2022-01-22)
- Enhancements
- Fix for serializing BSON Regex without options (thanks to MillionIntegrals)
- Misc doc changes (thanks to kianmeng)
- Added support for OP_MSG exhaustAllowed flag
- Added support for streaming protocol
- Added Insights app for development ]()
## 0.8.0 (2021-11-07) (0.7.5 was not published)
- Enhancements
- replica set connection: faster topology update if the primary is down (thanks to p-mongo)
- added custom `Mongo.Encoder` protocol (thanks to esse)
- added collection from yildun project
- fixed an issue that the bulk operation does not stop after any insert/update/delete failed (thanks to ja-jimenez)
## 0.7.4 (2021-06-21)
- Enhancements
- added a new option to specify a timeout, when increasing the connection pool is no option
## 0.7.3 (2021-05-29)
- Enhancements
- added support for OTP 24
- Add support for tls setting in connection string (tschmittni)
- Replace deprecated functions (OTP 24) (aenglisc )
## 0.7.2 (2021-05-19)
- Enhancements
- Adds test to cover one of Mongo.find/4 errors (vukanac)
- Update specs for Mongo.find/4 with error tuple (vukanac)
- Fix build warnings and correct typespec (joeapearson)
- Update db_connection version to remove System.stacktrace warnings (vukanac)
- Update SCRAM auth procedure (LetThereBeDwight)
## 0.7.1 (2021-01-01)
- Enhancements
- upgraded decimal to 2.0, jason to 1.2
- Add proper support for tailable cursors and awaitData (PR #74)
## 0.7.0 (2020-04-17)
- Enhancements
- refactored event notification system
- added support for retryable reads and writes
- refactored the test cases
- now using mtools for a MongoDB deployment in the travis ci environment
- travis ci uses only the latest MongoDB version [The failCommand](https://github.com/mongodb/mongo/wiki/The-%22failCommand%22-fail-point)
- `Session.commit_transaction` returns now `:ok` or an error `{:error, %Mongo.Error{}}`
- Bugfixes
- Using `max_staleness_ms` > 0 results in a crash
- Read preferences are sent to mongos
## 0.6.5 (2020-03-30)
- Enhancements
- updated db_connection dependency
- generalize inconsistent typespecs
- new function `BSON.ObjectId.decode/1` and `BSON.ObjectId.encode/1`
- new function `Mongo.uuid/1`
## 0.6.4 (2020-01-24)
- Bugfixes
- fixed bug in `Mongo.TopologyDescription` in case of a shard cluster deployment (#39)
## 0.6.3 (2020-01-23)
- Enhancements
- basic support for inserting structs
- removed duplicated code
- Cursor-API raises a `Mongo.Error` instead of a `FunctionClauseError`
- Bugfixes
- `:appname` option (typo) #38
- fixed index creation in `Mongo.GridFs.Bucket`
## 0.6.2 (2019-11-15)
- Enhancements
- refactored the api of `Mongo.limits` and `Mongo.wire_version`
- add support for tracking recovery token from response in a sharded transaction
## 0.6.1 (2019-11-01)
- Enhancements
- refactored `Mongo.Session` and `Mongo.Session.SessionPool` because of poor performance
## 0.6.0 (2019-09-18)
- Enhancements
- refactored `writeConcern`
- refactored `filter_nils`
- refactored usage of `ReadPreference`
- added support for sessions (`ServerSession`, `SessionPool`, `Session`)
- added support for transaction
- added Decimal128 encoder
- added support for transaction to gridfs and bulk operation
- added `create` command (explicitly creating a collection or view)
## 0.5.7 (2019-06-25)
- Bug Fixes
- Test for existing index in `Bucket` works right now
- Enhancements
- Better handling for the `:timeout` options
## 0.5.6 (2019-06-14)
- Bug Fixes
- Fixed a match error in `after_fun` of cursor module
- Fixed a match error in the result of function `Monitor.force_check`
- Resolved decode problem for the Binary (Old) BinData subtype
- Enhancements
- Added support for `Mongo.BulkWriteResult`
## 0.5.5 (2019-05-22)
- Bug Fixes
- Fixed a match error when using Windows OS
## 0.5.4 (2019-05-21)
- Enhancements
- The driver provides now client metadata
- Added support for connecting via UNIX sockets (`:socket` and `:socket_dir`)
- Added support for bulk writes (ordered/unordered, in-memory/stream)
- Added support for `op_msg` with payload type 1
- Merged code from https://github.com/ankhers/mongodb/commit/63c20ff7e427744a5df915751adfaf6e5e39ae62
- Merged changes from https://github.com/ankhers/mongodb/pull/283
- Merged changes from https://github.com/ankhers/mongodb/pull/281
## 0.5.3 (2019-05-02)
- Enhancements
- Travis now using the right MongoDB version
- Bug Fixes
- Added test unit for change streams
- Removed debug code from change streams
## 0.5.2 (2019-05-01)
- Enhancements
- Added `op_msg` support ([See](https://docs.mongodb.com/manual/reference/mongodb-wire-protocol/#op-msg))
- Fixed change streams in case of error codes: 11601, 136 and 237 from resuming
- Reorganized error handling
## 0.5.1 (2019-04-28)
- Enhancements
- Upgraded to DBConnection 2.0.6
- Refactored code, simplified code and api
- Replaced deprecated op_code by database commands
- Update_one, update_many, replace_one, replace_many return upserted ids
- Add support for all find options
- Add support for MongoDB 3.6 collection [Change Streams](https://docs.mongodb.com/manual/changeStreams/)
- Ass support for SCRAM-SHA-256 (MongoDB 4.x)
## 0.4.8-dev
- Enhancements
- Added hostname and port to exceptions
- Added support for x509 authentication
- Allow passing only partial `read_preference` information
- Add support for GridFS
- Bug Fixes
- Fixed a connection leak
- Properly parse write concern for URL
- Properly follow read preference for `secondary_preferred`
## v0.4.7 (2018-09-13)
- Enhancements
- Added 4.0 to supported versions
- Initial support for mongodb+srv URLs
- Support for Decimal128
## v0.4.6 (2018-05-20)
- Enhancements
- Added `:connect_timout_ms` to `Mongo.start_link/1`
- Reorganized documentation
## 0.4.5 (2018-04-08)
- Enhancements
- Should now be able to send a query to your server before the connection
is fully made
- Bug Fixes
- Should actually be able to query for longer than 5 seconds
## 0.4.4 (2018-02-09)
- Enhancements
- Added support for using a mongo url via the `:url` key
- Added MongoDB 3.6 to supported versions
- Added support for the deprecated `undefined` BSON type
- Bug Fixes
- Added another case for BSON NaN
- Fixed encoding and decoding of the BSON Timestamp type
- Should now figure out Topology for replica sets even if you exclude the
`:type` key
- Fixed an issue where our monitors would become empty, preventing the driver
from reconnecting to a downed database
## 0.4.3 (2017-09-16)
- Enhancements
- Send TLS server name indication (SNI) if none is set in the `:ssl_opts`
- Fixed a couple dialyzer issues
- Add basic examples of `$and`, `$or`, and `$in` operators in README
- Bug Fixes
- Ensure cursor requests are routed to the proper node in the cluster
- No longer attempting to authenticate against arbiter nodes
- Prevent monitor errors if you have stopped the mongo process
## 0.4.2 (2017-08-28)
- Bug fixes
- Fix application crash when a replica set member goes offline
- Fix application crash on start when a replica set member is offline
## 0.4.1 (2017-08-09)
- Bug fixes
- Monitors no longer use a pool
- Can now connect to a Mongo instance using a CNAME
- Pass options through Mongo.aggregate/4
## 0.4.0 (2017-06-07)
- Replica Set Support
## 0.3.0 (2017-05-11)
- Breaking changes
- Remove `BSON.DateTime` and replace it with native Elixir `DateTime`
## 0.2.1 (2017-05-08)
- Enhancements
- SSL support
- Add functions `BSON.DateTime.to_elixir_datetime/1` and `BSON.DateTime.from_elixir_datetime/1`
- Changes
- Requires Elixir ~> 1.3
## 0.2.0 (2016-11-11)
- Enhancements
- Add `BSON.ObjectID.encode!/1` and `BSON.ObjectID.decode!/1`
- Optimize and reduce binary copying
- Add tuple/raising versions of functions in `Mongo`
- Add `:inserted_count` field to `Mongo.InsertManyResult`
- Support NaN and infinite numbers in bson float encode/decode
- Add `Mongo.object_id/0` for generating objectids
- Add `Mongo.child_spec/2`
- Add `Mongo.find_one_and_update/5`
- Add `Mongo.find_one_and_replace/5`
- Add `Mongo.find_one_and_delete/4`
- Bug fixes
- Fix float endianness
- Breaking changes
- Switched to using `db_connection` library, see the current docs for changes
## 0.1.1 (2015-12-17)
- Enhancements
- Add `BSON.DateTime.from_datetime/1`
- Bug fixes
- Fix timestamp epoch in generated object ids
- Fix `Mongo.run_command/3` to accept errors without code
## 0.1.0 (2015-08-25)
Initial release