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