using Microsoft.AspNetCore.Components.Authorization; using Microsoft.AspNetCore.Identity; using Microsoft.EntityFrameworkCore; using MudBlazor.Services; using OpenArchival.Blazor.Components; using OpenArchival.Blazor.Components.Account; using OpenArchival.Blazor.Data; using OpenArchival.Database; using Dapper; using Npgsql; using OpenArchival.Core; var builder = WebApplication.CreateBuilder(args); // Add MudBlazor services builder.Services.AddMudServices(); // Add services to the container. builder.Services.AddRazorComponents() .AddInteractiveServerComponents(); builder.Services.AddMudExtensions(); var postgresOptions = builder.Configuration .GetSection(PostgresConnectionOptions.Key) .Get(); if (postgresOptions == null || string.IsNullOrEmpty(postgresOptions.ConnectionString)) throw new InvalidOperationException("Postgres connection options are not configured properly."); builder.Services.AddNpgsqlDataSource(postgresOptions.ConnectionString); // Add options builder.Services.AddOptions().Bind(builder.Configuration.GetSection(PostgresConnectionOptions.Key)); builder.Services.AddCascadingAuthenticationState(); builder.Services.AddScoped(); builder.Services.AddScoped(); builder.Services.AddScoped(); builder.Services.AddScoped(); builder.Services.AddScoped(); builder.Services.AddScoped(); builder.Services.AddScoped(); 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.UseSqlServer(connectionString)); builder.Services.AddDatabaseDeveloperPageExceptionFilter(); builder.Services.AddIdentityCore(options => options.SignIn.RequireConfirmedAccount = true) .AddEntityFrameworkStores() .AddSignInManager() .AddDefaultTokenProviders(); builder.Services.AddSingleton, IdentityNoOpEmailSender>(); builder.Services.AddLogging(); var app = builder.Build(); // 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(); } app.UseHttpsRedirection(); app.UseAntiforgery(); app.MapStaticAssets(); app.MapRazorComponents() .AddInteractiveServerRenderMode(); // Add additional endpoints required by the Identity /Account Razor components. app.MapAdditionalIdentityEndpoints(); await InitializeDatabaseAsync(app.Services); async Task InitializeDatabaseAsync(IServiceProvider services) { using var scope = services.CreateScope(); var serviceProvider = scope.ServiceProvider; var logger = serviceProvider.GetRequiredService>(); logger.LogInformation("Initializing database..."); var dataSource = serviceProvider.GetRequiredService(); await using var connection = await dataSource.OpenConnectionAsync(); await connection.ExecuteAsync(Tables.CategoryTable); await connection.ExecuteAsync(Tables.ArtifactTypesTable); await connection.ExecuteAsync(Tables.ArtifactAssociatedNamesTable); await connection.ExecuteAsync(Tables.TagsTable); await connection.ExecuteAsync(Tables.DefectsTable); await connection.ExecuteAsync(Tables.ArchiveFiles); var categoryProvider = serviceProvider.GetRequiredService(); await categoryProvider.InsertCategoryAsync(new Category() {CategoryName="Pictures", FieldSeparator="-", FieldNames=new string[]{"one", "two"},FieldDescriptions=new string[] { "one", "two"} }); await categoryProvider.InsertCategoryAsync(new Category() {CategoryName="Yearbooks", FieldSeparator="-", FieldNames=new string[]{"one", "two"},FieldDescriptions=new string[] { "one", "two"}}); await categoryProvider.InsertCategoryAsync(new Category() {CategoryName="Books", FieldSeparator="-", FieldNames=new string[]{"one", "two"}, FieldDescriptions = new string[] { "one", "two" } }); await categoryProvider.InsertCategoryAsync(new Category() {CategoryName="Newspapers", FieldSeparator="-", FieldNames=new string[]{"one", "two"}, FieldDescriptions = new string[] { "one", "two" }}); await categoryProvider.InsertCategoryAsync(new Category() {CategoryName="Letters", FieldSeparator="-", FieldNames=new string[]{"one", "two"}, FieldDescriptions = new string[] { "one", "two" } }); var artifactTypesProvider = serviceProvider.GetRequiredService(); await artifactTypesProvider.AddType("Photo"); await artifactTypesProvider.AddType("Yearbook"); await artifactTypesProvider.AddType("Book"); var associatedNamesProvider = serviceProvider.GetRequiredService(); await associatedNamesProvider.InsertName("Sawyer Allen"); await associatedNamesProvider.InsertName("Vincent Allen"); logger.LogInformation("Database initialization complete."); } app.Run();