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-model/src/main/java/com/megatim/fdxcommons/model/referentiel/ExtensionFichier.java |   90 +++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 90 insertions(+), 0 deletions(-)

diff --git a/fdx-commons/fdxcommons-model/src/main/java/com/megatim/fdxcommons/model/referentiel/ExtensionFichier.java b/fdx-commons/fdxcommons-model/src/main/java/com/megatim/fdxcommons/model/referentiel/ExtensionFichier.java
new file mode 100644
index 0000000..621aca9
--- /dev/null
+++ b/fdx-commons/fdxcommons-model/src/main/java/com/megatim/fdxcommons/model/referentiel/ExtensionFichier.java
@@ -0,0 +1,90 @@
+package com.megatim.fdxcommons.model.referentiel;
+
+import com.megatim.fdxcommons.model.enumeration.TypeExtension;
+import java.io.Serializable;
+import java.time.LocalDateTime;
+import java.util.Objects;
+import javax.persistence.Entity;
+import javax.persistence.EnumType;
+import javax.persistence.Enumerated;
+import javax.persistence.Id;
+import javax.persistence.ManyToOne;
+import javax.validation.constraints.NotEmpty;
+import javax.validation.constraints.NotNull;
+import javax.xml.bind.annotation.XmlAccessType;
+import javax.xml.bind.annotation.XmlAccessorType;
+import javax.xml.bind.annotation.XmlRootElement;
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+import lombok.Getter;
+import lombok.NoArgsConstructor;
+import lombok.Setter;
+import com.megatim.fdxcommons.model.search.CriteriaEntitySearch;
+
+/**
+ *
+ * @author ASUS
+ */
+@Entity
+@Getter
+@Setter
+@XmlRootElement(name = "extensionFichiers")
+@XmlAccessorType(XmlAccessType.FIELD)
+@NoArgsConstructor
+public class ExtensionFichier implements Serializable {
+
+    @Id
+    @NotEmpty(message = "Extension du fichier obligatoire")
+    @CriteriaEntitySearch(libelle = "Extension", rang = 1)
+    private String extension;
+
+    @NotEmpty(message = "Le libellé du fichier est obligatoire")
+    @CriteriaEntitySearch(libelle = "Libellé", rang = 2)
+    private String libelle;
+
+    @Enumerated(EnumType.STRING)
+    @NotNull(message = "Le type d'extension du fichier est obligatoire")
+    @CriteriaEntitySearch(libelle = "Type extension", rang = 3)
+    private TypeExtension typeExtension;
+
+    @NotNull(message = "L'extension de fichier doit être associée à un réfrérentiel en préparation")
+    @ManyToOne
+    @CriteriaEntitySearch(libelle = "Référentiel", fieldName = "referentiel.version", rang = 4)
+    private Referentiel referentiel;
+
+    @XmlJavaTypeAdapter(LocalDateTimeAdapter.class)
+    private LocalDateTime dateCreation;
+
+    @XmlJavaTypeAdapter(LocalDateTimeAdapter.class)
+    private LocalDateTime dateMiseAjour;
+
+    private String createBy;
+
+    private String lastModifiedBy;
+
+    @Override
+    public String toString() {
+        return this.getLibelle() + " (" + this.getExtension() + ")";
+    }
+
+    @Override
+    public int hashCode() {
+        int hash = 7;
+        hash = 53 * hash + Objects.hashCode(this.extension);
+        return hash;
+    }
+
+    @Override
+    public boolean equals(Object obj) {
+        if (this == obj) {
+            return true;
+        }
+        if (!(obj instanceof ExtensionFichier)) {
+            return false;
+        }
+        ExtensionFichier other = (ExtensionFichier) obj;
+        if (this.getExtension() != null && !this.getExtension().equals(other.getExtension())) {
+            return false;
+        }
+        return true;
+    }
+}

--
Gitblit v1.10.0