MadEyeMatt.Results.AspNetCore
2.0.2
See the version list below for details.
dotnet add package MadEyeMatt.Results.AspNetCore --version 2.0.2
NuGet\Install-Package MadEyeMatt.Results.AspNetCore -Version 2.0.2
<PackageReference Include="MadEyeMatt.Results.AspNetCore" Version="2.0.2" />
paket add MadEyeMatt.Results.AspNetCore --version 2.0.2
#r "nuget: MadEyeMatt.Results.AspNetCore, 2.0.2"
// Install MadEyeMatt.Results.AspNetCore as a Cake Addin #addin nuget:?package=MadEyeMatt.Results.AspNetCore&version=2.0.2 // Install MadEyeMatt.Results.AspNetCore as a Cake Tool #tool nuget:?package=MadEyeMatt.Results.AspNetCore&version=2.0.2
Results
A result object implementation. Return result objects from operations to indicate success or failure instead of throwing exceptions.
Features
- Default result implementations with and without a result value.
Result
Result<int>
- Supports multiple error messages.
- Supports optional multiple success messages.
- Supports custom error and success implementations.
- Provides FluentAssertions extensions for simpler unit testing.
- Provides extensions to transform results to
IActionResult
instances for ASP.NET controllers. - Provides extensions to transform results to
IResult
instances to be used with Minimal APIs.
Usage
Create Results
To create result instances use the static helper methods found in the Result
class.
// Create a successful result without a value.
Result result = Result.Ok();
// Create a successful result with a value.
Result<int> result = Result.Ok(42);
// Create a failed result without a value.
Result result = Result.Fail("An error occurred.");
Result result = Result.Fail(new Error("An error occurred));
// Create a failed result for a result that can have a value.
Result<int> result = Result.Fail<int>("An error occurred.");
Result<int> result = Result.Fail<int>(new Error("An error occurred));
The result type Result
is typically used by operations that have no return value.
public Result PerformOperation()
{
if(this.State == State.Failed)
{
return Result.Fail("The operation failed.");
}
return Result.Ok();
}
The result type Result<T>
is typically used by operations that have a return value.
public Result<int> PerformOperation()
{
if(this.State == State.Failed)
{
return Result.Fail<int>("The operation failed.");
}
return Result.Ok(42);
}
Process Results
To process the result of an operation you can check if the operation was
successful or failed by accessing the IsSuccessful
or IsFailed
properties.
// Handle the return value of a result without a value.
Result result = PerformOperation();
// Print all error messages, if the result is failed.
if(result.IsFailed)
{
foreach(IError error in result.Errors)
{
Console.WriteLine(error.Message);
}
}
// Print all success messages, if the result is successful.
if(result.IsSuccessful)
{
foreach(ISuccess success in result.Successes)
{
Console.WriteLine(success.Message);
}
}
// Handle the return value of a result with a value.
Result<int> result = PerformOperation();
// Get the value if the result is successful or will throw if the result is failed.
int value = result.Value;
// Get the value oif the result is successful or will return the default of the value.
int value = result.GetValueOrDefault();
References
Product | Versions 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 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. |
-
net6.0
- MadEyeMatt.Results (>= 2.0.2)
-
net7.0
- MadEyeMatt.Results (>= 2.0.2)
-
net8.0
- MadEyeMatt.Results (>= 2.0.2)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.