9.9 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	Database Migration Guide
Overview
The Database Migration feature allows you to compare and migrate data between Dexie (IndexedDB) and SQLite databases in the TimeSafari application. This is particularly useful during the transition from the old Dexie-based storage system to the new SQLite-based system.
⚠️ UPDATE: The migration is now controlled through the PlatformServiceMixin rather than a USE_DEXIE_DB constant. This provides a cleaner, more maintainable approach to database access control.
Features
1. Database Comparison
- Compare data between Dexie and SQLite databases
- View detailed differences in contacts and settings
- Identify added, modified, and missing records
- Export comparison results for analysis
2. Data Migration
- Migrate contacts from Dexie to SQLite
- Migrate settings from Dexie to SQLite
- Option to overwrite existing records or skip them
- Comprehensive error handling and reporting
3. User Interface
- Modern, responsive UI built with Tailwind CSS
- Real-time loading states and progress indicators
- Clear success and error messaging
- Export functionality for comparison data
Prerequisites
Enable Dexie Database Access
Before using the migration features, you must ensure the Dexie database is accessible for migration purposes. The migration tools will automatically handle database access through the PlatformServiceMixin.
Note: The migration tools are designed to work with both databases simultaneously during the migration process.
Accessing the Migration Interface
- Navigate to the Account page in the TimeSafari app
- Scroll down to find the Database Migration link
- Click the link to open the migration interface
Using the Migration Interface
Step 1: Compare Databases
- Click the "Compare Databases" button
- The system will retrieve data from both Dexie and SQLite databases
- Review the comparison results showing:
- Summary counts for each database
- Detailed differences (added, modified, missing records)
- Specific records that need attention
 
Step 2: Review Differences
The comparison results are displayed in several sections:
Summary Cards
- Dexie Contacts: Number of contacts in Dexie database
- SQLite Contacts: Number of contacts in SQLite database
- Dexie Settings: Number of settings in Dexie database
- SQLite Settings: Number of settings in SQLite database
Contact Differences
- Added: Contacts in Dexie but not in SQLite
- Modified: Contacts that differ between databases
- Missing: Contacts in SQLite but not in Dexie
Settings Differences
- Added: Settings in Dexie but not in SQLite
- Modified: Settings that differ between databases
- Missing: Settings in SQLite but not in Dexie
Step 3: Configure Migration Options
Before migrating data, configure the migration options:
- Overwrite existing records: When enabled, existing records in SQLite will be updated with data from Dexie. When disabled, existing records will be skipped.
Step 4: Migrate Data
Migrate Contacts
- Click the "Migrate Contacts" button
- The system will transfer contacts from Dexie to SQLite
- Review the migration results showing:
- Number of contacts successfully migrated
- Any warnings or errors encountered
 
Migrate Settings
- Click the "Migrate Settings" button
- The system will transfer settings from Dexie to SQLite
- Review the migration results showing:
- Number of settings successfully migrated
- Any warnings or errors encountered
 
Step 5: Export Comparison (Optional)
- Click the "Export Comparison" button
- A JSON file will be downloaded containing the complete comparison data
- This file can be used for analysis or backup purposes
Migration Process Details
Contact Migration
The contact migration process:
- Retrieves all contacts from Dexie database
- Checks for existing contacts in SQLite by DID
- Inserts new contacts or updates existing ones (if overwrite is enabled)
- Handles complex fields like contactMethods(JSON arrays)
- Reports success/failure for each contact
Settings Migration
The settings migration process:
- Retrieves all settings from Dexie database
- Focuses on key user-facing settings:
- firstName
- isRegistered
- profileImageUrl
- showShortcutBvc
- searchBoxes
 
