Move specs and masterplan to docs/archive/, add architecture.md with full technical overview, create 5 ADRs (Tauri v2, useReducer, sqlx migrations, AES-256-GCM encryption, multi-profile DB), and move guide-utilisateur.md into docs/. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2.2 KiB
2.2 KiB
ADR-0003 : Migrations sqlx inline et contrainte de checksum
- Date : 2025-02
- Statut : Accepté
Contexte
L'application utilise SQLite via tauri-plugin-sql pour le stockage local. Le schéma de la base de données évolue à chaque version (ajout de colonnes, nouvelles tables, changement de contraintes). Il faut un système de migration fiable qui :
- Applique les migrations dans l'ordre au démarrage
- Détecte les modifications non autorisées du schéma
- Supporte la création de nouvelles bases (nouveaux profils)
Le plugin tauri-plugin-sql fournit un système de migrations intégré basé sur sqlx::migrate, avec vérification de checksum.
Décision
Nous utilisons les migrations inline définies dans lib.rs via tauri_plugin_sql::Migration. Chaque migration est une chaîne SQL embarquée dans le binaire.
En complément, un fichier consolidated_schema.sql contient le schéma complet (toutes les migrations fusionnées) et est utilisé pour initialiser les nouveaux profils sans rejouer les 6 migrations.
Les 6 migrations actuelles :
- Schéma initial (13 tables, 9 index)
- Seed des catégories et mots-clés par défaut
- Ajout
has_headersurimport_sources - Ajout
is_inputablesurcategories - Création de
import_config_templates - Changement de contrainte unique sur
imported_files
Conséquences
Positives
- Vérification de checksum : sqlx détecte toute modification d'une migration déjà appliquée, empêchant les corruptions silencieuses
- Migrations embarquées dans le binaire : pas de fichiers SQL à distribuer séparément
- Schéma consolidé : les nouveaux profils démarrent avec un schéma propre sans passer par l'historique des migrations
- Traçabilité : chaque changement de schéma est versionné et documenté
Négatives
- Immutabilité : une migration appliquée ne peut jamais être modifiée (erreur de checksum), ce qui force la création de nouvelles migrations correctives
- Synchronisation manuelle : le fichier
consolidated_schema.sqldoit être mis à jour manuellement après chaque nouvelle migration - Pas de rollback : les migrations sont unidirectionnelles (pas de
down)