2026-02-06 19:58:01 +01:00
|
|
|
using IdentityShroud.Api;
|
|
|
|
|
using IdentityShroud.Core;
|
2026-02-08 11:57:57 +01:00
|
|
|
using IdentityShroud.Core.Contracts;
|
|
|
|
|
using IdentityShroud.Core.Security;
|
2026-02-06 19:58:01 +01:00
|
|
|
using Serilog;
|
|
|
|
|
using Serilog.Formatting.Json;
|
|
|
|
|
|
|
|
|
|
// Initial logging until we can set it up from Configuration
|
|
|
|
|
Log.Logger = new LoggerConfiguration()
|
|
|
|
|
.Enrich.FromLogContext()
|
|
|
|
|
.WriteTo.Console(new JsonFormatter())
|
|
|
|
|
.CreateLogger();
|
|
|
|
|
|
|
|
|
|
var applicationBuilder = WebApplication.CreateSlimBuilder(args);
|
|
|
|
|
ConfigureBuilder(applicationBuilder);
|
|
|
|
|
var application = applicationBuilder.Build();
|
|
|
|
|
ConfigureApplication(application);
|
|
|
|
|
application.Run();
|
|
|
|
|
|
|
|
|
|
void ConfigureBuilder(WebApplicationBuilder builder)
|
|
|
|
|
{
|
|
|
|
|
var services = builder.Services;
|
|
|
|
|
var configuration = builder.Configuration;
|
|
|
|
|
|
|
|
|
|
//services.AddControllers();
|
|
|
|
|
services.ConfigureHttpJsonOptions(options =>
|
|
|
|
|
{
|
|
|
|
|
options.SerializerOptions.TypeInfoResolverChain.Insert(0, AppJsonSerializerContext.Default);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// Learn more about configuring OpenAPI at https://aka.ms/aspnet/openapi
|
|
|
|
|
services.AddOpenApi();
|
|
|
|
|
services.AddScoped<Db>();
|
|
|
|
|
services.AddOptions<DbConfiguration>().Bind(configuration.GetSection("db"));
|
2026-02-08 11:57:57 +01:00
|
|
|
services.AddSingleton<ISecretProvider, ConfigurationSecretProvider>();
|
2026-02-06 19:58:01 +01:00
|
|
|
|
|
|
|
|
builder.Host.UseSerilog((context, services, configuration) => configuration
|
|
|
|
|
.Enrich.FromLogContext()
|
|
|
|
|
//.Enrich.With<UserEnricher>()
|
|
|
|
|
.ReadFrom.Configuration(context.Configuration));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void ConfigureApplication(WebApplication app)
|
|
|
|
|
{
|
|
|
|
|
if (app.Environment.IsDevelopment())
|
|
|
|
|
{
|
|
|
|
|
app.MapOpenApi();
|
|
|
|
|
}
|
|
|
|
|
app.UseSerilogRequestLogging();
|
|
|
|
|
app.MapRealmEndpoints();
|
|
|
|
|
// app.UseRouting();
|
|
|
|
|
// app.MapControllers();
|
|
|
|
|
}
|