/*
* Bitronix Transaction Manager
*
* Copyright (c) 2010, Bitronix Software.
*
* This copyrighted material is made available to anyone wishing to use, modify,
* copy, or redistribute it subject to the terms and conditions of the GNU
* Lesser General Public License, as published by the Free Software Foundation.
*
* 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 Lesser General Public License
* for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this distribution; if not, write to:
* Free Software Foundation, Inc.
* 51 Franklin Street, Fifth Floor
* Boston, MA 02110-1301 USA
*/
package bitronix.tm.resource.jdbc.lrc;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.Driver;
import java.sql.SQLException;
import java.util.Properties;
import javax.sql.XAConnection;
import javax.sql.XADataSource;
import bitronix.tm.resource.jdbc.proxy.JdbcProxyFactory;
import bitronix.tm.utils.ClassLoaderUtils;
/**
* XADataSource implementation for a non-XA JDBC resource emulating XA with Last Resource Commit.
*
* @author lorban, brettw
*/
public class LrcXADataSource implements XADataSource {
private volatile int loginTimeout;
private volatile String driverClassName;
private volatile String url;
private volatile String user;
private volatile String password;
public LrcXADataSource() {
}
public int getLoginTimeout() throws SQLException {
return loginTimeout;
}
public void setLoginTimeout(int seconds) throws SQLException {
this.loginTimeout = seconds;
}
public String getDriverClassName() {
return driverClassName;
}
public void setDriverClassName(String driverClassName) {
this.driverClassName = driverClassName;
}
public String getUrl() {
return url;
}
public void setUrl(String url) {
this.url = url;
}
public String getUser() {
return user;
}
public void setUser(String user) {
this.user = user;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public PrintWriter getLogWriter() throws SQLException {
return null;
}
public void setLogWriter(PrintWriter out) throws SQLException {
}
public XAConnection getXAConnection() throws SQLException {
try {
Class<?> driverClazz = ClassLoaderUtils.loadClass(driverClassName);
Driver driver = (Driver) driverClazz.newInstance();
Properties props = new Properties();
if (user != null) props.setProperty("user", user);
if (password != null) props.setProperty("password", password);
Connection connection = driver.connect(url, props);
XAConnection xaConnection = JdbcProxyFactory.INSTANCE.getProxyXaConnection(connection);
return xaConnection;
} catch (Exception ex) {
throw (SQLException) new SQLException("unable to connect to non-XA resource " + driverClassName).initCause(ex);
}
}
public XAConnection getXAConnection(String user, String password) throws SQLException {
try {
Class<?> driverClazz = ClassLoaderUtils.loadClass(driverClassName);
Driver driver = (Driver) driverClazz.newInstance();
Properties props = new Properties();
props.setProperty("user", user);
props.setProperty("password", password);
Connection connection = driver.connect(url, props);
XAConnection xaConnection = JdbcProxyFactory.INSTANCE.getProxyXaConnection(connection);
return xaConnection;
} catch (Exception ex) {
throw (SQLException) new SQLException("unable to connect to non-XA resource " + driverClassName).initCause(ex);
}
}
public String toString() {
return "a JDBC LrcXADataSource on " + driverClassName + " with URL " + url;
}
}