| | | 1 | | using System.Diagnostics; |
| | | 2 | | using System.Globalization; |
| | | 3 | | using ProjectTemplate.Web.Authentication.Extensions; |
| | | 4 | | using ProjectTemplate.Web.ErrorHandling; |
| | | 5 | | using ProjectTemplate.Web.Extensions; |
| | | 6 | | using Serilog; |
| | | 7 | | |
| | 148 | 8 | | Activity.DefaultIdFormat = ActivityIdFormat.W3C; |
| | 148 | 9 | | Activity.ForceDefaultIdFormat = true; |
| | | 10 | | |
| | 148 | 11 | | Log.Logger = new LoggerConfiguration() |
| | 148 | 12 | | .Enrich.FromLogContext() |
| | 148 | 13 | | .WriteTo.Debug( |
| | 148 | 14 | | outputTemplate: "[{Timestamp:yyyy-MM-dd HH:mm:ss.fff zzz} {Level:u3}] [{SourceContext}] [CorrelationId: {Correla |
| | 148 | 15 | | formatProvider: CultureInfo.InvariantCulture) |
| | 148 | 16 | | .WriteTo.Console( |
| | 148 | 17 | | outputTemplate: "[{Timestamp:yyyy-MM-dd HH:mm:ss.fff zzz} {Level:u3}] [{SourceContext}] [CorrelationId: {Correla |
| | 148 | 18 | | formatProvider: CultureInfo.InvariantCulture) |
| | 148 | 19 | | .CreateBootstrapLogger(); |
| | | 20 | | |
| | | 21 | | try |
| | | 22 | | { |
| | 148 | 23 | | WebApplicationBuilder builder = WebApplication.CreateBuilder(args); |
| | | 24 | | |
| | 148 | 25 | | builder.AddApplicationSerilog(); |
| | 148 | 26 | | Log.Information("Bootstrapping Template.Web application"); |
| | 148 | 27 | | builder.Services.AddControllersWithViews(); |
| | 148 | 28 | | builder.Services.AddApplicationApiVersioning(builder.Configuration); |
| | 148 | 29 | | builder.Services.AddRazorPages(); |
| | 148 | 30 | | builder.Services.AddApplicationHealthChecks(); |
| | 148 | 31 | | builder.Services.AddApplicationForwardedHeaders(builder.Configuration); |
| | 148 | 32 | | builder.Services.AddApplicationSecurityHeaders(builder.Configuration); |
| | 148 | 33 | | builder.Services.AddApplicationRateLimiting(builder.Configuration, builder.Environment); |
| | 148 | 34 | | builder.Services.AddApplicationRequestLogging(builder.Configuration); |
| | 148 | 35 | | builder.Services.AddApplicationOpenTelemetry(builder.Configuration, builder.Environment); |
| | 148 | 36 | | builder.Services.AddApplicationProblemDetails(builder.Environment); |
| | 148 | 37 | | builder.Services.AddApplicationAuthentication(builder.Configuration); |
| | 148 | 38 | | builder.Services.AddApplicationAuthorization(builder.Configuration); |
| | 148 | 39 | | builder.Services.AddApplicationDataAccess(builder.Configuration); |
| | | 40 | | |
| | 148 | 41 | | Log.Information("Starting ProjectTemplate.Web application"); |
| | 148 | 42 | | WebApplication app = builder.Build(); |
| | | 43 | | |
| | 148 | 44 | | Log.Information("Configuring pipeline for ProjectTemplate.Web application"); |
| | 148 | 45 | | app.UseApplicationPipeline(); |
| | 128 | 46 | | app.MapApplicationHealthChecks(); |
| | | 47 | | |
| | 128 | 48 | | Log.Information("Running ProjectTemplate.Web application"); |
| | 128 | 49 | | app.Run(); |
| | 126 | 50 | | } |
| | 22 | 51 | | catch (Exception ex) |
| | | 52 | | { |
| | 22 | 53 | | Log.Fatal(ex, "ProjectTemplate.Web application terminated unexpectedly"); |
| | 22 | 54 | | throw; |
| | | 55 | | } |
| | | 56 | | finally |
| | | 57 | | { |
| | 148 | 58 | | Log.CloseAndFlush(); |
| | 148 | 59 | | } |