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