org.javasimon.jdbc4.Driver Maven / Gradle / Ivy
package org.javasimon.jdbc4;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.DriverPropertyInfo;
import java.sql.SQLException;
import java.sql.SQLFeatureNotSupportedException;
import java.util.Properties;
import java.util.logging.Logger;
/**
* Simon JDBC 4.1 Proxy Driver (Java SE 7).
*
* An application should not use this class directly. The application (if standalone)
* should use {@link java.sql.DriverManager} only. For example:
*
*
* Connection conn = DriverManager.getConnection("jdbc:simon:oracle:thin:...", "scott", "tiger");
*
* Simon driver has following format of JDBC connection string:
* {@code
* jdbc:simon:;=;...}
* Simon driver recognizes two parameters:
*
* -
* {@code SIMON_REAL_DRV} - if you don't want or can't register real driver for any
* reason, you can use this parameter and Simon proxy driver will do the registration
* for you. You don't need to specify real driver parameter for some well known databases.
* Simon proxy driver recognize database by first key word after JDBC and register.
*
* -
* {@code SIMON_PREFIX} - setting this parameter you can choose different prefix
* for all monitors for one instance of driver. For example, setting
* {@code SIMON_PREFIX=com.foo} will ensure that all proxy related Simons are located
* under the subtree specified by the prefix, e.g. {@code com.foo.conn},
com.foo.stmt
,
* com.foo.select
, etc. If no prefix is set, default {@code org.javasimon.jdbc} prefix
* is used.
*
*
`
*
* By default, there is no need to load any driver explicitly, because drivers are loaded automatically
* (since JDK 1.5) if they are in class path and jar have appropriate
* meta information (see {@link java.sql.DriverManager}).
*
* If this is not a case for any reason, you need to register Simon proxy driver at least.
* For real driver Simon proxy driver contains following procedure for find and register it:
*
* - Simon proxy driver tries if there is registered driver for driver key word.
*
- If not, driver tries if there is real driver parameter in info properties and then registers it.
*
- If not, driver tries to find driver by key word within internal list of well known drivers and
* then registers it. For now, list contains default drivers for Oracle, PostgreSQL, Enterprise DB, H2,
* MySQL.
*
- If not, driver tries to find real driver param within connection string and then registers it.
*
- If not, getting new connection fails.
*
* The safest way to get Simon proxy driver work is to load the drivers, the real one (i.e. oracle)
* and a Simon proxy driver explicitly. This can be done using Class.forName. To load the driver and open a
* database connection, use following code:
*
* Class.forName("oracle.jdbc.driver.OracleDriver"); // loads real driver
* Class.forName("org.javasimon.jdbc4.Driver"); // loads Simon proxy driver
* Connection conn = DriverManager.getConnection(
* "jdbc:simon:oracle:thin:...", "scott", "tiger");
*
* @author Radovan Sninsky
* @author Richard "Virgo" Richter
* @see java.sql.DriverManager#getConnection(String)
* @since 2.4
*/
public final class Driver implements java.sql.Driver {
static {
try {
DriverManager.registerDriver(new Driver());
} catch (Exception e) {
// don't know what to do yet, maybe throw RuntimeException ???
e.printStackTrace();
}
}
private java.sql.Driver driver;
/**
* Class constructor. It loads well known driver list from resource file drivers.properties.
*/
public Driver() {
}
/**
* Opens new Simon proxy driver connection associated with real connection to the specified database.
*
* @param simonUrl JDBC connection string (i.e. jdbc:simon:h2:file:test)
* @param info properties for connection
* @return open connection to database or null if provided url is not accepted by this driver
* @throws java.sql.SQLException if there is no real driver registered/recognized or opening real connection fails
* @see Driver
*/
@Override
public Connection connect(String simonUrl, Properties info) throws SQLException {
if (!acceptsURL(simonUrl)) {
return null;
}
SimonConnectionConfiguration url = new SimonConnectionConfiguration(simonUrl);
driver = getRealDriver(url, info);
return new SimonConnection(driver.connect(url.getRealUrl(), info), url.getPrefix());
}
/**
* Tries to determine driver class, instantiate it and register if already not registered.
* For more detail look at {@link Driver} class javadoc.
*
* @param configuration instance of url object that represents url
* @param info parameters from {@link #connect(String, java.util.Properties)} method
* @return instance of real driver
* @throws java.sql.SQLException if real driver can't be determined or is not registerd
*/
private java.sql.Driver getRealDriver(SimonConnectionConfiguration configuration, Properties info) throws SQLException {
java.sql.Driver drv = null;
try {
drv = DriverManager.getDriver(configuration.getRealUrl());
} catch (SQLException e) {
// nothing, not an error
}
if (drv == null && info != null && info.keySet().contains(SimonConnectionConfiguration.REAL_DRIVER)) {
drv = registerDriver(info.getProperty(SimonConnectionConfiguration.REAL_DRIVER));
}
if (drv == null && configuration.getRealDriver() != null) {
drv = registerDriver(configuration.getRealDriver());
}
if (drv == null) {
if (configuration.getRealDriver() != null) {
drv = registerDriver(configuration.getRealDriver());
}
}
if (drv == null) {
throw new SQLException("Real driver is not registered and can't determine real driver class name for registration.");
}
return drv;
}
/**
* Registers real driver through {@link java.sql.DriverManager}.
*
* @param name real driver class name
* @return instance of registered real driver
* @throws java.sql.SQLException if registration fails
*/
private java.sql.Driver registerDriver(String name) throws SQLException {
try {
java.sql.Driver d = (java.sql.Driver) Class.forName(name).newInstance();
DriverManager.registerDriver(d);
return d;
} catch (SQLException e) {
throw e;
} catch (Exception e) {
return null;
}
}
@Override
public boolean acceptsURL(String url) throws SQLException {
return SimonConnectionConfiguration.isSimonUrl(url);
}
@Override
public DriverPropertyInfo[] getPropertyInfo(String s, Properties properties) throws SQLException {
return new DriverPropertyInfo[0];
}
@Override
public int getMajorVersion() {
return 2;
}
@Override
public int getMinorVersion() {
return 4;
}
@Override
public boolean jdbcCompliant() {
return true;
}
@Override
public Logger getParentLogger() throws SQLFeatureNotSupportedException {
return driver.getParentLogger();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy