001/* 002 * HA-JDBC: High-Availability JDBC 003 * Copyright (c) 2004-2008 Paul Ferraro 004 * 005 * This library is free software; you can redistribute it and/or modify it 006 * under the terms of the GNU Lesser General Public License as published by the 007 * Free Software Foundation; either version 2.1 of the License, or (at your 008 * option) any later version. 009 * 010 * This library is distributed in the hope that it will be useful, but WITHOUT 011 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 012 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License 013 * for more details. 014 * 015 * You should have received a copy of the GNU Lesser General Public License 016 * along with this library; if not, write to the Free Software Foundation, 017 * Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 018 * 019 * Contact: ferraro@users.sourceforge.net 020 */ 021package net.sf.hajdbc.sql.pool; 022 023import java.lang.reflect.InvocationHandler; 024import java.sql.SQLException; 025 026import javax.sql.ConnectionPoolDataSource; 027 028import net.sf.hajdbc.DatabaseCluster; 029import net.sf.hajdbc.DatabaseClusterFactory; 030import net.sf.hajdbc.sql.CommonDataSourceObjectFactory; 031 032/** 033 * @author Paul Ferraro 034 * 035 */ 036public class ConnectionPoolDataSourceFactory extends CommonDataSourceObjectFactory<ConnectionPoolDataSource> 037{ 038 /** 039 * Constructs a new factory for creating a <code>ConnectionPoolDataSource</code>. 040 */ 041 public ConnectionPoolDataSourceFactory() 042 { 043 super(ConnectionPoolDataSource.class); 044 } 045 046 /** 047 * @see net.sf.hajdbc.sql.CommonDataSourceObjectFactory#getDatabaseCluster(java.lang.String, java.lang.String) 048 */ 049 @Override 050 protected DatabaseCluster<ConnectionPoolDataSource> getDatabaseCluster(String id, String config) throws SQLException 051 { 052 return DatabaseClusterFactory.getDatabaseCluster(id, ConnectionPoolDataSourceDatabaseCluster.class, ConnectionPoolDataSourceDatabaseClusterMBean.class, config); 053 } 054 055 /** 056 * @see net.sf.hajdbc.sql.CommonDataSourceObjectFactory#getInvocationHandler(net.sf.hajdbc.DatabaseCluster) 057 */ 058 @Override 059 protected InvocationHandler getInvocationHandler(DatabaseCluster<ConnectionPoolDataSource> cluster) 060 { 061 return new ConnectionPoolDataSourceInvocationHandler(cluster); 062 } 063}