org.jdbi.v3.sqlobject.statement.internal.SqlCallHandler Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jdbi3-sqlobject Show documentation
Show all versions of jdbi3-sqlobject Show documentation
SqlObject is a declarative, annotation-driven API
for database access. It complements the core API.
Jdbi 3 is designed to provide convenient tabular data access in
Java(tm) and other JVM based languages.
It uses the Java collections framework for query results,
provides a convenient means of externalizing SQL statements, and
named parameter support for any database that supports JDBC.
/*
* 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.sqlobject.statement.internal;
import java.lang.reflect.Method;
import java.lang.reflect.Parameter;
import java.lang.reflect.Type;
import java.util.function.BiFunction;
import java.util.function.Consumer;
import java.util.function.Function;
import org.jdbi.v3.core.Handle;
import org.jdbi.v3.core.generic.GenericTypes;
import org.jdbi.v3.core.statement.Call;
import org.jdbi.v3.core.statement.OutParameters;
public class SqlCallHandler extends CustomizingStatementHandler {
private final BiFunction resultTransformer;
public SqlCallHandler(Class> sqlObjectType, Method method) {
super(sqlObjectType, method);
resultTransformer = createResultTransformer(sqlObjectType, method);
}
private BiFunction createResultTransformer(Class> sqlObjectType, Method method) {
Type returnType = GenericTypes.resolveType(method.getGenericReturnType(), sqlObjectType);
Class> returnClass = GenericTypes.getErasedType(returnType);
for (int idx = 0; idx < method.getParameterCount(); idx++) {
final int pIdx = idx;
Parameter p = method.getParameters()[idx];
if (p.getType().equals(Function.class)) {
return (outParameters, call) -> ((Function) call.getConfig(SqlObjectStatementConfiguration.class).getArgs()[pIdx]).apply(outParameters);
} else if (p.getType().equals(Consumer.class)) {
return (outParameters, call) -> {
((Consumer) call.getConfig(SqlObjectStatementConfiguration.class).getArgs()[pIdx]).accept(outParameters);
return null;
};
}
}
if (Void.TYPE.equals(returnClass)) {
return (outParameters, call) -> null;
} else if (OutParameters.class.isAssignableFrom(returnClass)) {
return (outParameters, call) -> outParameters;
} else {
throw new IllegalArgumentException("@SqlCall methods may only return null or OutParameters at present");
}
}
@Override
Call createStatement(Handle handle, String locatedSql) {
return handle.createCall(locatedSql);
}
@Override
void configureReturner(Call call, SqlObjectStatementConfiguration cfg) {
cfg.setReturner(() -> resultTransformer.apply(call.invoke(), call));
}
}