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-commons/fdxcommons-core-impl/src/main/java/com/megatim/fdxcommons/core/impl/interceptor/AfterUserActionImpl.java |   77 ++++++++++++++++++++++++++++++++++++++
 1 files changed, 77 insertions(+), 0 deletions(-)

diff --git a/fdx-commons/fdxcommons-core-impl/src/main/java/com/megatim/fdxcommons/core/impl/interceptor/AfterUserActionImpl.java b/fdx-commons/fdxcommons-core-impl/src/main/java/com/megatim/fdxcommons/core/impl/interceptor/AfterUserActionImpl.java
new file mode 100644
index 0000000..de57034
--- /dev/null
+++ b/fdx-commons/fdxcommons-core-impl/src/main/java/com/megatim/fdxcommons/core/impl/interceptor/AfterUserActionImpl.java
@@ -0,0 +1,77 @@
+/*
+ * Click nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt to change this license
+ * Click nbfs://nbhost/SystemFileSystem/Templates/Classes/Class.java to edit this template
+ */
+package com.megatim.fdxcommons.core.impl.interceptor;
+
+import com.megatim.fdxcommons.core.ifaces.interceptor.AfterUserAction;
+import com.megatim.fdxcommons.core.ifaces.interceptor.InterceptorHandler;
+import com.megatim.fdxcommons.core.ifaces.interceptor.LoggingInterceptorBinding;
+import com.megatim.fdxcommons.model.log.ContainerContextDto;
+import com.megatim.fdxcommons.model.log.UserActionLog;
+import com.megatim.fdxcommons.tools.context.AppContext;
+import java.lang.reflect.Method;
+import java.time.LocalDateTime;
+import javax.enterprise.context.Dependent;
+import javax.inject.Inject;
+import ua_parser.Client;
+import ua_parser.Parser;
+
+/**
+ *
+ * @author ASUS
+ */
+@Dependent
+public class AfterUserActionImpl implements AfterUserAction {
+
+    @Inject
+    private InterceptorHandler handler;
+
+    @Override
+    public UserActionLog filter(ContainerContextDto containerContext) throws Exception {
+        Method method = containerContext.getResourceInfo().getResourceMethod();
+
+        if (method != null && method.getAnnotation(LoggingInterceptorBinding.class) != null) {
+            return logMethodInvocation(method, containerContext);
+        } else {
+            return null;
+        }
+    }
+
+    private UserActionLog logMethodInvocation(Method method, ContainerContextDto containerContext) throws Exception {
+        Object responseEntity = containerContext.getContainerResponseContext().getEntity();
+        Object requestEntity = containerContext.getContainerRequestContext().getProperty("entity");
+        final int status = containerContext.getContainerResponseContext().getStatus();
+
+        UserActionLog log = new UserActionLog();
+        log.setDateAction(LocalDateTime.now());
+        log.setUserName(containerContext.getSecurityContext().getUserPrincipal() != null
+                ? containerContext.getSecurityContext().getUserPrincipal().getName()
+                : null);
+        log.setStatus(status);
+        log.setMotif(log.getStatus() != null ? log.getStatus().toString() + " (" + AppContext.registre_codes_http.get(log.getStatus().toString()) + ")" : null);
+        log.setIpAddress(containerContext.getHttpServletRequest().getRemoteAddr());
+        log.setHttpMethod(containerContext.getContainerRequestContext().getMethod());
+        log.setRelativePath(containerContext.getUriInfo().getPath());
+        Parser uaParser = new Parser();
+        Client c = uaParser.parse(containerContext.getHttpServletRequest().getHeader("User-Agent"));
+        log.setUserAgent(c.userAgent.family);
+
+        if (status < 400) {
+            log.setMessage(message(method, requestEntity, responseEntity, containerContext));
+        } else {
+            log.setMessage("Erreur " + status);
+        }
+        return log;
+    }
+
+    private String message(Method method, Object requestEntity, Object responseEntity, ContainerContextDto containerContext) throws Exception {
+        LoggingInterceptorBinding ann = method.getAnnotation(LoggingInterceptorBinding.class);
+        return handler.finalMessage(ann,
+                method.getParameters(),
+                containerContext.getContainerRequestContext().getUriInfo().getPathParameters(),
+                requestEntity,
+                responseEntity);
+    }
+
+}

--
Gitblit v1.10.0