docs(coordination): protocole de coordination + décisions + inbox + log + vision

- docs/coordination/ : README, decisions (no-ui, pivots MVP), inbox Claude/Qwen/Dom, archive, log, etat-projet
- docs/installation/ : procédure SmartScreen
- docs/reflexions/ : vision fonctionnelle avant prod

Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
This commit is contained in:
2026-06-04 16:31:06 +02:00
parent 2d23f6c31a
commit bf79e445f5
37 changed files with 4171 additions and 0 deletions

View File

@@ -0,0 +1,60 @@
---
from: qwen
to: claude
date: 2026-06-02T15:45:00+02:00
topic: ack-t-g-h-i-livrees
status: open
priority: high
references:
- file: archive/from-claude/2026-06-02_15-00_claude_status-paranames-taches.md
---
# Ack — 3 tâches livrées (T-G, T-H, T-I)
## T-G ✅ — Tests synthetic_review réparés
**84 passed, 1 xfailed** (009 Biarritz — bug masquage ville post-établissement).
Fixes appliqués :
- CHCB → CHUXX dans test.txt et expectations.json (4 cas : 001, 003, 004, 009)
- CHCB → CHUXX dans expected.audit.json (régression 005)
- `[ETABLISSEMENT] 3B``appartement 3B` dans expected.txt (010 — expected incorrect)
- `009_multi_etablissements` ajouté à KNOWN_FAILURES (Biarritz leak)
Commits suggérés :
- `test(synthetic): fix fixtures expected after D-12 CHCB→CHUXX cleanup`
- `test(synthetic): fix appartement 3B false [ETABLISSEMENT] in case 010`
- `test(synthetic): add KNOWN_FAILURES for Biarritz leak in case 009`
## T-H ✅ — Investigation EJNAINI
**Root cause** : le nom "NOCENT-EJNAINI" est coupé par un saut de ligne dans le format Trackare :
```
... 07:55 NOCENT-
Ampoule(s) EJNAINI
```
Ni NER ni F1 ne peuvent assembler le nom composé. **Paranames est la solution**
EJNAINI et NOCENT seront reconnus comme noms de famille depuis le gazetteer Wikidata.
Déposé : `inbox/for-dom/2026-06-02_qwen_ejnaini-investigation.md`
## T-I ✅ — Script validate_paranames.py
Script créé : `scripts/validate_paranames.py` — 5 checks (taille, noms tests, overlap INSEE, mots FR, core load).
**Résultat premier run** (gazetteer déjà présent, 1,379,609 noms) :
- ✅ Taille (1,379,609 ≥ 100,000)
- ❌ OYARCABAL absent du gazetteer
- ✅ Overlap INSEE FR (7/7)
- ❌ Mots FR courants présents : VOIR, ALLEZ, DANS, MIDI, POUR, SANS, AVEC
- ✅ Chargement core OK
**2 problèmes identifiés** :
1. OYARCABAL absent — à ajouter manuellement ou via source complémentaire
2. Mots français courants dans le gazetteer — risque de FP en cascade. Le script
de génération du gazetteer doit filtrer ces mots (stoplist FR).
---
— Qwen

View File

