// 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" // stringlint:disable static let needsConfigSync: Bool = false static let minExpectedRunDuration: TimeInterval = 0.01 static let fetchedTables: [(TableRecord & FetchableRecord).Type] = [] static let createdOrAlteredTables: [(TableRecord & FetchableRecord).Type] = [] static func migrate(_ db: Database) throws { try db.create( index: "interaction_on_wasRead_and_hasMention_and_threadId", // stringlint:disable 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", // stringlint:disable 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 } }