com.couchbase.client.core.api.search.queries.CoreDateRangeQuery Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of core-io Show documentation
Show all versions of core-io Show documentation
The official Couchbase JVM Core IO Library
/*
* Copyright (c) 2023 Couchbase, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.couchbase.client.core.api.search.queries;
import com.couchbase.client.core.annotation.Stability;
import com.couchbase.client.core.api.search.CoreSearchQuery;
import com.couchbase.client.core.deps.com.fasterxml.jackson.databind.node.ObjectNode;
import com.couchbase.client.protostellar.search.v1.DateRangeQuery;
import com.couchbase.client.protostellar.search.v1.Query;
import reactor.util.annotation.Nullable;
@Stability.Internal
public class CoreDateRangeQuery extends CoreSearchQuery {
private final @Nullable String start;
private final @Nullable String end;
private final @Nullable Boolean inclusiveStart;
private final @Nullable Boolean inclusiveEnd;
private final @Nullable String dateTimeParser;
private final @Nullable String field;
public CoreDateRangeQuery(@Nullable String start,
@Nullable String end,
@Nullable Boolean inclusiveStart,
@Nullable Boolean inclusiveEnd,
@Nullable String dateTimeParser,
@Nullable String field,
@Nullable Double boost) {
super(boost);
if (start == null && end == null) {
throw new NullPointerException("DateRangeQuery needs at least one of start or end");
}
this.start = start;
this.end = end;
this.inclusiveStart = inclusiveStart;
this.inclusiveEnd = inclusiveEnd;
this.dateTimeParser = dateTimeParser;
this.field = field;
}
@Override
protected void injectParams(ObjectNode input) {
if (start != null) {
input.put("start", start);
if (inclusiveStart != null) {
input.put("inclusive_start", inclusiveStart);
}
}
if (end != null) {
input.put("end", end);
if (inclusiveEnd != null) {
input.put("inclusive_end", inclusiveEnd);
}
}
if (dateTimeParser != null) {
input.put("datetime_parser", dateTimeParser);
}
if (field != null) {
input.put("field", field);
}
}
@Override
public Query asProtostellar() {
DateRangeQuery.Builder builder = DateRangeQuery.newBuilder();
if (start != null) {
builder.setStartDate(start);
if (inclusiveStart != null) {
// Requires ING-381
throw new UnsupportedOperationException("inclusiveStart is not currently supported in DateRangeQuery for Protostellar");
}
}
if (end != null) {
builder.setEndDate(end);
if (inclusiveEnd != null) {
// Requires ING-381
throw new UnsupportedOperationException("inclusiveStart is not currently supported in DateRangeQuery for Protostellar");
}
}
if (dateTimeParser != null) {
builder.setDateTimeParser(dateTimeParser);
}
if (field != null) {
builder.setField(field);
}
if (boost != null) {
builder.setBoost(boost.floatValue());
}
return Query.newBuilder().setDateRangeQuery(builder).build();
}
}