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