mirror of
https://github.com/oxen-io/session-ios.git
synced 2023-12-13 21:30:14 +01:00
38 lines
1.4 KiB
Swift
38 lines
1.4 KiB
Swift
|
// Copyright © 2022 Rangeproof Pty Ltd. All rights reserved.
|
||
|
|
||
|
import Foundation
|
||
|
import GRDB
|
||
|
import SessionUtilitiesKit
|
||
|
|
||
|
/// This migration adds an index to the interaction table in order to improve the performance of retrieving the number of unread interactions
|
||
|
enum _007_HomeQueryOptimisationIndexes: Migration {
|
||
|
static let target: TargetMigrations.Identifier = .messagingKit
|
||
|
static let identifier: String = "HomeQueryOptimisationIndexes"
|
||
|
static let needsConfigSync: Bool = false
|
||
|
static let minExpectedRunDuration: TimeInterval = 0.1
|
||
|
|
||
|
static func migrate(_ db: Database) throws {
|
||
|
try db.create(
|
||
|
index: "interaction_on_wasRead_and_hasMention_and_threadId",
|
||
|
on: Interaction.databaseTableName,
|
||
|
columns: [
|
||
|
Interaction.Columns.wasRead.name,
|
||
|
Interaction.Columns.hasMention.name,
|
||
|
Interaction.Columns.threadId.name
|
||
|
]
|
||
|
)
|
||
|
|
||
|
try db.create(
|
||
|
index: "interaction_on_threadId_and_timestampMs_and_variant",
|
||
|
on: Interaction.databaseTableName,
|
||
|
columns: [
|
||
|
Interaction.Columns.threadId.name,
|
||
|
Interaction.Columns.timestampMs.name,
|
||
|
Interaction.Columns.variant.name
|
||
|
]
|
||
|
)
|
||
|
|
||
|
Storage.update(progress: 1, for: self, in: target) // In case this is the last migration
|
||
|
}
|
||
|
}
|