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

com.landawn.abacus.util.SimpleDataSource Maven / Gradle / Ivy

package com.landawn.abacus.util;

import java.io.PrintWriter;
import java.lang.reflect.Method;
import java.lang.reflect.Modifier;
import java.sql.Connection;
import java.sql.SQLException;
import java.sql.SQLFeatureNotSupportedException;

import com.landawn.abacus.DataSource;
import com.landawn.abacus.SliceSelector;
import com.landawn.abacus.dataSource.NonSliceSelector;
import com.landawn.abacus.exception.UncheckedSQLException;

/**
 * The Class SimpleDataSource.
 */
class SimpleDataSource implements DataSource {

    /** The Constant PRIMARY. */
    static final String PRIMARY = "primary";

    /** The sql data source. */
    private final javax.sql.DataSource sqlDataSource;

    /** The props. */
    private final Properties props = new Properties<>();

    /** The slice selector. */
    private final SliceSelector sliceSelector = new NonSliceSelector();

    /** The close method. */
    private final Method closeMethod;

    /** The is closed. */
    private boolean isClosed = false;

    /**
     * Instantiates a new simple data source.
     *
     * @param sqlDataSource
     */
    public SimpleDataSource(final javax.sql.DataSource sqlDataSource) {
        this.sqlDataSource = sqlDataSource;

        Method method = null;

        try {
            method = ClassUtil.getDeclaredMethod(sqlDataSource.getClass(), "close");
        } catch (Exception e) {

        }

        closeMethod = method != null && Modifier.isPublic(method.getModifiers()) ? method : null;
    }

    /**
     * Gets the connection.
     *
     * @param username
     * @param password
     * @return
     * @throws SQLException the SQL exception
     */
    @Override
    public Connection getConnection(final String username, final String password) throws SQLException {
        return sqlDataSource.getConnection(username, password);
    }

    /**
     * Gets the log writer.
     *
     * @return
     * @throws SQLException the SQL exception
     */
    @Override
    public PrintWriter getLogWriter() throws SQLException {
        return sqlDataSource.getLogWriter();
    }

    /**
     * Sets the log writer.
     *
     * @param out the new log writer
     * @throws SQLException the SQL exception
     */
    @Override
    public void setLogWriter(final PrintWriter out) throws SQLException {
        sqlDataSource.setLogWriter(out);
    }

    /**
     * Sets the login timeout.
     *
     * @param seconds the new login timeout
     * @throws SQLException the SQL exception
     */
    @Override
    public void setLoginTimeout(final int seconds) throws SQLException {
        sqlDataSource.setLoginTimeout(seconds);
    }

    /**
     * Gets the login timeout.
     *
     * @return
     * @throws SQLException the SQL exception
     */
    @Override
    public int getLoginTimeout() throws SQLException {
        return sqlDataSource.getLoginTimeout();
    }

    /**
     * Gets the parent logger.
     *
     * @return
     * @throws SQLFeatureNotSupportedException the SQL feature not supported exception
     */
    @Override
    public java.util.logging.Logger getParentLogger() throws SQLFeatureNotSupportedException {
        return sqlDataSource.getParentLogger();
    }

    /**
     *
     * @param 
     * @param iface
     * @return
     * @throws SQLException the SQL exception
     */
    @Override
    public  T unwrap(final Class iface) throws SQLException {
        return sqlDataSource.unwrap(iface);
    }

    /**
     * Checks if is wrapper for.
     *
     * @param iface
     * @return true, if is wrapper for
     * @throws SQLException the SQL exception
     */
    @Override
    public boolean isWrapperFor(final Class iface) throws SQLException {
        return sqlDataSource.isWrapperFor(iface);
    }

    /**
     * Gets the connection.
     *
     * @return
     */
    @Override
    public Connection getConnection() {
        try {
            return sqlDataSource.getConnection();
        } catch (SQLException e) {
            throw new UncheckedSQLException(e);
        }
    }

    /**
     * Gets the read only connection.
     *
     * @return
     */
    @Override
    public Connection getReadOnlyConnection() {
        try {
            return sqlDataSource.getConnection();
        } catch (SQLException e) {
            throw new UncheckedSQLException(e);
        }
    }

    /**
     * Gets the slice selector.
     *
     * @return
     */
    @Override
    public SliceSelector getSliceSelector() {
        return sliceSelector;
    }

    /**
     * Gets the name.
     *
     * @return
     */
    @Override
    public String getName() {
        return PRIMARY;
    }

    /**
     * Gets the properties.
     *
     * @return
     */
    @Override
    public Properties getProperties() {
        return props;
    }

    /**
     * Gets the max active.
     *
     * @return
     */
    @Override
    public int getMaxActive() {
        throw new UnsupportedOperationException();
    }

    /**
     * Gets the current active.
     *
     * @return
     */
    @Override
    public int getCurrentActive() {
        throw new UnsupportedOperationException();
    }

    /**
     * Close.
     */
    @Override
    public void close() {
        if (isClosed) {
            return;
        }

        if (closeMethod != null) {
            try {
                ClassUtil.invokeMethod(sqlDataSource, closeMethod);
            } catch (Exception e) {
                // ignore.
            }
        }

        isClosed = true;
    }

    /**
     * Checks if is closed.
     *
     * @return true, if is closed
     */
    @Override
    public boolean isClosed() {
        return isClosed;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy