|  |  |  | // Copyright © 2022 Rangeproof Pty Ltd. All rights reserved. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import Foundation | 
					
						
							|  |  |  | import GRDB | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | enum _001_InitialSetupMigration: Migration { | 
					
						
							|  |  |  |     static let target: TargetMigrations.Identifier = .utilitiesKit | 
					
						
							|  |  |  |     static let identifier: String = "initialSetup" // stringlint:disable | 
					
						
							|  |  |  |     static let needsConfigSync: Bool = false | 
					
						
							|  |  |  |     static let minExpectedRunDuration: TimeInterval = 0.1 | 
					
						
							|  |  |  |     static let fetchedTables: [(TableRecord & FetchableRecord).Type] = [] | 
					
						
							|  |  |  |     static let createdOrAlteredTables: [(TableRecord & FetchableRecord).Type] = [ | 
					
						
							|  |  |  |         Identity.self, Job.self, JobDependencies.self, Setting.self | 
					
						
							|  |  |  |     ] | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     static func migrate(_ db: Database) throws { | 
					
						
							|  |  |  |         try db.create(table: Identity.self) { t in | 
					
						
							|  |  |  |             t.column(.variant, .text) | 
					
						
							|  |  |  |                 .notNull() | 
					
						
							|  |  |  |                 .unique() | 
					
						
							|  |  |  |                 .primaryKey() | 
					
						
							|  |  |  |             t.column(.data, .blob).notNull() | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         try db.create(table: Job.self) { t in | 
					
						
							|  |  |  |             t.column(.id, .integer) | 
					
						
							|  |  |  |                 .notNull() | 
					
						
							|  |  |  |                 .primaryKey(autoincrement: true) | 
					
						
							|  |  |  |             t.column(.failureCount, .integer) | 
					
						
							|  |  |  |                 .notNull() | 
					
						
							|  |  |  |                 .defaults(to: 0) | 
					
						
							|  |  |  |             t.column(.variant, .integer) | 
					
						
							|  |  |  |                 .notNull() | 
					
						
							|  |  |  |                 .indexed()                                            // Quicker querying | 
					
						
							|  |  |  |             t.column(.behaviour, .integer) | 
					
						
							|  |  |  |                 .notNull() | 
					
						
							|  |  |  |                 .indexed()                                            // Quicker querying | 
					
						
							|  |  |  |             t.column(.shouldBlock, .boolean) | 
					
						
							|  |  |  |                 .notNull() | 
					
						
							|  |  |  |                 .indexed()                                            // Quicker querying | 
					
						
							|  |  |  |                 .defaults(to: false) | 
					
						
							|  |  |  |             t.column(.shouldSkipLaunchBecomeActive, .boolean) | 
					
						
							|  |  |  |                 .notNull() | 
					
						
							|  |  |  |                 .defaults(to: false) | 
					
						
							|  |  |  |             t.column(.nextRunTimestamp, .double) | 
					
						
							|  |  |  |                 .notNull() | 
					
						
							|  |  |  |                 .indexed()                                            // Quicker querying | 
					
						
							|  |  |  |                 .defaults(to: 0) | 
					
						
							|  |  |  |             t.column(.threadId, .text) | 
					
						
							|  |  |  |                 .indexed()                                            // Quicker querying | 
					
						
							|  |  |  |             t.column(.interactionId, .text) | 
					
						
							|  |  |  |                 .indexed()                                            // Quicker querying | 
					
						
							|  |  |  |             t.column(.details, .blob) | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         try db.create(table: JobDependencies.self) { t in | 
					
						
							|  |  |  |             t.column(.jobId, .integer) | 
					
						
							|  |  |  |                 .notNull() | 
					
						
							|  |  |  |                 .references(Job.self, onDelete: .cascade)             // Delete if Job deleted | 
					
						
							|  |  |  |             t.column(.dependantId, .integer) | 
					
						
							|  |  |  |                 .indexed()                                            // Quicker querying | 
					
						
							|  |  |  |                 .references(Job.self, onDelete: .setNull)             // Delete if Job deleted | 
					
						
							|  |  |  |              | 
					
						
							|  |  |  |             t.primaryKey([.jobId, .dependantId]) | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         try db.create(table: Setting.self) { t in | 
					
						
							|  |  |  |             t.column(.key, .text) | 
					
						
							|  |  |  |                 .notNull() | 
					
						
							|  |  |  |                 .unique() | 
					
						
							|  |  |  |                 .primaryKey() | 
					
						
							|  |  |  |             t.column(.value, .blob).notNull() | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         Storage.update(progress: 1, for: self, in: target) // In case this is the last migration | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |