NEventFlow 1.1.0

dotnet add package NEventFlow --version 1.1.0                
NuGet\Install-Package NEventFlow -Version 1.1.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="NEventFlow" Version="1.1.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add NEventFlow --version 1.1.0                
#r "nuget: NEventFlow, 1.1.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 NEventFlow as a Cake Addin
#addin nuget:?package=NEventFlow&version=1.1.0

// Install NEventFlow as a Cake Tool
#tool nuget:?package=NEventFlow&version=1.1.0                

EventFlow Library

EventFlow is a .NET library designed to simplify the implementation of event sourcing and CQRS (Command Query Responsibility Segregation) patterns. It provides a clean and efficient way to handle events, snapshots, and state reconstruction in applications that require high performance and scalability.


Table of Contents


Features

  • Event Sourcing Support: Efficient handling and processing of events to reconstruct state.
  • Snapshot Mechanism: Supports snapshots to improve performance by reducing the number of events to process.
  • Flexible Configuration: Customize snapshot intervals and buffers.
  • Dependency Injection Friendly: Easily integrate with IServiceCollection for registration and configuration.

Getting Started

Installation

EventFlow is available as a NuGet package. You can install it using the Package Manager Console:

bash

Copy code

Install-Package NEventFlow

Or via the .NET CLI:

bash

dotnet add package NEventFlow

Prerequisites

  • .NET 5.0 or later.
  • Familiarity with event sourcing and CQRS patterns.
  • An event storage solution for storing events and snapshots.

Usage

Creating a Query Model

Create a query model by extending the QueryModel<TState> class and implementing the IHandler<TState, TEvent> interface for each event type.

    public class EmployeeProjectAllocationModel :
        QueryModel<EmployeeProjectAllocationModel.State>,
        IHandler<EmployeeProjectAllocationModel.State, ProjectEvents.EmployeeAssigned>,
        IHandler<EmployeeProjectAllocationModel.State, ProjectEvents.EmployeeUnassigned>
    {
        public record State(ImmutableList<string> ProjectIds);

        protected override State GetInitialState() => new State(ImmutableList<string>.Empty);

        public EmployeeProjectAllocationModel(QueryModelServices<State> services)
          : base(services)
        {}

        public string Correlate(ProjectEvents.EmployeeAssigned evt) => evt.EmployeeId;

        public string Correlate(ProjectEvents.EmployeeUnassigned evt) => evt.EmployeeId;

        public async Task<State> HandleAsync(State previousState, ProjectEvents.EmployeeAssigned evt)
        {
            await Task.CompletedTask;
            return previousState with { ProjectIds = previousState.ProjectIds.Add(evt.ProjectId) };
        }

        public async Task<State> HandleAsync(State previousState, ProjectEvents.EmployeeUnassigned evt)
        {
            await Task.CompletedTask;
            return previousState with { ProjectIds = previousState.ProjectIds.Remove(evt.ProjectId) };
        }
    }

Configuring Services

Use the provided EventFlowBuilder to register services and configurations in your Startup.cs or Program.cs.

using EventFlow;
using Microsoft.Extensions.DependencyInjection;

public class Startup
{
    public void ConfigureServices(IServiceCollection services)
    {
        // Add EventFlow and configure services
        services.AddEventFlow(builder =>
          {
            // Configure EventFlow options
            builder.ConfigureOptions(options => {
              options.SnapshotBuffer = 200;
              options.SnapshotInterval = TimeSpan.FromDays(7);
          })

        // Register ISnapshotStore for EmployeeProjectAllocationModel.State
         .AddSnapshotStore<EmployeeProjectAllocationModel.State>(sp =>  {
            // Implement and return your ISnapshotStore<TState>
              return new InMemorySnapshotStore<EmployeeProjectAllocationModel.State>();
          })
      
      // Register IEventSource
        .AddEventSource(sp => {
          // Implement and return your IEventSource
            return new InMemoryEventSource();
          })

    // Register the EmployeeProjectAllocationModel
      .AddQueryModel<EmployeeProjectAllocationModel.State, EmployeeProjectAllocationModel>();
    });
  }
}

Note: You need to implement ISnapshotStore<TState> and IEventSource according to your chosen storage mechanism. For example, you might create an in-memory implementation or use a database.

Using the Query Model

Inject the EmployeeProjectAllocationModel into your services or controllers and use it to get the state.

public class EmployeeService
{
    private readonly EmployeeProjectAllocationModel _model;

    public EmployeeService(EmployeeProjectAllocationModel model)
    {
        _model = model;
    }

    public async Task<EmployeeProjectAllocationModel.State> GetEmployeeProjectsAsync(string employeeId)
    {
        return await _model.GetStateAsync(employeeId);
    }
}

Configuration

EventFlow allows you to configure snapshot behavior via the Configuration class.

public class Configuration { public int SnapshotBuffer { get; set; } = 100; public TimeSpan SnapshotInterval { get; set; } = TimeSpan.FromDays(30); }

  • SnapshotBuffer: The number of events to process before considering saving a new snapshot.
  • SnapshotInterval: The time interval after which a new snapshot should be considered.

These settings can be configured when setting up the services:

builder.ConfigureOptions(options =>
{
options.SnapshotBuffer = 200;
options.SnapshotInterval = TimeSpan.FromDays(7);
});

License

EventFlow is licensed under the MIT License. See the LICENSE file for details.


Feel free to explore the library, and don't hesitate to reach out if you have any questions or need assistance!

Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  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.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.1.0 133 10/18/2024
1.0.1 97 10/4/2024
1.0.0 105 10/1/2024