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-model/src/main/java/com/megatim/fdxconsultation/model/administration/User.java | 252 ++++++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 252 insertions(+), 0 deletions(-)
diff --git a/fdx-consultation/fdxconsultation-model/src/main/java/com/megatim/fdxconsultation/model/administration/User.java b/fdx-consultation/fdxconsultation-model/src/main/java/com/megatim/fdxconsultation/model/administration/User.java
new file mode 100644
index 0000000..52f0827
--- /dev/null
+++ b/fdx-consultation/fdxconsultation-model/src/main/java/com/megatim/fdxconsultation/model/administration/User.java
@@ -0,0 +1,252 @@
+package com.megatim.fdxconsultation.model.administration;
+
+import com.megatim.fdxcommons.model.enumeration.EtatOperation;
+import com.megatim.fdxcommons.model.enumeration.Sexe;
+import com.megatim.fdxcommons.model.enumeration.TypeOperation;
+import com.megatim.fdxcommons.model.referentiel.Participant;
+import com.megatim.fdxcommons.model.referentiel.TypeFichier;
+import com.megatim.fdxcommons.model.search.CriteriaEntitySearch;
+import java.io.Serializable;
+import java.util.Date;
+import java.util.HashSet;
+import java.util.Objects;
+import java.util.Set;
+import javax.persistence.Column;
+import javax.persistence.Entity;
+import javax.persistence.EnumType;
+import javax.persistence.Enumerated;
+import javax.persistence.GeneratedValue;
+import javax.persistence.GenerationType;
+import javax.persistence.Id;
+import javax.persistence.JoinColumn;
+import javax.persistence.JoinTable;
+import javax.persistence.ManyToMany;
+import javax.persistence.ManyToOne;
+import javax.persistence.SequenceGenerator;
+import javax.persistence.Table;
+import javax.persistence.Temporal;
+import javax.persistence.TemporalType;
+import javax.persistence.Transient;
+import javax.validation.constraints.NotNull;
+import lombok.Getter;
+import lombok.Setter;
+
+/**
+ *
+ * @author DYNABOOK
+ */
+@Getter
+@Setter
+@Entity(name = "User")
+@Table(name = "FDX_USER")
+public class User implements Comparable<User>, Serializable {
+
+ public User() {
+ }
+
+ @SequenceGenerator(name = "SEQ_USER",
+ sequenceName = "SEQ_USER",
+ allocationSize = 1,
+ initialValue = 1)
+ @GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "SEQ_USER")
+ @Column(name = "ID")
+ @Id
+ private Long id;
+
+ @Column(name = "ID_GENERER")
+ protected String idGenerer;
+
+ @Column(name = "TYPE_OPERATION")
+ private TypeOperation typeOperation = TypeOperation.AJOUTER;
+
+ @Column(name = "username")
+ @CriteriaEntitySearch(libelle = "Nom utilisateur", rang = 1, fieldName = "userName")
+ private String userName;
+
+ @Column(name = "firstname")
+ @CriteriaEntitySearch(libelle = "Nom", rang = 3, fieldName = "firstName")
+ private String firstName;
+
+ @Column(name = "lastname")
+ @CriteriaEntitySearch(libelle = "Prénom", rang = 2, fieldName = "lastName")
+ private String lastName;
+
+ @Column(name = "motif_rejet")
+ private String motifRejet;
+
+ @Column(name = "DATE_VAL")
+ @Temporal(value = TemporalType.TIMESTAMP)
+ private Date dateValidation;
+
+ @Column(name = "USER_VAL")
+ private String utilisateurValidation;
+
+ @Column(name = "DATE_RJT_VAL")
+ @Temporal(value = TemporalType.TIMESTAMP)
+ private Date dateRejetValidation;
+
+ @Column(name = "USER_RJT")
+ private String utilisateurRejetValidation;
+
+ @Column(name = "expirationdelay")
+ private int expirationDelay;
+
+ @Column(name = "alertdelay")
+ private int alertDelay;
+
+ @Column(name = "attempsnumber")
+ private int attempsNumber;
+
+ @Column(name = "attemps")
+ private int attemps;
+
+ @Column(name = "locked")
+ private boolean locked;
+
+ @Column(name = "active")
+ private boolean active;
+
+ @Column(name = "editpassword")
+ private boolean editPassword;
+
+ @Column(name = "connected")
+ private boolean connected;
+
+ @Transient
+ private boolean updatePassword;
+
+ @Column(name = "lastconnexiondatetime")
+ @Temporal(TemporalType.TIMESTAMP)
+ private Date lastConnexionDateTime;
+
+ @Column(name = "pwd")
+ private String pwd;
+
+ @Transient
+ private String pwdConfirm;
+
+ @Column(name = "lastdateupdatepwd")
+ @Temporal(TemporalType.TIMESTAMP)
+ private Date dateDerniereModificationMotDePasse;
+
+ @Column(name = "DELAI_INACTIVITE")
+ private int delaiInactivite = 0;
+
+ @Column(name = "SESSION_KEY")
+ private String cleSession;
+
+ @NotNull(message = "Le sexe est obligatoire")
+ @Column(name = "SEXE")
+ @Enumerated(EnumType.STRING)
+ private Sexe sexe = Sexe.HOMME;
+
+ @Column(name = "ETAT_OPERATION")
+ @Enumerated(EnumType.STRING)
+ @CriteriaEntitySearch(libelle = "Etat", visible = false, fieldName = "etatOperation")
+ private EtatOperation etatOperation;
+
+ @Column(name = "DATE_CREATION")
+ @Temporal(TemporalType.TIMESTAMP)
+ private Date dateCreation;
+
+ @Column(name = "USER_CREATION")
+ private String utilisateurCreation;
+
+ @Column(name = "DATE_DERN_MOD")
+ @Temporal(TemporalType.TIMESTAMP)
+ private Date dateDerniereModification;
+
+ @Column(name = "USER_UPDATE")
+ private String utilisateurModification;
+
+ @Column(name = "DATE_SUPPR")
+ @Temporal(TemporalType.TIMESTAMP)
+ private Date dateSuppression;
+
+ @Column(name = "USER_DELETE")
+ private String utilisateurSuppression;
+
+ @ManyToOne
+ @JoinColumn(name = "ROLE")
+ @CriteriaEntitySearch(libelle = "Groupe utilisateur", fieldName = "role.libelle", rang = 4)
+ private Role role;
+
+ @ManyToMany
+ @JoinTable(name = "user_type_fichier",
+ joinColumns = @JoinColumn(name = "user_id"),
+ inverseJoinColumns = @JoinColumn(name = "type_fichier_id"))
+ private Set<TypeFichier> typeFichiers = new HashSet<>();
+
+ @ManyToMany
+ @JoinTable(name = "user_participant",
+ joinColumns = @JoinColumn(name = "user_id"),
+ inverseJoinColumns = @JoinColumn(name = "participant_id"))
+ private Set<Participant> participants = new HashSet<Participant>();
+
+ @Override
+ public int hashCode() {
+ int hash = 7;
+ hash = 79 * hash + Objects.hashCode(this.userName);
+ return hash;
+ }
+
+ @Override
+ public boolean equals(Object obj) {
+ if (this == obj) {
+ return true;
+ }
+ if (obj == null) {
+ return false;
+ }
+ if (getClass() != obj.getClass()) {
+ return false;
+ }
+ final User other = (User) obj;
+ return Objects.equals(this.userName, other.userName);
+ }
+
+ /*
+ * (non-Javadoc)
+ * @see java.lang.Comparable#compareTo(java.lang.Object)
+ */
+ @Override
+ public int compareTo(User parameter) {
+ if (parameter == null) {
+ return -1;
+ }
+
+ // Si le code du parametre est vide
+ if (parameter.userName == null || parameter.userName.trim().length() == 0) {
+ return -1;
+ }
+
+ // Si le code du parametre en cours est vide
+ if (userName == null || userName.trim().length() == 0) {
+ return 1;
+ }
+
+ // On retourne la comparaison des codes
+ return userName.compareTo(parameter.userName);
+ }
+
+ @Override
+ public String toString() {
+
+ //Variables
+ String variable = "";
+
+ if (this.lastName != null) {
+ variable = variable + this.lastName;
+ }
+
+ if (this.firstName != null) {
+ variable = variable + " " + this.firstName;
+ }
+
+ if (this.userName != null) {
+ variable = variable + " (" + this.userName + ")";
+ }
+
+ return variable;
+ }
+}
--
Gitblit v1.10.0