- Preserves other settings in SQLite
- Reports success/failure for each setting
Error Handling
Common Issues
Database Connection Issues
Error: "Failed to retrieve Dexie contacts" Solution: Check that the Dexie database is properly initialized and accessible
SQLite Query Errors
Error: "Failed to retrieve SQLite contacts" Solution: Verify that the SQLite database is properly set up and the platform service is working
Migration Failures
Error: "Migration failed: [specific error]" Solution: Review the error details and check data integrity in both databases
Error Recovery
- Review the error messages carefully
- Check the browser console for additional details
- Verify database connectivity and permissions
- Retry the operation if appropriate
- Export comparison data for manual review if needed
Best Practices
Before Migration
- Backup your data if possible
- Test the migration on a small dataset first
- Verify that both databases are accessible
- Review the comparison results before migrating
During Migration
- Don't interrupt the migration process
- Monitor the progress and error messages
- Note any warnings or skipped records
- Export comparison data for reference
After Migration
- Verify that data was migrated correctly
- Test the application functionality
- Use PlatformServiceMixin for all new database operations
- Clean up any temporary files or exports
Technical Details
Database Schema
The migration handles the following data structures:
Contacts Table
interface Contact {
  did: string;                    // Decentralized Identifier
  name: string;                   // Contact name
  contactMethods: ContactMethod[]; // Array of contact methods
  nextPubKeyHashB64: string;      // Next public key hash
  notes: string;                  // Contact notes
  profileImageUrl: string;        // Profile image URL
  publicKeyBase64: string;        // Public key in base64
  seesMe: boolean;                // Visibility flag
  registered: boolean;            // Registration status
}
Settings Table
interface Settings {
  id: number;                     // Settings ID
  accountDid: string;             // Account DID
  activeDid: string;              // Active DID
  firstName: string;              // User's first name
  isRegistered: boolean;          // Registration status
  profileImageUrl: string;        // Profile image URL
  showShortcutBvc: boolean;       // UI preference
  searchBoxes: any[];             // Search configuration
  // ... other fields
}
Migration Logic
The migration service uses sophisticated comparison logic:
- Primary Key Matching: Uses DID for contacts, ID for settings
- Deep Comparison: Compares all fields including complex objects
- JSON Handling: Properly handles JSON fields like contactMethodsandsearchBoxes
- Conflict Resolution: Provides options for handling existing records
Performance Considerations
- Batch Processing: Processes records one by one for reliability
- Error Isolation: Individual record failures don't stop the entire migration
- Memory Management: Handles large datasets efficiently
- Progress Reporting: Provides real-time feedback during migration
Troubleshooting
Migration Stuck
If the migration appears to be stuck:
- Check the browser console for errors
- Refresh the page and try again
- Verify database connectivity
- Check for large datasets that might take time
Incomplete Migration
If migration doesn't complete:
- Review error messages
- Check data integrity in both databases
- Export comparison data for manual review
- Consider migrating in smaller batches
Data Inconsistencies
If you notice data inconsistencies:
- Export comparison data
- Review the differences carefully
- Manually verify critical records
- Consider selective migration of specific records
Support
For issues with the Database Migration feature:
- Check this documentation first
- Review the browser console for error details
- Export comparison data for analysis
- Contact the development team with specific error details
Security Considerations
- Data Privacy: Migration data is processed locally and not sent to external servers
- Access Control: Only users with access to the account can perform migration
- Data Integrity: Migration preserves data integrity and handles conflicts gracefully
- Audit Trail: Export functionality provides an audit trail of migration operations
PlatformServiceMixin Integration
After migration, all database operations should use the PlatformServiceMixin:
// Use mixin methods for database access
const contacts = await this.$contacts();
const settings = await this.$settings();
const result = await this.$db("SELECT * FROM contacts WHERE did = ?", [accountDid]);
This provides:
- Caching: Automatic caching for performance
- Error Handling: Consistent error handling
- Type Safety: Enhanced TypeScript integration
- Code Reduction: Up to 80% reduction in boilerplate
Note: This migration tool is designed for the transition period between database systems. Once migration is complete and verified, the Dexie database should be disabled to avoid confusion and potential data conflicts. All new development should use the PlatformServiceMixin for database operations.