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

---
 apifdxweb/api/apifdxweb-dao-impl/src/main/java/com/megatim/apifdxweb/dao/impl/administration/UserDAOImpl.java |   83 +++++++++++++++++++++++++++++++++++++++++
 1 files changed, 83 insertions(+), 0 deletions(-)

diff --git a/apifdxweb/api/apifdxweb-dao-impl/src/main/java/com/megatim/apifdxweb/dao/impl/administration/UserDAOImpl.java b/apifdxweb/api/apifdxweb-dao-impl/src/main/java/com/megatim/apifdxweb/dao/impl/administration/UserDAOImpl.java
new file mode 100644
index 0000000..af9eb3e
--- /dev/null
+++ b/apifdxweb/api/apifdxweb-dao-impl/src/main/java/com/megatim/apifdxweb/dao/impl/administration/UserDAOImpl.java
@@ -0,0 +1,83 @@
+package com.megatim.apifdxweb.dao.impl.administration;
+
+import javax.persistence.EntityManager;
+import javax.persistence.PersistenceContext;
+import com.bekosoftware.genericdaolayer.dao.impl.AbstractGenericDAO;
+import com.bekosoftware.genericdaolayer.dao.tools.RestrictionsContainer;
+import com.google.common.hash.HashCode;
+import com.google.common.hash.Hashing;
+import com.megatim.apifdxweb.dao.ifaces.administration.UserDAO;
+import com.megatim.apifdxweb.model.administration.User;
+import com.megatim.fdxcommons.model.enumeration.TypeOperation;
+import java.nio.charset.StandardCharsets;
+import java.util.List;
+import javax.enterprise.context.Dependent;
+import javax.transaction.Transactional;
+
+@Dependent
+public class UserDAOImpl extends AbstractGenericDAO<User, Long> implements UserDAO {
+
+    @PersistenceContext(unitName = "fdxPU")
+    protected EntityManager em;
+
+    public UserDAOImpl() {
+    }
+
+    @Override
+    public EntityManager getEntityManager() {
+        return em;
+    }
+
+    @Override
+    public Class<User> getManagedEntityClass() {
+        return (User.class);
+    }
+
+    @Override
+    public User recuperUtilisateur(String username, String motDePasse) {
+
+        RestrictionsContainer requeteur = RestrictionsContainer.newInstance();
+        requeteur.addEq("userName", username);
+        requeteur.addEq("typeOperation", TypeOperation.AJOUTER);
+        requeteur.addEq("locked", false);
+
+        List<User> resultats = filter(requeteur.getPredicats(), null, null, 0, 1);
+        if (resultats == null || resultats.isEmpty()) {
+            return null;
+        }
+        
+        User user;
+        //On verifie si le mot de passe est correct
+        HashCode hashCode = Hashing.sha256().hashString(motDePasse, StandardCharsets.UTF_8);
+        if (!hashCode.toString().equals(resultats.get(0).getPwd())) {
+            user = null;
+        } else {
+            user = resultats.get(0);
+        }
+
+        return user;
+    }
+
+    @Transactional
+    @Override
+    public User recuperUtilisateur(String username) {
+        List<User> liste = em.createQuery("SELECT u FROM User u "
+                + "WHERE u.userName = :userName AND u.typeOperation = :typeOperation AND u.locked = :locked")
+                .setParameter("userName", username)
+                .setParameter("typeOperation", TypeOperation.AJOUTER)
+                .setParameter("locked", false)
+                .getResultList();
+        return liste != null && !liste.isEmpty() ? liste.stream().findFirst().get() : null;
+    }
+
+    @Override
+    public User getUser(String username) {
+        List<User> liste = em.createQuery("SELECT u FROM User u "
+                + "WHERE u.userName = :userName AND u.typeOperation = :typeOperation")
+                .setParameter("userName", username)
+                .setParameter("typeOperation", TypeOperation.AJOUTER)
+                .getResultList();
+        return liste != null && !liste.isEmpty() ? liste.stream().findFirst().get() : null;
+    }
+
+}

--
Gitblit v1.10.0