using Microsoft.EntityFrameworkCore; using System; using System.Linq; using Microsoft.EntityFrameworkCore.Infrastructure; namespace AsbCloudDb { public static class EFExtentionsInnitialization { public static void EnshureCreatedAndMigrated(this DatabaseFacade db) { db.SetCommandTimeout(TimeSpan.FromMinutes(5)); if (db.EnsureCreated()) { db.CreateMigrationTable(); db.WriteMigrationsInfo(); } else { db.SetCommandTimeout(TimeSpan.FromMinutes(20)); db.Migrate(); } } private static void CreateMigrationTable(this DatabaseFacade db) { var sqlCreateMigrationTable = $"CREATE TABLE public.\"__EFMigrationsHistory\" " + $"(\"MigrationId\" varchar(150) NOT NULL, " + $" \"ProductVersion\" varchar(32) NOT NULL, " + $" CONSTRAINT \"PK___EFMigrationsHistory\" PRIMARY KEY (\"MigrationId\"));"; db.ExecuteSqlRaw(sqlCreateMigrationTable); } private static void WriteMigrationsInfo(this DatabaseFacade db) { var efVersion = db.GetType().Assembly.GetName().Version!; var efVersionString = $"{efVersion.Major}.{efVersion.Minor}.{efVersion.Build}"; var migrations = db.GetPendingMigrations() .Select(migration => $" ('{migration}', '{efVersionString}')"); var sqlAddLastMigration = $"INSERT INTO public.\"__EFMigrationsHistory\" " + $"(\"MigrationId\", \"ProductVersion\") " + $"VALUES {string.Join(',', migrations)};"; db.ExecuteSqlRaw(sqlAddLastMigration); } } }