using IdentityServer4.EntityFramework.DbContexts; using Microsoft.AspNetCore; using Microsoft.AspNetCore.Hosting; using Microsoft.eShopOnContainers.Services.Identity.API.Data; using Microsoft.Extensions.Configuration; using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.Logging; using Microsoft.Extensions.Options; using Serilog; using System; using System.IO; namespace Microsoft.eShopOnContainers.Services.Identity.API { public class Program { public static void Main(string[] args) { BuildWebHost(args) .MigrateDbContext((_, __) => { }) .MigrateDbContext((context, services) => { var env = services.GetService(); var logger = services.GetService>(); var settings = services.GetService>(); new ApplicationDbContextSeed() .SeedAsync(context, env, logger, settings) .Wait(); }) .MigrateDbContext((context,services)=> { var configuration = services.GetService(); new ConfigurationDbContextSeed() .SeedAsync(context, configuration) .Wait(); }).Run(); } public static IWebHost BuildWebHost(string[] args) => WebHost.CreateDefaultBuilder(args) .UseKestrel() .UseContentRoot(Directory.GetCurrentDirectory()) .UseIISIntegration() .UseStartup() .ConfigureAppConfiguration((builderContext, config) => { var builtConfig = config.Build(); var configurationBuilder = new ConfigurationBuilder(); if (Convert.ToBoolean(builtConfig["UseVault"])) { configurationBuilder.AddAzureKeyVault( $"https://{builtConfig["Vault:Name"]}.vault.azure.net/", builtConfig["Vault:ClientId"], builtConfig["Vault:ClientSecret"]); } configurationBuilder.AddEnvironmentVariables(); config.AddConfiguration(configurationBuilder.Build()); }) .ConfigureLogging((hostingContext, builder) => { builder.AddConfiguration(hostingContext.Configuration.GetSection("Logging")); builder.AddConsole(); builder.AddDebug(); }) .UseApplicationInsights() .UseSerilog((builderContext, config) => { config .MinimumLevel.Information() .Enrich.FromLogContext() .WriteTo.Console(); }) .Build(); } }