AggregateKit 0.2.0

dotnet add package AggregateKit --version 0.2.0
                    
NuGet\Install-Package AggregateKit -Version 0.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="AggregateKit" Version="0.2.0" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="AggregateKit" Version="0.2.0" />
                    
Directory.Packages.props
<PackageReference Include="AggregateKit" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add AggregateKit --version 0.2.0
                    
#r "nuget: AggregateKit, 0.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.
#:package AggregateKit@0.2.0
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=AggregateKit&version=0.2.0
                    
Install as a Cake Addin
#tool nuget:?package=AggregateKit&version=0.2.0
                    
Install as a Cake Tool

AggregateKit

AggregateKit is a lightweight library providing essential building blocks for Domain-Driven Design (DDD) in .NET applications.

Features

  • Entity: Base class for domain entities with identity-based equality
  • AggregateRoot: Base class for aggregate roots with domain event handling
  • ValueObject: Base class for value objects with value-based equality
  • DomainEvents: Support for domain events through IDomainEvent and DomainEventBase
  • Result: Functional-style error handling with Result pattern
  • Guard: Utility methods for validating method arguments and enforcing invariants

Quick Start

// Create a value object
public class Money : ValueObject
{
    public decimal Amount { get; }
    public string Currency { get; }
    
    public Money(decimal amount, string currency)
    {
        Amount = amount;
        Currency = currency;
    }
    
    protected override IEnumerable<object?> GetEqualityComponents()
    {
        yield return Amount;
        yield return Currency;
    }
}

// Create an entity
public class Product : Entity<Guid>
{
    public string Name { get; private set; }
    public Money Price { get; private set; }
    
    public Product(Guid id, string name, Money price) : base(id)
    {
        Name = name;
        Price = price;
    }
}

// Create an aggregate root
public class Article : AggregateRoot<Guid>
{
    public string Title { get; private set; }
    public string Content { get; private set; }
    public string AuthorName { get; private set; }
    
    public Article(Guid id, string title, string content, string authorName) : base(id)
    {
        Title = title;
        Content = content;
        AuthorName = authorName;
        
        AddDomainEvent(new ArticleCreatedEvent(id, title, authorName));
    }
}
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.  net10.0 was computed.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • net8.0

    • No dependencies.

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
0.2.0 214 6/8/2025
0.1.0 191 6/8/2025