Go to file
2021-08-11 17:14:26 -04:00
Demo more extenson methods. :) 2021-08-11 17:00:22 -04:00
PoweredSoft.CQRS ready for 2.0.0 stable. 2021-08-11 17:05:56 -04:00
PoweredSoft.CQRS.Abstractions ready for 2.0.0 stable. 2021-08-11 17:05:56 -04:00
PoweredSoft.CQRS.AspNetCore ready for 2.0.0 stable. 2021-08-11 17:05:56 -04:00
PoweredSoft.CQRS.AspNetCore.Abstractions ready for 2.0.0 stable. 2021-08-11 17:05:56 -04:00
PoweredSoft.CQRS.AspNetCore.OData ready for 2.0.0 stable. 2021-08-11 17:05:56 -04:00
PoweredSoft.CQRS.AspNetCore.OData.Abstractions ready for 2.0.0 stable. 2021-08-11 17:05:56 -04:00
PoweredSoft.CQRS.DynamicQuery ready for 2.0.0 stable. 2021-08-11 17:05:56 -04:00
PoweredSoft.CQRS.DynamicQuery.Abstractions ready for 2.0.0 stable. 2021-08-11 17:05:56 -04:00
PoweredSoft.CQRS.DynamicQuery.AspNetCore ready for 2.0.0 stable. 2021-08-11 17:05:56 -04:00
PoweredSoft.CQRS.FluentValidation ready for 2.0.0 stable. 2021-08-11 17:05:56 -04:00
PoweredSoft.CQRS.GraphQL.Abstractions ready for 2.0.0 stable. 2021-08-11 17:05:56 -04:00
PoweredSoft.CQRS.GraphQL.DynamicQuery ready for 2.0.0 stable. 2021-08-11 17:05:56 -04:00
PoweredSoft.CQRS.GraphQL.FluentValidation ready for 2.0.0 stable. 2021-08-11 17:05:56 -04:00
PoweredSoft.CQRS.GraphQL.HotChocolate ready for 2.0.0 stable. 2021-08-11 17:05:56 -04:00
PoweredSoft.CQRS.GraphQL.HotChocolate.DynamicQuery ready for 2.0.0 stable. 2021-08-11 17:05:56 -04:00
.gitattributes Add .gitignore and .gitattributes. 2021-02-01 23:31:05 -05:00
.gitignore Add .gitignore and .gitattributes. 2021-02-01 23:31:05 -05:00
azure-pipeline.yaml Update azure-pipeline.yaml for Azure Pipelines 2021-02-07 00:25:20 -05:00
LICENSE Create LICENSE 2021-02-01 23:55:58 -05:00
PoweredSoft.CQRS.sln more extension method and fluent validation library :) 2021-08-11 16:56:27 -04:00
README.md Update README.md 2021-08-11 17:14:26 -04:00

CQRS

Our implementation of query and command responsability segregation (CQRS).

Getting Started

Install nuget package to your awesome project.

Full Version NuGet NuGet Install
PoweredSoft.CQRS.Abstractions NuGet PM> Install-Package PoweredSoft.CQRS.Abstractions
PoweredSoft.CQRS NuGet PM> Install-Package PoweredSoft.CQRS
PoweredSoft.CQRS.FluentValidation NuGet PM> Install-Package PoweredSoft.CQRS.FluentValidation
PoweredSoft.CQRS.AspNetCore.Abstractions NuGet PM> Install-Package PoweredSoft.CQRS.AspNetCore.Abstractions
PoweredSoft.CQRS.AspNetCore NuGet PM> Install-Package PoweredSoft.CQRS.AspNetCore
PoweredSoft.CQRS.GraphQL.HotChocolate NuGet PM> Install-Package PoweredSoft.CQRS.GraphQL.HotChocolate

Sample of startup code for aspnetcore MVC

public void ConfigureServices(IServiceCollection services)
{
    // make sure to add your queries and commands before the .AddPoweredSoftQueries and .AddPoweredSoftCommands
    AddQueries(services);
    AddCommands(services);

    // adds the non related to aspnet core features.
    services.AddPoweredSoftCQRS();
    
    services
        .AddControllers()
        .AddPoweredSoftQueries() // adds queries to aspnetcore mvc.(you can make it configurable to load balance only commands on a instance)
        .AddPoweredSoftCommands() // adds commands to aspnetcore mvc. (you can make it configurable to load balance only commands on a instance)
        .AddFluentValidation();

    // enabling gql.
    services
        .AddGraphQLServer()
        .AddProjections()
        .AddQueryType(d => d.Name("Query"))
        .AddPoweredSoftQueries()
        .AddPoweredSoftDynamicQueries()
        .AddMutationType(d => d.Name("Mutation"))
        .AddPoweredSoftMutations();

    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. PoweredSoft.CQRS.FluentValidation you can use this way of registrating your commands.

// without Package.
services.AddCommand<EchoCommand, string, EchoCommandHandler>();
services.AddTransient<IValidator<EchoCommand>, EchoCommandValidator>();*/

// with PoweredSoft.CQRS.FluentValidation package.
services.AddCommandWithValidator<EchoCommand, string, EchoCommandHandler, EchoCommandValidator>();