org.firebirdsql.pool.sun.AppServerConnectionPoolDataSource Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jaybird-jdk15 Show documentation
Show all versions of jaybird-jdk15 Show documentation
JDBC Driver for the Firebird RDBMS
/*
* Firebird Open Source J2ee connector - jdbc driver
*
* Distributable under LGPL license.
* You may obtain a copy of the License at http://www.gnu.org/copyleft/lgpl.html
*
* 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
* LGPL License for more details.
*
* This file was created by members of the firebird development team.
* All individual contributions remain the Copyright (C) of those
* individuals. Contributors to this file are either listed here or
* can be obtained from a CVS history command.
*
* All rights reserved.
*/
package org.firebirdsql.pool.sun;
import java.io.PrintWriter;
import java.io.Serializable;
import java.sql.SQLException;
import java.util.Enumeration;
import java.util.Hashtable;
import javax.naming.*;
import javax.naming.spi.ObjectFactory;
import javax.sql.ConnectionPoolDataSource;
import javax.sql.PooledConnection;
import org.firebirdsql.ds.RootCommonDataSource;
import org.firebirdsql.gds.ClassFactory;
import org.firebirdsql.pool.AbstractFBConnectionPoolDataSource;
import org.firebirdsql.pool.FBPooledDataSourceFactory;
/**
* Implementation of the {@link javax.sql.ConnectionPoolDataSource} interface
* for the Sun Application Server 8.x (tested with PE 8.1). The main difference
* to the {@link org.firebirdsql.pool.FBConnectionPoolDataSource} class is that
* property "userName" is renamed into "user" and the possibilities to set the
* custom properties is removed. All this is caused by a quite strange algorithm
* that Sun software engineers had chosen to set data source properties.
*
* This class also acts as an object factory for the JNDI de-referencing.
*
*
* NOTE: This implementation contains a bug in the handling of PooledConnections.
* We strongly advise you to use the replacement implementation {@link org.firebirdsql.ds.FBConnectionPoolDataSource}.
*
*
* @author Roman Rokytskyy
* @deprecated Use {@link org.firebirdsql.ds.FBConnectionPoolDataSource}
*/
public class AppServerConnectionPoolDataSource extends RootCommonDataSource implements Serializable,
ConnectionPoolDataSource, Referenceable, ObjectFactory {
private static final long serialVersionUID = 136149417226908998L;
private AbstractFBConnectionPoolDataSource dataSource;
private AppServerConnectionPoolDataSource(
AbstractFBConnectionPoolDataSource dataSource) {
this.dataSource = dataSource;
}
public AppServerConnectionPoolDataSource() {
this.dataSource = FBPooledDataSourceFactory.createFBConnectionPoolDataSource();
}
public PooledConnection getPooledConnection() throws SQLException {
return dataSource.getPooledConnection();
}
public PooledConnection getPooledConnection(String username, String password)
throws SQLException {
return dataSource.getPooledConnection(username, password);
}
public int getLoginTimeout() throws SQLException {
return dataSource.getLoginTimeout();
}
public PrintWriter getLogWriter() throws SQLException {
return dataSource.getLogWriter();
}
public void setLoginTimeout(int seconds) throws SQLException {
dataSource.setLoginTimeout(seconds);
}
public void setLogWriter(PrintWriter out) throws SQLException {
dataSource.setLogWriter(out);
}
public int getBlobBufferSize() {
return dataSource.getBlobBufferSize();
}
public void setBlobBufferSize(int value) {
dataSource.setBlobBufferSize(value);
}
public int getBlockingTimeout() {
return dataSource.getBlockingTimeout();
}
public void setBlockingTimeout(int value) {
dataSource.setBlockingTimeout(value);
}
public int getBuffersNumber() {
return dataSource.getBuffersNumber();
}
public void setBuffersNumber(int value) {
dataSource.setBuffersNumber(value);
}
public String getCharSet() {
return dataSource.getCharSet();
}
public void setCharSet(String value) {
dataSource.setCharSet(value);
}
public String getDatabaseName() {
return dataSource.getDatabase();
}
public void setDatabaseName(String value) {
dataSource.setDatabase(value);
}
public String getDefaultIsolation() {
return dataSource.getDefaultIsolation();
}
public void setDefaultIsolation(String value) {
dataSource.setDefaultIsolation(value);
}
public String getEncoding() {
return dataSource.getEncoding();
}
public void setEncoding(String value) {
dataSource.setEncoding(value);
}
public boolean isKeepStatements() {
return dataSource.isKeepStatements();
}
public void setKeepStatements(boolean value) {
dataSource.setKeepStatements(value);
}
public int getMaxIdleTime() {
return dataSource.getMaxIdleTime();
}
public void setMaxIdleTime(int value) {
dataSource.setMaxIdleTime(value);
}
public int getMaxPoolSize() {
return dataSource.getMaxPoolSize();
}
public void setMaxPoolSize(int value) {
dataSource.setMaxPoolSize(value);
}
public int getMaxStatements() {
return dataSource.getMaxStatements();
}
public void setMaxStatements(int value) {
dataSource.setMaxStatements(value);
}
public int getMinPoolSize() {
return dataSource.getMinPoolSize();
}
public void setMinPoolSize(int value) {
dataSource.setMinPoolSize(value);
}
public String getPassword() {
return dataSource.getPassword();
}
public void setPassword(String value) {
dataSource.setPassword(value);
}
public int getPingInterval() {
return dataSource.getPingInterval();
}
public void setPingInterval(int value) {
dataSource.setPingInterval(value);
}
public String getPingStatement() {
return dataSource.getPingStatement();
}
public void setPingStatement(String value) {
dataSource.setPingStatement(value);
}
public boolean isPooling() {
return dataSource.isPooling();
}
public void setPooling(boolean value) {
dataSource.setPooling(value);
}
public int getRetryInterval() {
return dataSource.getRetryInterval();
}
public void setRetryInterval(int value) {
dataSource.setRetryInterval(value);
}
public String getRoleName() {
return dataSource.getRoleName();
}
public void setRoleName(String value) {
dataSource.setRoleName(value);
}
public int getSocketBufferSize() {
return dataSource.getSocketBufferSize();
}
public void setSocketBufferSize(int value) {
dataSource.setSocketBufferSize(value);
}
public String getSqlDialect() {
return dataSource.getSqlDialect();
}
public void setSqlDialect(String value) {
dataSource.setSqlDialect(value);
}
public boolean isStatementPooling() {
return dataSource.isStatementPooling();
}
public void setStatementPooling(boolean value) {
dataSource.setStatementPooling(value);
}
public boolean isTimestampUsesLocalTimezone() {
return dataSource.isTimestampUsesLocalTimezone();
}
public void setTimestampUsesLocalTimezone(boolean value) {
dataSource.setTimestampUsesLocalTimezone(value);
}
public String getType() {
return dataSource.getType();
}
public void setType(String value) {
dataSource.setType(value);
}
public String getUser() {
return dataSource.getUserName();
}
public void setUser(String value) {
dataSource.setUserName(value);
}
public boolean isUseStandardUdf() {
return dataSource.isUseStandardUdf();
}
public void setUseStandardUdf(boolean value) {
dataSource.setUseStandardUdf(value);
}
public boolean isUseStreamBlobs() {
return dataSource.isUseStreamBlobs();
}
public void setUseStreamBlobs(boolean value) {
dataSource.setUseStreamBlobs(value);
}
public String getUseTranslation() {
return dataSource.getUseTranslation();
}
public void setUseTranslation(String value) {
dataSource.setUseTranslation(value);
}
public boolean isDefaultResultSetHoldable() {
return dataSource.isDefaultResultSetHoldable();
}
public void setDefaultResultSetHoldable(boolean isHoldable) {
dataSource.setDefaultResultSetHoldable(isHoldable);
}
public Reference getReference() throws NamingException {
Reference ref = new Reference(getClass().getName(), getClass()
.getName(), null);
Reference defaultRef = dataSource.getDefaultReference();
convertReference(ref, defaultRef);
return ref;
}
private void convertReference(Reference ref, Reference defaultRef) {
Enumeration en = defaultRef.getAll();
while (en.hasMoreElements()) {
RefAddr addr = (RefAddr) en.nextElement();
ref.add(addr);
}
}
public Object getObjectInstance(Object obj, Name name, Context nameCtx,
Hashtable environment) throws Exception {
if (!(obj instanceof Reference))
return null;
Reference passedRef = (Reference) obj;
passedRef = (Reference) passedRef.clone();
if (!getClass().getName().equals(passedRef.getClassName()))
return null;
Reference ref = new Reference(ClassFactory.FBConnectionPoolDataSource,
ClassFactory.FBConnectionPoolDataSource, null);
convertReference(ref, passedRef);
return new AppServerConnectionPoolDataSource(FBPooledDataSourceFactory
.getFBConnectionPoolInstance(ref, name, nameCtx, environment));
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy