diff options
author | crupest <crupest@outlook.com> | 2021-04-23 17:28:18 +0800 |
---|---|---|
committer | crupest <crupest@outlook.com> | 2021-04-23 17:37:37 +0800 |
commit | 5b9f8cfb458bdefaa82c326e03ded7a678034346 (patch) | |
tree | 803b5aba53bdffd5dc72f8e186a79b7abf2a239e /BackEnd/Timeline/Services/DatabaseManagement/DatabaseManagementService.cs | |
parent | ffdc747c5b2cefff117f4da049386ba9f30bd792 (diff) | |
download | timeline-5b9f8cfb458bdefaa82c326e03ded7a678034346.tar.gz timeline-5b9f8cfb458bdefaa82c326e03ded7a678034346.tar.bz2 timeline-5b9f8cfb458bdefaa82c326e03ded7a678034346.zip |
refactor: Refactor a lot.
Diffstat (limited to 'BackEnd/Timeline/Services/DatabaseManagement/DatabaseManagementService.cs')
-rw-r--r-- | BackEnd/Timeline/Services/DatabaseManagement/DatabaseManagementService.cs | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/BackEnd/Timeline/Services/DatabaseManagement/DatabaseManagementService.cs b/BackEnd/Timeline/Services/DatabaseManagement/DatabaseManagementService.cs new file mode 100644 index 00000000..4d54d3dc --- /dev/null +++ b/BackEnd/Timeline/Services/DatabaseManagement/DatabaseManagementService.cs @@ -0,0 +1,34 @@ +using Microsoft.EntityFrameworkCore;
+using Microsoft.Extensions.Hosting;
+using System.Threading;
+using System.Threading.Tasks;
+using Timeline.Entities;
+
+namespace Timeline.Services.DatabaseManagement
+{
+ public class DatabaseManagementService : IHostedService
+ {
+ private readonly DatabaseContext _database;
+ private readonly IDatabaseBackupService _backupService;
+ private readonly IDatabaseCustomMigrator _customMigrator;
+
+ public DatabaseManagementService(DatabaseContext database, IDatabaseBackupService backupService, IDatabaseCustomMigrator customMigrator)
+ {
+ _database = database;
+ _backupService = backupService;
+ _customMigrator = customMigrator;
+ }
+
+ public async Task StartAsync(CancellationToken cancellationToken = default)
+ {
+ await _backupService.BackupAsync(cancellationToken);
+ await _database.Database.MigrateAsync(cancellationToken);
+ await _customMigrator.MigrateAsync(cancellationToken);
+ }
+
+ public Task StopAsync(CancellationToken cancellationToken)
+ {
+ return Task.CompletedTask;
+ }
+ }
+}
|