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