ResultCommander 2.1.2

There is a newer version of this package available.
See the version list below for details.
dotnet add package ResultCommander --version 2.1.2                
NuGet\Install-Package ResultCommander -Version 2.1.2                
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="ResultCommander" Version="2.1.2" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add ResultCommander --version 2.1.2                
#r "nuget: ResultCommander, 2.1.2"                
#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 ResultCommander as a Cake Addin
#addin nuget:?package=ResultCommander&version=2.1.2

// Install ResultCommander as a Cake Tool
#tool nuget:?package=ResultCommander&version=2.1.2                

ResultCommander

Build Status

Library featuring a command handler pattern for both synchronous and asynchronous operations.

Uses a functional Result approach for failure-prone operations.

To utilize all features using Autofac is required.

Features

  • Synchronous and asynchronous command handler definitions
  • Definitions and base implementations of commands
  • Supports decorators and adapters via Autofac's methods

Description

There are two command types - one that only returns a Result and one that returns an additional entity contained within the Result.

Every handler must return a Result struct which determines whether the operation succedeed or not, handlers may or may not return additional results contained within the Result struct - this is defined by the handled comand.

Installation

To register handlers with the DI container use the ContainerBuilder or IServiceCollection extension methods provided by the library:

builder.AddResultCommander(assembliesToScan);

To register decorators or adapters use the methods available on ResultCommanderConfiguration like so:

builder.AddResultCommander(assembliesToScan, options => 
{
    options.AddDecorator<FancyDecorator, ISyncCommandHandler<SimpleCommand>();
});

You can register multiple decorators and they'll be applied in the order that you register them - read more at Autofac's docs regarding decorators and adapters.

Documentation

Documentation available at https://docs.result-commander.mikym.me/.

Example usage

<b> You should never throw exceptions from within handlers, they should be exception free - instead return appropriate error results (and catch possible exceptions).</b> Library offers a simple error catching, logging and exception to result error decorators for uses where writing try-catch blocks becomes a pain - but remember that these results will never be as informative as manually returned proper result error types.

A command without a concrete result:

public SimpleCommand : ICommand
{
    public bool IsSuccess { get; }
    
    public SimpleCommand(bool isSuccess = true)
        => IsSuccess = isSuccess;
}

And a synchronous handler that handles it:

public SimpleSyncCommandHandler : ISyncCommandHandler<SimpleCommand>
{
    Result Handle(SimpleCommand command)
    {
        if (command.IsSuccess)
            return Result.FromSuccess();
            
        return new InvalidOperationError();
    }
}

A command with a concrete result:

public SimpleCommandWithConcreteResult : ICommand<int>
{
    public bool IsSuccess { get; }
    
    public SimpleCommand(bool isSuccess = true)
        => IsSuccess = isSuccess;
}

And a synchronous handler that handles it:

public SimpleSyncCommandHandlerWithConcreteResult : ISyncCommandHandler<SimpleCommand, int>
{
    Result<int> Handle(SimpleCommand command)
    {
        if (command.IsSuccess)
            return 1;
            
        return new InvalidOperationError();
    }
}
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 is compatible.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on ResultCommander:

Package Downloads
ResultCommander.Autofac

Library featuring a command handler pattern.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2.2.4 164 7/23/2024
2.2.3 258 1/22/2024
2.2.2 254 11/22/2023
2.2.1 155 11/20/2023
2.2.0 150 11/20/2023
2.1.6 210 8/18/2023
2.1.5 202 8/8/2023
2.1.4 202 7/10/2023
2.1.3 187 6/25/2023
2.1.2 201 5/10/2023
2.1.1 218 4/4/2023
2.1.0 264 3/14/2023
2.0.9 273 2/21/2023
2.0.8 327 1/9/2023
2.0.7 293 1/9/2023
2.0.6 393 11/21/2022
2.0.5 340 11/21/2022
2.0.4 357 11/21/2022
2.0.3 362 11/19/2022
2.0.2 341 11/19/2022
2.0.1 336 11/19/2022
2.0.0 332 11/19/2022
1.1.17 429 9/27/2022
1.1.16 413 9/27/2022
1.1.15 452 9/26/2022
1.1.14 450 9/24/2022
1.1.13 408 9/24/2022
1.1.12 453 9/24/2022
1.1.11 437 9/24/2022
1.1.10 442 9/24/2022
1.1.9 440 9/24/2022
1.1.8 424 9/24/2022
1.1.7 423 9/24/2022
1.1.6 427 9/19/2022
1.1.5 440 9/19/2022
1.1.4 428 9/19/2022
1.1.3 430 9/19/2022
1.1.2 427 9/19/2022
1.1.0 455 9/17/2022
1.0.14 427 8/28/2022
1.0.13 421 8/24/2022
1.0.12 422 8/24/2022
1.0.11 418 8/24/2022
1.0.10 410 8/24/2022
1.0.9 416 8/24/2022
1.0.8 421 8/24/2022
1.0.7 418 8/24/2022
1.0.6 423 8/23/2022
1.0.5 413 8/23/2022
1.0.4 422 8/23/2022
1.0.3 421 8/23/2022
1.0.2 417 8/23/2022
1.0.1 430 8/22/2022
1.0.0 413 8/22/2022