Dolittle.SDK.Common 14.2.0

There is a newer version of this package available.
See the version list below for details.
dotnet add package Dolittle.SDK.Common --version 14.2.0
NuGet\Install-Package Dolittle.SDK.Common -Version 14.2.0
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Dolittle.SDK.Common" Version="14.2.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Dolittle.SDK.Common --version 14.2.0
#r "nuget: Dolittle.SDK.Common, 14.2.0"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Dolittle.SDK.Common as a Cake Addin
#addin nuget:?package=Dolittle.SDK.Common&version=14.2.0

// Install Dolittle.SDK.Common as a Cake Tool
#tool nuget:?package=Dolittle.SDK.Common&version=14.2.0

Dolittle

Dolittle is a decentralized, distributed, event-driven microservice platform built to harness the power of events.

This is our C# SDK, install it with:

dotnet add package Dolittle.SDK 

Get Started

Want to try another language?

Issues and Contributing

Issues and contributions are always welcome!

To learn how to contribute, please read our contributing guide.

Product Compatible and additional computed target framework versions.
.NET net5.0 is compatible.  net5.0-windows was computed.  net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
.NET Core netcoreapp3.1 is compatible. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (2)

Showing the top 2 NuGet packages that depend on Dolittle.SDK.Common:

Package Downloads
Dolittle.SDK.Artifacts

Dolittle is a decentralized, distributed, event-driven microservice platform built to harness the power of events.

Dolittle.SDK

Dolittle is a decentralized, distributed, event-driven microservice platform built to harness the power of events.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
23.2.0 648 3/14/2024
23.1.0 427 3/12/2024
23.0.0 411 3/8/2024
22.1.3 583 2/26/2024
22.1.2 1,710 10/24/2023
22.1.1 1,036 10/4/2023
22.1.0 956 9/18/2023
22.0.5 1,044 9/7/2023
22.0.4 1,140 8/28/2023
22.0.3 1,179 8/15/2023
22.0.2 1,159 8/8/2023
22.0.1 1,084 8/8/2023
22.0.0 1,426 6/22/2023
22.0.0-arkenstone.1 68 6/21/2023
22.0.0-arkenstone.0 71 6/12/2023
21.0.2 1,197 9/7/2023
21.0.1 2,222 6/8/2023
21.0.0 1,464 6/2/2023
21.0.0-feanor.2 69 5/31/2023
21.0.0-feanor.1 1,122 5/30/2023
21.0.0-feanor.0 65 5/30/2023
20.2.0 4,833 1/23/2023
20.2.0-shire.17 106 1/19/2023
20.2.0-shire.16 93 1/16/2023
20.2.0-shire.15 113 1/12/2023
20.2.0-shire.14 101 1/12/2023
20.2.0-shire.13 93 1/12/2023
20.2.0-shire.12 125 1/11/2023
20.2.0-shire.11 94 1/10/2023
20.2.0-shire.10 95 1/6/2023
20.2.0-shire.9 177 1/6/2023
20.2.0-shire.8 96 1/6/2023
20.2.0-shire.7 96 1/6/2023
20.2.0-shire.6 103 1/5/2023
20.2.0-shire.5 99 1/5/2023
20.2.0-shire.4 106 1/5/2023
20.2.0-shire.3 106 1/5/2023
20.2.0-shire.2 105 12/26/2022
20.2.0-shire.1 105 12/26/2022
20.2.0-shire.0 96 12/26/2022
20.1.0 2,305 12/25/2022
20.1.0-faramir.1 86 12/12/2022
20.1.0-faramir.0 85 12/9/2022
20.0.2 3,011 12/13/2022
20.0.1 2,319 12/12/2022
20.0.0 2,358 12/8/2022
19.1.0-elrond.7 86 12/7/2022
19.1.0-elrond.6 90 12/5/2022
19.1.0-elrond.5 83 12/5/2022
19.1.0-elrond.4 96 12/2/2022
19.1.0-elrond.3 88 12/2/2022
19.1.0-elrond.2 92 11/29/2022
19.1.0-elrond.1 91 11/28/2022
19.1.0-elrond.0 89 11/28/2022
19.0.0 4,212 11/25/2022
19.0.0-proto.5 85 11/25/2022
19.0.0-proto.4 109 11/22/2022
19.0.0-proto.3 87 11/21/2022
19.0.0-proto.2 83 11/21/2022
19.0.0-proto.1 88 11/21/2022
19.0.0-proto.0 95 11/18/2022
18.2.0-bolt.1 85 11/16/2022
18.2.0-bolt.0 101 11/16/2022
18.1.1 5,063 10/31/2022
18.1.0 5,135 10/26/2022
18.0.1 5,286 10/20/2022
18.0.0 5,457 9/15/2022
17.2.3 5,549 9/9/2022
17.2.2 6,151 8/26/2022
17.2.1 6,309 8/10/2022
17.2.0 5,652 7/8/2022
17.1.2 5,538 7/7/2022
17.1.1 5,535 7/7/2022
17.1.0 5,499 7/5/2022
17.1.0-boromir.4 121 7/8/2022
17.1.0-boromir.3 109 7/5/2022
17.1.0-boromir.2 110 7/1/2022
17.1.0-boromir.1 103 7/1/2022
17.0.2 6,043 6/21/2022
17.0.0 8,811 3/25/2022
17.0.0-meriadoc.0 118 3/24/2022
16.0.1 5,745 3/22/2022
16.0.0 5,765 3/14/2022
15.1.3 5,640 3/8/2022
15.1.2 5,658 3/1/2022
15.1.1 5,631 2/11/2022
15.1.0 5,602 2/11/2022
15.0.1 5,705 2/10/2022
15.0.0 5,580 2/10/2022
14.2.0 5,571 2/9/2022
14.2.0-sam.2 116 2/9/2022
14.2.0-sam.1 111 2/7/2022
14.2.0-sam.0 116 2/7/2022
14.1.0 5,648 1/28/2022
14.0.0 5,667 1/25/2022
14.0.0-gollum.1 119 1/25/2022
14.0.0-gollum.0 124 1/24/2022
13.1.0-bilbo.4 124 1/24/2022
13.1.0-bilbo.3 126 1/24/2022
13.1.0-bilbo.2 109 1/21/2022
13.1.0-bilbo.1 121 1/21/2022
13.1.0-bilbo.0 114 1/21/2022
13.0.1 5,541 1/24/2022
13.0.0 5,592 1/20/2022
13.0.0-gimli.10 120 1/20/2022
13.0.0-gimli.9 172 1/19/2022
13.0.0-gimli.8 118 1/19/2022
13.0.0-gimli.7 121 1/18/2022
13.0.0-gimli.6 123 1/17/2022
13.0.0-gimli.5 128 1/17/2022
13.0.0-gimli.4 123 1/17/2022

