Search in sources :

Example 11 with Specification

use of org.springframework.data.jpa.domain.Specification in project FP-PSP-SERVER by FundacionParaguaya.

the class SnapshotDraftSpecification method createdAtLessDays.

public static Specification<SnapshotDraftEntity> createdAtLessDays(long days) {
    return new Specification<SnapshotDraftEntity>() {

        @Override
        public Predicate toPredicate(Root<SnapshotDraftEntity> root, CriteriaQuery<?> query, CriteriaBuilder cb) {
            LocalDateTime limit = LocalDateTime.now();
            limit = limit.minusDays(days);
            return cb.and(cb.greaterThan(root.<LocalDateTime>get(SnapshotDraftEntity_.getCreatedAt()), limit));
        }
    };
}
Also used : CriteriaBuilder(javax.persistence.criteria.CriteriaBuilder) LocalDateTime(java.time.LocalDateTime) Root(javax.persistence.criteria.Root) CriteriaQuery(javax.persistence.criteria.CriteriaQuery) Specification(org.springframework.data.jpa.domain.Specification)

Example 12 with Specification

use of org.springframework.data.jpa.domain.Specification in project FP-PSP-SERVER by FundacionParaguaya.

the class SnapshotEconomicSpecification method createdAtLess2Months.

public static Specification<SnapshotEconomicEntity> createdAtLess2Months() {
    return new Specification<SnapshotEconomicEntity>() {

        @Override
        public Predicate toPredicate(Root<SnapshotEconomicEntity> root, CriteriaQuery<?> query, CriteriaBuilder cb) {
            LocalDateTime limit = LocalDateTime.now();
            limit = limit.minusMonths(MONTH_AGO).withDayOfMonth(1);
            return cb.and(cb.greaterThan(root.<LocalDateTime>get(SnapshotEconomicEntity_.getCreatedAt()), limit));
        }
    };
}
Also used : CriteriaBuilder(javax.persistence.criteria.CriteriaBuilder) LocalDateTime(java.time.LocalDateTime) Root(javax.persistence.criteria.Root) CriteriaQuery(javax.persistence.criteria.CriteriaQuery) Specification(org.springframework.data.jpa.domain.Specification)

Example 13 with Specification

use of org.springframework.data.jpa.domain.Specification in project FP-PSP-SERVER by FundacionParaguaya.

the class FamilySpecification method byFilter.

public static Specification<FamilyEntity> byFilter(FamilyFilterDTO filter) {
    return new Specification<FamilyEntity>() {

        @Override
        public Predicate toPredicate(Root<FamilyEntity> root, CriteriaQuery<?> query, CriteriaBuilder cb) {
            List<Predicate> predicates = new ArrayList<>();
            if (filter.getApplicationId() != null) {
                Join<FamilyEntity, ApplicationEntity> joinApplication = root.join(FamilyEntity_.getApplication());
                Expression<Long> byApplicationId = joinApplication.<Long>get(ID_ATTRIBUTE);
                predicates.add(cb.equal(byApplicationId, filter.getApplicationId()));
            }
            if (filter.getOrganizationId() != null) {
                Expression<Long> byOrganizationId = root.join(FamilyEntity_.getOrganization()).<Long>get(ID_ATTRIBUTE);
                predicates.add(cb.equal(byOrganizationId, filter.getOrganizationId()));
            }
            if (filter.getCountryId() != null) {
                Join<FamilyEntity, CountryEntity> joinCountry = root.join(FamilyEntity_.getCountry());
                Expression<Long> byCountryId = joinCountry.<Long>get(ID_ATTRIBUTE);
                predicates.add(cb.equal(byCountryId, filter.getCountryId()));
            }
            if (filter.getCityId() != null) {
                Join<FamilyEntity, CityEntity> joinCity = root.join(FamilyEntity_.getCity());
                Expression<Long> byCityId = joinCity.<Long>get(ID_ATTRIBUTE);
                predicates.add(cb.equal(byCityId, filter.getCityId()));
            }
            if (StringUtils.isNotEmpty(filter.getName())) {
                String nameParamQuery = "%" + filter.getName().toLowerCase().replaceAll("\\s", "%") + "%";
                Expression<String> likeName = cb.lower(root.get(FamilyEntity_.getName()));
                predicates.add(cb.like(likeName, nameParamQuery));
            }
            if (filter.getLastModifiedGt() != null) {
                LocalDateTime dateTimeParam = LocalDateTime.parse(filter.getLastModifiedGt());
                Predicate predicate = cb.greaterThan(root.get(FamilyEntity_.getLastModifiedAt()), dateTimeParam);
                predicates.add(predicate);
            }
            predicates.add(cb.isTrue(root.get(FamilyEntity_.getIsActive())));
            return cb.and(predicates.toArray(new Predicate[predicates.size()]));
        }
    };
}
Also used : CriteriaBuilder(javax.persistence.criteria.CriteriaBuilder) LocalDateTime(java.time.LocalDateTime) FamilyEntity(py.org.fundacionparaguaya.pspserver.families.entities.FamilyEntity) Root(javax.persistence.criteria.Root) CriteriaQuery(javax.persistence.criteria.CriteriaQuery) ArrayList(java.util.ArrayList) CityEntity(py.org.fundacionparaguaya.pspserver.system.entities.CityEntity) Specification(org.springframework.data.jpa.domain.Specification) Predicate(javax.persistence.criteria.Predicate) ApplicationEntity(py.org.fundacionparaguaya.pspserver.network.entities.ApplicationEntity) CountryEntity(py.org.fundacionparaguaya.pspserver.system.entities.CountryEntity)

Example 14 with Specification

use of org.springframework.data.jpa.domain.Specification in project FP-PSP-SERVER by FundacionParaguaya.

the class SnapshotReportManagerImpl method listFamilyByOrganizationAndCreatedDate.

@Override
public List<OrganizationFamilyDTO> listFamilyByOrganizationAndCreatedDate(SnapshotFilterDTO filters) {
    List<FamilyEntity> families = new ArrayList<>();
    Sort sort = new Sort(new Sort.Order(Direction.ASC, "organization.name"), new Sort.Order(Direction.ASC, "name"));
    Specification<FamilyEntity> dateRange = FamilySpecification.createdAtBetween2Dates(filters.getDateFrom(), filters.getDateTo());
    families = familyRepository.findAll(where(byOrganization(filters.getOrganizationId())).and(dateRange).and(byApplication(filters.getApplicationId())).and(dateRange), sort);
    Map<OrganizationEntity, List<FamilyEntity>> groupByOrganization = families.stream().collect(Collectors.groupingBy(f -> f.getOrganization()));
    List<OrganizationFamilyDTO> toRet = new ArrayList<>();
    groupByOrganization.forEach((k, v) -> {
        OrganizationFamilyDTO fa = new OrganizationFamilyDTO(k.getName(), k.getCode(), k.getDescription(), k.isActive());
        fa.setFamilies(familyReportMapper.entityListToDtoList(v));
        toRet.add(fa);
    });
    return toRet;
}
Also used : Specifications.where(org.springframework.data.jpa.domain.Specifications.where) Arrays(java.util.Arrays) FamilyRepository(py.org.fundacionparaguaya.pspserver.families.repositories.FamilyRepository) SurveyEntity(py.org.fundacionparaguaya.pspserver.surveys.entities.SurveyEntity) SnapshotFilterDTO(py.org.fundacionparaguaya.pspserver.reports.dtos.SnapshotFilterDTO) FamilySpecification.byOrganization(py.org.fundacionparaguaya.pspserver.families.specifications.FamilySpecification.byOrganization) SurveyData(py.org.fundacionparaguaya.pspserver.surveys.dtos.SurveyData) OrganizationFamilyDTO(py.org.fundacionparaguaya.pspserver.reports.dtos.OrganizationFamilyDTO) FamilyEntity(py.org.fundacionparaguaya.pspserver.families.entities.FamilyEntity) ArrayList(java.util.ArrayList) SnapshotEconomicSpecification(py.org.fundacionparaguaya.pspserver.surveys.specifications.SnapshotEconomicSpecification) Service(org.springframework.stereotype.Service) Map(java.util.Map) Sort(org.springframework.data.domain.Sort) Direction(org.springframework.data.domain.Sort.Direction) SnapshotReportManager(py.org.fundacionparaguaya.pspserver.reports.services.SnapshotReportManager) OrganizationEntity(py.org.fundacionparaguaya.pspserver.network.entities.OrganizationEntity) ReportDTO(py.org.fundacionparaguaya.pspserver.reports.dtos.ReportDTO) StringConverter(py.org.fundacionparaguaya.pspserver.common.utils.StringConverter) FamilySnapshotDTO(py.org.fundacionparaguaya.pspserver.reports.dtos.FamilySnapshotDTO) Collectors(java.util.stream.Collectors) FamilyDTOMapper(py.org.fundacionparaguaya.pspserver.reports.mapper.FamilyDTOMapper) SnapshotEconomicRepository(py.org.fundacionparaguaya.pspserver.surveys.repositories.SnapshotEconomicRepository) List(java.util.List) SnapshotEconomicEntity(py.org.fundacionparaguaya.pspserver.surveys.entities.SnapshotEconomicEntity) FamilySpecification(py.org.fundacionparaguaya.pspserver.families.specifications.FamilySpecification) Specification(org.springframework.data.jpa.domain.Specification) FamilySpecification.byApplication(py.org.fundacionparaguaya.pspserver.families.specifications.FamilySpecification.byApplication) SnapshotIndicatorMapper(py.org.fundacionparaguaya.pspserver.surveys.mapper.SnapshotIndicatorMapper) SnapshotEconomicSpecification.forFamily(py.org.fundacionparaguaya.pspserver.surveys.specifications.SnapshotEconomicSpecification.forFamily) FamilyEntity(py.org.fundacionparaguaya.pspserver.families.entities.FamilyEntity) OrganizationEntity(py.org.fundacionparaguaya.pspserver.network.entities.OrganizationEntity) OrganizationFamilyDTO(py.org.fundacionparaguaya.pspserver.reports.dtos.OrganizationFamilyDTO) ArrayList(java.util.ArrayList) Sort(org.springframework.data.domain.Sort) ArrayList(java.util.ArrayList) List(java.util.List)

Example 15 with Specification

use of org.springframework.data.jpa.domain.Specification in project summer by foxsugar.

the class HomeServiceImpl method findChargeByOrderId.

@Override
public Charge findChargeByOrderId(long oId) {
    Specification<Charge> specification = new Specification<Charge>() {

        @Override
        public Predicate toPredicate(Root<Charge> root, CriteriaQuery<?> query, CriteriaBuilder cb) {
            Path path = root.get("orderId");
            Predicate predicate = path.as(Long.class).in(Arrays.asList(oId));
            return predicate;
        }
    };
    Charge charge = chargeDao.findOne(specification);
    return charge;
}
Also used : Charge(com.code.server.db.model.Charge) Specification(org.springframework.data.jpa.domain.Specification)

Aggregations

Specification (org.springframework.data.jpa.domain.Specification)19 CriteriaBuilder (javax.persistence.criteria.CriteriaBuilder)14 CriteriaQuery (javax.persistence.criteria.CriteriaQuery)14 Root (javax.persistence.criteria.Root)14 Predicate (javax.persistence.criteria.Predicate)12 ArrayList (java.util.ArrayList)8 Test (org.junit.Test)4 Charge (com.code.server.db.model.Charge)3 LocalDateTime (java.time.LocalDateTime)3 Sort (org.springframework.data.domain.Sort)3 IdmRoleDto (eu.bcvsolutions.idm.core.api.dto.IdmRoleDto)2 IdmFormAttributeDto (eu.bcvsolutions.idm.core.eav.api.dto.IdmFormAttributeDto)2 IdmFormDefinitionDto (eu.bcvsolutions.idm.core.eav.api.dto.IdmFormDefinitionDto)2 IdmRole (eu.bcvsolutions.idm.core.model.entity.IdmRole)2 IdmRoleFormValue (eu.bcvsolutions.idm.core.model.entity.eav.IdmRoleFormValue)2 BasePermission (eu.bcvsolutions.idm.core.security.api.domain.BasePermission)2 AuthorizableType (eu.bcvsolutions.idm.core.security.api.dto.AuthorizableType)2 AuthorizableService (eu.bcvsolutions.idm.core.security.api.service.AuthorizableService)2 AbstractIntegrationTest (eu.bcvsolutions.idm.test.api.AbstractIntegrationTest)2 DateTimeFormatter (java.time.format.DateTimeFormatter)2