Encamina.Enmarcha.Services.Abstractions 8.1.6

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

// Install Encamina.Enmarcha.Services.Abstractions as a Cake Tool
#tool nuget:?package=Encamina.Enmarcha.Services.Abstractions&version=8.1.6

Services - Abstractions

Nuget package

Services Abstractions is a project that provides useful abstractions for your services. It contains classes and interfaces so that you can create an execution context and gather information that you can later consume from your services.

Setup

Nuget package

First, install NuGet. Then, install Encamina.Enmarcha.Services.Abstractions from the package manager console:

PM> Install-Package Encamina.Enmarcha.Services.Abstractions

.NET CLI:

Install .NET CLI. Next, install Encamina.Enmarcha.Services.Abstractions from the .NET CLI:

dotnet add package Encamina.Enmarcha.Services.Abstractions

How to use

ExecutionContext/ExecutionContextTemplate

This is a set of base classes and interfaces that are useful for creating an execution context that aggregates information and can be consumed from any point in your application. This way, the information from the execution context is centralized in a single point.

To illustrate the usage, let's create an execution context that can be used in a Web API. In addition to the basic information, a new field called FooInformation will be added. Some of the constants referenced in the following code block belong to the NuGet package Encamina.Enmarcha.Net.Http.

public interface IApiExecutionContextTemplate : IExecutionContextTemplate
{
    string FooInformation { get; init; }
}

public class ApiExecutionContextTemplate: ExecutionContextTemplate, IApiExecutionContextTemplate
{
    public ApiExecutionContextTemplate(IHttpContextAccessor httpContextAccessor)
    {
        var httpContext = httpContextAccessor.HttpContext;
        CorrelationCallId = httpContext.ReadValueFromRequestHeader(Constants.HttpHeaders.CorrelationCallId, Guid.NewGuid().ToString());
        CorrelationId = httpContext.ReadValueFromRequestHeader(Constants.HttpHeaders.CorrelationId, httpContext.TraceIdentifier);
        CancellationToken = httpContext.RequestAborted;
        CultureInfo = CultureInfo.CurrentCulture;
        FooInformation = "Bar";
    }

    public string FooInformation { get; init; }
}

public interface IApiExecutionContext<T> : IApiExecutionContextTemplate, IExecutionContext<T>
    where T : class
{

}

public class ApiExecutionContext<T> : ExecutionContext<T>, IApiExecutionContext<T> where T : class
{
    public ApiExecutionContext(IApiExecutionContextTemplate template, ILogger<T> logger) : base(template, logger)
    {
        FooInformation = template.FooInformation;
    }

    public string FooInformation { get; init; }
}

In the code above, ApiExecutionContextTemplate is created to contain the required information. Subsequently, this template is received in ApiExecutionContext, which will be the class passed to the controllers.

The next step is, at some point in the Program.cs or a similar entry point file in your project, to add the following code to configure the IoC Container.

var builder = WebApplication.CreateBuilder(new WebApplicationOptions
{
    // ...
});

// ...

builder.Services.AddLogging();

// ...

builder.Services.AddExecutionContext(
    typeof(IApiExecutionContext<>),
    typeof(ApiExecutionContext<>),
    typeof(IApiExecutionContextTemplate),
    typeof(ApiExecutionContextTemplate));

// ...

The AddExecutionContext method is responsible for validating and configuring everything necessary as Scoped. Now, everything is set up to receive the execution context in a controller.

[ApiController]
[Route(@"api/[controller]")]
public class MyCustomController : Controller
{
    private readonly IApiExecutionContext<MyCustomController> executionContext;
    
    public MyCustomController(IApiExecutionContext<MyCustomController> executionContext)
    {
        this.executionContext = executionContext;
    }
   
    [HttpGet("say_hello")]
    [ActionName(nameof(SayHello))]
    [ProducesResponseType(StatusCodes.Status200OK)]
    public async Task<IActionResult> SayHello(CancellationToken cancellationToken)
    {
        // ...

        // Now, we can access executionContext, and we have all the information related to this execution context.
        executionContext.Logger.LogInformation($"Logger from {nameof(SayHello)} method with {executionContext.CorrelationId} and {executionContext.CultureInfo.TwoLetterISOLanguageName}");
        executionContext.Logger.LogInformation($"FooInformation is {executionContext.FooInformation}");
        
        // ...

        return Ok("Hello");
    }
}
Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  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 was computed.  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. 
.NET Core netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.1 is compatible. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

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.7-preview-03 45 5/24/2024
8.1.7-preview-02 75 5/10/2024
8.1.7-preview-01 69 5/8/2024
8.1.6 168 5/7/2024
8.1.6-preview-08 44 5/2/2024
8.1.6-preview-07 69 4/29/2024
8.1.6-preview-06 78 4/26/2024
8.1.6-preview-05 74 4/24/2024
8.1.6-preview-04 60 4/22/2024
8.1.6-preview-03 71 4/22/2024
8.1.6-preview-02 68 4/17/2024
8.1.6-preview-01 150 4/15/2024
8.1.5 80 4/15/2024
8.1.5-preview-15 71 4/10/2024
8.1.5-preview-14 76 3/20/2024
8.1.5-preview-13 62 3/18/2024
8.1.5-preview-12 86 3/13/2024
8.1.5-preview-11 65 3/13/2024
8.1.5-preview-10 64 3/13/2024
8.1.5-preview-09 67 3/12/2024
8.1.5-preview-08 56 3/12/2024
8.1.5-preview-07 57 3/8/2024
8.1.5-preview-06 59 3/8/2024
8.1.5-preview-05 58 3/7/2024
8.1.5-preview-04 54 3/7/2024
8.1.5-preview-03 77 3/7/2024
8.1.5-preview-02 59 2/28/2024
8.1.5-preview-01 67 2/19/2024
8.1.4 127 2/15/2024
8.1.3 94 2/13/2024
8.1.3-preview-07 49 2/13/2024
8.1.3-preview-06 61 2/12/2024
8.1.3-preview-05 75 2/9/2024
8.1.3-preview-04 56 2/8/2024
8.1.3-preview-03 64 2/7/2024
8.1.3-preview-02 58 2/2/2024
8.1.3-preview-01 65 2/2/2024
8.1.2 81 2/1/2024
8.1.2-preview-9 74 1/22/2024
8.1.2-preview-8 63 1/19/2024
8.1.2-preview-7 62 1/19/2024
8.1.2-preview-6 63 1/19/2024
8.1.2-preview-5 62 1/19/2024
8.1.2-preview-4 68 1/19/2024
8.1.2-preview-3 62 1/18/2024
8.1.2-preview-2 64 1/18/2024
8.1.2-preview-16 54 1/31/2024
8.1.2-preview-15 55 1/31/2024
8.1.2-preview-14 53 1/25/2024
8.1.2-preview-13 66 1/25/2024
8.1.2-preview-12 66 1/23/2024
8.1.2-preview-11 65 1/23/2024
8.1.2-preview-10 62 1/22/2024
8.1.2-preview-1 55 1/18/2024
8.1.1 88 1/18/2024
8.1.0 78 1/18/2024
8.0.3 124 12/29/2023
8.0.1 88 12/14/2023
8.0.0 108 12/7/2023
6.0.4.3 83 12/29/2023
6.0.4.2 79 12/20/2023
6.0.4.1 162 12/19/2023
6.0.4 96 12/4/2023
6.0.3.20 99 11/27/2023
6.0.3.19 96 11/22/2023