| 
									
										
										
										
											2021-12-15 00:17:14 -08:00
										 |  |  | // Copyright 2021 Signal Messenger, LLC
 | 
					
						
							|  |  |  | // SPDX-License-Identifier: AGPL-3.0-only
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-12-14 12:48:36 -08:00
										 |  |  | import type { Database } from '@signalapp/better-sqlite3'; | 
					
						
							| 
									
										
										
										
											2021-12-15 00:17:14 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | import type { LoggerType } from '../../types/Logging'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default function updateToSchemaVersion46( | 
					
						
							|  |  |  |   currentVersion: number, | 
					
						
							|  |  |  |   db: Database, | 
					
						
							|  |  |  |   logger: LoggerType | 
					
						
							|  |  |  | ): void { | 
					
						
							|  |  |  |   if (currentVersion >= 46) { | 
					
						
							|  |  |  |     return; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   db.transaction(() => { | 
					
						
							|  |  |  |     db.exec( | 
					
						
							|  |  |  |       `
 | 
					
						
							|  |  |  |       --- Add column to messages table | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       ALTER TABLE messages | 
					
						
							|  |  |  |       ADD COLUMN | 
					
						
							|  |  |  |       isStory INTEGER | 
					
						
							|  |  |  |       GENERATED ALWAYS | 
					
						
							|  |  |  |       AS (type = 'story'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       --- Update important message indices | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       DROP INDEX   messages_conversation; | 
					
						
							|  |  |  |       CREATE INDEX messages_conversation ON messages | 
					
						
							|  |  |  |         (conversationId, isStory, storyId, received_at, sent_at); | 
					
						
							|  |  |  |       `
 | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     db.pragma('user_version = 46'); | 
					
						
							|  |  |  |   })(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   logger.info('updateToSchemaVersion46: success!'); | 
					
						
							|  |  |  | } |