package com.megatim.fdxconsultation.service.impl.referentiel;
|
|
import com.megatim.fdxcommons.model.referentiel.Pays;
|
import com.megatim.fdxconsultation.core.ifaces.administration.UserManager;
|
import com.megatim.fdxconsultation.core.ifaces.referentiel.PaysManager;
|
import com.megatim.fdxcommons.model.dtos.referentiel.PaysDto;
|
import com.megatim.fdxcommons.model.pojo.CriteriaEntityFromView;
|
import com.megatim.fdxconsultation.model.administration.User;
|
import com.megatim.fdxcommons.model.pojo.CriteriaFormRequest;
|
import com.megatim.fdxcommons.tools.exceptions.CommonApplicationServerException;
|
import com.megatim.fdxconsultation.core.ifaces.log.UserActionLogManager;
|
import com.megatim.fdxconsultation.core.impl.utils.CriteriaEntitySearchUtil;
|
import com.megatim.fdxconsultation.reporting.model.referentiel.PaysReporting;
|
import com.megatim.fdxconsultation.model.mappers.MapStructMapper;
|
import com.megatim.fdxconsultation.service.ifaces.referentiel.PaysRS;
|
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.SecuredAdmin;
|
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 = "Pays", description = "Pays")
|
@Path("pays")
|
@SecuredAdmin(action = {"valider", "rejeter", "consulter"})
|
public class PaysRSImpl implements PaysRS {
|
|
@Inject
|
private PaysManager manager;
|
|
@Inject
|
private UserManager userManager;
|
|
@Inject
|
private UserActionLogManager userActionLogManager;
|
|
@AuthenticatedUser
|
private static User utilisateurConnecte;
|
|
@Inject
|
MapStructMapper mapStructMapper;
|
|
@Inject
|
com.megatim.fdxcommons.model.mappers.MapStructMapper commonMapper;
|
|
public PaysRSImpl() {
|
super();
|
}
|
|
public void handleAuthenticationEvent(@Observes @AuthenticatedUser String username) {
|
utilisateurConnecte = userManager.recuperUtilisateur(username);
|
}
|
|
@Override
|
public PaysDto mapToDto(Pays entity) {
|
return commonMapper.paysToPaysDto(entity);
|
}
|
|
@Override
|
public Response getSearchColumns(HttpHeaders headers) {
|
return Response.ok(CriteriaEntitySearchUtil.getSearchColumns(Pays.class)).build();
|
}
|
|
@Override
|
public Response findWithPagination(HttpHeaders headers, Integer pageNumber, Integer pageSize, CriteriaFormRequest criteriaFormRequest) {
|
try {
|
List<Pays> data = manager.findWithPagination(criteriaFormRequest, Arrays.asList("participants"), pageNumber, pageSize);
|
return Response.ok(commonMapper.paysListToPaysDtoList(data)).build();
|
} catch (Exception ex) {
|
Logger.getLogger(PaysRSImpl.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(PaysRSImpl.class.getName()).log(Level.SEVERE, ex.getMessage(), ex);
|
throw new CommonApplicationServerException();
|
}
|
}
|
|
@Override
|
public Response findById(HttpHeaders headers, String id) {
|
Pays datum = manager.getById(id);
|
return Response.ok(mapToDto(datum)).build();
|
}
|
|
@Override
|
public Response printAll(HttpHeaders headers, ReportConfiguration<CriteriaFormRequest> 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, String id, ReportConfiguration<CriteriaFormRequest> reportConfiguration) {
|
try {
|
Pays entite = manager.getById(id);
|
// userActionLogManager.log(headers, request, "Export pdf détail pays : "+entite.getCode()+" (id="+entite.getCode()+")",
|
// utilisateurConnecte.getUserName());
|
reportConfiguration.setSearchEntity(manager.getExportOneCriterion(id));
|
File file = manager.printOne(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 getPrintableColumns(HttpHeaders headers) {
|
List<CustomField> customFields = PrintableColumnExtractor.extract(PaysReporting.class);
|
return Response.ok(mapStructMapper.customFieldListToCustomFieldDtoList(customFields)).build();
|
}
|
|
@Override
|
public Response exportExcelAll(HttpHeaders headers, ReportConfiguration<CriteriaFormRequest> reportConfiguration) {
|
try {
|
File file = manager.exportExcelAll(reportConfiguration, utilisateurConnecte);
|
return manager.downloadFile(file);
|
} catch (Exception ex) {
|
ex.printStackTrace();
|
throw new CommonApplicationServerException();
|
}
|
}
|
|
@Override
|
public Response exportExcelOne(@Context HttpHeaders headers, @Context HttpServletRequest request, String id, ReportConfiguration<CriteriaFormRequest> reportConfiguration) {
|
try {
|
Pays entite = manager.getById(id);
|
userActionLogManager.log(headers, request, "Export excel détail pays : " + entite.getCode() + " (id=" + entite.getCode() + ")",
|
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 findAll(HttpHeaders headers, CriteriaFormRequest criteriaFormRequest) {
|
return Response.ok(manager.findAll(criteriaFormRequest, Arrays.asList("participants"))).build();
|
}
|
|
}
|