/*!
* This program is free software; you can redistribute it and/or modify it under the
* terms of the GNU Lesser General Public License, version 2.1 as published by the Free Software
* Foundation.
*
* You should have received a copy of the GNU Lesser General Public License along with this
* program; if not, you can obtain a copy at http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html
* or from the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*
* 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.
*
* Copyright (c) 2002-2017 Pentaho Corporation.. All rights reserved.
*/
package org.pentaho.reporting.platform.plugin.connection;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.ArrayList;
import javax.sql.DataSource;
import org.pentaho.platform.api.data.IDBDatasourceService;
import org.pentaho.platform.api.engine.ObjectFactoryException;
import org.pentaho.platform.engine.core.system.PentahoSystem;
import org.pentaho.reporting.engine.classic.core.modules.misc.datafactory.sql.ConnectionProvider;
public class PentahoPoolDataSourceConnectionProvider implements ConnectionProvider {
private static final long serialVersionUID = 20170113L;
private String name;
private String username;
private String password;
public PentahoPoolDataSourceConnectionProvider() {
super();
}
@Override
public Connection createConnection( final String user, final String password ) throws SQLException {
try {
final IDBDatasourceService datasourceService =
PentahoSystem.getObjectFactory().get( IDBDatasourceService.class, null );
final DataSource dataSource = datasourceService.getDataSource( name );
if ( dataSource != null ) {
final String realUser;
final String realPassword;
if ( username != null ) {
realUser = username;
} else {
realUser = user;
}
if ( this.password != null ) {
realPassword = this.password;
} else {
realPassword = password;
}
if ( realUser == null ) {
final Connection connection = dataSource.getConnection( );
if ( connection == null ) {
datasourceService.clearDataSource( name );
throw new SQLException( "Pool DataSource is invalid; it returned null "
+ "without throwing a meaningful error." );
}
return connection;
}
try {
final Connection connection = dataSource.getConnection( realUser, realPassword );
if ( connection == null ) {
datasourceService.clearDataSource( name );
throw new SQLException( "Pool DataSource is invalid; it returned null "
+ "without throwing a meaningful error." );
}
return connection;
} catch ( UnsupportedOperationException uoe ) {
final Connection connection = dataSource.getConnection();
if ( connection == null ) {
datasourceService.clearDataSource( name );
throw new SQLException( Messages.getInstance().getErrorString(
"PentahoDatasourceConnectionProvider.ERROR_0001_INVALID_CONNECTION", name ) ); //$NON-NLS-1$
}
return connection;
} catch ( SQLException ex ) {
final Connection nativeConnection = dataSource.getConnection();
if ( nativeConnection == null ) {
// clear datasource cache
datasourceService.clearDataSource( name );
throw new SQLException( Messages.getInstance().getErrorString(
"PentahoDatasourceConnectionProvider.ERROR_0001_INVALID_CONNECTION", name ) ); //$NON-NLS-1$
}
return nativeConnection;
}
} else {
// clear datasource cache
datasourceService.clearDataSource( name );
throw new SQLException( Messages.getInstance().getErrorString(
"PentahoDatasourceConnectionProvider.ERROR_0001_INVALID_CONNECTION", name ) ); //$NON-NLS-1$
}
} catch ( Exception e ) {
try {
final IDBDatasourceService datasourceService =
PentahoSystem.getObjectFactory().get( IDBDatasourceService.class, null );
datasourceService.clearDataSource( name );
throw new SQLException(
Messages
.getInstance()
.getErrorString(
"PentahoDatasourceConnectionProvider.ERROR_0002_UNABLE_TO_FACTORY_OBJECT", name, e.getLocalizedMessage() ) ); //$NON-NLS-1$
} catch ( ObjectFactoryException objface ) {
throw new SQLException(
Messages
.getInstance()
.getErrorString(
"PentahoDatasourceConnectionProvider.ERROR_0002_UNABLE_TO_FACTORY_OBJECT", name, e.getLocalizedMessage() ) ); //$NON-NLS-1$
}
}
}
public String getName() {
return this.name;
}
public void setName( final String name ) {
this.name = name;
}
public String getUsername() {
return username;
}
public void setUsername( final String username ) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword( final String password ) {
this.password = password;
}
public Object getConnectionHash() {
final ArrayList<Object> list = new ArrayList<Object>();
list.add( getClass().getName() );
list.add( name );
list.add( username );
return list;
}
}