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-ifaces/src/main/java/com/megatim/fdxconsultation/service/ifaces/abstracts/AbstractGenericValidationIFaces.java |   99 +++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 99 insertions(+), 0 deletions(-)

diff --git a/fdx-consultation/fdxconsultation-service-ifaces/src/main/java/com/megatim/fdxconsultation/service/ifaces/abstracts/AbstractGenericValidationIFaces.java b/fdx-consultation/fdxconsultation-service-ifaces/src/main/java/com/megatim/fdxconsultation/service/ifaces/abstracts/AbstractGenericValidationIFaces.java
new file mode 100644
index 0000000..20d197c
--- /dev/null
+++ b/fdx-consultation/fdxconsultation-service-ifaces/src/main/java/com/megatim/fdxconsultation/service/ifaces/abstracts/AbstractGenericValidationIFaces.java
@@ -0,0 +1,99 @@
+package com.megatim.fdxconsultation.service.ifaces.abstracts;
+
+import com.bekosoftware.genericdaolayer.dao.tools.RestrictionsContainer;
+import com.bekosoftware.genericmanagerlayer.core.ifaces.GenericManager;
+import com.megatim.fdxcommons.model.enumeration.TypeOperation;
+import java.io.Serializable;
+import java.util.ArrayList;
+import java.util.List;
+import javax.annotation.security.PermitAll;
+import javax.ws.rs.Consumes;
+import javax.ws.rs.POST;
+import javax.ws.rs.Path;
+import javax.ws.rs.PathParam;
+import javax.ws.rs.Produces;
+import javax.ws.rs.core.Context;
+import javax.ws.rs.core.HttpHeaders;
+import javax.ws.rs.core.MediaType;
+
+/**
+ *
+ * @author lenovo
+ */
+public interface AbstractGenericValidationIFaces<T, U, K, ID extends Serializable> {
+
+    @PermitAll
+    @POST
+    @Consumes({MediaType.APPLICATION_JSON})
+    @Produces({MediaType.APPLICATION_JSON})
+    @Path("validate")
+    public default void validate(@Context HttpHeaders headers, T entity) {
+
+    }
+
+    @PermitAll
+    @POST
+    @Consumes({MediaType.APPLICATION_JSON})
+    @Produces({MediaType.APPLICATION_JSON})
+    @Path("reject")
+    public default void reject(@Context HttpHeaders headers, T entity) {
+
+    }
+
+    @PermitAll
+    @POST
+    @Produces({MediaType.APPLICATION_JSON})
+    @Path("findwithpagination/{pageNumber}/{pagesize}")
+    public default List<T> findWithPagination(@Context HttpHeaders headers, @PathParam("pageNumber") Integer pageNumber, @PathParam("pagesize") Integer pagesize, K searchEntity) {
+
+        //Variables
+        List<T> datas = null;
+
+        //On construit la requete
+        RestrictionsContainer requeteur = construireRequete(searchEntity, TypeOperation.AJOUTER);
+
+        //Construction de l'index
+        int index = (pageNumber - 1) * pagesize;
+
+        //Si non vide
+        if (datas == null || datas.isEmpty()) {
+
+            //Liste vide
+            datas = new ArrayList<>();
+
+        }
+
+        return datas;
+
+    }
+
+    @PermitAll
+    @POST
+    @Produces({MediaType.APPLICATION_JSON})
+    @Path("count")
+    public default Long count(@Context HttpHeaders headers, K searchEntity) {
+
+        //Variables
+        Long count = 0l;
+
+        //On construit la requete
+        RestrictionsContainer requeteur = construireRequete(searchEntity, TypeOperation.AJOUTER);
+
+        //On on recherche l'entité
+        count = getManager().count(requeteur.getPredicats());
+
+        return count;
+
+    }
+
+    public abstract GenericManager<T, ID> getManager();
+
+    public abstract U getActualState();
+
+    public abstract U getNextState();
+
+    public abstract U getRejectionState();
+
+    public abstract RestrictionsContainer construireRequete(K parametre, TypeOperation typeOperation);
+
+}

--
Gitblit v1.10.0