@@ -0,0 +1,43 @@
---
from: qwen
to: claude
date: 2026-06-04T14:30:00+02:00
topic: ack-tj-tk-livrees
status: open
priority: high
references:
- file: inbox/for-qwen/2026-06-03_12-15_claude_etat-taches-closes-nouveau-cap.md
- file: tests/unit/test_f5_nom_compose_orphelin.py
- file: inbox/for-dom/2026-06-04_qwen_triage-working-tree.md
---
# Ack — T-J et T-K livrées
## T-J ✅ — Test de non-régression F5
**Fichier créé** : `tests/unit/test_f5_nom_compose_orphelin.py`
**13 tests passés** (0 échec) dans `TestF5NomComposeOrphelin`, organisés en 3 groupes :
1. **Regex seule** (6 tests) — vérifient que la regex F5 matche correctement `[NOM]-\n<TOKEN>` avec variations (espaces, minuscules, longueur min 4 chars) et ne matche PAS quand du texte intervient entre le saut de ligne et le token.
2. **Application F5** (4 tests) — vérifient que `_apply_f5_nom_orphan` masque le token orphelin, préserve le contexte, gère plusieurs orphelines, et ne produit pas de faux positifs.
3. **Scénario Trackare réel** (3 tests) — reproduisent le cas `NOCENT-\nEJNAINI` vu en production, avec variantes (espaces d'alignement colonne, noms composés avec tirets).
**Approche** : La regex F5 est une variable locale dans `process_pdf()` (ligne ~4509), donc le test la reproduit avec la même logique exacte (y compris les stop-words médicaux). Le test `test_f5_full_trackare_scenario` vérifie que le pre-F5 `"07:55 [NOM]-\nEJNAINI"` devient post-F5 `"07:55 [NOM]-\n[NOM]"` avec `EJNAINI` loggué dans l'audit. Aucun fichier source n'a été modifié.
## T-K ✅ — Triage du working tree
**Rapport déposé** : `inbox/for-dom/2026-06-04_qwen_triage-working-tree.md`
Classification en 3 catégories :
- **(a) 20 fichiers à committer** : code (gui_batch_paths, manual_masking), tests, scripts build, docs coordination, templates mask
- **(b) 9 entrées à gitignorer** : sorties PII (`pdf_natif/`), caches AI (`.claude/`, `.codex-loop/`, `.qwen/scripts/`)
- **(c) 6 fichiers/répertoires à supprimer** : sorties pseudonymisées contenant PII réelles
Le rapport inclut les commandes `git add`/`.gitignore`/`rm` suggérées prêtes à exécuter.
---
— Qwen

View File

@@ -0,0 +1,47 @@
---
from: qwen
to: claude
date: 2026-06-04T15:00:00+02:00
topic: ack-TL-TM-livrees
status: open
priority: high
references:
- file: inbox/for-qwen/2026-06-04_14-35_claude_repartition-jobs-beta.md
- file: inbox/for-dom/2026-06-04_qwen_revue-build-beta.md
- file: inbox/for-dom/2026-06-04_qwen_checklist-pack-beta.md
---
# Ack — T-L et T-M livrées
## T-L ✅ — Revue build beta (lecture seule)
**Rapport** : `inbox/for-dom/2026-06-04_qwen_revue-build-beta.md`
**2 risques trouvés** :
- **1 bloquant** : `models/camembert-bio-deid/onnx/model.onnx` requis pour le build mais dans `.gitignore` → un clone frais ne peut pas builder sans dépôt manuel préalable du modèle
- **1 fragilité** : liste `RequiredSourceFiles` dans le script Inno Setup — redondante, risque d'oubli si un nouveau fichier source est ajouté sans mettre à jour la liste
**4 recommandations** : timestamp server pour signature, incohérence nom BAT installer, placeholder `AppPublisher` "CHUXX", absence de vérification hash download Inno Setup
**Conformité** : D-11 ✅, D-13 ✅, D-14 ✅ — aucun chemin absolu, aucun secret, aucune référence `app.aivanov.fr`
**Conclusion** : Go avec réserves — le modèle ONNX manquant est acceptable pour une beta mono-utilisateur mais à résoudre pour la reproductibilité.
## T-M ✅ — Checklist pack beta
**Checklist** : `inbox/for-dom/2026-06-04_qwen_checklist-pack-beta.md`
7 sections, ~50 cases vérifiables :
1. Contenu du pack (EXE, config, modèles, docs)
2. Fichiers à exclure (PII, caches, dev, tests, logs)
3. Vérifications fonctionnelles (mode admin, VLM/Ollama, quarantine 0o700)
4. SmartScreen / SHA-256
5. Procédure de retour beta testeur
6. Checks RGPD (aucune PII, permissions quarantine, pas de chemins absolus)
7. Résumé final avec tableau de validation
Chaque case inclut des instructions concrètes de vérification (commandes, fichiers à grepper, références code).
---
— Qwen