101 lines
4.3 KiB
C#
Raw Normal View History

2024-06-01 10:50:38 +03:00
using Microsoft.AspNetCore.Builder;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.Hosting;
using Mirea.Api.Endpoint.Common.Services;
2024-10-07 02:13:35 +03:00
using Mirea.Api.Endpoint.Configuration.Model;
2024-06-01 10:50:38 +03:00
using Serilog;
using Serilog.Context;
2024-06-01 10:50:38 +03:00
using Serilog.Events;
using Serilog.Filters;
using Serilog.Formatting.Compact;
2024-12-22 07:21:51 +03:00
using System;
using System.Diagnostics;
2024-06-01 10:50:38 +03:00
using System.IO;
2024-10-07 02:13:35 +03:00
namespace Mirea.Api.Endpoint.Configuration.Core.Startup;
2024-06-01 10:50:38 +03:00
public static class LoggerConfiguration
{
public static IHostBuilder AddCustomSerilog(this IHostBuilder hostBuilder)
{
return hostBuilder.UseSerilog((context, _, configuration) =>
2024-06-01 10:50:38 +03:00
{
2024-06-01 11:10:42 +03:00
var generalConfig = context.Configuration.Get<GeneralConfig>()?.LogSettings;
2024-06-01 10:50:38 +03:00
configuration
.MinimumLevel.Debug()
.MinimumLevel.Override("Microsoft", LogEventLevel.Information)
.Enrich.FromLogContext()
.WriteTo.Console(
outputTemplate:
"[{Level:u3}] [{Timestamp:dd.MM.yyyy HH:mm:ss}] {Message:lj}{NewLine}{Exception}");
2024-06-01 11:10:42 +03:00
if (generalConfig?.EnableLogToFile == true)
2024-06-01 10:50:38 +03:00
{
2024-08-10 22:04:11 +03:00
generalConfig.LogFilePath = PathBuilder.Combine(generalConfig.LogFilePath ?? string.Empty);
if (!string.IsNullOrEmpty(generalConfig.LogFilePath) && Directory.Exists(generalConfig.LogFilePath))
2024-06-01 11:10:42 +03:00
Directory.CreateDirectory(generalConfig.LogFilePath);
2024-06-01 10:50:38 +03:00
configuration.WriteTo.File(
new CompactJsonFormatter(),
PathBuilder.Combine(
2024-06-01 11:10:42 +03:00
generalConfig.LogFilePath!,
generalConfig.LogFileName + ".json"
2024-06-01 10:50:38 +03:00
),
LogEventLevel.Debug,
rollingInterval: RollingInterval.Day);
}
2024-12-22 07:13:59 +03:00
if (generalConfig != null && !string.IsNullOrEmpty(generalConfig.ApiServerSeq) &&
Uri.TryCreate(generalConfig.ApiServerSeq, UriKind.Absolute, out var _))
configuration.WriteTo.Seq(generalConfig.ApiServerSeq, apiKey: generalConfig.ApiKeySeq);
2024-06-01 10:50:38 +03:00
configuration
.MinimumLevel.Override("Microsoft.AspNetCore.Hosting", LogEventLevel.Warning)
.MinimumLevel.Override("Microsoft.AspNetCore.Mvc", LogEventLevel.Warning)
.MinimumLevel.Override("Microsoft.AspNetCore.Routing", LogEventLevel.Warning);
configuration.Filter.ByExcluding(Matching.WithProperty<string>("SourceContext", sc =>
sc.Contains("Microsoft.EntityFrameworkCore.Database.Command")));
});
}
public static IApplicationBuilder UseCustomSerilog(this IApplicationBuilder app)
{
return app.Use(async (context, next) =>
{
var traceId = Activity.Current?.Id ?? context.TraceIdentifier;
2024-12-23 07:48:28 +03:00
using (LogContext.PushProperty("TraceId", traceId))
2024-12-23 07:48:28 +03:00
using (LogContext.PushProperty("UserAgent", context.Request.Headers.UserAgent.ToString()))
using (LogContext.PushProperty("RemoteIPAddress", context.Connection.RemoteIpAddress?.ToString()))
{
await next();
}
}).UseSerilogRequestLogging(options =>
2024-06-01 10:50:38 +03:00
{
2024-06-10 22:02:29 +03:00
options.MessageTemplate = "[{RequestMethod}] {RequestPath} [Client {RemoteIPAddress}] [{StatusCode}] in {Elapsed:0.0000} ms";
2024-06-01 10:50:38 +03:00
options.GetLevel = (httpContext, elapsed, ex) =>
2024-06-01 10:50:38 +03:00
{
if (httpContext.Request.Path.StartsWithSegments("/health"))
return LogEventLevel.Verbose;
return elapsed >= 2500 || ex != null
? LogEventLevel.Warning
: elapsed >= 1000
? LogEventLevel.Information
: LogEventLevel.Debug;
2024-06-01 10:50:38 +03:00
};
options.EnrichDiagnosticContext = (diagnosticContext, httpContext) =>
{
diagnosticContext.Set("RequestHost", httpContext.Request.Host.Value);
diagnosticContext.Set("RequestScheme", httpContext.Request.Scheme);
diagnosticContext.Set("UserAgent", httpContext.Request.Headers.UserAgent);
diagnosticContext.Set("RemoteIPAddress", httpContext.Connection.RemoteIpAddress?.ToString());
};
2024-06-01 10:50:38 +03:00
});
}
}