|
|
|
@ -0,0 +1,88 @@
|
|
|
|
|
using Microsoft.Extensions.Logging.Abstractions;
|
|
|
|
|
using Volo.Abp.Data;
|
|
|
|
|
using Volo.Abp.DependencyInjection;
|
|
|
|
|
using Volo.Abp.Identity;
|
|
|
|
|
using Volo.Abp.MultiTenancy;
|
|
|
|
|
using Volo.Abp.TenantManagement;
|
|
|
|
|
|
|
|
|
|
namespace MyCompanyName.MyProjectName.Data;
|
|
|
|
|
|
|
|
|
|
public class MyProjectNameDbMigrationService : ITransientDependency
|
|
|
|
|
{
|
|
|
|
|
public ILogger<MyProjectNameDbMigrationService> Logger { get; set; }
|
|
|
|
|
|
|
|
|
|
private readonly IDataSeeder _dataSeeder;
|
|
|
|
|
private readonly MyProjectNameEFCoreDbSchemaMigrator _dbSchemaMigrator;
|
|
|
|
|
private readonly ITenantRepository _tenantRepository;
|
|
|
|
|
private readonly ICurrentTenant _currentTenant;
|
|
|
|
|
|
|
|
|
|
public MyProjectNameDbMigrationService(
|
|
|
|
|
IDataSeeder dataSeeder,
|
|
|
|
|
MyProjectNameEFCoreDbSchemaMigrator dbSchemaMigrator,
|
|
|
|
|
ITenantRepository tenantRepository,
|
|
|
|
|
ICurrentTenant currentTenant)
|
|
|
|
|
{
|
|
|
|
|
_dataSeeder = dataSeeder;
|
|
|
|
|
_dbSchemaMigrator = dbSchemaMigrator;
|
|
|
|
|
_tenantRepository = tenantRepository;
|
|
|
|
|
_currentTenant = currentTenant;
|
|
|
|
|
|
|
|
|
|
Logger = NullLogger<MyProjectNameDbMigrationService>.Instance;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public async Task MigrateAsync()
|
|
|
|
|
{
|
|
|
|
|
Logger.LogInformation("Started database migrations...");
|
|
|
|
|
|
|
|
|
|
await MigrateDatabaseSchemaAsync();
|
|
|
|
|
await SeedDataAsync();
|
|
|
|
|
|
|
|
|
|
Logger.LogInformation($"Successfully completed host database migrations.");
|
|
|
|
|
|
|
|
|
|
var tenants = await _tenantRepository.GetListAsync(includeDetails: true);
|
|
|
|
|
|
|
|
|
|
var migratedDatabaseSchemas = new HashSet<string>();
|
|
|
|
|
foreach (var tenant in tenants)
|
|
|
|
|
{
|
|
|
|
|
using (_currentTenant.Change(tenant.Id))
|
|
|
|
|
{
|
|
|
|
|
if (tenant.ConnectionStrings.Any())
|
|
|
|
|
{
|
|
|
|
|
var tenantConnectionStrings = tenant.ConnectionStrings
|
|
|
|
|
.Select(x => x.Value)
|
|
|
|
|
.ToList();
|
|
|
|
|
|
|
|
|
|
if (!migratedDatabaseSchemas.IsSupersetOf(tenantConnectionStrings))
|
|
|
|
|
{
|
|
|
|
|
await MigrateDatabaseSchemaAsync(tenant);
|
|
|
|
|
|
|
|
|
|
migratedDatabaseSchemas.AddIfNotContains(tenantConnectionStrings);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
await SeedDataAsync(tenant);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Logger.LogInformation($"Successfully completed {tenant.Name} tenant database migrations.");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Logger.LogInformation("Successfully completed all database migrations.");
|
|
|
|
|
Logger.LogInformation("You can safely end this process...");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private async Task MigrateDatabaseSchemaAsync(Tenant tenant = null)
|
|
|
|
|
{
|
|
|
|
|
Logger.LogInformation($"Migrating schema for {(tenant == null ? "host" : tenant.Name + " tenant")} database...");
|
|
|
|
|
await _dbSchemaMigrator.MigrateAsync();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private async Task SeedDataAsync(Tenant tenant = null)
|
|
|
|
|
{
|
|
|
|
|
Logger.LogInformation($"Executing {(tenant == null ? "host" : tenant.Name + " tenant")} database seed...");
|
|
|
|
|
|
|
|
|
|
await _dataSeeder.SeedAsync(new DataSeedContext(tenant?.Id)
|
|
|
|
|
.WithProperty(IdentityDataSeedContributor.AdminEmailPropertyName, IdentityDataSeedContributor.AdminEmailDefaultValue)
|
|
|
|
|
.WithProperty(IdentityDataSeedContributor.AdminPasswordPropertyName, IdentityDataSeedContributor.AdminPasswordDefaultValue)
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
}
|