MongoDB.Entities.ReactiveChangeStream
1.0.1
See the version list below for details.
dotnet add package MongoDB.Entities.ReactiveChangeStream --version 1.0.1
NuGet\Install-Package MongoDB.Entities.ReactiveChangeStream -Version 1.0.1
<PackageReference Include="MongoDB.Entities.ReactiveChangeStream" Version="1.0.1" />
paket add MongoDB.Entities.ReactiveChangeStream --version 1.0.1
#r "nuget: MongoDB.Entities.ReactiveChangeStream, 1.0.1"
// Install MongoDB.Entities.ReactiveChangeStream as a Cake Addin
#addin nuget:?package=MongoDB.Entities.ReactiveChangeStream&version=1.0.1
// Install MongoDB.Entities.ReactiveChangeStream as a Cake Tool
#tool nuget:?package=MongoDB.Entities.ReactiveChangeStream&version=1.0.1
MongoDB.Entities.ReactiveChangeStream
Extension for MongoDB Entities Library to handle MongoDB Change Streams as an IObservale
MongoDB Change Streams are a feature that allow the database to notify subscribers for any change, more about Change Streams
For MongoDB Official C# Driver use MongoDB.ReactiveChangeStream
MongoDB.Entities
A light-weight .net standard library with barely any overhead that aims to simplify access to mongodb by abstracting the official driver while adding useful features on top of it resulting in an elegant API surface which produces beautiful, human friendly data access code.
Installation
First, install the MongoDB.Entities.ReactiveChangeStream
Nuget package into your app
Install-Package MongoDB.Entities.ReactiveChangeStream
Example Usage
Create Reactive Change Stream directly:
using System.Reactive.Linq;
using MongoDB.Driver;
using MongoDB.Entities;
await DB.InitAsync("foo",
MongoClientSettings.FromConnectionString("mongodb://localhost:27017/foo?replicaSet=rs0"));
var changeObservable = DBEx.StartReactiveWatcher<Entity>();
changeObservable
.Buffer(TimeSpan.FromSeconds(5))
.Do(changes =>
{
// Do something
})
.Subscribe();
From a Watcher instance:
using System.Reactive.Linq;
using MongoDB.Driver;
using MongoDB.Entities;
await DB.InitAsync("foo",
MongoClientSettings.FromConnectionString("mongodb://localhost:27017/foo?replicaSet=rs0"));
var watcher = DB.Watcher<Entity>("watcher");
watcher.Start(EventType.Created | EventType.Deleted | EventType.Updated);
watcher
.ToObservableChangeStream();
.Buffer(TimeSpan.FromSeconds(5))
.Do(changes =>
{
// Do something
})
.Subscribe();
Watch individual Entities changes filtered by their IDs:
using System.Reactive.Linq;
using MongoDB.Driver;
using MongoDB.Entities;
using MongoDB.Entities.ReactiveChangeStream;
var foo = DB.Entity<Foo>();
foo
.ObserveChanges()
.Buffer(TimeSpan.FromSeconds(5))
.Do(changes =>
{
// Do something
})
.Subscribe();
class Foo : Entity
{
/*
*/
}
Note:
Make sure you connecting to a MongoDB instance with Replica Set Enabled, as Change Streams require it. read more about how to initialize a Replica Set here...
Product | Versions |
---|---|
.NET | net5.0 net5.0-windows net6.0 net6.0-android net6.0-ios net6.0-maccatalyst net6.0-macos net6.0-tvos net6.0-windows net7.0 net7.0-android net7.0-ios net7.0-maccatalyst net7.0-macos net7.0-tvos net7.0-windows |
.NET Core | netcoreapp2.0 netcoreapp2.1 netcoreapp2.2 netcoreapp3.0 netcoreapp3.1 |
.NET Standard | netstandard2.0 netstandard2.1 |
.NET Framework | net461 net462 net463 net47 net471 net472 net48 net481 |
MonoAndroid | monoandroid |
MonoMac | monomac |
MonoTouch | monotouch |
Tizen | tizen40 tizen60 |
Xamarin.iOS | xamarinios |
Xamarin.Mac | xamarinmac |
Xamarin.TVOS | xamarintvos |
Xamarin.WatchOS | xamarinwatchos |
-
.NETStandard 2.0
- MongoDB.Entities (>= 20.26.3)
- System.Reactive (>= 5.0.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.