Rystem.RepositoryFramework.Abstractions 1.1.1

There is a newer version of this package available.
See the version list below for details.
dotnet add package Rystem.RepositoryFramework.Abstractions --version 1.1.1
                    
NuGet\Install-Package Rystem.RepositoryFramework.Abstractions -Version 1.1.1
                    
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="Rystem.RepositoryFramework.Abstractions" Version="1.1.1" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Rystem.RepositoryFramework.Abstractions" Version="1.1.1" />
                    
Directory.Packages.props
<PackageReference Include="Rystem.RepositoryFramework.Abstractions" />
                    
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 Rystem.RepositoryFramework.Abstractions --version 1.1.1
                    
#r "nuget: Rystem.RepositoryFramework.Abstractions, 1.1.1"
                    
#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 Rystem.RepositoryFramework.Abstractions@1.1.1
                    
#: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=Rystem.RepositoryFramework.Abstractions&version=1.1.1
                    
Install as a Cake Addin
#tool nuget:?package=Rystem.RepositoryFramework.Abstractions&version=1.1.1
                    
Install as a Cake Tool

Interfaces

Based on CQRS we could split our repository pattern in two main interfaces, one for update (write, delete) and one for read.

Command (Write-Delete)
public interface ICommandPattern<T, TKey, TState> : ICommandPattern
    where TKey : notnull
    where TState : class, IState
{
    Task<TState> InsertAsync(TKey key, T value, CancellationToken cancellationToken = default);
    Task<TState> UpdateAsync(TKey key, T value, CancellationToken cancellationToken = default);
    Task<TState> DeleteAsync(TKey key, CancellationToken cancellationToken = default);
    Task<IEnumerable<BatchResult<TKey, TState>>> BatchAsync(List<BatchOperation<T, TKey>> operations, CancellationToken cancellationToken = default);
}
Query (Read)
public interface IQueryPattern<T, TKey, TState> : IQueryPattern
    where TKey : notnull
    where TState : class, IState
{
    Task<T?> GetAsync(TKey key, CancellationToken cancellationToken = default);
    Task<TState> ExistAsync(TKey key, CancellationToken cancellationToken = default);
    Task<IEnumerable<T>> QueryAsync(QueryOptions<T>? options = null, CancellationToken cancellationToken = default);
    Task<long> CountAsync(QueryOptions<T>? options = null, CancellationToken cancellationToken = default);
}
Repository Pattern (Write-Delete-Read)

Repository pattern is a sum of CQRS interfaces.

public interface IRepositoryPattern<T, TKey, TState> : ICommandPattern<T, TKey, TState>, IQueryPattern<T, TKey, TState>, IRepositoryPattern, ICommandPattern, IQueryPattern
    where TKey : notnull
    where TState : class, IState
{
}

With State as TState

Command (Write-Delete)
public interface ICommandPattern<T, TKey> : ICommandPattern<T, TKey, State>, ICommandPattern
    where TKey : notnull
{
    Task<State> InsertAsync(TKey key, T value, CancellationToken cancellationToken = default);
    Task<State> UpdateAsync(TKey key, T value, CancellationToken cancellationToken = default);
    Task<State> DeleteAsync(TKey key, CancellationToken cancellationToken = default);
    Task<IEnumerable<BatchResult<TKey, State>>> BatchAsync(List<BatchOperation<T, TKey>> operations, CancellationToken cancellationToken = default);
}
Query (Read)
public interface IQueryPattern<T, TKey> : IQueryPattern<T, TKey, State>, IQueryPattern
    where TKey : notnull
{
    Task<T?> GetAsync(TKey key, CancellationToken cancellationToken = default);
    Task<State> ExistAsync(TKey key, CancellationToken cancellationToken = default);
    Task<IEnumerable<T>> QueryAsync(QueryOptions<T>? options = null, CancellationToken cancellationToken = default);
    Task<long> CountAsync(QueryOptions<T>? options = null, CancellationToken cancellationToken = default);
}
Repository Pattern (Write-Delete-Read)

Repository pattern is a sum of CQRS interfaces.

public interface IRepositoryPattern<T, TKey> : IRepositoryPattern<T, TKey, State>, ICommandPattern<T, TKey>, IQueryPattern<T, TKey>, IRepositoryPattern, ICommandPattern, IQueryPattern
    where TKey : notnull
{
}

