/* * HA-JDBC: High-Availability JDBC * Copyright (C) 2013 Paul Ferraro * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. */ package net.sf.hajdbc.sql; import java.sql.Connection; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import java.util.LinkedList; import java.util.List; import java.util.Map; import net.sf.hajdbc.Database; import net.sf.hajdbc.invocation.Invoker; import net.sf.hajdbc.io.InputSinkRegistry; import net.sf.hajdbc.util.reflect.Proxies; /** * * @author Paul Ferraro */ public class ResultSetProxyFactory<Z, D extends Database<Z>, S extends Statement> extends AbstractInputSinkRegistryProxyFactory<Z, D, S, ResultSet> { private List<Invoker<Z, D, ResultSet, ?, SQLException>> invokers = new LinkedList<>(); public ResultSetProxyFactory(S statementProxy, ProxyFactory<Z, D, S, SQLException> statementFactory, Invoker<Z, D, S, ResultSet, SQLException> invoker, Map<D, ResultSet> map, TransactionContext<Z, D> context, InputSinkRegistry<Object> sinkRegistry) { super(statementProxy, statementFactory, invoker, map, context, sinkRegistry); } public void addInvoker(Invoker<Z, D, ResultSet, ?, SQLException> invoker) { this.invokers.add(invoker); } public void clearInvokers() { this.invokers.clear(); } @Override public Connection getConnection(D database) throws SQLException { return this.get(database).getStatement().getConnection(); } @Override public void replay(D database, ResultSet results) throws SQLException { super.replay(database, results); for (Invoker<Z, D, ResultSet, ?, SQLException> invoker: this.invokers) { invoker.invoke(database, results); } } @Override public void close(D database, ResultSet results) throws SQLException { if (!results.isClosed()) { results.close(); } } @Override public ResultSet createProxy() { return Proxies.createProxy(ResultSet.class, new ResultSetInvocationHandler<>(this)); } }