session-ios/SignalMessaging/environment/migrations/OWSDatabaseMigrationRunner.m

102 lines
3.3 KiB
Mathematica
Raw Normal View History

//
// Copyright (c) 2018 Open Whisper Systems. All rights reserved.
//
#import "OWSDatabaseMigrationRunner.h"
2017-12-04 18:38:44 +01:00
#import "OWS100RemoveTSRecipientsMigration.h"
#import "OWS102MoveLoggingPreferenceToUserDefaults.h"
#import "OWS103EnableVideoCalling.h"
#import "OWS104CreateRecipientIdentities.h"
2017-12-04 18:38:44 +01:00
#import "OWS105AttachmentFilePaths.h"
#import "OWS107LegacySounds.h"
2018-03-06 19:16:34 +01:00
#import "OWS108CallLoggingPreference.h"
2018-04-24 22:02:35 +02:00
#import "OWS109OutgoingMessageState.h"
#import "OWSDatabaseMigration.h"
2017-12-04 18:38:44 +01:00
#import <SignalMessaging/SignalMessaging-Swift.h>
#import <SignalServiceKit/AppContext.h>
NS_ASSUME_NONNULL_BEGIN
@implementation OWSDatabaseMigrationRunner
- (instancetype)initWithPrimaryStorage:(OWSPrimaryStorage *)primaryStorage
{
self = [super init];
if (!self) {
return self;
}
_primaryStorage = primaryStorage;
return self;
}
2017-12-04 18:38:44 +01:00
// This should all migrations which do NOT qualify as safeBlockingMigrations:
- (NSArray<OWSDatabaseMigration *> *)allMigrations
{
OWSPrimaryStorage *primaryStorage = OWSPrimaryStorage.sharedManager;
2017-12-04 18:38:44 +01:00
return @[
[[OWS100RemoveTSRecipientsMigration alloc] initWithPrimaryStorage:primaryStorage],
[[OWS102MoveLoggingPreferenceToUserDefaults alloc] initWithPrimaryStorage:primaryStorage],
[[OWS103EnableVideoCalling alloc] initWithPrimaryStorage:primaryStorage],
[[OWS104CreateRecipientIdentities alloc] initWithPrimaryStorage:primaryStorage],
[[OWS105AttachmentFilePaths alloc] initWithPrimaryStorage:primaryStorage],
[[OWS106EnsureProfileComplete alloc] initWithPrimaryStorage:primaryStorage],
2018-03-06 22:43:33 +01:00
[[OWS107LegacySounds alloc] initWithPrimaryStorage:primaryStorage],
2018-04-24 22:02:35 +02:00
[[OWS108CallLoggingPreference alloc] initWithPrimaryStorage:primaryStorage],
[[OWS109OutgoingMessageState alloc] initWithPrimaryStorage:primaryStorage]
2017-12-04 18:38:44 +01:00
];
}
- (void)assumeAllExistingMigrationsRun
{
for (OWSDatabaseMigration *migration in self.allMigrations) {
OWSLogInfo(@"Skipping migration on new install: %@", migration);
[migration save];
}
}
- (void)runAllOutstandingWithCompletion:(OWSDatabaseMigrationCompletion)completion
{
2018-03-13 14:51:57 +01:00
[self runMigrations:[self.allMigrations mutableCopy] completion:completion];
}
2018-03-13 14:51:57 +01:00
// Run migrations serially to:
//
// * Ensure predictable ordering.
// * Prevent them from interfering with each other (e.g. deadlock).
- (void)runMigrations:(NSMutableArray<OWSDatabaseMigration *> *)migrations
completion:(OWSDatabaseMigrationCompletion)completion
{
OWSAssert(migrations);
OWSAssert(completion);
2018-03-13 14:51:57 +01:00
// If there are no more migrations to run, complete.
if (migrations.count < 1) {
dispatch_async(dispatch_get_main_queue(), ^{
completion();
});
return;
}
2018-03-13 14:51:57 +01:00
// Pop next migration from front of queue.
OWSDatabaseMigration *migration = migrations.firstObject;
[migrations removeObjectAtIndex:0];
// If migration has already been run, skip it.
if ([OWSDatabaseMigration fetchObjectWithUniqueID:migration.uniqueId] != nil) {
[self runMigrations:migrations completion:completion];
return;
}
2018-03-13 14:51:57 +01:00
OWSLogInfo(@"Running migration: %@", migration);
2018-03-13 14:51:57 +01:00
[migration runUpWithCompletion:^{
OWSLogInfo(@"Migration complete: %@", migration);
2018-03-13 14:51:57 +01:00
[self runMigrations:migrations completion:completion];
}];
}
@end
NS_ASSUME_NONNULL_END