With State as TState and string as TKey

Command (Write-Delete)
public interface ICommandPattern<T> : ICommandPattern<T, string>, ICommandPattern
{
    Task<State> InsertAsync(string key, T value, CancellationToken cancellationToken = default);
    Task<State> UpdateAsync(string key, T value, CancellationToken cancellationToken = default);
    Task<State> DeleteAsync(string key, CancellationToken cancellationToken = default);
    Task<IEnumerable<BatchResult<string, State>>> BatchAsync(IEnumerable<BatchOperation<T, string>> operations, CancellationToken cancellationToken = default);
}
Query (Read)
public interface IQueryPattern<T> : IQueryPattern<T, string>, IQueryPattern
{
    Task<T?> GetAsync(string key, CancellationToken cancellationToken = default);
    Task<State> ExistAsync(string key, CancellationToken cancellationToken = default);
    Task<IEnumerable<T>> QueryAsync(QueryOptions<T>? options = null, CancellationToken cancellationToken = default);
    Task<long> CountAsync(QueryOptions<T>? options = null, CancellationToken cancellationToken = default);
}
Repository Pattern (Write-Delete-Read)

Repository pattern is a sum of CQRS interfaces.

public interface IRepositoryPattern<T> : IRepositoryPattern<T, string>, ICommandPattern<T>, IQueryPattern<T>, IRepositoryPattern, ICommandPattern, IQueryPattern
    where TKey : notnull
{
}    

Examples

Model
public class User
{
    public string Id { get; set; }
    public string Name { get; set; }
    public string Email { get; set; }
}
Command
public class UserWriter : ICommandPattern<User, string>
{
    public Task<State> DeleteAsync(string key, CancellationToken cancellationToken = default)
    {
        //delete on with DB or storage context
        throw new NotImplementedException();
    }
    public Task<State> InsertAsync(string key, User value, CancellationToken cancellationToken = default)
    {
        //insert on DB or storage context
        throw new NotImplementedException();
    }
    public Task<State> UpdateAsync(string key, User value, CancellationToken cancellationToken = default)
    {
        //update on DB or storage context
        throw new NotImplementedException();
    }
    public Task<IEnumerable<BatchResult<string, State>>> BatchAsync(IEnumerable<BatchOperation<User, string>> operations, CancellationToken cancellationToken = default)
    {
        //insert, update or delete some items on DB or storage context
        throw new NotImplementedException();
    }
}
Query
public class UserReader : IQueryPattern<User, string>
{
    public Task<User?> GetAsync(string key, CancellationToken cancellationToken = default)
    {
        //get an item by key from DB or storage context
        throw new NotImplementedException();
    }
    public Task<State> ExistAsync(string key, CancellationToken cancellationToken = default)
    {
        //check if an item by key exists in DB or storage context
        throw new NotImplementedException();
    }
    public Task<IEnumerable<User>> QueryAsync(QueryOptions<T>? options = null, CancellationToken cancellationToken = default)
    {
        //get a list of items by a predicate with top and skip from DB or storage context
        throw new NotImplementedException();
    }
    public Task<long> CountAsync(QueryOptions<T>? options = null, CancellationToken cancellationToken = default)
    {
        //get an items count by a predicate with top and skip from DB or storage context
        throw new NotImplementedException();
    }
}
Alltogether as repository pattern

if you don't have CQRS infrastructure (usually it's correct to use CQRS when you have minimum two infrastructures one for write and delete and at least one for read)

