73 lines
3.1 KiB
C#
73 lines
3.1 KiB
C#
|
using Hydra.Backend.Middleware;
|
||
|
using Serilog;
|
||
|
using Serilog.Events;
|
||
|
|
||
|
namespace Hydra.Backend.Utils;
|
||
|
|
||
|
public static class StartupExtensions
|
||
|
{
|
||
|
/// <summary>
|
||
|
/// Adds Serilog to this service collection. This method also initializes Serilog, so it should be called as early as possible, before any log calls.
|
||
|
/// </summary>
|
||
|
public static WebApplicationBuilder AddSerilog(this WebApplicationBuilder builder)
|
||
|
{
|
||
|
var config = builder.Configuration.Get<Config>() ?? new();
|
||
|
|
||
|
var logCfg = new LoggerConfiguration()
|
||
|
.Enrich.FromLogContext()
|
||
|
.Enrich.WithEnvironmentName()
|
||
|
.Enrich.WithMachineName()
|
||
|
.Enrich.WithProcessId()
|
||
|
.Enrich.WithProcessName()
|
||
|
.MinimumLevel.Is(config.Logging.LogEventLevel)
|
||
|
// ASP.NET's built in request logs are extremely verbose, so we use Serilog's instead.
|
||
|
// Serilog doesn't disable the built-in logs, so we do it here.
|
||
|
.MinimumLevel.Override("Microsoft", LogEventLevel.Information)
|
||
|
.MinimumLevel.Override("Microsoft.EntityFrameworkCore.Database.Command",
|
||
|
config.Logging.LogQueries ? LogEventLevel.Information : LogEventLevel.Fatal)
|
||
|
.MinimumLevel.Override("Microsoft.AspNetCore.Hosting", LogEventLevel.Warning)
|
||
|
.MinimumLevel.Override("Microsoft.AspNetCore.Mvc", LogEventLevel.Warning)
|
||
|
.MinimumLevel.Override("Microsoft.AspNetCore.Routing", LogEventLevel.Warning)
|
||
|
.MinimumLevel.Override("Hangfire", LogEventLevel.Information)
|
||
|
.WriteTo.Console();
|
||
|
|
||
|
if (config.Logging.SeqLogUrl != null)
|
||
|
{
|
||
|
logCfg.WriteTo.Seq(config.Logging.SeqLogUrl, restrictedToMinimumLevel: LogEventLevel.Verbose);
|
||
|
}
|
||
|
|
||
|
// AddSerilog doesn't seem to add an ILogger to the service collection, so add that manually.
|
||
|
builder.Services.AddSerilog().AddSingleton(Log.Logger = logCfg.CreateLogger());
|
||
|
|
||
|
return builder;
|
||
|
}
|
||
|
|
||
|
public static IServiceCollection AddCustomMiddleware(this IServiceCollection services) => services
|
||
|
.AddScoped<AuthenticationMiddleware>()
|
||
|
.AddScoped<AuthorizationMiddleware>();
|
||
|
|
||
|
public static IApplicationBuilder UseCustomMiddleware(this IApplicationBuilder app) => app
|
||
|
.UseMiddleware<AuthenticationMiddleware>()
|
||
|
.UseMiddleware<AuthorizationMiddleware>();
|
||
|
|
||
|
public static Config AddConfiguration(this WebApplicationBuilder builder, string[] args)
|
||
|
{
|
||
|
builder.Configuration.Sources.Clear();
|
||
|
builder.Configuration.AddConfiguration(args);
|
||
|
|
||
|
var config = builder.Configuration.Get<Config>() ?? new();
|
||
|
builder.Services.AddSingleton(config);
|
||
|
return config;
|
||
|
}
|
||
|
|
||
|
public static IConfigurationBuilder AddConfiguration(this IConfigurationBuilder builder, string[] args)
|
||
|
{
|
||
|
var file = Environment.GetEnvironmentVariable("HDYRA_CONFIG_FILE") ?? "config.ini";
|
||
|
|
||
|
return builder
|
||
|
.SetBasePath(Directory.GetCurrentDirectory())
|
||
|
.AddIniFile(file, optional: false, reloadOnChange: true)
|
||
|
.AddEnvironmentVariables()
|
||
|
.AddCommandLine(args);
|
||
|
}
|
||
|
}
|