/*
* 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.jdbi.v3.core.argument;
import static org.jdbi.v3.core.internal.JdbiStreams.toStream;
import java.lang.reflect.Type;
import java.sql.Types;
import java.util.List;
import java.util.Optional;
import java.util.concurrent.CopyOnWriteArrayList;
import org.jdbi.v3.core.array.SqlArrayArgumentFactory;
import org.jdbi.v3.core.config.ConfigRegistry;
import org.jdbi.v3.core.config.JdbiConfig;
public class Arguments implements JdbiConfig<Arguments> {
private final List<ArgumentFactory> argumentFactories = new CopyOnWriteArrayList<>();
private ConfigRegistry registry;
private Argument untypedNullArgument = new NullArgument(Types.OTHER);
public Arguments() {
register(BuiltInArgumentFactory.INSTANCE);
register(new SqlArrayArgumentFactory());
}
@Override
public void setRegistry(ConfigRegistry registry) {
this.registry = registry;
}
private Arguments(Arguments that) {
argumentFactories.addAll(that.argumentFactories);
untypedNullArgument = that.untypedNullArgument;
}
public Arguments register(ArgumentFactory factory) {
argumentFactories.add(0, factory);
return this;
}
/**
* Obtain an argument for given value in the given context
*
* @param type the type of the argument.
* @param value the argument value.
* @return an Argument for the given value.
*/
public Optional<Argument> findFor(Type type, Object value) {
return argumentFactories.stream()
.flatMap(factory -> toStream(factory.build(type, value, registry)))
.findFirst();
}
/**
* Configure the {@link Argument} to use when binding a null
* we don't have a type for.
* @param untypedNullArgument the argument to bind
*/
public void setUntypedNullArgument(Argument untypedNullArgument) {
if (untypedNullArgument == null) {
throw new IllegalArgumentException("the Argument itself may not be null");
}
this.untypedNullArgument = untypedNullArgument;
}
/**
* @return the untyped null argument
*/
public Argument getUntypedNullArgument() {
return untypedNullArgument;
}
@Override
public Arguments createCopy() {
return new Arguments(this);
}
}