fix: _llm_lock dans nexus pour éviter les appels LLM concurrents

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
2026-03-09 18:02:26 +00:00
parent 46367679be
commit 3478bd637f
+7 -2
View File
@@ -160,12 +160,17 @@ class Nexus(BaseAgent):
self._xmpp_reply(sender, "Broadcast envoyé à tous les agents.", is_muc)
return
# ── Mode naturel → LLM → skills
# ── Mode naturel → LLM → skills (un seul appel à la fois)
if not self._llm_lock.acquire(blocking=False):
self._xmpp_reply(sender, "⏳ Je traite déjà une demande, attends un instant.", is_muc)
return
try:
extra_ctx = self.registry.summary_for_llm(self._online_agents)
response = self._llm_loop(body, context, extra_ctx)
if self.xmpp:
self._xmpp_reply(sender, response, is_muc)
finally:
self._llm_lock.release()
def _xmpp_reply(self, sender: str, body: str, is_muc: bool):
"""Répond dans le bon canal : MUC si message vient du MUC, direct sinon."""