backup: snapshot post-démo GHT 2026-05-19
Some checks failed
tests / Lint (ruff + black) (push) Successful in 1m50s
tests / Tests unitaires (sans GPU) (push) Failing after 1m50s
tests / Tests sécurité (critique) (push) Has been skipped

Backup état complet après enregistrement vidéo démo de bout en bout.
À utiliser comme point de référence pour la consolidation post-démo.

Changements majeurs de la session 18-19 mai :
- AIVA-URGENCE : page autonome avec preset URL + auto-focus chain
- Workflow Demo_urgence_3_db : merge linux_db + steps AIVA + pause humaine NoMachine
- Bypass LLM (static_result / static_text) dans replay_engine
  pour démos déterministes sans appel Ollama
- Fix api_stream:3013 — replay_paused au premier polling /next
- dag_execute : lift duration_ms vers top-level pour wait runtime
- NPM bypass auth /aiva-urgence/ via location ^~ (proxy_host/10.conf hors git)
- scripts/cancel-replays.sh — workaround Stop VWB qui ne purge pas la queue

Anchors visuels (468) forcés dans le commit pour garantir restorabilité.
DB workflows actuelle + ~12 .bak DB de la journée incluses.

Sujets identifiés pour consolidation post-démo (TODO) :
1. Bug VWB recapture anchor ne régénère pas le PNG
2. Léa client accumule état mémoire (restart périodique requis)
3. Stop VWB ne purge pas la queue serveur (lien manquant vers /replay/cancel)
4. Bug coord client mss tronqué 2560x60 → mapping Y cassé
5. delay_before/delay_after ignorés au runtime (fix partiel duration_ms)

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
Dom
2026-05-19 14:55:06 +02:00
parent f2212e77e3
commit 5ea4960e65
627 changed files with 211348 additions and 169 deletions

View File

@@ -2643,6 +2643,76 @@ def finish_execution(workflow_name: str, success: bool, message: str):
})
# =============================================================================
# Orchestration démo GHT Sud 95 — "traite N dossiers"
# =============================================================================
# Délégué à agent_chat.urgences_orchestrator (gemma3:1b NLP + thread orchestrateur).
# Routes :
# POST /api/urgences/parse — test parsing intent (debug)
# POST /api/urgences/start — démarrer une orchestration
# GET /api/urgences/status/<id>— état d'une orchestration
# GET /api/urgences/list — toutes les orchestrations en mémoire
try:
from agent_chat.urgences_orchestrator import (
parse_lea_command,
start_orchestration,
get_orchestration,
list_orchestrations,
)
_URGENCES_AVAILABLE = True
except Exception as _e_urg:
logger.warning("Module urgences_orchestrator indisponible : %s", _e_urg)
_URGENCES_AVAILABLE = False
@app.route('/api/urgences/parse', methods=['POST'])
def urgences_parse():
if not _URGENCES_AVAILABLE:
return jsonify({"error": "module urgences_orchestrator indisponible"}), 503
payload = request.get_json(silent=True) or {}
text = (payload.get("text") or "").strip()
if not text:
return jsonify({"error": "champ 'text' manquant"}), 400
intent = parse_lea_command(text)
return jsonify(intent)
@app.route('/api/urgences/start', methods=['POST'])
def urgences_start():
if not _URGENCES_AVAILABLE:
return jsonify({"error": "module urgences_orchestrator indisponible"}), 503
payload = request.get_json(silent=True) or {}
text = (payload.get("text") or "").strip()
session_id = payload.get("session_id") or ""
machine_id = payload.get("machine_id") or None
if not text:
return jsonify({"error": "champ 'text' manquant"}), 400
intent = parse_lea_command(text)
if intent.get("action") != "process_patients":
return jsonify({"intent": intent, "started": False,
"reply": "Je n'ai pas compris la commande. Exemples : 'traite-moi 3 dossiers', 'code les 5 premiers'."})
state = start_orchestration(intent, session_id=session_id, machine_id=machine_id)
return jsonify({"intent": intent, "started": True, "orchestration": state.to_dict()})
@app.route('/api/urgences/status/<orch_id>')
def urgences_status(orch_id):
if not _URGENCES_AVAILABLE:
return jsonify({"error": "module urgences_orchestrator indisponible"}), 503
state = get_orchestration(orch_id)
if not state:
return jsonify({"error": f"orchestration {orch_id} introuvable"}), 404
return jsonify(state.to_dict())
@app.route('/api/urgences/list')
def urgences_list():
if not _URGENCES_AVAILABLE:
return jsonify({"error": "module urgences_orchestrator indisponible"}), 503
return jsonify({"orchestrations": list_orchestrations()})
# =============================================================================
# Main
# =============================================================================