mirror of https://github.com/oxen-io/session-ios
				
				
				
			
			You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
	
	
		
			38 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Swift
		
	
		
		
			
		
	
	
			38 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Swift
		
	
| 
											3 years ago
										 | // 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 | ||
|  |     } | ||
|  | } |