All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.lithium.flow.db.TomcatSchema Maven / Gradle / Ivy

/*
 * Copyright 2015 Lithium Technologies, Inc.
 *
 * 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 com.lithium.flow.db;

import static com.google.common.base.Preconditions.checkNotNull;
import static java.sql.ResultSet.CONCUR_READ_ONLY;
import static java.sql.ResultSet.TYPE_FORWARD_ONLY;

import com.lithium.flow.config.Config;
import com.lithium.flow.util.Logs;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;

import javax.annotation.Nonnull;

import org.apache.tomcat.jdbc.pool.DataSource;
import org.apache.tomcat.jdbc.pool.PoolProperties;
import org.slf4j.Logger;

/**
 * @author Matt Ayres
 */
public class TomcatSchema extends AbstractSchema {
	private static final Logger log = Logs.getLogger();

	private final DataSource dataSource;
	private final boolean streaming;

	public TomcatSchema(@Nonnull Config config) {
		checkNotNull(config);

		log.debug("{} sql.url: {}", config.getName(), config.getString("sql.url"));

		PoolProperties poolProps = new PoolProperties();
		poolProps.setUrl(config.getString("sql.url"));
		poolProps.setUsername(config.getString("sql.login"));
		poolProps.setPassword(config.getString("sql.password"));
		poolProps.setDriverClassName(config.getString("sql.driver"));
		poolProps.setMinIdle(config.getInt("sql.pool.minIdle", 1));
		poolProps.setMaxIdle(config.getInt("sql.pool.maxIdle", 3));
		poolProps.setMaxActive(config.getInt("sql.pool.maxActive", 5));
		poolProps.setInitialSize(poolProps.getMinIdle());
		poolProps.setValidationQuery("SELECT 1");
		poolProps.setValidationQueryTimeout((int) config.getTime("sql.pool.validationQueryTimeout", "5s"));
		poolProps.setTestOnBorrow(config.getBoolean("sql.pool.testOnBorrow", true));
		poolProps.setDefaultReadOnly(config.getBoolean("sql.pool.defaultReadOnly", true));
		dataSource = new DataSource(poolProps);
		streaming = config.getBoolean("sql.streaming", false);
	}

	@Override
	@Nonnull
	public Connection getConnection() throws SQLException {
		return dataSource.getConnection();
	}

	@Nonnull
	protected PreparedStatement readQuery(@Nonnull Connection con, @Nonnull String query) throws SQLException {
		if (streaming) {
			PreparedStatement ps = con.prepareStatement(query, TYPE_FORWARD_ONLY, CONCUR_READ_ONLY);
			ps.setFetchSize(Integer.MIN_VALUE);
			return ps;
		} else {
			return super.readQuery(con, query);
		}
	}

	@Override
	public void close() {
		dataSource.close();
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy