@ -1,23 +1,23 @@ 
			
		
	
		
			
				
					/ * *  
			
		
	
		
			
				
					 *  Database  Migration  Service  for  TimeSafari  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  This  module  provides  a  comprehensive  database  migration  system  that  manages    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  This  module  provides  a  comprehensive  database  migration  system  that  manages  
			
		
	
		
			
				
					 *  schema  changes  as  users  upgrade  their  TimeSafari  application  over  time .  
			
		
	
		
			
				
					 *  The  system  ensures  that  database  changes  are  applied  safely ,  tracked  properly ,  
			
		
	
		
			
				
					 *  and  can  handle  edge  cases  gracefully .  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  # #  Architecture  Overview  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  The  migration  system  follows  these  key  principles :  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  1 .  * * Single  Application * * :  Each  migration  runs  exactly  once  per  database  
			
		
	
		
			
				
					 *  2 .  * * Tracked  Execution * * :  All  applied  migrations  are  recorded  in  a  migrations  table  
			
		
	
		
			
				
					 *  3 .  * * Schema  Validation * * :  Actual  database  schema  is  validated  before  and  after  migrations  
			
		
	
		
			
				
					 *  4 .  * * Graceful  Recovery * * :  Handles  cases  where  schema  exists  but  tracking  is  missing  
			
		
	
		
			
				
					 *  5 .  * * Comprehensive  Logging * * :  Detailed  logging  for  debugging  and  monitoring  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  # #  Migration  Flow  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  ` ` `  
			
		
	
		
			
				
					 *  1 .  Create  migrations  table  ( if  needed )  
			
		
	
		
			
				
					 *  2 .  Query  existing  applied  migrations  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -30,28 +30,28 @@ 
			
		
	
		
			
				
					 *     f .  Record  migration  as  applied  
			
		
	
		
			
				
					 *  4 .  Final  validation  of  all  migrations  
			
		
	
		
			
				
					 *  ` ` `  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  # #  Usage  Example  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  ` ` ` typescript
  
			
		
	
		
			
				
					 *  // Register migrations (typically in migration.ts)
  
			
		
	
		
			
				
					 *  registerMigration ( {  
			
		
	
		
			
				
					 *    name :  "001_initial" ,  
			
		
	
		
			
				
					 *    sql :  "CREATE TABLE accounts (id INTEGER PRIMARY KEY, ...)"  
			
		
	
		
			
				
					 *  } ) ;  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  // Run migrations (typically in platform service)
  
			
		
	
		
			
				
					 *  await  runMigrations ( sqlExec ,  sqlQuery ,  extractMigrationNames ) ;  
			
		
	
		
			
				
					 *  ` ` `  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  # #  Error  Handling  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  The  system  handles  several  error  scenarios :  
			
		
	
		
			
				
					 *  -  Duplicate  table / column  errors  ( schema  already  exists )  
			
		
	
		
			
				
					 *  -  Migration  tracking  inconsistencies  
			
		
	
		
			
				
					 *  -  Database  connection  issues  
			
		
	
		
			
				
					 *  -  Schema  validation  failures  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  @author  Matthew  Raymer  
			
		
	
		
			
				
					 *  @version  1.0 . 0  
			
		
	
		
			
				
					 *  @since  2025 - 06 - 30  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -61,11 +61,11 @@ import { logger } from "../utils/logger"; 
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					/ * *  
			
		
	
		
			
				
					 *  Migration  interface  for  database  schema  migrations  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  Represents  a  single  database  migration  that  can  be  applied  to  upgrade  
			
		
	
		
			
				
					 *  the  database  schema .  Each  migration  should  be  idempotent  and  focused  
			
		
	
		
			
				
					 *  on  a  single  schema  change .  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  @interface  Migration  
			
		
	
		
			
				
					 * /  
			
		
	
		
			
				
					interface  Migration  {  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -77,10 +77,10 @@ interface Migration { 
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					/ * *  
			
		
	
		
			
				
					 *  Migration  validation  result  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  Contains  the  results  of  validating  that  a  migration  was  successfully  
			
		
	
		
			
				
					 *  applied  by  checking  the  actual  database  schema .  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  @interface  MigrationValidation  
			
		
	
		
			
				
					 * /  
			
		
	
		
			
				
					interface  MigrationValidation  {  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -96,11 +96,11 @@ interface MigrationValidation { 
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					/ * *  
			
		
	
		
			
				
					 *  Migration  registry  to  store  and  manage  database  migrations  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  This  class  maintains  a  registry  of  all  migrations  that  need  to  be  applied  
			
		
	
		
			
				
					 *  to  the  database .  It  uses  the  singleton  pattern  to  ensure  migrations  are  
			
		
	
		
			
				
					 *  registered  once  and  can  be  accessed  globally .  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  @class  MigrationRegistry  
			
		
	
		
			
				
					 * /  
			
		
	
		
			
				
					class  MigrationRegistry  {  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -109,14 +109,14 @@ class MigrationRegistry { 
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					  / * *  
			
		
	
		
			
				
					   *  Register  a  migration  with  the  registry  
			
		
	
		
			
				
					   *    
			
		
	
		
			
				
					   *  
			
		
	
		
			
				
					   *  Adds  a  migration  to  the  list  of  migrations  that  will  be  applied  when  
			
		
	
		
			
				
					   *  runMigrations ( )  is  called .  Migrations  should  be  registered  in  order  
			
		
	
		
			
				
					   *  of  their  intended  execution .  
			
		
	
		
			
				
					   *  
			
		
	
		
			
				
					   *  @param  migration  -  The  migration  to  register  
			
		
	
		
			
				
					   *  @throws  { Error }  If  migration  name  is  empty  or  already  exists  
			
		
	
		
			
				
					   *    
			
		
	
		
			
				
					   *  
			
		
	
		
			
				
					   *  @example  
			
		
	
		
			
				
					   *  ` ` ` typescript
  
			
		
	
		
			
				
					   *  registry . registerMigration ( {  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -126,14 +126,14 @@ class MigrationRegistry { 
			
		
	
		
			
				
					   *  ` ` `  
			
		
	
		
			
				
					   * /  
			
		
	
		
			
				
					  registerMigration ( migration : Migration ) :  void  {  
			
		
	
		
			
				
					    if  ( ! migration . name  ||  migration . name . trim ( )  ===  '' )  {  
			
		
	
		
			
				
					      throw  new  Error ( 'Migration name cannot be empty' ) ;  
			
		
	
		
			
				
					    if  ( ! migration . name  ||  migration . name . trim ( )  ===  "" )  {  
			
		
	
		
			
				
					      throw  new  Error ( "Migration name cannot be empty" ) ;  
			
		
	
		
			
				
					    }  
			
		
	
		
			
				
					      
			
		
	
		
			
				
					    if  ( this . migrations . some ( m  = >  m . name  ===  migration . name ) )  {  
			
		
	
		
			
				
					
  
			
		
	
		
			
				
					    if  ( this . migrations . some ( ( m ) = >  m . name  ===  migration . name ) )  {  
			
		
	
		
			
				
					      throw  new  Error ( ` Migration with name ' ${ migration . name } ' already exists ` ) ;  
			
		
	
		
			
				
					    }  
			
		
	
		
			
				
					      
			
		
	
		
			
				
					
  
			
		
	
		
			
				
					    this . migrations . push ( migration ) ;  
			
		
	
		
			
				
					  }  
			
		
	
		
			
				
					
 
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -142,7 +142,7 @@ class MigrationRegistry { 
			
		
	
		
			
				
					   *  
			
		
	
		
			
				
					   *  Returns  a  copy  of  all  migrations  that  have  been  registered  with  this  
			
		
	
		
			
				
					   *  registry .  The  migrations  are  returned  in  the  order  they  were  registered .  
			
		
	
		
			
				
					   *    
			
		
	
		
			
				
					   *  
			
		
	
		
			
				
					   *  @returns  Array  of  registered  migrations  ( defensive  copy )  
			
		
	
		
			
				
					   * /  
			
		
	
		
			
				
					  getMigrations ( ) :  Migration [ ]  {  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -151,10 +151,10 @@ class MigrationRegistry { 
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					  / * *  
			
		
	
		
			
				
					   *  Clear  all  registered  migrations  
			
		
	
		
			
				
					   *    
			
		
	
		
			
				
					   *  
			
		
	
		
			
				
					   *  Removes  all  migrations  from  the  registry .  This  is  primarily  used  for  
			
		
	
		
			
				
					   *  testing  purposes  to  ensure  a  clean  state  between  test  runs .  
			
		
	
		
			
				
					   *    
			
		
	
		
			
				
					   *  
			
		
	
		
			
				
					   *  @internal  Used  primarily  for  testing  
			
		
	
		
			
				
					   * /  
			
		
	
		
			
				
					  clearMigrations ( ) :  void  {  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -163,7 +163,7 @@ class MigrationRegistry { 
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					  / * *  
			
		
	
		
			
				
					   *  Get  the  count  of  registered  migrations  
			
		
	
		
			
				
					   *    
			
		
	
		
			
				
					   *  
			
		
	
		
			
				
					   *  @returns  Number  of  migrations  currently  registered  
			
		
	
		
			
				
					   * /  
			
		
	
		
			
				
					  getCount ( ) :  number  {  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -183,7 +183,7 @@ const migrationRegistry = new MigrationRegistry(); 
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  @param  migration  -  The  migration  to  register  
			
		
	
		
			
				
					 *  @throws  { Error }  If  migration  is  invalid  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  @example  
			
		
	
		
			
				
					 *  ` ` ` typescript
  
			
		
	
		
			
				
					 *  registerMigration ( {  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -207,16 +207,16 @@ export function registerMigration(migration: Migration): void { 
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					/ * *  
			
		
	
		
			
				
					 *  Validate  that  a  migration  was  successfully  applied  by  checking  schema  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  This  function  performs  post - migration  validation  to  ensure  that  the  
			
		
	
		
			
				
					 *  expected  database  schema  changes  were  actually  applied .  It  checks  for  
			
		
	
		
			
				
					 *  the  existence  of  tables ,  columns ,  and  other  schema  elements  that  should  
			
		
	
		
			
				
					 *  have  been  created  by  the  migration .  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  @param  migration  -  The  migration  to  validate  
			
		
	
		
			
				
					 *  @param  sqlQuery  -  Function  to  execute  SQL  queries  
			
		
	
		
			
				
					 *  @returns  Promise  resolving  to  validation  results  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  @example  
			
		
	
		
			
				
					 *  ` ` ` typescript
  
			
		
	
		
			
				
					 *  const  validation  =  await  validateMigrationApplication ( migration ,  sqlQuery ) ;  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -233,48 +233,68 @@ async function validateMigrationApplication<T>( 
			
		
	
		
			
				
					    isValid : true ,  
			
		
	
		
			
				
					    tableExists : false ,  
			
		
	
		
			
				
					    hasExpectedColumns : false ,  
			
		
	
		
			
				
					    errors :  [ ]  
			
		
	
		
			
				
					    errors :  [ ] ,  
			
		
	
		
			
				
					  } ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					  try  {  
			
		
	
		
			
				
					    if  ( migration . name  ===  "001_initial" )  {  
			
		
	
		
			
				
					      // Validate core tables exist for initial migration
  
			
		
	
		
			
				
					      const  tables  =  [ 'accounts' ,  'secret' ,  'settings' ,  'contacts' ,  'logs' ,  'temp' ] ;  
			
		
	
		
			
				
					       
			
		
	
		
			
				
					      const  tables  =  [  
			
		
	
		
			
				
					        "accounts" ,  
			
		
	
		
			
				
					        "secret" ,  
			
		
	
		
			
				
					        "settings" ,  
			
		
	
		
			
				
					        "contacts" ,  
			
		
	
		
			
				
					        "logs" ,  
			
		
	
		
			
				
					        "temp" ,  
			
		
	
		
			
				
					      ] ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					      for  ( const  tableName  of  tables )  {  
			
		
	
		
			
				
					        try  {  
			
		
	
		
			
				
					          await  sqlQuery ( ` SELECT name FROM sqlite_master WHERE type='table' AND name=' ${ tableName } ' ` ) ;  
			
		
	
		
			
				
					          console . log ( ` ✅ [Migration-Validation] Table  ${ tableName }  exists ` ) ;  
			
		
	
		
			
				
					          await  sqlQuery (  
			
		
	
		
			
				
					            ` SELECT name FROM sqlite_master WHERE type='table' AND name=' ${ tableName } ' ` ,  
			
		
	
		
			
				
					          ) ;  
			
		
	
		
			
				
					          logger . log ( ` ✅ [Migration-Validation] Table  ${ tableName }  exists ` ) ;  
			
		
	
		
			
				
					        }  catch  ( error )  {  
			
		
	
		
			
				
					          validation . isValid  =  false ;  
			
		
	
		
			
				
					          validation . errors . push ( ` Table  ${ tableName }  missing ` ) ;  
			
		
	
		
			
				
					          console . error ( ` ❌ [Migration-Validation] Table  ${ tableName }  missing: ` ,  error ) ;  
			
		
	
		
			
				
					          logger . error (  
			
		
	
		
			
				
					            ` ❌ [Migration-Validation] Table  ${ tableName }  missing: ` ,  
			
		
	
		
			
				
					            error ,  
			
		
	
		
			
				
					          ) ;  
			
		
	
		
			
				
					        }  
			
		
	
		
			
				
					      }  
			
		
	
		
			
				
					      validation . tableExists  =  validation . errors . length  ===  0 ;  
			
		
	
		
			
				
					       
			
		
	
		
			
				
					    }  else  if  ( migration . name  ===  "002_add_iViewContent_to_contacts" )  {  
			
		
	
		
			
				
					      // Validate iViewContent column exists in contacts table
  
			
		
	
		
			
				
					      try  {  
			
		
	
		
			
				
					        await  sqlQuery ( ` SELECT iViewContent FROM contacts LIMIT 1 ` ) ;  
			
		
	
		
			
				
					        validation . hasExpectedColumns  =  true ;  
			
		
	
		
			
				
					        console . log ( ` ✅ [Migration-Validation] Column iViewContent exists in contacts table ` ) ;  
			
		
	
		
			
				
					        logger . log (  
			
		
	
		
			
				
					          ` ✅ [Migration-Validation] Column iViewContent exists in contacts table ` ,  
			
		
	
		
			
				
					        ) ;  
			
		
	
		
			
				
					      }  catch  ( error )  {  
			
		
	
		
			
				
					        validation . isValid  =  false ;  
			
		
	
		
			
				
					        validation . errors . push ( ` Column iViewContent missing from contacts table ` ) ;  
			
		
	
		
			
				
					        console . error ( ` ❌ [Migration-Validation] Column iViewContent missing: ` ,  error ) ;  
			
		
	
		
			
				
					        validation . errors . push (  
			
		
	
		
			
				
					          ` Column iViewContent missing from contacts table ` ,  
			
		
	
		
			
				
					        ) ;  
			
		
	
		
			
				
					        logger . error (  
			
		
	
		
			
				
					          ` ❌ [Migration-Validation] Column iViewContent missing: ` ,  
			
		
	
		
			
				
					          error ,  
			
		
	
		
			
				
					        ) ;  
			
		
	
		
			
				
					      }  
			
		
	
		
			
				
					    }  
			
		
	
		
			
				
					     
			
		
	
		
			
				
					
  
			
		
	
		
			
				
					    // Add validation for future migrations here
  
			
		
	
		
			
				
					    // } else if (migration.name === "003_future_migration") {
  
			
		
	
		
			
				
					    //   // Validate future migration schema changes
  
			
		
	
		
			
				
					    // }
  
			
		
	
		
			
				
					     
			
		
	
		
			
				
					  }  catch  ( error )  {  
			
		
	
		
			
				
					    validation . isValid  =  false ;  
			
		
	
		
			
				
					    validation . errors . push ( ` Validation error:  ${ error } ` ) ;  
			
		
	
		
			
				
					    console . error ( ` ❌ [Migration-Validation] Validation failed for  ${ migration . name } : ` ,  error ) ;  
			
		
	
		
			
				
					    logger . error (  
			
		
	
		
			
				
					      ` ❌ [Migration-Validation] Validation failed for  ${ migration . name } : ` ,  
			
		
	
		
			
				
					      error ,  
			
		
	
		
			
				
					    ) ;  
			
		
	
		
			
				
					  }  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					  return  validation ;  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -282,16 +302,16 @@ async function validateMigrationApplication<T>( 
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					/ * *  
			
		
	
		
			
				
					 *  Check  if  migration  is  already  applied  by  examining  actual  schema  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  This  function  performs  schema  introspection  to  determine  if  a  migration  
			
		
	
		
			
				
					 *  has  already  been  applied ,  even  if  it ' s  not  recorded  in  the  migrations  
			
		
	
		
			
				
					 *  table .  This  is  useful  for  handling  cases  where  the  database  schema  exists  
			
		
	
		
			
				
					 *  but  the  migration  tracking  got  out  of  sync .  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  @param  migration  -  The  migration  to  check  
			
		
	
		
			
				
					 *  @param  sqlQuery  -  Function  to  execute  SQL  queries  
			
		
	
		
			
				
					 *  @returns  Promise  resolving  to  true  if  schema  already  exists  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  @example  
			
		
	
		
			
				
					 *  ` ` ` typescript
  
			
		
	
		
			
				
					 *  const  schemaExists  =  await  isSchemaAlreadyPresent ( migration ,  sqlQuery ) ;  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -307,33 +327,40 @@ async function isSchemaAlreadyPresent<T>( 
			
		
	
		
			
				
					  try  {  
			
		
	
		
			
				
					    if  ( migration . name  ===  "001_initial" )  {  
			
		
	
		
			
				
					      // Check if accounts table exists (primary indicator of initial migration)
  
			
		
	
		
			
				
					      const  result  =  await  sqlQuery ( ` SELECT name FROM sqlite_master WHERE type='table' AND name='accounts' ` )  as  any ;  
			
		
	
		
			
				
					      const  hasTable  =  result ? . values ? . length  >  0  ||  ( Array . isArray ( result )  &&  result . length  >  0 ) ;  
			
		
	
		
			
				
					      console . log ( ` 🔍 [Migration-Schema] Initial migration schema check - accounts table exists:  ${ hasTable } ` ) ;  
			
		
	
		
			
				
					      const  result  =  ( await  sqlQuery (  
			
		
	
		
			
				
					        ` SELECT name FROM sqlite_master WHERE type='table' AND name='accounts' ` ,  
			
		
	
		
			
				
					      ) )  as  unknown  as  {  values : unknown [ ] [ ]  } ;  
			
		
	
		
			
				
					      const  hasTable  =  
			
		
	
		
			
				
					        result ? . values ? . length  >  0  ||  
			
		
	
		
			
				
					        ( Array . isArray ( result )  &&  result . length  >  0 ) ;  
			
		
	
		
			
				
					      logger . log (  
			
		
	
		
			
				
					        ` 🔍 [Migration-Schema] Initial migration schema check - accounts table exists:  ${ hasTable } ` ,  
			
		
	
		
			
				
					      ) ;  
			
		
	
		
			
				
					      return  hasTable ;  
			
		
	
		
			
				
					       
			
		
	
		
			
				
					    }  else  if  ( migration . name  ===  "002_add_iViewContent_to_contacts" )  {  
			
		
	
		
			
				
					      // Check if iViewContent column exists in contacts table
  
			
		
	
		
			
				
					      try  {  
			
		
	
		
			
				
					        await  sqlQuery ( ` SELECT iViewContent FROM contacts LIMIT 1 ` ) ;  
			
		
	
		
			
				
					        console . log ( ` 🔍 [Migration-Schema] iViewContent column already exists ` ) ;  
			
		
	
		
			
				
					        logger . log ( ` 🔍 [Migration-Schema] iViewContent column already exists ` ) ;  
			
		
	
		
			
				
					        return  true ;  
			
		
	
		
			
				
					      }  catch  ( error )  {  
			
		
	
		
			
				
					        console . log ( ` 🔍 [Migration-Schema] iViewContent column does not exist ` ) ;  
			
		
	
		
			
				
					        logger . log ( ` 🔍 [Migration-Schema] iViewContent column does not exist ` ) ;  
			
		
	
		
			
				
					        return  false ;  
			
		
	
		
			
				
					      }  
			
		
	
		
			
				
					    }  
			
		
	
		
			
				
					      
			
		
	
		
			
				
					
  
			
		
	
		
			
				
					    // Add schema checks for future migrations here
  
			
		
	
		
			
				
					    // } else if (migration.name === "003_future_migration") {
  
			
		
	
		
			
				
					    //   // Check if future migration schema already exists
  
			
		
	
		
			
				
					    // }
  
			
		
	
		
			
				
					     
			
		
	
		
			
				
					  }  catch  ( error )  {  
			
		
	
		
			
				
					    console . log ( ` 🔍 [Migration-Schema] Schema check failed for  ${ migration . name } , assuming not present: ` ,  error ) ;  
			
		
	
		
			
				
					    logger . log (  
			
		
	
		
			
				
					      ` 🔍 [Migration-Schema] Schema check failed for  ${ migration . name } , assuming not present: ` ,  
			
		
	
		
			
				
					      error ,  
			
		
	
		
			
				
					    ) ;  
			
		
	
		
			
				
					    return  false ;  
			
		
	
		
			
				
					  }  
			
		
	
		
			
				
					   
			
		
	
		
			
				
					
  
			
		
	
		
			
				
					  return  false ;  
			
		
	
		
			
				
					}  
			
		
	
		
			
				
					
 
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -347,7 +374,7 @@ async function isSchemaAlreadyPresent<T>( 
			
		
	
		
			
				
					 *  4 .  Validates  that  migrations  were  applied  correctly  
			
		
	
		
			
				
					 *  5 .  Records  successful  migrations  in  the  tracking  table  
			
		
	
		
			
				
					 *  6 .  Performs  final  validation  of  the  migration  state  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  The  function  is  designed  to  be  idempotent  -  it  can  be  run  multiple  times  
			
		
	
		
			
				
					 *  safely  without  re - applying  migrations  that  have  already  been  completed .  
			
		
	
		
			
				
					 *  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -357,22 +384,22 @@ async function isSchemaAlreadyPresent<T>( 
			
		
	
		
			
				
					 *  @param  extractMigrationNames  -  Function  to  extract  migration  names  from  query  results  
			
		
	
		
			
				
					 *  @returns  Promise  that  resolves  when  all  migrations  are  complete  
			
		
	
		
			
				
					 *  @throws  { Error }  If  any  migration  fails  to  apply  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  @example  
			
		
	
		
			
				
					 *  ` ` ` typescript
  
			
		
	
		
			
				
					 *  // Platform-specific implementation
  
			
		
	
		
			
				
					 *  const  sqlExec  =  async  ( sql : string ,  params? : unknown [ ] )  = >  {  
			
		
	
		
			
				
					 *    return  await  db . run ( sql ,  params ) ;  
			
		
	
		
			
				
					 *  } ;  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  const  sqlQuery  =  async  ( sql : string ,  params? : unknown [ ] )  = >  {  
			
		
	
		
			
				
					 *    return  await  db . query ( sql ,  params ) ;  
			
		
	
		
			
				
					 *  } ;  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  const  extractNames  =  ( result : DBResult )  = >  {  
			
		
	
		
			
				
					 *    return  new  Set ( result . values . map ( row  = >  row [ 0 ] ) ) ;  
			
		
	
		
			
				
					 *  } ;  
			
		
	
		
			
				
					 *    
			
		
	
		
			
				
					 *  
			
		
	
		
			
				
					 *  await  runMigrations ( sqlExec ,  sqlQuery ,  extractNames ) ;  
			
		
	
		
			
				
					 *  ` ` `  
			
		
	
		
			
				
					 * /  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -382,113 +409,146 @@ export async function runMigrations<T>( 
			
		
	
		
			
				
					  extractMigrationNames :  ( result : T )  = >  Set < string > ,  
			
		
	
		
			
				
					) :  Promise < void >  {  
			
		
	
		
			
				
					  try  {  
			
		
	
		
			
				
					    console . log ( "📋 [Migration] Starting migration process..." ) ;  
			
		
	
		
			
				
					      
			
		
	
		
			
				
					    logger . log ( "📋 [Migration] Starting migration process..." ) ;  
			
		
	
		
			
				
					
  
			
		
	
		
			
				
					    // Step 1: Create migrations table if it doesn't exist
  
			
		
	
		
			
				
					    // Note: We use IF NOT EXISTS here because this is infrastructure, not a business migration
  
			
		
	
		
			
				
					    console . log ( "🔧 [Migration] Creating migrations table if it doesn't exist..." ) ;  
			
		
	
		
			
				
					    logger . log (  
			
		
	
		
			
				
					      "🔧 [Migration] Creating migrations table if it doesn't exist..." ,  
			
		
	
		
			
				
					    ) ;  
			
		
	
		
			
				
					    await  sqlExec ( `  
			
		
	
		
			
				
					      CREATE  TABLE  IF  NOT  EXISTS  migrations  (  
			
		
	
		
			
				
					        name  TEXT  PRIMARY  KEY ,  
			
		
	
		
			
				
					        applied_at  TEXT  DEFAULT  CURRENT_TIMESTAMP  
			
		
	
		
			
				
					      ) ;  
			
		
	
		
			
				
					    ` );
  
			
		
	
		
			
				
					    console . log ( "✅ [Migration] Migrations table ready" ) ;  
			
		
	
		
			
				
					    logger . log ( "✅ [Migration] Migrations table ready" ) ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					    // Step 2: Get list of already applied migrations
  
			
		
	
		
			
				
					    console . log ( "🔍 [Migration] Querying existing migrations..." ) ;  
			
		
	
		
			
				
					    logger . log ( "🔍 [Migration] Querying existing migrations..." ) ;  
			
		
	
		
			
				
					    const  appliedMigrationsResult  =  await  sqlQuery (  
			
		
	
		
			
				
					      "SELECT name FROM migrations" ,  
			
		
	
		
			
				
					    ) ;  
			
		
	
		
			
				
					    console . log ( "📊 [Migration] Raw query result:" ,  appliedMigrationsResult ) ;  
			
		
	
		
			
				
					      
			
		
	
		
			
				
					    logger . log ( "📊 [Migration] Raw query result:" ,  appliedMigrationsResult ) ;  
			
		
	
		
			
				
					
  
			
		
	
		
			
				
					    const  appliedMigrations  =  extractMigrationNames ( appliedMigrationsResult ) ;  
			
		
	
		
			
				
					    console . log ( "📋 [Migration] Extracted applied migrations:" ,  Array . from ( appliedMigrations ) ) ;  
			
		
	
		
			
				
					    logger . log (  
			
		
	
		
			
				
					      "📋 [Migration] Extracted applied migrations:" ,  
			
		
	
		
			
				
					      Array . from ( appliedMigrations ) ,  
			
		
	
		
			
				
					    ) ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					    // Step 3: Get all registered migrations
  
			
		
	
		
			
				
					    const  migrations  =  migrationRegistry . getMigrations ( ) ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					    if  ( migrations . length  ===  0 )  {  
			
		
	
		
			
				
					      console . log ( "⚠️  [Migration] No migrations registered" ) ;  
			
		
	
		
			
				
					      logger . warn ( "⚠️  [Migration] No migrations registered" ) ;  
			
		
	
		
			
				
					      logger . warn ( "[MigrationService] No migrations registered" ) ;  
			
		
	
		
			
				
					      return ;  
			
		
	
		
			
				
					    }  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					    console . log ( ` 📊 [Migration] Found  ${ migrations . length }  total migrations,  ${ appliedMigrations . size }  already applied ` ) ;  
			
		
	
		
			
				
					    console . log ( ` 📝 [Migration] Registered migrations:  ${ migrations . map ( m  = >  m . name ) . join ( ', ' ) } ` ) ;  
			
		
	
		
			
				
					    logger . log (  
			
		
	
		
			
				
					      ` 📊 [Migration] Found  ${ migrations . length }  total migrations,  ${ appliedMigrations . size }  already applied ` ,  
			
		
	
		
			
				
					    ) ;  
			
		
	
		
			
				
					    logger . log (  
			
		
	
		
			
				
					      ` 📝 [Migration] Registered migrations:  ${ migrations . map ( ( m )  = >  m . name ) . join ( ", " ) } ` ,  
			
		
	
		
			
				
					    ) ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					    let  appliedCount  =  0 ;  
			
		
	
		
			
				
					    let  skippedCount  =  0 ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					    // Step 4: Process each migration
  
			
		
	
		
			
				
					    for  ( const  migration  of  migrations )  {  
			
		
	
		
			
				
					      console . log ( ` \ n🔍 [Migration] Processing migration:  ${ migration . name } ` ) ;  
			
		
	
		
			
				
					        
			
		
	
		
			
				
					      logger . log ( ` \ n🔍 [Migration] Processing migration:  ${ migration . name } ` ) ;  
			
		
	
		
			
				
					
  
			
		
	
		
			
				
					      // Check 1: Is it recorded as applied in migrations table?
  
			
		
	
		
			
				
					      const  isRecordedAsApplied  =  appliedMigrations . has ( migration . name ) ;  
			
		
	
		
			
				
					        
			
		
	
		
			
				
					
  
			
		
	
		
			
				
					      // Check 2: Does the schema already exist in the database?
  
			
		
	
		
			
				
					      const  isSchemaPresent  =  await  isSchemaAlreadyPresent ( migration ,  sqlQuery ) ;  
			
		
	
		
			
				
					       
			
		
	
		
			
				
					      console . log ( ` 🔍 [Migration]  ${ migration . name }  - Recorded:  ${ isRecordedAsApplied } , Schema:  ${ isSchemaPresent } ` ) ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					      logger . log (  
			
		
	
		
			
				
					        ` 🔍 [Migration]  ${ migration . name }  - Recorded:  ${ isRecordedAsApplied } , Schema:  ${ isSchemaPresent } ` ,  
			
		
	
		
			
				
					      ) ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					      // Skip if already recorded as applied
  
			
		
	
		
			
				
					      if  ( isRecordedAsApplied )  {  
			
		
	
		
			
				
					        console . log ( ` ⏭️  [Migration] Skipping already applied:  ${ migration . name } ` ) ;  
			
		
	
		
			
				
					        logger . log (  
			
		
	
		
			
				
					          ` ⏭️  [Migration] Skipping already applied:  ${ migration . name } ` ,  
			
		
	
		
			
				
					        ) ;  
			
		
	
		
			
				
					        skippedCount ++ ;  
			
		
	
		
			
				
					        continue ;  
			
		
	
		
			
				
					      }  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					      // Handle case where schema exists but isn't recorded
  
			
		
	
		
			
				
					      if  ( isSchemaPresent )  {  
			
		
	
		
			
				
					        console . log ( ` 🔄 [Migration] Schema exists but not recorded. Marking  ${ migration . name }  as applied... ` ) ;  
			
		
	
		
			
				
					        logger . log (  
			
		
	
		
			
				
					          ` 🔄 [Migration] Schema exists but not recorded. Marking  ${ migration . name }  as applied... ` ,  
			
		
	
		
			
				
					        ) ;  
			
		
	
		
			
				
					        try  {  
			
		
	
		
			
				
					          const  insertResult  =  await  sqlExec ( "INSERT INTO migrations (name) VALUES (?)" ,  [  
			
		
	
		
			
				
					            migration . name ,  
			
		
	
		
			
				
					          ] ) ;  
			
		
	
		
			
				
					          console . log ( ` ✅ [Migration] Migration record inserted: ` ,  insertResult ) ;  
			
		
	
		
			
				
					          console . log ( ` ✅ [Migration] Marked existing schema as applied:  ${ migration . name } ` ) ;  
			
		
	
		
			
				
					          const  insertResult  =  await  sqlExec (  
			
		
	
		
			
				
					            "INSERT INTO migrations (name) VALUES (?)" ,  
			
		
	
		
			
				
					            [ migration . name ] ,  
			
		
	
		
			
				
					          ) ;  
			
		
	
		
			
				
					          logger . log ( ` ✅ [Migration] Migration record inserted: ` ,  insertResult ) ;  
			
		
	
		
			
				
					          logger . log (  
			
		
	
		
			
				
					            ` ✅ [Migration] Marked existing schema as applied:  ${ migration . name } ` ,  
			
		
	
		
			
				
					          ) ;  
			
		
	
		
			
				
					          skippedCount ++ ;  
			
		
	
		
			
				
					          continue ;  
			
		
	
		
			
				
					        }  catch  ( insertError )  {  
			
		
	
		
			
				
					          console . warn ( ` ⚠️  [Migration] Could not record existing schema  ${ migration . name } : ` ,  insertError ) ;  
			
		
	
		
			
				
					          logger . warn (  
			
		
	
		
			
				
					            ` ⚠️  [Migration] Could not record existing schema  ${ migration . name } : ` ,  
			
		
	
		
			
				
					            insertError ,  
			
		
	
		
			
				
					          ) ;  
			
		
	
		
			
				
					          // Continue with normal migration process as fallback
  
			
		
	
		
			
				
					        }  
			
		
	
		
			
				
					      }  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					      // Apply the migration
  
			
		
	
		
			
				
					      console . log ( ` 🔄 [Migration] Applying migration:  ${ migration . name } ` ) ;  
			
		
	
		
			
				
					      logger . log ( ` 🔄 [Migration] Applying migration:  ${ migration . name } ` ) ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					      try  {  
			
		
	
		
			
				
					        // Execute the migration SQL
  
			
		
	
		
			
				
					        console . log ( ` 🔧 [Migration] Executing SQL for  ${ migration . name } ... ` ) ;  
			
		
	
		
			
				
					        logger . log ( ` 🔧 [Migration] Executing SQL for  ${ migration . name } ... ` ) ;  
			
		
	
		
			
				
					        await  sqlExec ( migration . sql ) ;  
			
		
	
		
			
				
					        console . log ( ` ✅ [Migration] SQL executed successfully for  ${ migration . name } ` ) ;  
			
		
	
		
			
				
					        logger . log (  
			
		
	
		
			
				
					          ` ✅ [Migration] SQL executed successfully for  ${ migration . name } ` ,  
			
		
	
		
			
				
					        ) ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					        // Validate the migration was applied correctly
  
			
		
	
		
			
				
					        const  validation  =  await  validateMigrationApplication ( migration ,  sqlQuery ) ;  
			
		
	
		
			
				
					        const  validation  =  await  validateMigrationApplication (  
			
		
	
		
			
				
					          migration ,  
			
		
	
		
			
				
					          sqlQuery ,  
			
		
	
		
			
				
					        ) ;  
			
		
	
		
			
				
					        if  ( ! validation . isValid )  {  
			
		
	
		
			
				
					          console . warn ( ` ⚠️  [Migration] Validation failed for  ${ migration . name } : ` ,  validation . errors ) ;  
			
		
	
		
			
				
					          logger . warn (  
			
		
	
		
			
				
					            ` ⚠️  [Migration] Validation failed for  ${ migration . name } : ` ,  
			
		
	
		
			
				
					            validation . errors ,  
			
		
	
		
			
				
					          ) ;  
			
		
	
		
			
				
					        }  else  {  
			
		
	
		
			
				
					          console . log ( ` ✅ [Migration] Schema validation passed for  ${ migration . name } ` ) ;  
			
		
	
		
			
				
					          logger . log (  
			
		
	
		
			
				
					            ` ✅ [Migration] Schema validation passed for  ${ migration . name } ` ,  
			
		
	
		
			
				
					          ) ;  
			
		
	
		
			
				
					        }  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					        // Record that the migration was applied
  
			
		
	
		
			
				
					        console . log ( ` 📝 [Migration] Recording migration  ${ migration . name }  as applied... ` ) ;  
			
		
	
		
			
				
					        const  insertResult  =  await  sqlExec ( "INSERT INTO migrations (name) VALUES (?)" ,  [  
			
		
	
		
			
				
					          migration . name ,  
			
		
	
		
			
				
					        ] ) ;  
			
		
	
		
			
				
					        console . log ( ` ✅ [Migration] Migration record inserted: ` ,  insertResult ) ;  
			
		
	
		
			
				
					        logger . log (  
			
		
	
		
			
				
					          ` 📝 [Migration] Recording migration  ${ migration . name }  as applied... ` ,  
			
		
	
		
			
				
					        ) ;  
			
		
	
		
			
				
					        const  insertResult  =  await  sqlExec (  
			
		
	
		
			
				
					          "INSERT INTO migrations (name) VALUES (?)" ,  
			
		
	
		
			
				
					          [ migration . name ] ,  
			
		
	
		
			
				
					        ) ;  
			
		
	
		
			
				
					        logger . log ( ` ✅ [Migration] Migration record inserted: ` ,  insertResult ) ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					        console . log ( ` 🎉 [Migration] Successfully applied:  ${ migration . name } ` ) ;  
			
		
	
		
			
				
					        logger . log ( ` 🎉 [Migration] Successfully applied:  ${ migration . name } ` ) ;  
			
		
	
		
			
				
					        logger . info (  
			
		
	
		
			
				
					          ` [MigrationService] Successfully applied migration:  ${ migration . name } ` ,  
			
		
	
		
			
				
					        ) ;  
			
		
	
		
			
				
					        appliedCount ++ ;  
			
		
	
		
			
				
					         
			
		
	
		
			
				
					      }  catch  ( error )  {  
			
		
	
		
			
				
					        console . error ( ` ❌ [Migration] Error applying  ${ migration . name } : ` ,  error ) ;  
			
		
	
		
			
				
					          
			
		
	
		
			
				
					        logger . error ( ` ❌ [Migration] Error applying  ${ migration . name } : ` ,  error ) ;  
			
		
	
		
			
				
					
  
			
		
	
		
			
				
					        // Handle specific cases where the migration might be partially applied
  
			
		
	
		
			
				
					        const  errorMessage  =  String ( error ) . toLowerCase ( ) ;  
			
		
	
		
			
				
					
 
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -497,33 +557,53 @@ export async function runMigrations<T>( 
			
		
	
		
			
				
					          errorMessage . includes ( "duplicate column" )  ||  
			
		
	
		
			
				
					          errorMessage . includes ( "column already exists" )  ||  
			
		
	
		
			
				
					          errorMessage . includes ( "already exists" )  ||  
			
		
	
		
			
				
					          errorMessage . includes ( "table" )  &&  errorMessage . includes ( "already exists" )  
			
		
	
		
			
				
					          ( errorMessage . includes ( "table" )  &&  
			
		
	
		
			
				
					            errorMessage . includes ( "already exists" ) )  
			
		
	
		
			
				
					        )  {  
			
		
	
		
			
				
					          console . log ( ` ⚠️  [Migration]  ${ migration . name }  appears already applied ( ${ errorMessage } ). Validating and marking as complete. ` ) ;  
			
		
	
		
			
				
					           
			
		
	
		
			
				
					          logger . log (  
			
		
	
		
			
				
					            ` ⚠️  [Migration]  ${ migration . name }  appears already applied ( ${ errorMessage } ). Validating and marking as complete. ` ,  
			
		
	
		
			
				
					          ) ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					          // Validate the existing schema
  
			
		
	
		
			
				
					          const  validation  =  await  validateMigrationApplication ( migration ,  sqlQuery ) ;  
			
		
	
		
			
				
					          const  validation  =  await  validateMigrationApplication (  
			
		
	
		
			
				
					            migration ,  
			
		
	
		
			
				
					            sqlQuery ,  
			
		
	
		
			
				
					          ) ;  
			
		
	
		
			
				
					          if  ( validation . isValid )  {  
			
		
	
		
			
				
					            console . log ( ` ✅ [Migration] Schema validation passed for  ${ migration . name } ` ) ;  
			
		
	
		
			
				
					            logger . log (  
			
		
	
		
			
				
					              ` ✅ [Migration] Schema validation passed for  ${ migration . name } ` ,  
			
		
	
		
			
				
					            ) ;  
			
		
	
		
			
				
					          }  else  {  
			
		
	
		
			
				
					            console . warn ( ` ⚠️  [Migration] Schema validation failed for  ${ migration . name } : ` ,  validation . errors ) ;  
			
		
	
		
			
				
					            logger . warn (  
			
		
	
		
			
				
					              ` ⚠️  [Migration] Schema validation failed for  ${ migration . name } : ` ,  
			
		
	
		
			
				
					              validation . errors ,  
			
		
	
		
			
				
					            ) ;  
			
		
	
		
			
				
					          }  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					          // Mark the migration as applied since the schema change already exists
  
			
		
	
		
			
				
					          try  {  
			
		
	
		
			
				
					            console . log ( ` 📝 [Migration] Attempting to record  ${ migration . name }  as applied despite error... ` ) ;  
			
		
	
		
			
				
					            const  insertResult  =  await  sqlExec ( "INSERT INTO migrations (name) VALUES (?)" ,  [  
			
		
	
		
			
				
					              migration . name ,  
			
		
	
		
			
				
					            ] ) ;  
			
		
	
		
			
				
					            console . log ( ` ✅ [Migration] Migration record inserted after error: ` ,  insertResult ) ;  
			
		
	
		
			
				
					            console . log ( ` ✅ [Migration] Marked as applied:  ${ migration . name } ` ) ;  
			
		
	
		
			
				
					            logger . log (  
			
		
	
		
			
				
					              ` 📝 [Migration] Attempting to record  ${ migration . name }  as applied despite error... ` ,  
			
		
	
		
			
				
					            ) ;  
			
		
	
		
			
				
					            const  insertResult  =  await  sqlExec (  
			
		
	
		
			
				
					              "INSERT INTO migrations (name) VALUES (?)" ,  
			
		
	
		
			
				
					              [ migration . name ] ,  
			
		
	
		
			
				
					            ) ;  
			
		
	
		
			
				
					            logger . log (  
			
		
	
		
			
				
					              ` ✅ [Migration] Migration record inserted after error: ` ,  
			
		
	
		
			
				
					              insertResult ,  
			
		
	
		
			
				
					            ) ;  
			
		
	
		
			
				
					            logger . log ( ` ✅ [Migration] Marked as applied:  ${ migration . name } ` ) ;  
			
		
	
		
			
				
					            logger . info (  
			
		
	
		
			
				
					              ` [MigrationService] Successfully marked migration as applied:  ${ migration . name } ` ,  
			
		
	
		
			
				
					            ) ;  
			
		
	
		
			
				
					            appliedCount ++ ;  
			
		
	
		
			
				
					          }  catch  ( insertError )  {  
			
		
	
		
			
				
					            // If we can't insert the migration record, log it but don't fail
  
			
		
	
		
			
				
					            console . warn ( ` ⚠️  [Migration] Could not record  ${ migration . name }  as applied: ` ,  insertError ) ;  
			
		
	
		
			
				
					            logger . warn (  
			
		
	
		
			
				
					              ` ⚠️  [Migration] Could not record  ${ migration . name }  as applied: ` ,  
			
		
	
		
			
				
					              insertError ,  
			
		
	
		
			
				
					            ) ;  
			
		
	
		
			
				
					            logger . warn (  
			
		
	
		
			
				
					              ` [MigrationService] Could not record migration  ${ migration . name }  as applied: ` ,  
			
		
	
		
			
				
					              insertError ,  
			
		
	
	
		
			
				
					
						
						
						
							
								 
						
					 
				
				@ -531,40 +611,55 @@ export async function runMigrations<T>( 
			
		
	
		
			
				
					          }  
			
		
	
		
			
				
					        }  else  {  
			
		
	
		
			
				
					          // For other types of errors, still fail the migration
  
			
		
	
		
			
				
					          console . error ( ` ❌ [Migration] Failed to apply  ${ migration . name } : ` ,  error ) ;  
			
		
	
		
			
				
					        logger . error (  
			
		
	
		
			
				
					          ` [MigrationService] Failed to apply migration  ${ migration . name } : ` ,  
			
		
	
		
			
				
					          error ,  
			
		
	
		
			
				
					        ) ;  
			
		
	
		
			
				
					        throw  new  Error ( ` Migration  ${ migration . name }  failed:  ${ error } ` ) ;  
			
		
	
		
			
				
					          logger . error (  
			
		
	
		
			
				
					            ` ❌ [Migration] Failed to apply  ${ migration . name } : ` ,  
			
		
	
		
			
				
					            error ,  
			
		
	
		
			
				
					          ) ;  
			
		
	
		
			
				
					          logger . error (  
			
		
	
		
			
				
					            ` [MigrationService] Failed to apply migration  ${ migration . name } : ` ,  
			
		
	
		
			
				
					            error ,  
			
		
	
		
			
				
					          ) ;  
			
		
	
		
			
				
					          throw  new  Error ( ` Migration  ${ migration . name }  failed:  ${ error } ` ) ;  
			
		
	
		
			
				
					        }  
			
		
	
		
			
				
					      }  
			
		
	
		
			
				
					    }  
			
		
	
		
			
				
					    }  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					    // Step 5: Final validation - verify all migrations are properly recorded
  
			
		
	
		
			
				
					    console . log ( "\n🔍 [Migration] Final validation - checking migrations table..." ) ;  
			
		
	
		
			
				
					    logger . log (  
			
		
	
		
			
				
					      "\n🔍 [Migration] Final validation - checking migrations table..." ,  
			
		
	
		
			
				
					    ) ;  
			
		
	
		
			
				
					    const  finalMigrationsResult  =  await  sqlQuery ( "SELECT name FROM migrations" ) ;  
			
		
	
		
			
				
					    const  finalAppliedMigrations  =  extractMigrationNames ( finalMigrationsResult ) ;  
			
		
	
		
			
				
					    console . log ( "📋 [Migration] Final applied migrations:" ,  Array . from ( finalAppliedMigrations ) ) ;  
			
		
	
		
			
				
					    logger . log (  
			
		
	
		
			
				
					      "📋 [Migration] Final applied migrations:" ,  
			
		
	
		
			
				
					      Array . from ( finalAppliedMigrations ) ,  
			
		
	
		
			
				
					    ) ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					    // Check that all expected migrations are recorded
  
			
		
	
		
			
				
					    const  expectedMigrations  =  new  Set ( migrations . map ( m  = >  m . name ) ) ;  
			
		
	
		
			
				
					    const  missingMigrations  =  [ . . . expectedMigrations ] . filter ( name  = >  ! finalAppliedMigrations . has ( name ) ) ;  
			
		
	
		
			
				
					     
			
		
	
		
			
				
					    const  expectedMigrations  =  new  Set ( migrations . map ( ( m )  = >  m . name ) ) ;  
			
		
	
		
			
				
					    const  missingMigrations  =  [ . . . expectedMigrations ] . filter (  
			
		
	
		
			
				
					      ( name )  = >  ! finalAppliedMigrations . has ( name ) ,  
			
		
	
		
			
				
					    ) ;  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					    if  ( missingMigrations . length  >  0 )  {  
			
		
	
		
			
				
					      console . warn ( ` ⚠️  [Migration] Missing migration records:  ${ missingMigrations . join ( ', ' ) } ` ) ;  
			
		
	
		
			
				
					      logger . warn ( ` [MigrationService] Missing migration records:  ${ missingMigrations . join ( ', ' ) } ` ) ;  
			
		
	
		
			
				
					      logger . warn (  
			
		
	
		
			
				
					        ` ⚠️  [Migration] Missing migration records:  ${ missingMigrations . join ( ", " ) } ` ,  
			
		
	
		
			
				
					      ) ;  
			
		
	
		
			
				
					      logger . warn (  
			
		
	
		
			
				
					        ` [MigrationService] Missing migration records:  ${ missingMigrations . join ( ", " ) } ` ,  
			
		
	
		
			
				
					      ) ;  
			
		
	
		
			
				
					    }  
			
		
	
		
			
				
					
 
			
		
	
		
			
				
					    console . log ( ` \ n🎉 [Migration] Migration process complete! ` ) ;  
			
		
	
		
			
				
					    console . log ( ` 📊 [Migration] Summary: Applied:  ${ appliedCount } , Skipped:  ${ skippedCount } , Total:  ${ migrations . length } ` ) ;  
			
		
	
		
			
				
					    logger . info ( ` [MigrationService] Migration process complete. Applied:  ${ appliedCount } , Skipped:  ${ skippedCount } ` ) ;  
			
		
	
		
			
				
					     
			
		
	
		
			
				
					    logger . log ( ` \ n🎉 [Migration] Migration process complete! ` ) ;  
			
		
	
		
			
				
					    logger . log (  
			
		
	
		
			
				
					      ` 📊 [Migration] Summary: Applied:  ${ appliedCount } , Skipped:  ${ skippedCount } , Total:  ${ migrations . length } ` ,  
			
		
	
		
			
				
					    ) ;  
			
		
	
		
			
				
					    logger . info (  
			
		
	
		
			
				
					      ` [MigrationService] Migration process complete. Applied:  ${ appliedCount } , Skipped:  ${ skippedCount } ` ,  
			
		
	
		
			
				
					    ) ;  
			
		
	
		
			
				
					  }  catch  ( error )  {  
			
		
	
		
			
				
					    console . error ( "\n💥 [Migration] Migration process failed:" ,  error ) ;  
			
		
	
		
			
				
					    logger . error ( "\n💥 [Migration] Migration process failed:" ,  error ) ;  
			
		
	
		
			
				
					    logger . error ( "[MigrationService] Migration process failed:" ,  error ) ;  
			
		
	
		
			
				
					    throw  error ;  
			
		
	
		
			
				
					  }  
			
		
	
		
			
				
					}