Merge branch 'feat/versioning-config'

This commit is contained in:
dom
2026-03-08 12:44:25 +01:00
5 changed files with 75 additions and 2 deletions

3
src/__version__.py Normal file
View File

@@ -0,0 +1,3 @@
"""Version unique du projet T2A v2 (single source of truth)."""
__version__ = "2.1.0"

View File

@@ -123,6 +123,57 @@ def check_adversarial_model_config() -> tuple[bool, str]:
return False, ""
def validate_config() -> list[str]:
"""Valide la configuration au démarrage et retourne la liste des warnings émis.
Vérifie :
- OLLAMA_URL défini et accessible (warning si injoignable, pas de crash)
- ANTHROPIC_API_KEY présente (warning si absente — fallback cloud indisponible)
- Modèles CPAM et validation distincts (validation adversariale)
- Au moins un modèle LLM configuré
Ne fait jamais crasher l'application.
"""
warnings_emitted: list[str] = []
# 1. Vérifier OLLAMA_URL
if not OLLAMA_URL:
msg = "OLLAMA_URL non défini — aucun LLM local disponible"
_cfg_logger.warning(msg)
warnings_emitted.append(msg)
else:
try:
import requests as _req
resp = _req.get(f"{OLLAMA_URL}/api/tags", timeout=5)
resp.raise_for_status()
_cfg_logger.info("Ollama accessible sur %s", OLLAMA_URL)
except Exception as e:
msg = f"Ollama injoignable sur {OLLAMA_URL}{e}"
_cfg_logger.warning(msg)
warnings_emitted.append(msg)
# 2. Vérifier ANTHROPIC_API_KEY
if not os.environ.get("ANTHROPIC_API_KEY"):
msg = "ANTHROPIC_API_KEY absente — fallback cloud (Haiku) indisponible"
_cfg_logger.warning(msg)
warnings_emitted.append(msg)
# 3. Vérifier modèles CPAM vs validation (adversarial)
same, adv_msg = check_adversarial_model_config()
if same:
_cfg_logger.warning(adv_msg)
warnings_emitted.append(adv_msg)
# 4. Vérifier qu'au moins un modèle LLM est configuré
has_model = bool(OLLAMA_MODEL) or any(OLLAMA_MODELS.values())
if not has_model:
msg = "Aucun modèle LLM configuré (OLLAMA_MODEL et OLLAMA_MODELS vides)"
_cfg_logger.warning(msg)
warnings_emitted.append(msg)
return warnings_emitted
# --- Configuration RUM / établissement ---
FINESS = os.environ.get("T2A_FINESS", "000000000")

View File

@@ -22,6 +22,7 @@ from ..config import (
ALLOWED_EXTENSIONS, UPLOAD_MAX_SIZE_MB,
)
from .. import config as cfg
from ..__version__ import __version__ as APP_VERSION
from ..control.cpam_context import _assess_dossier_strength
from ..medical.bio_normals import BIO_NORMALS
from .referentiels import ReferentielManager
@@ -84,6 +85,13 @@ def create_app() -> Flask:
except Exception as e:
logger.error("Verification FAISS echouee : %s", e)
# Validation config au démarrage
try:
from ..config import validate_config
validate_config()
except Exception as e:
logger.error("Validation config échouée : %s", e)
ref_manager = ReferentielManager()
val_manager = ValidationManager()
@@ -102,7 +110,12 @@ def create_app() -> Flask:
rep = item
break
dossier_list.append({"name": format_dossier_name(group_name), "path": rep["path_rel"]})
return {"dossier_list": dossier_list}
return {"dossier_list": dossier_list, "app_version": APP_VERSION}
# --- Health check ---
@app.route("/health")
def health():
return jsonify({"status": "ok", "version": APP_VERSION})
# ===================================================================
# Routes principales

View File

@@ -421,6 +421,9 @@
<input type="text" id="sidebar-search" placeholder="Rechercher un dossier…" autocomplete="off">
<div id="sidebar-autocomplete" style="display:none;position:absolute;left:0;right:0;background:#0f172a;border:1px solid #475569;border-radius:0 0 6px 6px;max-height:250px;overflow-y:auto;z-index:100;"></div>
</div>
<div style="padding:0.5rem 1rem;border-top:1px solid #334155;font-size:0.6rem;color:#475569;text-align:center;">
v{{ app_version }}
</div>
</aside>
<!-- Main -->