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-core-impl/src/main/java/com/megatim/fdxconsultation/core/impl/sockets/DataProductionSessionHandler.java |   49 +++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 49 insertions(+), 0 deletions(-)

diff --git a/fdx-consultation/fdxconsultation-core-impl/src/main/java/com/megatim/fdxconsultation/core/impl/sockets/DataProductionSessionHandler.java b/fdx-consultation/fdxconsultation-core-impl/src/main/java/com/megatim/fdxconsultation/core/impl/sockets/DataProductionSessionHandler.java
new file mode 100644
index 0000000..bb00f46
--- /dev/null
+++ b/fdx-consultation/fdxconsultation-core-impl/src/main/java/com/megatim/fdxconsultation/core/impl/sockets/DataProductionSessionHandler.java
@@ -0,0 +1,49 @@
+package com.megatim.fdxconsultation.core.impl.sockets;
+
+import com.megatim.fdxconsultation.model.dataproduction.DataProduction;
+import java.io.IOException;
+import java.util.List;
+import java.util.Map;
+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.websocket.EncodeException;
+import javax.websocket.Session;
+
+/**
+ *
+ * @author Gabuntu
+ */
+@ApplicationScoped
+public class DataProductionSessionHandler {
+
+    private final Map<String, Session> idToSessions = new ConcurrentHashMap<>();
+
+    public void publishMessage(DataProduction dataProduction) {
+        getSessions().forEach(s -> {
+            try {
+                s.getBasicRemote().sendObject(dataProduction);
+            } catch (IOException | EncodeException ex) {
+                Logger.getLogger(getClass().getName()).log(Level.SEVERE, ex.getMessage(), ex);
+            }
+        });
+    }
+
+    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());
+    }
+}

--
Gitblit v1.10.0