| using Microsoft.AspNetCore.Hosting; | 
| using Microsoft.Extensions.DependencyInjection; | 
| using Microsoft.Extensions.Hosting; | 
| using Microsoft.Extensions.Logging; | 
| using System; | 
| using System.Collections.Generic; | 
| using System.Linq; | 
| using System.Text; | 
| using System.Threading.Tasks; | 
| using WIDESEA_Core.Helper; | 
| using WIDESEA_Core.Seed; | 
|   | 
| namespace WIDESEA_Core | 
| { | 
|     public sealed class SeedDataHostedService : IHostedService | 
|     { | 
|         private readonly DBContext _dbContext; | 
|         private readonly ILogger<SeedDataHostedService> _logger; | 
|         private readonly string _webRootPath; | 
|         private readonly IServiceProvider _serviceProvider; | 
|   | 
|         public SeedDataHostedService( | 
|             IServiceProvider serviceProvider, | 
|             IWebHostEnvironment webHostEnvironment, | 
|             ILogger<SeedDataHostedService> logger) | 
|         { | 
|             _serviceProvider = serviceProvider; | 
|             _logger = logger; | 
|             _webRootPath = webHostEnvironment.WebRootPath; | 
|   | 
|             using var scope = _serviceProvider.CreateScope(); | 
|   | 
|             var dbContext = scope.ServiceProvider.GetService<DBContext>(); | 
|             //dbContext.Db.Aop.DataExecuting = SqlSugarAop.DataExecuting; | 
|             _dbContext = dbContext; | 
|         } | 
|   | 
|         public async Task StartAsync(CancellationToken cancellationToken) | 
|         { | 
|             _logger.LogInformation("Start Initialization Db Seed Service!"); | 
|             await DoWork(); | 
|         } | 
|   | 
|         private async Task DoWork() | 
|         { | 
|             try | 
|             { | 
|                 //if (AppSettings.app("AppSettings", "SeedDBEnabled").ObjToBool() || AppSettings.app("AppSettings", "SeedDBDataEnabled").ObjToBool()) | 
|                 { | 
|                     // 使用 myScopedService 执行任务 | 
|   | 
|                     await DBSeed.SeedAsync(_dbContext, _webRootPath); | 
|   | 
|                     //多租户 同步 | 
|                     //await DBSeed.TenantSeedAsync(_dbContext); | 
|                 } | 
|             } | 
|             catch (Exception ex) | 
|             { | 
|                 _logger.LogError(ex, "Error occured seeding the Database."); | 
|                 throw; | 
|             } | 
|         } | 
|   | 
|         public Task StopAsync(CancellationToken cancellationToken) | 
|         { | 
|             _logger.LogInformation("Stop Initialization Db Seed Service!"); | 
|             return Task.CompletedTask; | 
|         } | 
|   | 
|     } | 
| } |