From 23a46b4be35277e06ec89f48730eeb694e686be8 Mon Sep 17 00:00:00 2001
From: Kenmegne <stephanie.kenmegne@gmail.com>
Date: Thu, 18 Jun 2026 15:40:06 +0000
Subject: [PATCH] add fdx-commons and fdx-consultation

---
 fdx-consultation/fdxconsultation-service-impl/src/main/java/com/megatim/fdxconsultation/service/impl/sockets/helpers/ConnexionStatutSessionHandler.java |   89 ++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 89 insertions(+), 0 deletions(-)

diff --git a/fdx-consultation/fdxconsultation-service-impl/src/main/java/com/megatim/fdxconsultation/service/impl/sockets/helpers/ConnexionStatutSessionHandler.java b/fdx-consultation/fdxconsultation-service-impl/src/main/java/com/megatim/fdxconsultation/service/impl/sockets/helpers/ConnexionStatutSessionHandler.java
new file mode 100644
index 0000000..5c8fb6b
--- /dev/null
+++ b/fdx-consultation/fdxconsultation-service-impl/src/main/java/com/megatim/fdxconsultation/service/impl/sockets/helpers/ConnexionStatutSessionHandler.java
@@ -0,0 +1,89 @@
+package com.megatim.fdxconsultation.service.impl.sockets.helpers;
+
+import com.fdx.messaging.common.ConnexionStatut;
+import com.megatim.fdxconsultation.core.ifaces.supervision.StandaloneServerStateEntityManager;
+import com.megatim.fdxconsultation.model.supervision.StandaloneServerStateEntity;
+import java.io.IOException;
+import java.util.List;
+import java.util.Map;
+import java.util.Timer;
+import java.util.TimerTask;
+import java.util.concurrent.ConcurrentHashMap;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+import java.util.stream.Collectors;
+import javax.enterprise.context.ApplicationScoped;
+import javax.inject.Inject;
+import javax.websocket.EncodeException;
+import javax.websocket.Session;
+
+/**
+ *
+ * @author Gabuntu
+ */
+@ApplicationScoped
+public class ConnexionStatutSessionHandler {
+
+    @Inject
+    StandaloneServerStateEntityManager serverStateManager;
+
+    private final Map<String, Session> idToSessions = new ConcurrentHashMap<>();
+
+    private Timer timer = new Timer();
+
+    public void publishMessage(List<ConnexionStatut> connectedStatuts) {
+        getSessions().forEach(s -> {
+            try {
+                s.getBasicRemote().sendObject(connectedStatuts);
+            } catch (IOException | EncodeException ex) {
+                Logger.getLogger(getClass().getName()).log(Level.SEVERE, null, ex);
+            }
+        });
+
+        scheduleTask();
+
+    }
+
+    public void addSession(Session session) {
+        idToSessions.put(session.getId(), session);
+    }
+
+    public void removeSession(Session session) {
+        idToSessions.remove(session.getId());
+    }
+
+    private List<Session> getSessions() {
+        return idToSessions
+                .entrySet()
+                .stream()
+                .map(e -> e.getValue())
+                .collect(Collectors.toList());
+    }
+
+    private void scheduleTask() {
+
+        timer.cancel();
+
+        final long lastPublishTime = System.nanoTime();
+        timer = new Timer();
+        timer.schedule(new TimerTask() {
+            @Override
+            public void run() {
+                if (System.nanoTime() - lastPublishTime >= 10_000_000_000L) {
+                    StandaloneServerStateEntity stateEntity = serverStateManager.getCurrentStandaloneServerStateEntity();
+                    if (stateEntity != null) {
+                        List<ConnexionStatut> connectedStatuts = stateEntity.getAgentConfigurations().stream().map(a -> {
+                            ConnexionStatut connexionStatut = new ConnexionStatut();
+                            connexionStatut.setAgentCode(a.getAgentCode());
+                            connexionStatut.setConnected(false);
+                            return connexionStatut;
+                        }).collect(Collectors.toList());
+
+                        publishMessage(connectedStatuts);
+                    }
+                }
+            }
+        }, 0, 5000);
+
+    }
+}

--
Gitblit v1.10.0