Kenmegne
7 days ago 23a46b4be35277e06ec89f48730eeb694e686be8
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
/*
 * Click nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt to change this license
 * Click nbfs://nbhost/SystemFileSystem/Templates/Classes/Interface.java to edit this template
 */
package com.megatim.fdxcommons.core.ifaces.abstracts;
 
import com.megatim.fdxcommons.model.enumeration.TypeDonnee;
import com.megatim.fdxcommons.model.search.SearchColumn;
import com.megatim.fdxcommons.tools.utils.SqlUtilities;
import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection;
import java.util.List;
import java.util.Map;
import java.util.Optional;
import javax.persistence.EnumType;
import javax.persistence.Enumerated;
import com.megatim.fdxcommons.dao.ifaces.abstracts.CustomDAOIfaces;
import com.megatim.fdxcommons.model.search.CriteriaEntitySearch;
 
/**
 *
 * @author ASUS
 * @param <T> : Entite reelle
 * @param <ID> : Classe de l'identifiant
 * @param <S> : entité de recherche
 * @param <U> : entité qui représente un utilisateur
 */
public interface CustomManagerIFaces<T, ID, S, U> {
 
    <R extends CustomDAOIfaces<T, ID, S>> R getDao();
 
    default T save(T entity) {
        return getDao().save(entity);
    }
 
    default void delete(T entity) {
        getDao().delete(entity);
    }
 
    public default T getById(ID id, U connectedUser) {
        T entity = getDao().getById(id);
        return entity;
    }
 
    public default T getById(ID id) {
 
        return getDao().getById(id);
    }
 
    public default List<T> findWithPagination(Integer pageNumber, Integer pagesize, S searchEntity, U connectedUser) {
        return getDao().findWithPagination(pageNumber, pagesize, searchEntity);
    }
 
    public default List<T> getAll(S searchEntity, U connectedUser) {
        List<T> data = getDao().getAll(searchEntity);
        return data;
    }
 
    public default List<T> getAll(S searchEntity) {
        List<T> data = getDao().getAll(searchEntity);
        return data;
    }
 
    public default List<T> getAll() {
        return getDao().getAll(null);
    }
 
    public default Long count(S searchEntity) {
        return getDao().count(searchEntity);
    }
 
    public default List<SearchColumn> getSearchColumns(Class<T> classe) {
        List<SearchColumn> searchColumns = new ArrayList<>();
        List<Field> fields = Arrays.asList(classe.getDeclaredFields());
 
        for (Field f : fields) {
            CriteriaEntitySearch searchAnn = f.getAnnotation(CriteriaEntitySearch.class);
            if (searchAnn != null) {
                SearchColumn searchColumn = new SearchColumn();
                searchColumn.setLibelle(searchAnn.libelle());
//                searchColumn.setName(searchAnn.fieldName().isEmpty() ? f.getName() : searchAnn.fieldName());
 
                TypeDonnee typeDonnee = getTypeDonnee(f, searchAnn);
 
                if (typeDonnee != null) {
                    searchColumn.setTypeDonnee(typeDonnee);
                    searchColumns.add(searchColumn);
                }
 
            }
        }
        return searchColumns;
    }
 
    public default TypeDonnee getTypeDonnee(Field field, CriteriaEntitySearch searchAnn) {
        Class<?> fieldClass = field.getType();
        TypeDonnee typeDonnee = null;
 
        if (fieldClass.isPrimitive()) {
            typeDonnee = SqlUtilities.typeDonneeFromJavaClass(fieldClass);
 
        } else if (fieldClass.isEnum()) {
            Enumerated enumerated = field.getAnnotation(Enumerated.class);
            typeDonnee = enumerated == null || enumerated.value().equals(EnumType.ORDINAL) ? TypeDonnee.NUMERIQUE : TypeDonnee.ALPHANUMERIQUE;
 
        } else if (!fieldClass.isInterface() && !Collection.class.isAssignableFrom(fieldClass) && !Map.class.isAssignableFrom(fieldClass)) {
            String[] fieldPath = searchAnn.fieldName().split("\\.");
            if (fieldPath.length < 2) {
                typeDonnee = SqlUtilities.typeDonneeFromJavaClass(fieldClass);
            } else {
                typeDonnee = SqlUtilities.typeDonneeFromJavaClass(getFieldType(fieldClass, Arrays.copyOfRange(fieldPath, 1, fieldPath.length)));
            }
        }
 
        return typeDonnee;
    }
 
    public default Class<?> getFieldType(Class<?> classe, String[] fieldPath) {
        String fieldName = fieldPath[0];
        List<Field> fields = Arrays.asList(classe.getDeclaredFields());
        Optional<Field> optField = fields.stream().filter(f -> f.getName().equals(fieldName)).findFirst();
 
        if (optField.isPresent()) {
            Field field = optField.get();
            if (fieldPath.length == 1) {
                return field.getType();
            } else {
                return getFieldType(field.getType(), Arrays.copyOfRange(fieldPath, 1, fieldPath.length));
            }
        } else {
            return null;
        }
    }
}