Version 14.2.0:
Introduces APIs to configure secondary storage for Projection read models for querying, as introduced in https://github.com/dolittle/Runtime/pull/614 (https://github.com/dolittle/Runtime/pull/614) (requires Runtime v7.6.0). These changes makes it easy to query Projection read models by specifying that you want copies stored in MongoDB, and then use an IMongoCollection<> for that Projection as any other MongoDB collection. The Projection still operates normally and can be fetched from the Projection Store. Modifications of documents in the copied collections will affect the original Projection processing, but should be avoided as it could cause unexpected behaviour. The collections are automatically created and dropped as needed by the Runtime when Projections are created or changed.

There is currently no mechanism for detecting multiple projections copied to the same collection, so be aware of possible strange behaviour if you have multiple Projections with the same name.

Added:
- The [CopyToMongoDB(...)] attribute that enables read model copies for a Projection class to MongoDB. The default collection name is the same as the class name. The attribute accepts an argument to override the collection name.
- The [ConvertToMongoDB(conversion)] attribute to specify a BSON conversion to apply when copying the Projection read model to a MongoDB collection. By default the same conversions as the MongoDB driver uses is applied.
- A .CopyToMongoDB(...) method on the Projection builder for enabling read model copies for Projections created using the builder API. This method accepts a callback that you can use to set the collection name and conversions for the read model copies. You can also disable default MongoDB driver conversions.
- Binding for IMongoDatabase in the tenant scoped DI containers.
- Binding for IMongoCollection<TReadModel> in the tenant scoped DI containers for each Projection.
- Extension method IMongoDatabase.GetCollection<TReadModel>(settings = null) to get a collection using the name of the read model or the collection specified in the [CopyToMongoDB(collection)] attribute.

Changed:
- To make deserialising work from a Projection read model copy collection, we have enabled IgnoreExtraElements for all types in the MongoDB driver when the Dolittle Client is used. This is not default behaviour for the MongoDB driver, but when using MongoDB for read model storage, this should not affect the application adversely.

Changelog:
For all release notes, see changelog (https://github.com/dolittle/DotNET.SDK/blob/master/CHANGELOG.md)