using System.Globalization; using Microsoft.AspNetCore.Components.Authorization; using Microsoft.AspNetCore.Identity; using Microsoft.AspNetCore.Localization; using Microsoft.EntityFrameworkCore; using Microsoft.Extensions.Options; using MongoDB.Driver; using WorkTracker.Components; using WorkTracker.Components.Account; using WorkTracker.Configuration; using WorkTracker.Data; using WorkTracker.Services.Auth; using WorkTracker.Services.Festivities; using WorkTracker.Services.Settings; var builder = WebApplication.CreateBuilder(args); // Add services to the container. builder.Services.AddRazorComponents() .AddInteractiveServerComponents(); builder.Services.AddCascadingAuthenticationState(); builder.Services.AddScoped(); builder.Services.AddScoped(); builder.Services.AddScoped(); builder.Services.AddAuthentication(options => { options.DefaultScheme = IdentityConstants.ApplicationScheme; options.DefaultSignInScheme = IdentityConstants.ExternalScheme; }) .AddIdentityCookies(); var connectionString = builder.Configuration.GetConnectionString("DefaultConnection") ?? throw new InvalidOperationException("Connection string 'DefaultConnection' not found."); builder.Services.AddDbContext(options => options.UseSqlite(connectionString)); builder.Services.AddDatabaseDeveloperPageExceptionFilter(); builder.Services.AddIdentityCore(options => options.SignIn.RequireConfirmedAccount = false) .AddEntityFrameworkStores() .AddSignInManager() .AddDefaultTokenProviders(); builder.Services.AddSingleton, IdentityNoOpEmailSender>(); builder.Services.AddLocalization(); builder.Services.Configure(builder.Configuration.GetSection(MongoDbOptions.SectionName)); builder.Services.Configure(builder.Configuration.GetSection(SingleUserOptions.SectionName)); builder.Services.AddSingleton(sp => { var options = sp.GetRequiredService>().Value; return new MongoClient(options.ConnectionString); }); builder.Services.AddSingleton(sp => { var options = sp.GetRequiredService>().Value; var mongoClient = sp.GetRequiredService(); return mongoClient.GetDatabase(options.DatabaseName); }); builder.Services.AddScoped(); builder.Services.AddSingleton(); builder.Services.AddHostedService(); var app = builder.Build(); var italianCulture = new CultureInfo("it-IT"); CultureInfo.DefaultThreadCurrentCulture = italianCulture; CultureInfo.DefaultThreadCurrentUICulture = italianCulture; var localizationOptions = new RequestLocalizationOptions { DefaultRequestCulture = new RequestCulture(italianCulture), SupportedCultures = [italianCulture], SupportedUICultures = [italianCulture] }; // Configure the HTTP request pipeline. if (app.Environment.IsDevelopment()) { app.UseMigrationsEndPoint(); } else { app.UseExceptionHandler("/Error", createScopeForErrors: true); // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts. app.UseHsts(); } var useHttpsRedirection = app.Configuration.GetValue("UseHttpsRedirection", !app.Environment.IsDevelopment()); if (useHttpsRedirection) { app.UseHttpsRedirection(); } app.UseRequestLocalization(localizationOptions); app.UseAntiforgery(); app.MapStaticAssets(); app.MapRazorComponents() .AddInteractiveServerRenderMode(); // Add additional endpoints required by the Identity /Account Razor components. app.MapAdditionalIdentityEndpoints(); app.Run();