feat: add SerilogRegistrar and ContextualSerilogLogger
- IContextualSerilogLogger<T> / ContextualSerilogLogger<T> in Services/Logging (handlers get a ForContext<T>-scoped logger via DI, consistent with ItemTracker) - SerilogRegistrar extension on WebApplicationBuilder (Api) - SerilogRegistrar extension on HostApplicationBuilder (Worker) - Both registrars: set Log.Logger, wire Logging + Host/Services, register ILogger singleton - ServiceCollectionExtensions: register IContextualSerilogLogger<> as transient - Program.cs in both apps simplified to single builder.AddSerilog() call Ref: IT-628 Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
This commit is contained in:
@@ -19,6 +19,7 @@
|
|||||||
<PackageVersion Include="Microsoft.AspNetCore.OpenApi" Version="10.0.6" />
|
<PackageVersion Include="Microsoft.AspNetCore.OpenApi" Version="10.0.6" />
|
||||||
|
|
||||||
<!-- Serilog -->
|
<!-- Serilog -->
|
||||||
|
<PackageVersion Include="Serilog" Version="4.2.0" />
|
||||||
<PackageVersion Include="Serilog.AspNetCore" Version="9.0.0" />
|
<PackageVersion Include="Serilog.AspNetCore" Version="9.0.0" />
|
||||||
<PackageVersion Include="Serilog.Extensions.Hosting" Version="9.0.0" />
|
<PackageVersion Include="Serilog.Extensions.Hosting" Version="9.0.0" />
|
||||||
<PackageVersion Include="Serilog.Settings.Configuration" Version="9.0.0" />
|
<PackageVersion Include="Serilog.Settings.Configuration" Version="9.0.0" />
|
||||||
|
|||||||
@@ -1,12 +1,10 @@
|
|||||||
using HrynCo.NotificationService.Api;
|
using HrynCo.NotificationService.Api;
|
||||||
using HrynCo.NotificationService.DAL.EF;
|
using HrynCo.NotificationService.DAL.EF;
|
||||||
using HrynCo.NotificationService.Services;
|
using HrynCo.NotificationService.Services;
|
||||||
using Serilog;
|
|
||||||
|
|
||||||
var builder = WebApplication.CreateBuilder(args);
|
var builder = WebApplication.CreateBuilder(args);
|
||||||
|
|
||||||
builder.Host.UseSerilog((context, lc) =>
|
builder.AddSerilog();
|
||||||
lc.ReadFrom.Configuration(context.Configuration));
|
|
||||||
|
|
||||||
var appSettings = builder.Configuration
|
var appSettings = builder.Configuration
|
||||||
.GetSection(AppSettings.SectionName)
|
.GetSection(AppSettings.SectionName)
|
||||||
|
|||||||
@@ -0,0 +1,20 @@
|
|||||||
|
using Serilog;
|
||||||
|
|
||||||
|
namespace HrynCo.NotificationService.Api;
|
||||||
|
|
||||||
|
public static class SerilogRegistrar
|
||||||
|
{
|
||||||
|
public static void AddSerilog(this WebApplicationBuilder builder)
|
||||||
|
{
|
||||||
|
var loggerConfiguration = new LoggerConfiguration()
|
||||||
|
.ReadFrom.Configuration(builder.Configuration)
|
||||||
|
.Enrich.FromLogContext();
|
||||||
|
|
||||||
|
Log.Logger = loggerConfiguration.CreateLogger();
|
||||||
|
|
||||||
|
builder.Logging.AddSerilog(Log.Logger);
|
||||||
|
builder.Host.UseSerilog();
|
||||||
|
|
||||||
|
builder.Services.AddSingleton(Log.Logger);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -3,6 +3,7 @@
|
|||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<PackageReference Include="MediatR" />
|
<PackageReference Include="MediatR" />
|
||||||
<PackageReference Include="Microsoft.Extensions.Logging.Abstractions" />
|
<PackageReference Include="Microsoft.Extensions.Logging.Abstractions" />
|
||||||
|
<PackageReference Include="Serilog" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
|||||||
@@ -0,0 +1,8 @@
|
|||||||
|
using Serilog;
|
||||||
|
|
||||||
|
namespace HrynCo.NotificationService.Services.Logging;
|
||||||
|
|
||||||
|
public sealed class ContextualSerilogLogger<TContext> : IContextualSerilogLogger<TContext>
|
||||||
|
{
|
||||||
|
public ILogger Logger { get; } = Log.ForContext<TContext>();
|
||||||
|
}
|
||||||
@@ -0,0 +1,11 @@
|
|||||||
|
using System.Diagnostics.CodeAnalysis;
|
||||||
|
using Serilog;
|
||||||
|
|
||||||
|
namespace HrynCo.NotificationService.Services.Logging;
|
||||||
|
|
||||||
|
[SuppressMessage("Major Code Smell", "S2326:Unused type parameters should be removed",
|
||||||
|
Justification = "Generic parameter used in implementation via ForContext<T>.")]
|
||||||
|
public interface IContextualSerilogLogger<TContext>
|
||||||
|
{
|
||||||
|
ILogger Logger { get; }
|
||||||
|
}
|
||||||
@@ -1,4 +1,5 @@
|
|||||||
using HrynCo.NotificationService.Services.Behaviors;
|
using HrynCo.NotificationService.Services.Behaviors;
|
||||||
|
using HrynCo.NotificationService.Services.Logging;
|
||||||
using MediatR;
|
using MediatR;
|
||||||
using Microsoft.Extensions.DependencyInjection;
|
using Microsoft.Extensions.DependencyInjection;
|
||||||
|
|
||||||
@@ -14,6 +15,8 @@ public static class ServiceCollectionExtensions
|
|||||||
cfg.AddBehavior(typeof(IPipelineBehavior<,>), typeof(TransactionBehavior<,>));
|
cfg.AddBehavior(typeof(IPipelineBehavior<,>), typeof(TransactionBehavior<,>));
|
||||||
});
|
});
|
||||||
|
|
||||||
|
services.AddTransient(typeof(IContextualSerilogLogger<>), typeof(ContextualSerilogLogger<>));
|
||||||
|
|
||||||
return services;
|
return services;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,12 +1,10 @@
|
|||||||
using HrynCo.NotificationService.DAL.EF;
|
using HrynCo.NotificationService.DAL.EF;
|
||||||
using HrynCo.NotificationService.Services;
|
using HrynCo.NotificationService.Services;
|
||||||
using HrynCo.NotificationService.Worker;
|
using HrynCo.NotificationService.Worker;
|
||||||
using Serilog;
|
|
||||||
|
|
||||||
var builder = Host.CreateApplicationBuilder(args);
|
var builder = Host.CreateApplicationBuilder(args);
|
||||||
|
|
||||||
builder.Services.AddSerilog(lc =>
|
builder.AddSerilog();
|
||||||
lc.ReadFrom.Configuration(builder.Configuration));
|
|
||||||
|
|
||||||
var appSettings = builder.Configuration
|
var appSettings = builder.Configuration
|
||||||
.GetSection(AppSettings.SectionName)
|
.GetSection(AppSettings.SectionName)
|
||||||
|
|||||||
@@ -0,0 +1,21 @@
|
|||||||
|
using Microsoft.Extensions.Logging;
|
||||||
|
using Serilog;
|
||||||
|
|
||||||
|
namespace HrynCo.NotificationService.Worker;
|
||||||
|
|
||||||
|
public static class SerilogRegistrar
|
||||||
|
{
|
||||||
|
public static void AddSerilog(this HostApplicationBuilder builder)
|
||||||
|
{
|
||||||
|
var loggerConfiguration = new LoggerConfiguration()
|
||||||
|
.ReadFrom.Configuration(builder.Configuration)
|
||||||
|
.Enrich.FromLogContext();
|
||||||
|
|
||||||
|
Log.Logger = loggerConfiguration.CreateLogger();
|
||||||
|
|
||||||
|
builder.Logging.AddSerilog(Log.Logger);
|
||||||
|
builder.Services.AddSerilog();
|
||||||
|
|
||||||
|
builder.Services.AddSingleton(Log.Logger);
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user