CodeRoom.Utils.DependencyInjection 8.0.0.3

There is a newer version of this package available.
See the version list below for details.
dotnet add package CodeRoom.Utils.DependencyInjection --version 8.0.0.3
                    
NuGet\Install-Package CodeRoom.Utils.DependencyInjection -Version 8.0.0.3
                    
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="CodeRoom.Utils.DependencyInjection" Version="8.0.0.3" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="CodeRoom.Utils.DependencyInjection" Version="8.0.0.3" />
                    
Directory.Packages.props
<PackageReference Include="CodeRoom.Utils.DependencyInjection" />
                    
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 CodeRoom.Utils.DependencyInjection --version 8.0.0.3
                    
#r "nuget: CodeRoom.Utils.DependencyInjection, 8.0.0.3"
                    
#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.
#:package CodeRoom.Utils.DependencyInjection@8.0.0.3
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=CodeRoom.Utils.DependencyInjection&version=8.0.0.3
                    
Install as a Cake Addin
#tool nuget:?package=CodeRoom.Utils.DependencyInjection&version=8.0.0.3
                    
Install as a Cake Tool

CodeRoom.Utilities.DependencyInjection

Static Badge Nuget GitHub License GitHub repo size built with Codeium


Sumário


Mediatr

public static class MediatorInjection
{
    public static void AddMediator(this IServiceCollection services)
    {
        services.AddMediatR(mediator =>
        {
            mediator
                .RegisterServicesFromAssemblies(
                    AppDomain.CurrentDomain.GetAssemblies()
                );

            mediator.AddOpenBehavior(typeof(MediatorLoggingPipelineBehavior<,>));
        });
    }
}

Log

  • Serilog.

Para adicionar o serviço de log.

Appsettings:

{
  "Logging": {
    "LogLevel": {
      "Default": "Information",
      "Microsoft.AspNetCore": "Warning"
    }
  }
}

Injeção de Dependência

  • Método
// Program.cs
builder.Host.UseLogService();
  • Código:

    public static void UseLogService(
        this IServiceCollection services,
        ConfigureHostBuilder host
    )
    {
        var options = services
            .BuildServiceProvider()
            .GetRequiredService<IOptions<LoggingOptions>>()
            .Value;

        host.UseSerilog((_, loggerConfig) =>
        {
            loggerConfig
                .Enrich.FromLogContext()
                .MinimumLevel.Is(options.LogLevel)
                .WriteTo.Console();
        });
    }

Request Middleware

  • Método:
// ApiBootstrap.cs
public static void ConfigureApi(this IApplicationBuilder app)
{
    app.UseLogService();
}
  • Código:
public static void UseLogService(this IApplicationBuilder app)
{
    app.UseMiddleware<RequestLogMiddleware>();
    app.UseSerilogRequestLogging();
}

Validação

Suprimir validação padrão do ASP.NET

  • Método:
// ApiBootstrap.cs
services.SuppressDefaultFilterValidation();
  • Código:
public static class ServiceExtension
{
    public static void SuppressDefaultFilterValidation(
        this IServiceCollection services
    )
    {
        services.Configure<ApiBehaviorOptions>(options =>
            options.SuppressModelStateInvalidFilter = true
        );
    }
}

Injetando a validação

  • Método
// ApiBootstrap.cs
services.AddControllers(mvcOptions =>
{
    mvcOptions.AddCodeRoomValidation();
});
  • Código
public static class ValidationInjection
{
    public static void AddCodeRoomValidation(this MvcOptions options)
    {
        options.Filters.Add(item: new ValidateModelAttribute());
        options.Filters.Add(item: new HttpApplicationExceptionFilter());
    }
}

Variáveis de Ambiente

  • App Settings
// Program.cs
builder.Environment.AddEnvironment(builder.Configuration);
  • Todas as variáveis de ambiente da lib.
public static class OptionsInjection
{
    public static void AddUtilityOptions(this IServiceCollection services)
    {
        services.AddLogOptions();
    }
}
  • Apenas log.
public static class LogOptionsInjection
{
    public static void AddLogOptions(this IServiceCollection services)
    {
        services.AddOptions<LoggingOptions>()
            .BindConfiguration(LoggingOptions.Section)
            .ValidateDataAnnotations()
            .ValidateOnStart();
    }
}
Product Compatible and additional computed target framework versions.
.NET 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.  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.  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

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.0 128 5/11/2024
8.0.0.3 114 5/10/2024