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
/*
 * Click nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt to change this license
 * Click nbfs://nbhost/SystemFileSystem/Templates/Classes/Class.java to edit this template
 */
package com.megatim.fdxconsultation.core.impl.log;
 
import com.megatim.fdxcommons.model.log.UserActionLog;
import com.megatim.fdxcommons.model.pojo.CriteriaEntity;
import com.megatim.fdxcommons.model.pojo.CriteriaEntityFromView;
import com.megatim.fdxcommons.model.pojo.CriteriaFormRequest;
import com.megatim.fdxcommons.tools.context.AppContext;
import com.megatim.fdxconsultation.core.ifaces.log.UserActionLogManager;
import com.megatim.fdxconsultation.dao.ifaces.log.UserActionLogDAO;
import com.megatim.fdxconsultation.model.administration.User;
import com.megatim.fdxconsultation.model.dto.log.UserActionLogDto;
import com.megatim.fdxconsultation.model.mappers.MapStructMapper;
import com.megatim.fdxconsultation.tools.CommonTools;
import com.megatim.fdxconsultation.tools.context.AppCommonContext;
import com.megatim.reporting.adhoc.dto.ReportConfiguration;
import java.io.File;
import java.time.LocalDateTime;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import javax.ejb.EJB;
import javax.enterprise.context.Dependent;
import javax.inject.Inject;
import javax.servlet.http.HttpServletRequest;
import javax.ws.rs.core.Context;
import javax.ws.rs.core.HttpHeaders;
 
/**
 *
 * @author ASUS
 */
@Dependent
public class UserActionLogManagerImpl implements UserActionLogManager {
 
    @EJB
    private UserActionLogDAO dao;
    
    @Inject
    com.megatim.fdxcommons.model.mappers.MapStructMapper commonMapper;
 
    @Inject
    MapStructMapper mapper;
 
    @Override
    public UserActionLogDAO getDao() {
        return dao;
    }
 
    @Override
    public String getEntityIdName() {
        return "id";
    }
 
    @Override
    public Class<UserActionLogDto> getClazz() {
        return UserActionLogDto.class;
    }
 
    @Override
    public Map<String, Object> getParameters() {
        return new HashMap<>();
    }
 
    @Override
    public List<UserActionLogDto> getDatas(CriteriaEntityFromView criterion) throws Exception {
        return mapper.userActionLogListToUserActionLogDtoList(findAll(criterion, Arrays.asList(), Arrays.asList()));
    }
 
    @Override
    public File printAll(ReportConfiguration<CriteriaFormRequest> reportConfiguration, User userConnected) throws Exception {
        return generatePdf(finalReportConfiguration(reportConfiguration), userConnected, false);
    }
 
    @Override
    public File printOne(ReportConfiguration<CriteriaFormRequest> reportConfiguration, User userConnected) throws Exception {
        return generatePdf(finalReportConfiguration(reportConfiguration), userConnected, true);
    }
    
    @Override
    public File exportExcelAll(ReportConfiguration<CriteriaFormRequest> reportConfiguration, User userConnected) throws Exception {
        return exportExcel(finalReportConfiguration(reportConfiguration), userConnected, false);
    }
 
    @Override
    public File exportExcelOne(ReportConfiguration<CriteriaFormRequest> reportConfiguration, User userConnected) throws Exception {
        return exportExcel(finalReportConfiguration(reportConfiguration), userConnected, true);
    }
 
    @Override
    public void log(HttpHeaders headers, @Context HttpServletRequest request, String message, String utilisateur) {
        Map<String, String> map = CommonTools.recupererInfosRequete(headers, request);
        UserActionLog log = new UserActionLog();
        log.setDateAction(LocalDateTime.now());
        log.setMessage(message);
        log.setUserAgent(map.get(AppCommonContext.REQUETE_HTTP_CLIENT));
        log.setIpAddress(map.get(AppCommonContext.REQUETE_HTTP_ADRESSE_IP));
        log.setHttpMethod(map.get(AppCommonContext.REQUETE_HTTP_METHODE));
        log.setRelativePath(map.get(AppCommonContext.REQUETE_HTTP_PATH));
        log.setUserName(utilisateur);
        log.setStatus(200);
        log.setMotif(log.getStatus() != null ? log.getStatus().toString()+" ("+AppContext.registre_codes_http.get(log.getStatus().toString())+")" : null);
        save(log);
    }
 
}