yann64
236d37976c
Compatibilité MySQL + suppression de Redis comme dépendance requise
...
DbCompat (app/Support/DbCompat.php) :
- like() → ilike (pgsql) ou like (mysql)
- jsonRegexRaw() → data::text ~* ? (pgsql) ou CAST(data AS CHAR) REGEXP ? (mysql)
- ftsRaw() → to_tsvector/plainto_tsquery (pgsql) ou null/fallback LIKE (mysql)
- generatedJsonCol() → syntaxe colonne générée JSON selon le SGBD
- generatedJsonNestedCol() → idem pour champs imbriqués
Migrations :
- create_releves_table : JSON/JSONB selon SGBD, colonnes générées adaptées,
index GIN uniquement pour PostgreSQL
Controllers :
- LieuController (search + index) : ilike → DbCompat::like()
- Admin\UserController (index) : ilike → DbCompat::like()
- RechercheController : FTS + regex → DbCompat, fallback LIKE MySQL
- ExportController : regex → DbCompat::jsonRegexRaw()
UpdateService :
- backupDatabase() : pg_dump (pgsql) ou mysqldump (mysql)
- restoreBackup() : psql (pgsql) ou mysql (mysql)
Docker :
- docker-compose.yml : suppression Redis (plus requis)
- docker-compose.mysql.yml : nouveau fichier pour dev MySQL
- docker-compose.prod.yml : suppression Redis, DB_IMAGE configurable,
CACHE_STORE/SESSION_DRIVER/QUEUE_CONNECTION → database par défaut
.env.example :
- DB_PORT commenté avec les deux valeurs (5432/3306)
- CACHE_STORE et QUEUE_CONNECTION commentés (database par défaut)
- Redis marqué optionnel
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com >
2026-06-04 18:13:42 +02:00
yann64
d064f8d28e
Étapes 6-9 + types de lieux + picker + filtres
...
- Étape 6 : formulaire de saisie dynamique des relevés (piloté par source_type_fields, calendriers grégorien/julien/républicain)
- Étape 7 : workflow de statut des sources + notifications mail+DB (SourceAValider, SourceRejetee)
- Étape 8 : recherche fulltext PostgreSQL avec filtres type/lieu/années et CTE récursive pour les subdivisions de lieux
- Étape 9 : export GEDCOM 5.5.1 (GedcomExportService + DateConversionService)
- Types de lieux : CRUD admin (LieuTypeController) avec champ ordre
- Composant lieu-picker : modale Alpine.js avec recherche AJAX + debounce
- Filtres sources : statut, type, lieu (CTE récursive), période annee_debut/annee_fin
- Filtres lieux : type, texte, lieu parent avec descendants (CTE récursive)
- Migration : lieu_id + annee_debut + annee_fin sur sources
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com >
2026-06-04 17:17:53 +02:00