BridgingIT.DevKit.Common.Abstractions 9.0.2-preview.46

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

bITDevKit

Empowering developers with modular components for modern application development, centered around Domain-Driven Design principles.

Our goal is to empower developers by offering modular components that can be easily integrated into your projects. Whether you're working with repositories, commands, queries, or other components, the bITDevKit provides flexible solutions that can adapt to your specific needs.

This repository includes the complete source code for the bITDevKit, along with a variety of sample applications located in the ./examples folder within the solution. These samples serve as practical demonstrations of how to leverage the capabilities of the bITDevKit in real-world scenarios. All components are available as nuget packages.

For the latest updates and release notes, please refer to the RELEASES.

Join us in advancing the world of software development with the bITDevKit!


Result.cs Overview

The Result class encapsulates the outcome of an operation, promoting an expressive and error-tolerant way to handle success and failure states.

The Result class is a central component designed to encapsulate the outcome of an operation, providing a way to represent both successful and failed operations. This class promotes a more expressive and error-tolerant approach to handling operation results, encouraging the explicit declaration of success or failure states.

Returning a Result

To return a Result from a method, you typically define the method to return Result or Result<T>, where T is the type of the value returned in case of success. Here is an example method returning a Result:

public Result PerformOperation()
{
    // Your logic here
    
    if (success)
    {
        return Result.Success();
    }
    else
    {
        return Result.Failure(new Error("Operation Failed"));
    }
}

Handling a Result

When you receive a Result from a method, you can handle it by checking its success or failure state. Here's an example:

var result = PerformOperation();

if (result.IsSuccess)
{
    // Handle success
}
else
{
    // Handle failure
    var error = result.Error;
    Console.WriteLine(error.Message);
}

Using Typed Results

Sometimes, you may want to return a result with a value. This is where Result<T> comes in handy:

public Result<int> CalculateSum(int a, int b)
{
    if (a < 0 || b < 0)
    {
        return Result.Failure<int>(new Error("Inputs must be non-negative"));
    }

    return Result.Success(a + b);
}

Handling a Result<T> involves extracting the value if the operation was successful:

var result = CalculateSum(5, 10);

if (result.IsSuccess)
{
    int sum = result.Value;
    Console.WriteLine($"Sum: {sum}");
}
else
{
    Console.WriteLine(result.Error.Message);
}

Typed Errors

Typed errors provide a more specific and structured way to handle different error scenarios. For example, the EntityNotFoundResultError class can be used to represent an error where an entity is not found:

EntityNotFoundResultError.cs:
public class EntityNotFoundResultError : Error
{
    public EntityNotFoundResultError(string entityName, object key)
        : base($"Entity '{entityName}' with key '{key}' was not found.")
    {
    }
}

You can return this typed error as follows:

public Result GetEntity(int id)
{
    var entity = repository.FindById(id);

    if (entity == null)
    {
        return Result.Failure(new EntityNotFoundResultError("EntityName", id));
    }

    return Result.Success(entity);
}

When handling the result, you can check if the error is of a specific type:

var result = GetEntity(1);

if (result.IsSuccess)
{
    // Handle success
}
else if (result.Error is EntityNotFoundResultError)
{
    var error = (EntityNotFoundResultError)result.Error;
    Console.WriteLine(error.Message);
}
else
{
    // Handle other errors
}

Other available typed errors are:

By using typed errors, you can create more expressive and manageable error handling in your application.

Product Compatible and additional computed target framework versions.
.NET net9.0 is compatible.  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 (14)

Showing the top 5 NuGet packages that depend on BridgingIT.DevKit.Common.Abstractions:

Package Downloads
BridgingIT.DevKit.Common.Utilities

BridgingIT DevKit: Empowering developers with modular components for modern application development, centered around Domain-Driven Design principles. Our goal is to empower developers by offering modular components that can be easily integrated into your projects. Whether you're working with repositories, commands, queries, or other components, the bITDevKit provides flexible solutions that can adapt to your specific needs.

BridgingIT.DevKit.Common.Serialization

BridgingIT DevKit: Empowering developers with modular components for modern application development, centered around Domain-Driven Design principles. Our goal is to empower developers by offering modular components that can be easily integrated into your projects. Whether you're working with repositories, commands, queries, or other components, the bITDevKit provides flexible solutions that can adapt to your specific needs.

BridgingIT.DevKit.Domain

BridgingIT DevKit: Empowering developers with modular components for modern application development, centered around Domain-Driven Design principles. Our goal is to empower developers by offering modular components that can be easily integrated into your projects. Whether you're working with repositories, commands, queries, or other components, the bITDevKit provides flexible solutions that can adapt to your specific needs.

