/*
* Copyright 2013 ENERKO Informatik GmbH
*
* 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.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package de.enerko.reports2.engine;
import java.sql.PreparedStatement;
import java.sql.SQLException;
import java.util.Iterator;
import java.util.List;
import oracle.jdbc.OracleConnection;
import de.enerko.reports2.engine.FormalArgument.DataType;
import de.enerko.reports2.utils.Unchecker;
/**
* This report source represents a call of a pipellined function
* either in package or global scope that returns t_hre_cell_definitions<br>
* The function may have any of the supported {@link DataType}s as arguments
* @author Michael J. Simons, 2013-06-18
*/
public class FunctionBasedReportSource implements ReportSource {
private final OracleConnection connection;
private final String sqlStatement;
private final ConcreteArgument[] arguments;
public FunctionBasedReportSource(OracleConnection connection, final String methodName, final String... arguments) {
this.connection = connection;
// Get number and type of all arguments
final ArgumentResolver argumentResolver = new ArgumentResolver(connection);
final List<FormalArgument> formalArguments = argumentResolver.getArguments(methodName);
if(formalArguments.size() != arguments.length)
throw new RuntimeException("The number of formal arguments doesn't match the number of concrete arguments");
// Build sql statement
final StringBuilder sb = new StringBuilder();
String sep = "";
sb.append("Select * from table(").append(methodName).append("(");
for(int i=0; i<arguments.length; ++i) {
sb.append(sep).append("?");
sep = ", ";
}
sb.append("))");
this.sqlStatement = sb.toString();
this.arguments = new ConcreteArgument[arguments.length];
int cnt = 0;
for(FormalArgument argument : formalArguments)
// Position in PL/SQL is 1-based
this.arguments[cnt++] = new ConcreteArgument(argument, arguments[argument.position-1]);
}
/**
* Execute the query and retrieve an iterator over all celldefinitions
*/
public Iterator<CellDefinition> iterator() {
try {
final PreparedStatement statement = this.connection.prepareStatement(this.sqlStatement);
for(ConcreteArgument argument : arguments)
argument.setTo(statement);
return new ReportSourceIterator(statement.executeQuery());
} catch (SQLException e) {
throw Unchecker.uncheck(e);
}
}
}