public class UserRepository : IRepositoryPattern<User, string>, IQueryPattern<User, string>, ICommandPattern<User, string>
{
    public Task<State> DeleteAsync(string key, CancellationToken cancellationToken = default)
    {
        //delete on with DB or storage context
        throw new NotImplementedException();
    }
    public Task<State> InsertAsync(string key, User value, CancellationToken cancellationToken = default)
    {
        //insert on DB or storage context
        throw new NotImplementedException();
    }
    public Task<State> UpdateAsync(string key, User value, CancellationToken cancellationToken = default)
    {
        //update on DB or storage context
        throw new NotImplementedException();
    }
    public Task<IEnumerable<BatchResult<string, State>>> BatchAsync(IEnumerable<BatchOperation<User, string>> operations, CancellationToken cancellationToken = default)
    {
        //insert, update or delete some items on DB or storage context
        throw new NotImplementedException();
    }
    public Task<User?> GetAsync(string key, CancellationToken cancellationToken = default)
    {
        //get an item by key from DB or storage context
        throw new NotImplementedException();
    }
    public Task<State> ExistAsync(string key, CancellationToken cancellationToken = default)
    {
        //check if an item by key exists in DB or storage context
        throw new NotImplementedException();
    }
    public Task<IEnumerable<User>> QueryAsync(QueryOptions<T>? options = null, CancellationToken cancellationToken = default)
    {
        //get a list of items by a predicate with top and skip from DB or storage context
        throw new NotImplementedException();
    }
    public Task<long> CountAsync(QueryOptions<T>? options = null, CancellationToken cancellationToken = default)
    {
        //get an items count by a predicate with top and skip from DB or storage context
        throw new NotImplementedException();
    }
}

How to use it

In DI you install the service

services.AddRepository<User, string, UserRepository>();

And you may inject the object

IRepository<User, string> repository

Query and Command

In DI you install the services

services.AddCommand<User, string, UserWriter>();
services.AddQuery<User, string, UserReader>();

And you may inject the objects

ICommand<User, string> command
IQuery<User, string> command

Example with default key

In DI you install the services

services.AddRepository<User, UserRepository>();
services.AddCommand<User, UserWriter>();
services.AddQuery<User, UserReader>();

And you may inject the objects

IRepository<User> repository
ICommand<User> command
IQuery<User> command

Example with TState

In DI you install the services, in example we are using a Result class that is an IState, instead the default integration State.

services.AddRepository<User, string, Result, UserRepository>();
services.AddCommand<User, string, Result, UserWriter>();
services.AddQuery<User, string, Result, UserReader>();

And you may inject the objects

IRepository<User, string, Result> repository
ICommand<User, string, Result> command
IQuery<User, string, Result> command
Product Compatible and additional computed target framework versions.
.NET 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.  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.

NuGet packages (13)

Showing the top 5 NuGet packages that depend on Rystem.RepositoryFramework.Abstractions:

Package Downloads
Rystem.RepositoryFramework.Api.Server

Rystem.RepositoryFramework allows you to use correctly concepts like repository pattern, CQRS and DDD. You have interfaces for your domains, auto-generated api, auto-generated HttpClient to simplify connection "api to front-end", a functionality for auto-population in memory of your models, a functionality to simulate exceptions and waiting time from external sources to improve your implementation/business test and load test.

Rystem.RepositoryFramework.Api.Client

Rystem.RepositoryFramework allows you to use correctly concepts like repository pattern, CQRS and DDD. You have interfaces for your domains, auto-generated api, auto-generated HttpClient to simplify connection "api to front-end", a functionality for auto-population in memory of your models, a functionality to simulate exceptions and waiting time from external sources to improve your implementation/business test and load test.

Rystem.RepositoryFramework.Infrastructure.Azure.Storage.Blob

Rystem.RepositoryFramework allows you to use correctly concepts like repository pattern, CQRS and DDD. You have interfaces for your domains, auto-generated api, auto-generated HttpClient to simplify connection "api to front-end", a functionality for auto-population in memory of your models, a functionality to simulate exceptions and waiting time from external sources to improve your implementation/business test and load test.

Rystem.RepositoryFramework.Infrastructure.Azure.Storage.Table

Rystem.RepositoryFramework allows you to use correctly concepts like repository pattern, CQRS and DDD. You have interfaces for your domains, auto-generated api, auto-generated HttpClient to simplify connection "api to front-end", a functionality for auto-population in memory of your models, a functionality to simulate exceptions and waiting time from external sources to improve your implementation/business test and load test.

Rystem.RepositoryFramework.Cache

