org.dominokit.rest.shared.request.ParameterSetter Maven / Gradle / Ivy
/*
* Copyright © 2019 Dominokit
*
* 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 org.dominokit.rest.shared.request;
import static java.util.Objects.isNull;
import java.util.Collection;
import java.util.Date;
import java.util.function.Supplier;
/** A utility class to set query parameters for a request */
public class ParameterSetter {
/**
* General query parameters setter
*
* @param request {@link ServerRequest} the target request for which we add the query parameter
* @param name String name of the query parameter
* @param valueSupplier {@link Supplier} for the query parameter value
* @param The generic type of the query parameter value
*/
public static void setQueryParameter(
ServerRequest, ?> request, String name, Supplier valueSupplier) {
if (isNull(valueSupplier) || isNull(valueSupplier.get())) {
request.getNullQueryParamStrategy().setNullValue(request, name);
} else {
request.addQueryParameter(name, String.valueOf(valueSupplier.get()));
}
}
/**
* General query parameters setter
*
* @param request {@link ServerRequest} the target request for which we add the query parameter
* @param name String name of the query parameter
* @param valueSupplier {@link Supplier} for the query parameter value
* @param The generic type of the query parameter value
*/
public static > void setCollectionQueryParameter(
ServerRequest, ?> request, String name, Supplier valueSupplier) {
if (isNull(valueSupplier) || isNull(valueSupplier.get()) || valueSupplier.get().size() < 1) {
request.getNullQueryParamStrategy().setNullValue(request, name);
} else {
valueSupplier
.get()
.forEach(value -> ParameterSetter.setQueryParameter(request, name, () -> value));
}
}
/**
* Date query parameter setter that formats the date using the {@link
* RestConfig#getDateParamFormatter()}
*
* @param request {@link ServerRequest} the target request for which we add the query parameter
* @param name String name of the query parameter
* @param valueSupplier a {@link Date} value {@link Supplier}
* @param pattern String date format pattern
*/
public static void setDateQueryParameter(
ServerRequest, ?> request, String name, Supplier valueSupplier, String pattern) {
if (isNull(valueSupplier) || isNull(valueSupplier.get())) {
request.getNullQueryParamStrategy().setNullValue(request, name);
} else {
request.addQueryParameter(
name,
DominoRestContext.make()
.getConfig()
.getDateParamFormatter()
.format(valueSupplier.get(), pattern));
}
}
/**
* Date query parameter setter that formats the date using the {@link
* RestConfig#getDateParamFormatter()}
*
* @param request {@link ServerRequest} the target request for which we add the query parameter
* @param name String name of the query parameter
* @param valueSupplier a {@link Date} collection value {@link Supplier}
* @param pattern String date format pattern
*/
public static void setDateCollectionQueryParameter(
ServerRequest, ?> request,
String name,
Supplier extends Collection> valueSupplier,
String pattern) {
if (isNull(valueSupplier) || isNull(valueSupplier.get()) || valueSupplier.get().size() < 1) {
request.getNullQueryParamStrategy().setNullValue(request, name);
} else {
valueSupplier
.get()
.forEach(
value -> ParameterSetter.setDateQueryParameter(request, name, () -> value, pattern));
}
}
/**
* Sets general path parameters
*
* @param request {@link ServerRequest} the target request for which we add the path parameter
* @param name String name of the path parameter
* @param valueSupplier {@link Supplier} for the path parameter value
* @param The generic type of the path parameter value
*/
public static void setPathParameter(
ServerRequest, ?> request, String name, Supplier valueSupplier) {
request.setPathParameter(name, request.emptyOrStringValue(valueSupplier));
}
/**
* Sets a date path parameter
*
* @param request {@link ServerRequest} the target request for which we add the path parameter
* @param name String name of the path parameter
* @param valueSupplier a {@link Date} value {@link Supplier}
* @param pattern String date format pattern
*/
public static void setPathParameter(
ServerRequest, ?> request, String name, Supplier valueSupplier, String pattern) {
request.setPathParameter(name, request.formatDate(valueSupplier, pattern));
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy