OpenHarbor.CQRS.DynamicQuery.AspNetCore
                               
                            
                                8.1.0-rc1
                            
                        
                    dotnet add package OpenHarbor.CQRS.DynamicQuery.AspNetCore --version 8.1.0-rc1
NuGet\Install-Package OpenHarbor.CQRS.DynamicQuery.AspNetCore -Version 8.1.0-rc1
<PackageReference Include="OpenHarbor.CQRS.DynamicQuery.AspNetCore" Version="8.1.0-rc1" />
<PackageVersion Include="OpenHarbor.CQRS.DynamicQuery.AspNetCore" Version="8.1.0-rc1" />
<PackageReference Include="OpenHarbor.CQRS.DynamicQuery.AspNetCore" />
paket add OpenHarbor.CQRS.DynamicQuery.AspNetCore --version 8.1.0-rc1
#r "nuget: OpenHarbor.CQRS.DynamicQuery.AspNetCore, 8.1.0-rc1"
#:package OpenHarbor.CQRS.DynamicQuery.AspNetCore@8.1.0-rc1
#addin nuget:?package=OpenHarbor.CQRS.DynamicQuery.AspNetCore&version=8.1.0-rc1&prerelease
#tool nuget:?package=OpenHarbor.CQRS.DynamicQuery.AspNetCore&version=8.1.0-rc1&prerelease
This project was originally initiated by Powered Software Inc. and was forked from the PoweredSoft.CQRS Repository
CQRS
Our implementation of query and command responsibility segregation (CQRS).
Getting Started
Install nuget package to your awesome project.
Abstractions Packages.
Sample of startup code for aspnetcore MVC
public void ConfigureServices(IServiceCollection services)
{
    // make sure to add your queries and commands before configuring MvCBuilder with .AddOpenHarborCommands and .AddOpenHarborQueries
    AddQueries(services);
    AddCommands(services);
    // adds the non related to aspnet core features.
    services.AddOpenHarborCQRS();
    
    services
        .AddControllers()
        .AddOpenHarborQueries() // adds queries to aspnetcore mvc.(you can make it configurable to load balance only commands on a instance)
        .AddOpenHarborCommands() // adds commands to aspnetcore mvc. (you can make it configurable to load balance only commands on a instance)
        .AddFluentValidation();
    services.AddSwaggerGen();
}
Example how to add your queries and commands.
private void AddCommands(IServiceCollection services)
{
    services.AddCommand<CreatePersonCommand, CreatePersonCommandHandler>();
    services.AddTransient<IValidator<CreatePersonCommand>, CreatePersonCommandValidator>();
    services.AddCommand<EchoCommand, string, EchoCommandHandler>();
    services.AddTransient<IValidator<EchoCommand>, EchoCommandValidator>();
}
private void AddQueries(IServiceCollection services)
{
    services.AddQuery<PersonQuery, IQueryable<Person>, PersonQueryHandler>();
}
Fluent Validation
We use fluent validation in all of our projects, but we don't want it to be enforced.
If you install OpenHarbor.CQRS.FluentValidation you can use this way of registrating your commands.
public void ConfigureServices(IServiceCollection services) 
{
    // without Package.
    services.AddCommand<EchoCommand, string, EchoCommandHandler>();
    services.AddTransient<IValidator<EchoCommand>, EchoCommandValidator>();
}
public void ConfigureServices(IServiceCollection services) 
{
    // with OpenHarbor.CQRS.FluentValidation package.
    services.AddCommand<EchoCommand, string, EchoCommandHandler, EchoCommandValidator>();
}
2024 Roadmap
| Task | Description | Status | 
|---|---|---|
| Support .NET 8 | Ensure compatibility with .NET 8. | ✅ | 
| Create a new demo project as an example | Develop a new demo project to serve as an example for users. | ⬜️ | 
| New Independent Module for MVC | Develop a standalone module, independent of MVC, to enhance framework flexibility. | ⬜️ | 
| Implement .NET Native Compilation (AOT) | Enable Ahead-of-Time (AOT) compilation support for .NET 8. | ⬜️ | 
| Update FluentValidation | Upgrade FluentValidation to the latest version, addressing potential breaking changes. | ⬜️ | 
| Create a website for the Framework | Develop a website to host comprehensive documentation for the framework. | ⬜️ | 
| Re-add support for GraphQL | Re-integrate support for GraphQL, exploring lightweight solutions. | ⬜️ | 
| Product | Versions 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. | 
- 
                                                    net8.0- OpenHarbor.CQRS.Abstractions (>= 8.1.0-rc1)
- OpenHarbor.CQRS.AspNetCore (>= 8.1.0-rc1)
- OpenHarbor.CQRS.AspNetCore.Abstractions (>= 8.1.0-rc1)
- OpenHarbor.CQRS.DynamicQuery (>= 8.1.0-rc1)
- OpenHarbor.CQRS.DynamicQuery.Abstractions (>= 8.1.0-rc1)
 
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 | 
|---|---|---|
| 8.1.0-rc1 | 82 | 12/22/2024 | 
| 8.0.0-preview.6 | 217 | 9/2/2024 | 
| 8.0.0-preview.5 | 211 | 11/4/2023 |