BridgingIT.DevKit.Application.Storage

BridgingIT DevKit: Empowering developers with modular components for modern application development, centered around Domain-Driven Design principles. Our goal is to empower developers by offering modular components that can be easily integrated into your projects. Whether you're working with repositories, commands, queries, or other components, the bITDevKit provides flexible solutions that can adapt to your specific needs.

BridgingIT.DevKit.Application.Messaging

BridgingIT DevKit: Empowering developers with modular components for modern application development, centered around Domain-Driven Design principles. Our goal is to empower developers by offering modular components that can be easily integrated into your projects. Whether you're working with repositories, commands, queries, or other components, the bITDevKit provides flexible solutions that can adapt to your specific needs.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
9.0.3 118 7/4/2025
9.0.3-preview.0.1 113 7/3/2025
9.0.2 239 7/2/2025
9.0.2-preview.55 122 7/1/2025
9.0.2-preview.54 147 6/26/2025
9.0.2-preview.53 113 6/26/2025
9.0.2-preview.51 111 6/26/2025
9.0.2-preview.50 111 6/26/2025
9.0.2-preview.49 128 6/25/2025
9.0.2-preview.47 124 6/25/2025
9.0.2-preview.46 109 6/25/2025
9.0.2-preview.45 125 6/25/2025
9.0.2-preview.44 155 6/25/2025
9.0.2-preview.43 146 6/24/2025
9.0.2-preview.42 140 6/24/2025
9.0.2-preview.41 125 6/23/2025
9.0.2-preview.39 44 6/21/2025
9.0.2-preview.38 75 6/20/2025
9.0.2-preview.37 89 6/20/2025
9.0.2-preview.36 113 6/17/2025
9.0.2-preview.35 126 6/14/2025
9.0.2-preview.34 255 6/12/2025
9.0.2-preview.33 258 6/11/2025
9.0.2-preview.32 271 6/11/2025
9.0.2-preview.31 257 6/11/2025
9.0.2-preview.28 260 6/11/2025
9.0.2-preview.25 254 6/11/2025
9.0.2-preview.24 260 6/11/2025
9.0.2-preview.23 257 6/11/2025
9.0.2-preview.22 255 6/11/2025
9.0.2-preview.21 281 6/10/2025
9.0.2-preview.20 262 6/10/2025
9.0.2-preview.19 255 6/10/2025
9.0.2-preview.18 257 6/9/2025
9.0.2-preview.16 211 6/9/2025
9.0.2-preview.14 43 6/7/2025
9.0.2-preview.13 43 6/6/2025
9.0.2-preview.12 43 6/6/2025
9.0.2-preview.5 62 6/6/2025
9.0.2-preview.3 126 6/4/2025
9.0.2-preview.2 121 6/4/2025
9.0.2-preview.1 112 6/4/2025
9.0.1-preview.0.335 216 6/2/2025
9.0.1-preview.0.333 124 6/2/2025
9.0.1-preview.0.332 116 6/1/2025
9.0.1-preview.0.331 116 6/1/2025
9.0.1-preview.0.329 40 5/30/2025
9.0.1-preview.0.326 52 5/30/2025
9.0.1-preview.0.324 41 5/30/2025
9.0.1-preview.0.323 46 5/30/2025
9.0.1-preview.0.321 68 5/30/2025
9.0.1-preview.0.319 50 5/30/2025
9.0.1-preview.0.318 62 5/30/2025
9.0.1-preview.0.317 68 5/30/2025
9.0.1-preview.0.316 72 5/30/2025
9.0.1-preview.0.315 91 5/30/2025
9.0.1-preview.0.314 75 5/30/2025
9.0.1-preview.0.312 79 5/30/2025
9.0.1-preview.0.309 115 5/28/2025
9.0.1-preview.0.302 116 5/21/2025
9.0.1-preview.0.301 155 5/21/2025
9.0.1-preview.0.300 117 5/21/2025
9.0.1-preview.0.299 123 5/21/2025
9.0.1-preview.0.297 172 5/21/2025
9.0.1-preview.0.296 126 6/4/2025
9.0.1-preview.0.295 113 5/21/2025
9.0.1-preview.0.294 119 5/21/2025
9.0.1-preview.0.293 114 5/21/2025
9.0.1-preview.0.290 122 5/19/2025
9.0.1-preview.0.287 131 5/19/2025
9.0.1-preview.0.286 216 5/15/2025
9.0.1-preview.0.285 207 5/13/2025
9.0.1-preview.0.279 198 5/13/2025
9.0.1-preview.0.278 210 5/13/2025
9.0.1-preview.0.277 206 5/13/2025
9.0.1-preview.0.276 261 5/13/2025
9.0.1-preview.0.274 123 5/19/2025
9.0.1-preview.0.272 108 5/11/2025
9.0.1-preview.0.271 107 5/11/2025
9.0.1-preview.0.270 88 5/9/2025
9.0.1-preview.0.267 114 5/7/2025
9.0.1-preview.0.266 114 5/7/2025
9.0.1-preview.0.265 121 5/6/2025
9.0.1-preview.0.264 167 5/6/2025
9.0.1-preview.0.263 118 5/6/2025
9.0.1-preview.0.262 121 5/6/2025
9.0.1-preview.0.261 124 5/6/2025
9.0.1-preview.0.258 475 5/6/2025
9.0.1-preview.0.255 87 5/9/2025
9.0.1-preview.0.254 123 5/8/2025
9.0.1-preview.0.253 116 5/8/2025
9.0.1-preview.0.252 119 5/8/2025
9.0.1-preview.0.251 116 5/8/2025
9.0.1-preview.0.250 126 5/7/2025
9.0.1-preview.0.247 133 5/7/2025
9.0.1-preview.0.246 116 5/7/2025
9.0.1-preview.0.244 153 4/17/2025
9.0.1-preview.0.243 228 4/15/2025
9.0.1-preview.0.242 158 4/15/2025
9.0.1-preview.0.241 155 4/15/2025
9.0.1-preview.0.239 155 4/15/2025
9.0.1-preview.0.238 257 4/15/2025
9.0.1-preview.0.237 214 4/13/2025
9.0.1-preview.0.236 151 4/10/2025
9.0.1-preview.0.235 132 4/10/2025
9.0.1-preview.0.234 144 4/10/2025
9.0.1-preview.0.233 167 4/9/2025
9.0.1-preview.0.232 130 4/9/2025
9.0.1-preview.0.231 127 4/9/2025
9.0.1-preview.0.230 183 4/7/2025
9.0.1-preview.0.229 142 4/7/2025
9.0.1-preview.0.228 146 4/7/2025
9.0.1-preview.0.227 137 4/4/2025
9.0.1-preview.0.226 132 4/3/2025
9.0.1-preview.0.220 168 4/2/2025
9.0.1-preview.0.219 121 4/1/2025
9.0.1-preview.0.218 120 4/1/2025
9.0.1-preview.0.217 184 4/1/2025
9.0.1-preview.0.215 146 4/1/2025
9.0.1-preview.0.214 126 4/1/2025
9.0.1-preview.0.213 146 4/1/2025
9.0.1-preview.0.212 153 4/1/2025
9.0.1-preview.0.211 125 4/1/2025
9.0.1-preview.0.210 130 4/1/2025
9.0.1-preview.0.209 143 3/31/2025
9.0.1-preview.0.208 146 3/31/2025
9.0.1-preview.0.206 128 3/31/2025
9.0.1-preview.0.205 137 3/31/2025
9.0.1-preview.0.204 134 3/31/2025
9.0.1-preview.0.202 126 3/31/2025
9.0.1-preview.0.199 63 3/29/2025
9.0.1-preview.0.198 102 3/28/2025
9.0.1-preview.0.196 108 3/28/2025
9.0.1-preview.0.193 101 3/27/2025
9.0.1-preview.0.189 126 3/26/2025
9.0.1-preview.0.188 455 3/25/2025
9.0.1-preview.0.187 465 3/24/2025
9.0.1-preview.0.186 452 3/24/2025
9.0.1-preview.0.185 453 3/24/2025
9.0.1-preview.0.184 456 3/24/2025
9.0.1-preview.0.183 452 3/24/2025
9.0.1-preview.0.182 62 3/21/2025
9.0.1-preview.0.180 113 3/21/2025
9.0.1-preview.0.179 122 3/21/2025
9.0.1-preview.0.178 119 3/21/2025
9.0.1-preview.0.175 121 3/20/2025
9.0.1-preview.0.174 121 3/19/2025
9.0.1-preview.0.173 136 3/19/2025
9.0.1-preview.0.172 284 3/19/2025
9.0.1-preview.0.171 119 3/19/2025
9.0.1-preview.0.170 119 3/18/2025
9.0.1-preview.0.165 118 3/18/2025
9.0.1-preview.0.162 128 3/17/2025
9.0.1-preview.0.160 121 3/17/2025
9.0.1-preview.0.152 101 3/14/2025
9.0.1-preview.0.148 142 3/13/2025
9.0.1-preview.0.147 123 3/13/2025
9.0.1-preview.0.146 125 3/12/2025
9.0.1-preview.0.145 132 3/12/2025
9.0.1-preview.0.141 129 3/12/2025
9.0.1-preview.0.140 170 3/10/2025
9.0.1-preview.0.139 127 3/10/2025
9.0.1-preview.0.138 142 3/10/2025
9.0.1-preview.0.137 120 3/8/2025
9.0.1-preview.0.135 137 3/8/2025
9.0.1-preview.0.134 176 3/7/2025
9.0.1-preview.0.133 171 3/6/2025
9.0.1-preview.0.132 166 3/6/2025
9.0.1-preview.0.130 165 3/6/2025
9.0.1-preview.0.129 219 3/6/2025
9.0.1-preview.0.128 171 3/6/2025
9.0.1-preview.0.127 177 3/6/2025
9.0.1-preview.0.125 185 3/4/2025
9.0.1-preview.0.119 80 2/28/2025
9.0.1-preview.0.118 62 2/28/2025
9.0.1-preview.0.116 68 2/28/2025
9.0.1-preview.0.112 58 2/27/2025
9.0.1-preview.0.111 66 2/27/2025
9.0.1-preview.0.110 115 2/26/2025
9.0.1-preview.0.107 80 2/26/2025
9.0.1-preview.0.106 71 2/26/2025
9.0.1-preview.0.105 67 2/26/2025
9.0.1-preview.0.104 73 2/26/2025
9.0.1-preview.0.103 92 2/26/2025
9.0.1-preview.0.102 89 2/26/2025
9.0.1-preview.0.100 58 2/26/2025
9.0.1-preview.0.99 100 2/25/2025
9.0.1-preview.0.97 69 2/25/2025
9.0.1-preview.0.96 63 2/25/2025
9.0.1-preview.0.94 65 2/24/2025
9.0.1-preview.0.93 94 2/24/2025
9.0.1-preview.0.92 65 2/21/2025
9.0.1-preview.0.91 57 2/21/2025
9.0.1-preview.0.88 64 2/19/2025
9.0.1-preview.0.87 248 2/18/2025
9.0.1-preview.0.85 267 2/18/2025
9.0.1-preview.0.84 206 2/17/2025
9.0.1-preview.0.82 166 2/17/2025
9.0.1-preview.0.79 174 2/14/2025
9.0.1-preview.0.78 194 2/14/2025
9.0.1-preview.0.77 169 2/14/2025
9.0.1-preview.0.76 206 2/14/2025
9.0.1-preview.0.73 198 2/14/2025
9.0.1-preview.0.71 143 2/14/2025
9.0.1-preview.0.70 189 2/13/2025
9.0.1-preview.0.69 181 2/13/2025
9.0.1-preview.0.67 188 2/13/2025
9.0.1-preview.0.62 172 2/11/2025
9.0.1-preview.0.58 80 2/7/2025
9.0.1-preview.0.56 72 2/7/2025
9.0.1-preview.0.55 58 2/6/2025
9.0.1-preview.0.54 62 2/6/2025
9.0.1-preview.0.53 56 2/6/2025
9.0.1-preview.0.52 60 2/6/2025
9.0.1-preview.0.50 76 2/6/2025
9.0.1-preview.0.49 119 2/6/2025
9.0.1-preview.0.47 59 2/6/2025
9.0.1-preview.0.45 65 2/6/2025
9.0.1-preview.0.43 67 2/5/2025
9.0.1-preview.0.42 64 2/5/2025
9.0.1-preview.0.41 67 2/5/2025
9.0.1-preview.0.35 67 2/4/2025
9.0.1-preview.0.20 64 1/30/2025
9.0.1-preview.0.19 57 1/30/2025
9.0.1-preview.0.18 61 1/30/2025
9.0.1-preview.0.14 60 1/30/2025
9.0.1-preview.0.13 68 1/30/2025
9.0.1-preview.0.11 56 1/29/2025
9.0.1-preview.0.10 54 1/29/2025
9.0.1-preview.0.9 60 1/27/2025
9.0.1-preview.0.2 117 1/27/2025
3.0.5-preview.0.2 130 4/1/2025
3.0.5-preview.0.1 81 2/11/2025
3.0.4 504 1/25/2025
3.0.4-preview.0.38 69 1/25/2025
3.0.4-preview.0.37 107 12/6/2024
3.0.4-preview.0.36 200 12/5/2024
3.0.4-preview.0.34 71 12/5/2024
3.0.4-preview.0.32 71 12/4/2024
3.0.4-preview.0.31 88 11/25/2024
3.0.4-preview.0.30 68 11/25/2024
3.0.4-preview.0.29 61 11/21/2024
3.0.4-preview.0.28 120 11/19/2024
3.0.4-preview.0.27 63 11/19/2024
3.0.4-preview.0.23 64 11/19/2024
3.0.4-preview.0.21 55 11/19/2024
3.0.4-preview.0.20 60 11/18/2024
3.0.4-preview.0.19 70 11/18/2024
3.0.4-preview.0.18 56 11/18/2024
3.0.4-preview.0.17 58 11/18/2024
3.0.4-preview.0.16 63 11/15/2024
3.0.4-preview.0.15 58 11/15/2024
3.0.4-preview.0.14 77 11/2/2024
3.0.4-preview.0.13 72 10/29/2024
3.0.4-preview.0.12 64 10/29/2024
3.0.4-preview.0.8 70 10/29/2024
3.0.4-preview.0.7 71 10/29/2024
3.0.4-preview.0.6 62 10/24/2024
3.0.4-preview.0.5 69 10/23/2024
3.0.4-preview.0.4 61 10/23/2024
3.0.4-preview.0.3 62 10/23/2024
3.0.4-preview.0.2 67 10/23/2024
3.0.4-preview.0.1 203 10/16/2024
3.0.3 391 10/11/2024
3.0.3-preview.0.56 78 10/10/2024
3.0.3-preview.0.55 71 10/10/2024
3.0.3-preview.0.54 76 10/10/2024
3.0.3-preview.0.50 72 10/10/2024
3.0.3-preview.0.49 88 10/9/2024
3.0.3-preview.0.44 93 10/8/2024
3.0.3-preview.0.43 69 10/8/2024
3.0.3-preview.0.42 70 10/7/2024
3.0.3-preview.0.41 72 10/7/2024
3.0.3-preview.0.40 105 10/1/2024
3.0.3-preview.0.39 73 10/1/2024
3.0.3-preview.0.38 69 10/1/2024
3.0.3-preview.0.36 74 9/30/2024
3.0.3-preview.0.35 89 9/26/2024
3.0.3-preview.0.34 82 9/26/2024
3.0.3-preview.0.33 70 9/26/2024
3.0.3-preview.0.32 100 9/24/2024
3.0.3-preview.0.31 760 9/10/2024
3.0.3-preview.0.30 68 9/9/2024
3.0.3-preview.0.29 64 9/9/2024
3.0.3-preview.0.28 55 9/8/2024
3.0.3-preview.0.27 77 9/5/2024
3.0.3-preview.0.26 75 9/3/2024
3.0.3-preview.0.25 65 9/3/2024
3.0.3-preview.0.24 79 9/3/2024
3.0.3-preview.0.23 89 8/21/2024
3.0.3-preview.0.22 59 7/29/2024
3.0.3-preview.0.21 77 7/25/2024
3.0.3-preview.0.18 78 7/12/2024
3.0.3-preview.0.17 73 7/12/2024
3.0.3-preview.0.16 61 7/12/2024
3.0.3-preview.0.15 65 7/5/2024
3.0.3-preview.0.14 131 6/24/2024
3.0.3-preview.0.13 93 6/23/2024
3.0.3-preview.0.12 85 6/21/2024
3.0.3-preview.0.11 84 6/20/2024
3.0.3-preview.0.9 366 5/27/2024
3.0.3-preview.0.8 76 5/27/2024
3.0.3-preview.0.7 105 5/17/2024
3.0.3-preview.0.6 80 5/14/2024
3.0.3-preview.0.5 309 5/8/2024
3.0.3-preview.0.3 102 5/6/2024
3.0.3-preview.0.1 91 4/25/2024
3.0.2 1,338 4/25/2024
3.0.2-preview.0.4 99 4/25/2024
3.0.2-preview.0.3 153 4/25/2024
3.0.2-preview.0.2 102 4/25/2024
3.0.2-preview.0.1 78 4/25/2024
3.0.1 441 4/25/2024
3.0.1-preview.0.10 87 4/24/2024
3.0.1-preview.0.9 190 4/19/2024
3.0.1-preview.0.8 72 4/24/2024
3.0.1-preview.0.7 140 4/24/2024

## Release 3.0.1 [25.04.24]

- [N] Initial release

-----

- [N] New
- [M] Modified
- [B] Breaking