- Rename
Authorization
toCosmosDbAuthorization
and make it public. - Add optional
authorization
parameter to methods already supportingCosmosDbPermission
. - Make
usePermission
obsolete: please useuseAuthorization
instead. ACosmosDbAuthorization
can be built from aCosmosDbPermission
. - Rename
InvalidTokenException
toParsingException
. - Add new
InvalidTokenException
as an HTTP exception for invalid or missing tokens. - Reworked tests & activate Wasm tests.
- Update jGenHTML to version 1.6 (test coverage tooling).
- Fix lints warnings reported by pub.dev.
- Update tests as Azure/azure-cosmos-dotnet-v3#3659 has been fixed.
- Add support for older containers where
PartitionKeySpec.version
is null -- fixes #12.
- Add none constructor to throughput for serverless config - PR #10 by https://github.com/djkingCanada - fixes #7.
- Improve error message if partition key is not provided for a new container - PR #9 by https://github.com/djkingCanada.
- Upgrade version of
http
.
- Enable support for Dart 3.
- Upgrade version of
murmur3
.
- Improved documentation & tests.
- Retry batch operations failing with a 429 "Too many requests" status.
- Added [PartitionKeySpec] for partition key definition. A [PartitionKeySpec] must be provided when creating a [CosmosDbContainer]. The static final instance [PartitionKeySpec.id] can be used as the default partition key
['/id']
. When opening an existing collection, the [PartitionKeySpec] is loaded from the Cosmos DB response. [PartitionKeySpec.from] extracts the partition key from a [BaseDocument] according to the partition key definition. - Support for multiple paths in [PartitionKeySpec] is available, in which case the [CosmosDbServer] connection must be initialized with
preview: true
. - Added [PartitionKey] for providing a partition key when operating on documents/queries. The special value [PartitionKey.all] enables cross-partition queries.
- Added [TransactionalBatch] and [CrossPartionBatch] for batch processing.
- Please note that support for batch and multi-partition key are still experimental.
- Breaking changes - several classes have been renamed e.g. [CosmosDbCollection] --> [CosmosDbContainer], APIs dealing with bare
String
partition keys now use [PartitionKey]/[PartitionKeySpec], etc.
_client.dart
: return early withnull
upon a "204 - No Content" status code (fix for #1). Also skip parsing the response body ifcontent-length
is zero.
- Added support for patching documents. A document may be patched conditionally and the condition can be parameterized (parameter values are integrated into the condition client-side, as Cosmos DB does not accept parameterized conditions out-of-the-box). Variable names MUST start with
@
. - Added
CosmosDbCollection.get()
to retrieve the latest version of a document. When thedocument
has mixinEtagMixin
, the value of the_etag
field is sent to Cosmos DB in theIf-None-Match
header (causing a response with HTTP status code 304 "Not modified", in which case thedocument
is returned as is). - Added optional
document
parameter forCosmosDbCollection.delete()
. When provided, thedocument
attributes takes over theid
value. Theid
parameter is deprecated and will eventually be removed. - Added optional
checkEtag
parameter (default value:true
) forCosmosDbCollection.delete()
andCosmosDbCollection.replace()
. When thedocument
has mixinEtagMixin
andcheckEtag
istrue
, the value of the_etag
field is sent to Cosmos DB in theIf-Match
header. If the document has been updated in the meantime, aPreconditionFailureException
exception will be thrown because the_etag
field's value will have changed in Cosmos DB (causing a response with HTTP status code 412 "Precondition failure"). - Added
PartitionKey
field onCosmosDbCollection
and markedPartitionKeys
as obsolete. UsePartitionKey
instead. - Added
PartitionKeyMixin
to support custom partition keys in documents. - Added support for throttling requests when Cosmos DB replies with HTTP status code 429 "Too many requests".
- Update README.md
- Added support for throughput when creating a database or a collection.
- Renamed
Line
class toLineString
. - Fix various issues in GeoJSON serialization (lat/long order in the JSON-array, serialization/deserialization...).
- Added unit tests to validate the spatial data sets used in tests.
- Added unit tests for spatial queries.
- Supports bounding box in spatial indexes.
- New class
Point
to represent spatial positions.- 2D/3D euclidean coordinates (aka geometry).
- Latitude/longitude/optional altitude coordinates (aka geography).
- New classes to represent shapes supported by CosmosDB:
Line
,Polygon
,MultiPolygon
. - Distance calculators for both geometrical (euclidean) and geographical (latitude/longitude) shapes.
- Comes with a geographical distance calculator preconfigured with the Earth's radius in kilometers.
- Renamed
Exception
class toCosmosDbException
(could be a breaking change). - Most base classes
ClassName
have also been renamed toCosmosDbClassName
.- This should eliminate the need for aliasing the Cosmos DB library while avoiding name collisions in your app. E.g. names for
User
,Collection
, ... were too generic and could cause conflict with your code or other libraries. - This should not be a breaking change as previous names are still available, yet deprecated. They will be removed in a future version.
- This should eliminate the need for aliasing the Cosmos DB library while avoiding name collisions in your app. E.g. names for
- Removed
DebugHttpClient
from the mainstreamazure_cosmosdb
library (could be a breaking change).- The debug HTTP client can still be used by importing
azure_cosmosdb_debug
instead.
- The debug HTTP client can still be used by importing
- Test cases have been updated accordingly, and enriched to cover indexing policies and geometrical/geographical shapes.
- Add support for indexing policies when creating collections.
- Re-enable Web platforms support.
- Improve description.
- Added default retry policy from package https://pub.dev/packages/retry.
- Initial release.
- Support for Server, Databases, Collections, Users and Permissions
- Document base classes: BaseDocument, BaseDocumentWithEtag
- Support for SQL query
- Unit tests & code coverage (currently limited to Server, Databases and Collections)