net.anwiba.commons.jdbc.connection.DefaultDatabaseConnector Maven / Gradle / Ivy
/*
* #%L
* anwiba commons advanced
* %%
* Copyright (C) 2007 - 2016 Andreas Bartels
* %%
* 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 2.1 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 General Lesser Public License for more details.
*
* You should have received a copy of the GNU General Lesser Public
* License along with this program. If not, see
* .
* #L%
*/
package net.anwiba.commons.jdbc.connection;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
public class DefaultDatabaseConnector implements IRegisterableDatabaseConnector {
private static final int TIMEOUT = 10;
@Override
public synchronized Connection connectReadOnly(
final String url,
final String userName,
final String password,
final int timeout)
throws SQLException {
return connect(url, userName, password, timeout, true);
}
@Override
public Connection connectWritable(final String url, final String userName, final String password, final int timeout)
throws SQLException {
return connect(url, userName, password, timeout, false);
}
public synchronized Connection connect(
final String url,
final String userName,
final String password,
final int timeout,
final boolean isReadOnly)
throws SQLException {
if (timeout == -1) {
return createConnection(url, userName, password, isReadOnly);
}
final int loginTimeout = DriverManager.getLoginTimeout();
try {
DriverManager.setLoginTimeout(timeout);
return createConnection(url, userName, password, isReadOnly);
} finally {
DriverManager.setLoginTimeout(loginTimeout);
}
}
private Connection createConnection(
final String url,
final String user,
final String password,
final boolean isReadOnly)
throws SQLException {
final Connection connection = DriverManager.getConnection(url, user, password);
connection.setReadOnly(isReadOnly);
return connection;
}
@Override
public boolean isApplicable(final String context) {
return true;
}
@Override
public boolean isConnectable(final String url, final String userName, final String password) {
try (Connection connection = connectReadOnly(url, userName, password, TIMEOUT)) {
return true;
} catch (final SQLException exception) {
return false;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy