io.r2dbc.postgresql.OptionMapper Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of r2dbc-postgresql Show documentation
Show all versions of r2dbc-postgresql Show documentation
Reactive Relational Database Connectivity Driver Implementation for Postgresql
/*
* Copyright 2020 the original author or authors.
*
* 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
*
* https://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 io.r2dbc.postgresql;
import io.r2dbc.postgresql.util.Assert;
import io.r2dbc.spi.ConnectionFactoryOptions;
import io.r2dbc.spi.Option;
import java.time.Duration;
import java.util.Locale;
import java.util.function.Consumer;
import java.util.function.Function;
import java.util.function.Supplier;
/**
* An utility data parser for {@link Option}.
*
* @since 0.8.3
*/
final class OptionMapper {
private final ConnectionFactoryOptions options;
private OptionMapper(ConnectionFactoryOptions options) {
this.options = options;
}
/**
* Construct a new {@link OptionMapper} given {@link ConnectionFactoryOptions}.
*
* @param options must not be {@code null}.
* @return the option mapper.
*/
public static OptionMapper create(ConnectionFactoryOptions options) {
return new OptionMapper(options);
}
/**
* Construct a new {@link Source} for a {@link Option}. Options without a value are not bound or mapped in the later stages of {@link Source}.
*
* @param option the option to apply.
* @param inferred option type.
* @return the source object.
*/
public Source from(Option option) {
if (this.options.hasOption(option)) {
return new AvailableSource(() -> {
return this.options.getRequiredValue(option);
}, option.name());
}
return NullSource.instance();
}
/**
* Parse an {@link Option} to int.
*/
static int toInteger(Object value) {
if (value instanceof Number) {
return ((Number) value).intValue();
}
if (value instanceof String) {
return Integer.parseInt(value.toString());
}
throw new IllegalArgumentException(String.format("Cannot convert value %s into integer", value));
}
/**
* Parse an {@link Option} to boolean.
*/
static boolean toBoolean(Object value) {
if (value instanceof Boolean) {
return ((Boolean) value).booleanValue();
}
if (value instanceof String) {
return Boolean.parseBoolean(value.toString());
}
throw new IllegalArgumentException(String.format("Cannot convert value %s into boolean", value));
}
/**
* Parse an {@link Option} to {@link Enum}.
*/
@SuppressWarnings("unchecked")
static > T toEnum(Object value, Class enumType) {
if (enumType.isInstance(value)) {
return ((T) value);
}
if (value instanceof String) {
return T.valueOf(enumType, value.toString().toUpperCase(Locale.ENGLISH));
}
throw new IllegalArgumentException(String.format("Cannot convert value %s into %s", value, enumType.getName()));
}
/**
* Parse an ISO-8601 formatted {@link Option} to {@link Duration}.
*/
static Duration toDuration(Object value) {
if (value instanceof Duration) {
return ((Duration) value);
}
if (value instanceof String) {
return Duration.parse(value.toString());
}
throw new IllegalArgumentException(String.format("Cannot convert value %s into Duration", value));
}
public interface Source {
/**
* Return an mapped version of the source changed via the given mapping function.
*
* @param the resulting type
* @param mappingFunction the mapping function to apply
* @return a new adapted source instance
*/
Source map(Function