|  |  |  | // 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 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |