diff --git a/odd-platform-api/src/main/java/org/opendatadiscovery/oddplatform/controller/TermController.java b/odd-platform-api/src/main/java/org/opendatadiscovery/oddplatform/controller/TermController.java index 5d7e6fc9f..d77d547c0 100644 --- a/odd-platform-api/src/main/java/org/opendatadiscovery/oddplatform/controller/TermController.java +++ b/odd-platform-api/src/main/java/org/opendatadiscovery/oddplatform/controller/TermController.java @@ -1,5 +1,6 @@ package org.opendatadiscovery.oddplatform.controller; +import java.time.LocalDate; import java.util.UUID; import lombok.RequiredArgsConstructor; import org.opendatadiscovery.oddplatform.api.contract.api.TermApi; @@ -50,8 +51,10 @@ public class TermController implements TermApi { @Override public Mono> getTermsList(final Integer page, final Integer size, final String query, + final LocalDate updatedAtRangeStartDateTime, + final LocalDate updatedAtRangeEndDateTime, final ServerWebExchange exchange) { - return termService.getTerms(page, size, query) + return termService.getTerms(page, size, query, updatedAtRangeStartDateTime, updatedAtRangeEndDateTime) .map(ResponseEntity::ok); } diff --git a/odd-platform-api/src/main/java/org/opendatadiscovery/oddplatform/repository/reactive/ReactiveTermRepository.java b/odd-platform-api/src/main/java/org/opendatadiscovery/oddplatform/repository/reactive/ReactiveTermRepository.java index 81b5d2f18..86feedb4b 100644 --- a/odd-platform-api/src/main/java/org/opendatadiscovery/oddplatform/repository/reactive/ReactiveTermRepository.java +++ b/odd-platform-api/src/main/java/org/opendatadiscovery/oddplatform/repository/reactive/ReactiveTermRepository.java @@ -1,5 +1,6 @@ package org.opendatadiscovery.oddplatform.repository.reactive; +import java.time.LocalDate; import java.util.List; import org.opendatadiscovery.oddplatform.dto.FacetStateDto; import org.opendatadiscovery.oddplatform.dto.term.LinkedTermDto; @@ -14,7 +15,9 @@ public interface ReactiveTermRepository extends ReactiveCRUDRepository { - Mono> listTermRefDtos(final int page, final int size, final String query); + Mono> listTermRefDtos(final int page, final int size, final String query, + final LocalDate updatedAtRangeStartDateTime, + final LocalDate updatedAtRangeEndDateTime); Mono existsByNamespace(final Long namespaceId); diff --git a/odd-platform-api/src/main/java/org/opendatadiscovery/oddplatform/repository/reactive/ReactiveTermRepositoryImpl.java b/odd-platform-api/src/main/java/org/opendatadiscovery/oddplatform/repository/reactive/ReactiveTermRepositoryImpl.java index 023069a7b..36abc02b0 100644 --- a/odd-platform-api/src/main/java/org/opendatadiscovery/oddplatform/repository/reactive/ReactiveTermRepositoryImpl.java +++ b/odd-platform-api/src/main/java/org/opendatadiscovery/oddplatform/repository/reactive/ReactiveTermRepositoryImpl.java @@ -1,13 +1,16 @@ package org.opendatadiscovery.oddplatform.repository.reactive; +import java.time.LocalDate; import java.util.ArrayList; import java.util.Arrays; +import java.util.Collections; import java.util.List; import java.util.Map; import java.util.Set; import java.util.stream.Collectors; import java.util.stream.Stream; import org.apache.commons.collections4.CollectionUtils; +import org.apache.commons.collections4.ListUtils; import org.apache.commons.lang3.StringUtils; import org.jooq.Condition; import org.jooq.Field; @@ -102,9 +105,12 @@ public ReactiveTermRepositoryImpl(final JooqReactiveOperations jooqReactiveOpera } @Override - public Mono> listTermRefDtos(final int page, final int size, final String nameQuery) { + public Mono> listTermRefDtos(final int page, final int size, final String nameQuery, + final LocalDate updatedAtRangeStartDateTime, + final LocalDate updatedAtRangeEndDateTime) { final Select homogeneousQuery = DSL.selectFrom(TERM) - .where(listCondition(nameQuery)); + .where(ListUtils.union(listCondition(nameQuery), + dateConditions(updatedAtRangeStartDateTime, updatedAtRangeEndDateTime))); final Select termSelect = paginate(homogeneousQuery, List.of(new OrderByField(TERM.ID, SortOrder.ASC)), (page - 1) * size, size); @@ -627,4 +633,23 @@ private List extractTerms(final Record record) { }) .toList(); } + + private List dateConditions(final LocalDate updatedAtRangeStartDateTime, + final LocalDate updatedAtRangeEndDateTime) { + if (updatedAtRangeStartDateTime == null && updatedAtRangeEndDateTime == null) { + return Collections.emptyList(); + } + + final List conditions = new ArrayList<>(); + + if (updatedAtRangeStartDateTime != null) { + conditions.add(TERM.UPDATED_AT.greaterOrEqual(updatedAtRangeStartDateTime.atStartOfDay())); + } + + if (updatedAtRangeEndDateTime != null) { + conditions.add(TERM.UPDATED_AT.lessThan(updatedAtRangeEndDateTime.atStartOfDay())); + } + + return conditions; + } } diff --git a/odd-platform-api/src/main/java/org/opendatadiscovery/oddplatform/service/term/TermService.java b/odd-platform-api/src/main/java/org/opendatadiscovery/oddplatform/service/term/TermService.java index b44243caa..f80b25e8a 100644 --- a/odd-platform-api/src/main/java/org/opendatadiscovery/oddplatform/service/term/TermService.java +++ b/odd-platform-api/src/main/java/org/opendatadiscovery/oddplatform/service/term/TermService.java @@ -1,5 +1,6 @@ package org.opendatadiscovery.oddplatform.service.term; +import java.time.LocalDate; import java.util.List; import org.opendatadiscovery.oddplatform.api.contract.model.LinkedTerm; import org.opendatadiscovery.oddplatform.api.contract.model.LinkedTermList; @@ -14,7 +15,8 @@ import reactor.core.publisher.Mono; public interface TermService { - Mono getTerms(final Integer page, final Integer size, final String query); + Mono getTerms(final Integer page, final Integer size, final String query, + LocalDate updatedAtRangeStartDateTime, LocalDate updatedAtRangeEndDateTime); Mono getTermByNamespaceAndName(final String namespaceName, final String name); diff --git a/odd-platform-api/src/main/java/org/opendatadiscovery/oddplatform/service/term/TermServiceImpl.java b/odd-platform-api/src/main/java/org/opendatadiscovery/oddplatform/service/term/TermServiceImpl.java index c89d188fa..30965e138 100644 --- a/odd-platform-api/src/main/java/org/opendatadiscovery/oddplatform/service/term/TermServiceImpl.java +++ b/odd-platform-api/src/main/java/org/opendatadiscovery/oddplatform/service/term/TermServiceImpl.java @@ -1,5 +1,6 @@ package org.opendatadiscovery.oddplatform.service.term; +import java.time.LocalDate; import java.util.ArrayList; import java.util.HashSet; import java.util.List; @@ -80,8 +81,10 @@ public class TermServiceImpl implements TermService { private final TagMapper tagMapper; @Override - public Mono getTerms(final Integer page, final Integer size, final String query) { - return termRepository.listTermRefDtos(page, size, query) + public Mono getTerms(final Integer page, final Integer size, final String query, + final LocalDate updatedAtRangeStartDateTime, + final LocalDate updatedAtRangeEndDateTime) { + return termRepository.listTermRefDtos(page, size, query, updatedAtRangeStartDateTime, updatedAtRangeEndDateTime) .map(termMapper::mapToRefPage); } diff --git a/odd-platform-specification/components.yaml b/odd-platform-specification/components.yaml index decd7940b..a45e1d260 100644 --- a/odd-platform-specification/components.yaml +++ b/odd-platform-specification/components.yaml @@ -2558,6 +2558,9 @@ components: type: string definition: type: string + updated_at: + type: string + format: date-time namespace: $ref: '#/components/schemas/Namespace' required: diff --git a/odd-platform-specification/openapi.yaml b/odd-platform-specification/openapi.yaml index 60e90c010..7ea77b0a2 100644 --- a/odd-platform-specification/openapi.yaml +++ b/odd-platform-specification/openapi.yaml @@ -2725,6 +2725,18 @@ paths: - $ref: './components.yaml/#/components/parameters/PageParam' - $ref: './components.yaml/#/components/parameters/SizeParam' - $ref: './components.yaml/#/components/parameters/SearchParam' + - name: updated_at_range_start_date_time + in: query + required: false + schema: + type: string + format: date + - name: updated_at_range_end_date_time + in: query + required: false + schema: + type: string + format: date responses: '200': description: OK