Rystem.RepositoryFramework allows you to use correctly concepts like repository pattern, CQRS and DDD. You have interfaces for your domains, auto-generated api, auto-generated HttpClient to simplify connection "api to front-end", a functionality for auto-population in memory of your models, a functionality to simulate exceptions and waiting time from external sources to improve your implementation/business test and load test.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
10.0.1 25,682 11/12/2025
9.1.3 631 9/2/2025
9.1.2 765,152 5/29/2025
9.1.1 98,146 5/2/2025
9.0.32 186,943 4/15/2025
9.0.31 6,072 4/2/2025
9.0.30 89,029 3/26/2025
9.0.29 9,266 3/18/2025
9.0.28 449 3/17/2025
9.0.27 424 3/16/2025
9.0.26 484 3/13/2025
9.0.25 52,360 3/9/2025
9.0.23 253 3/9/2025
9.0.21 970 3/6/2025
9.0.20 19,789 3/6/2025
9.0.19 513 3/6/2025
9.0.18 508 3/4/2025
9.0.17 406 3/1/2025
9.0.16 363 3/1/2025
9.0.15 75,753 2/22/2025
9.0.14 22,794 2/18/2025
9.0.13 402 2/9/2025
9.0.12 218,217 1/13/2025
9.0.11 24,243 1/9/2025
9.0.10 332 1/9/2025
9.0.9 4,252 1/7/2025
9.0.8 12,724 1/6/2025
9.0.7 367 1/6/2025
9.0.5 19,215 12/30/2024
9.0.4 92,477 12/23/2024
9.0.3 386 12/22/2024
9.0.2 10,910 12/21/2024
9.0.1 1,407 12/21/2024
9.0.0 173,319 11/16/2024
9.0.0-rc.1 226 10/18/2024
6.2.0 219,882 10/9/2024
6.1.1 478 10/9/2024
6.1.0 48,340 9/29/2024
6.0.24 588 9/11/2024
6.0.23 340,495 7/18/2024
6.0.21 536 6/18/2024
6.0.20 728,115 6/16/2024
6.0.19 31,265 6/14/2024
6.0.18 503 6/14/2024
6.0.17 485 6/14/2024
6.0.16 50,401 6/10/2024
6.0.15 490 6/9/2024
6.0.14 94,858 5/24/2024
6.0.13 538 5/23/2024
6.0.12 480 5/23/2024
6.0.11 543 5/20/2024
6.0.9 507 5/19/2024
6.0.7 512 5/18/2024
6.0.6 516 5/10/2024
6.0.5 465 5/10/2024
6.0.4 550,510 4/3/2024
6.0.3 2,094 3/25/2024
6.0.2 378,420 3/11/2024
6.0.1 51,289 3/8/2024
6.0.0 1,172,183 11/21/2023
6.0.0-rc.6 214 10/25/2023
6.0.0-rc.5 183 10/25/2023
6.0.0-rc.4 150 10/23/2023
6.0.0-rc.3 140 10/19/2023
6.0.0-rc.2 174 10/18/2023
6.0.0-rc.1 192 10/16/2023
5.0.20 641,748 9/25/2023
5.0.19 3,426 9/10/2023
5.0.18 2,702 9/6/2023
5.0.17 2,588 9/6/2023
5.0.16 2,660 9/5/2023
5.0.15 2,651 9/5/2023
5.0.14 2,676 9/5/2023
5.0.13 2,691 9/1/2023
5.0.12 2,541 8/31/2023
5.0.11 2,586 8/30/2023
5.0.10 2,647 8/29/2023
5.0.9 2,675 8/24/2023
5.0.8 2,714 8/24/2023
5.0.7 452,195 8/23/2023
5.0.6 20,048 8/21/2023
5.0.5 6,830 8/21/2023
5.0.4 2,716 8/16/2023
5.0.3 215,258 8/2/2023
5.0.2 4,541 8/2/2023
5.0.1 14,339 8/1/2023
5.0.0 14,734 7/31/2023
4.1.26 143,568 7/20/2023
4.1.25 27,394 7/16/2023
4.1.24 400,776 6/13/2023
4.1.23 48,479 6/13/2023
4.1.22 132,476 5/30/2023
4.1.21 58,430 5/20/2023
4.1.20 407,853 4/19/2023
4.1.19 98,592 3/20/2023
4.1.18 3,153 3/20/2023
4.1.17 3,396 3/16/2023
4.1.16 3,185 3/16/2023
4.1.15 3,157 3/15/2023
4.1.14 10,831 3/9/2023
4.1.13 3,264 3/7/2023
4.1.12 3,754 2/9/2023
4.1.11 3,323 1/26/2023
4.1.10 3,626 1/22/2023
4.1.9 3,247 1/20/2023
4.1.8 3,506 1/18/2023
4.1.7 3,431 1/18/2023
4.1.6 3,534 1/17/2023
4.1.1 3,469 1/4/2023
4.1.0 3,342 1/1/2023
3.1.5 3,288 12/21/2022
3.1.4 1,666 12/21/2022
3.1.3 3,645 12/12/2022
3.1.2 3,370 12/7/2022
3.1.1 3,444 12/7/2022
3.1.0 3,446 12/1/2022
3.0.29 3,371 12/1/2022
3.0.28 4,296 12/1/2022
3.0.27 3,584 11/23/2022
3.0.25 8,264 11/23/2022
3.0.24 4,880 11/18/2022
3.0.23 4,496 11/18/2022
3.0.22 4,679 11/15/2022
3.0.21 4,684 11/14/2022
3.0.20 4,759 11/13/2022
3.0.19 5,039 11/2/2022
3.0.18 4,781 11/2/2022
3.0.17 4,845 10/29/2022
3.0.16 4,914 10/29/2022
3.0.15 1,774 10/29/2022
3.0.14 7,967 10/24/2022
3.0.13 5,025 10/24/2022
3.0.12 5,011 10/17/2022
3.0.11 4,955 10/10/2022
3.0.10 4,510 10/6/2022
3.0.9 4,425 10/6/2022
3.0.8 4,378 10/6/2022
3.0.7 4,495 10/6/2022
3.0.6 4,510 10/5/2022
3.0.5 4,371 10/5/2022
3.0.4 4,458 10/5/2022
3.0.3 4,447 10/3/2022
3.0.2 4,495 9/30/2022
3.0.1 4,467 9/29/2022
3.0.0 1,805 9/29/2022
2.0.17 4,068 9/29/2022
2.0.16 4,566 9/27/2022
2.0.15 4,651 9/27/2022
2.0.14 4,579 9/26/2022
2.0.13 4,508 9/26/2022
2.0.12 4,475 9/26/2022
2.0.11 4,431 9/25/2022
2.0.10 4,641 9/25/2022
2.0.9 4,532 9/22/2022
2.0.8 4,421 9/22/2022
2.0.7 1,829 9/22/2022
2.0.6 4,428 9/20/2022
2.0.5 4,686 9/20/2022
2.0.4 4,518 9/20/2022
2.0.2 4,538 9/20/2022
2.0.1 4,762 9/13/2022
2.0.0 4,631 8/19/2022
1.1.24 4,647 7/30/2022
1.1.23 4,598 7/29/2022
1.1.22 4,369 7/29/2022
1.1.21 4,817 7/29/2022
1.1.20 4,577 7/29/2022
1.1.19 4,605 7/27/2022
1.1.17 4,617 7/27/2022
1.1.16 4,613 7/26/2022
1.1.15 4,636 7/25/2022
1.1.14 4,596 7/25/2022
1.1.13 4,492 7/22/2022
1.1.12 4,498 7/19/2022
1.1.11 4,573 7/19/2022
1.1.10 4,596 7/19/2022
1.1.9 4,592 7/19/2022
1.1.8 4,685 7/18/2022
1.1.7 4,533 7/18/2022
1.1.6 4,596 7/18/2022
1.1.5 4,558 7/17/2022
1.1.4 1,815 7/17/2022
1.1.3 7,198 7/17/2022
1.1.2 4,643 7/17/2022
1.1.1 1,846 7/17/2022
1.1.0 4,583 7/17/2022
1.0.2 4,568 7/15/2022
1.0.1 3,209 7/15/2022
1.0.0 5,828 7/8/2022
0.10.7 4,601 7/7/2022
0.10.6 1,893 7/7/2022
0.10.3 2,389 7/7/2022
0.10.2 6,063 7/2/2022
0.10.1 4,575 7/1/2022
0.10.0 4,393 7/1/2022
0.9.10 5,745 6/20/2022
0.9.9 4,643 6/11/2022
0.9.8 1,822 6/10/2022
0.9.7 4,503 6/9/2022
0.9.6 4,529 6/5/2022
0.9.5 3,084 6/3/2022
0.9.3 4,426 6/3/2022
0.9.2 2,636 5/31/2022
0.9.1 2,603 5/31/2022
0.9.0 2,605 5/31/2022
0.8.3-beta.1 233 5/31/2022
0.8.2 1,886 5/30/2022
0.8.1 1,902 5/29/2022