package com.megatim.fdxconsultation.service.impl.log; import com.megatim.fdxcommons.model.enumeration.OrderByType; import com.megatim.fdxcommons.model.pojo.CriteriaEntityFromView; import com.megatim.fdxcommons.model.pojo.CriteriaFormRequest; import com.megatim.fdxcommons.model.pojo.OrderByDefinition; import com.megatim.fdxcommons.tools.exceptions.CommonApplicationServerException; import com.megatim.fdxconsultation.core.ifaces.administration.UserManager; import com.megatim.fdxconsultation.core.ifaces.log.ApiUserActionLogManager; import com.megatim.fdxconsultation.core.ifaces.log.UserActionLogManager; import com.megatim.fdxconsultation.core.impl.utils.CriteriaEntitySearchUtil; import com.megatim.fdxconsultation.model.administration.User; import com.megatim.fdxconsultation.model.dto.log.UserActionLogDto; import com.megatim.fdxconsultation.model.log.ApiUserActionLog; import com.megatim.fdxconsultation.model.log.dtos.ApiUserActionSummarySearch; import com.megatim.fdxconsultation.model.mappers.MapStructMapper; import com.megatim.fdxconsultation.reporting.model.log.ApiUserActionLogReporting; import com.megatim.fdxconsultation.service.ifaces.log.ApiUserActionLogRS; import com.megatim.fdxconsultation.service.impl.referentiel.PaysRSImpl; import com.megatim.fdxconsultation.tools.context.AppCommonContext; import com.megatim.reporting.adhoc.dto.ReportConfiguration; import com.megatim.reporting.adhoc.pojo.CustomField; import com.megatim.reporting.adhoc.util.PrintableColumnExtractor; import com.mgt.rs.security.core.common.AuthenticatedUser; import com.mgt.rs.security.core.common.SecuredClass; import java.io.File; import java.util.Arrays; import java.util.List; import java.util.logging.Level; import java.util.logging.Logger; import javax.enterprise.event.Observes; import javax.inject.Inject; import javax.servlet.http.HttpServletRequest; import javax.ws.rs.Path; import javax.ws.rs.core.Context; import javax.ws.rs.core.HttpHeaders; import javax.ws.rs.core.Response; /** * * @author ASUS */ @SecuredClass(module = AppCommonContext.MODULE_INFRASTRUCTURES, path = "Fdx API", description = "Fdx API") @Path("api-user-action-log") public class ApiUserActionLogRSImpl implements ApiUserActionLogRS { @Inject MapStructMapper mapper; @Inject private UserManager userManager; @Inject private UserActionLogManager userActionLogManager; @Inject ApiUserActionLogManager manager; @AuthenticatedUser private static User utilisateurConnecte; @Inject com.megatim.fdxcommons.model.mappers.MapStructMapper commonMapper; public ApiUserActionLogRSImpl() { super(); } public void handleAuthenticationEvent(@Observes @AuthenticatedUser String username) { utilisateurConnecte = userManager.recuperUtilisateur(username); } @Override public UserActionLogDto mapToDto(ApiUserActionLog entity) { return mapper.apiUserActionLogToUserActionLogDto(entity); } @Override public Response findById(HttpHeaders headers, Long id) { throw new UnsupportedOperationException("Not supported yet."); } @Override public Response findWithPagination(HttpHeaders headers, Integer pageNumber, Integer pageSize, CriteriaFormRequest criteriaFormRequest) { try { CriteriaEntityFromView criterion = criteriaFormRequest != null ? criteriaFormRequest.getCriteria() : null; List logs = manager.findWithPagination(criterion, Arrays.asList(), Arrays.asList(new OrderByDefinition(manager.getEntityIdName(), OrderByType.DESC)), pageNumber, pageSize); return Response.ok(mapper.apiUserActionLogListToUserActionLogDtoList(logs)).build(); } catch (Exception ex) { Logger.getLogger(UserActionLogRSImpl.class.getName()).log(Level.SEVERE, ex.getMessage(), ex); throw new CommonApplicationServerException(); } } @Override public Long count(HttpHeaders headers, CriteriaFormRequest criteriaFormRequest) { try { CriteriaEntityFromView criterion = criteriaFormRequest != null ? criteriaFormRequest.getCriteria() : null; return manager.count(criterion); } catch (Exception ex) { Logger.getLogger(UserActionLogRSImpl.class.getName()).log(Level.SEVERE, ex.getMessage(), ex); throw new CommonApplicationServerException(); } } @Override public Response getSearchColumns(HttpHeaders headers) { return Response.ok(CriteriaEntitySearchUtil.getSearchColumns(ApiUserActionLog.class)).build(); } @Override public Response findAll(HttpHeaders headers, CriteriaFormRequest criteriaFormRequest) { try { CriteriaEntityFromView criterion = criteriaFormRequest != null ? criteriaFormRequest.getCriteria() : null; List logs = manager.findAll(criterion, Arrays.asList(), Arrays.asList(new OrderByDefinition(manager.getEntityIdName(), OrderByType.DESC))); return Response.ok(mapper.apiUserActionLogListToUserActionLogDtoList(logs)).build(); } catch (Exception ex) { Logger.getLogger(UserActionLogRSImpl.class.getName()).log(Level.SEVERE, ex.getMessage(), ex); throw new CommonApplicationServerException(); } } @Override public Response printAll(HttpHeaders headers, ReportConfiguration reportConfiguration) { try { File file = manager.printAll(reportConfiguration, utilisateurConnecte); return manager.downloadFile(file); } catch (Exception ex) { Logger.getLogger(PaysRSImpl.class.getName()).log(Level.SEVERE, ex.getMessage(), ex); throw new CommonApplicationServerException(); } } @Override public Response printOne(@Context HttpHeaders headers, @Context HttpServletRequest request, Long id, ReportConfiguration reportConfiguration) { try { ApiUserActionLog entite = manager.getById(id); userActionLogManager.log(headers, request, "Export pdf détail log API (id=" + entite.getId() + ")", utilisateurConnecte.getUserName()); File file = manager.printOne(reportConfiguration, utilisateurConnecte); return manager.downloadFile(file); } catch (Exception ex) { Logger.getLogger(UserActionLogRSImpl.class.getName()).log(Level.SEVERE, ex.getMessage(), ex); throw new CommonApplicationServerException(); } } @Override public Response getPrintableColumns(HttpHeaders headers) { List customFields = PrintableColumnExtractor.extract(ApiUserActionLogReporting.class); return Response.ok(mapper.customFieldListToCustomFieldDtoList(customFields)).build(); } @Override public Response exportExcelAll(HttpHeaders headers, ReportConfiguration reportConfiguration) { try { File file = manager.exportExcelAll(reportConfiguration, utilisateurConnecte); return manager.downloadFile(file); } catch (Exception ex) { ex.printStackTrace(); throw new CommonApplicationServerException(); } } @Override public Response exportExcelOne(HttpHeaders headers, @Context HttpServletRequest request, Long id, ReportConfiguration reportConfiguration) { try { ApiUserActionLog entite = manager.getById(id); userActionLogManager.log(headers, request, "Export excel détail log API (id=" + entite.getId() + ")", utilisateurConnecte.getUserName()); reportConfiguration.setSearchEntity(manager.getExportOneCriterion(id)); File file = manager.exportExcelOne(reportConfiguration, utilisateurConnecte); return manager.downloadFile(file); } catch (Exception ex) { ex.printStackTrace(); throw new CommonApplicationServerException(); } } @Override public Response getByStatut(HttpHeaders headers, ApiUserActionSummarySearch apiUserActionSummarySearch) { return Response.ok(manager.getByStatut(apiUserActionSummarySearch)).build(); } @Override public Response getByStatutAndUserName(HttpHeaders headers, ApiUserActionSummarySearch apiUserActionSummarySearch) { return Response.ok(manager.getByStatutAndUserName(apiUserActionSummarySearch)).build(); } @Override public Response getByStatutAndPath(HttpHeaders headers, ApiUserActionSummarySearch apiUserActionSummarySearch) { return Response.ok(manager.getByStatutAndPath(apiUserActionSummarySearch)).build(); } }