Mercurial > dive4elements > framework
view artifact-database/src/main/java/de/intevation/artifactdatabase/db/DBConnection.java @ 431:29bd60a3ee67
added tags
author | Thomas Arendsen Hein <thomas@intevation.de> |
---|---|
date | Fri, 28 Sep 2012 12:16:04 +0200 |
parents | 6d239c58c636 |
children |
line wrap: on
line source
package de.intevation.artifactdatabase.db; import javax.sql.DataSource; import java.io.File; import org.apache.commons.pool.ObjectPool; import org.apache.commons.pool.impl.GenericObjectPool; import org.apache.commons.dbcp.DriverManagerConnectionFactory; import org.apache.commons.dbcp.PoolableConnectionFactory; import org.apache.commons.dbcp.PoolingDataSource; import de.intevation.artifacts.common.utils.Config; import org.apache.log4j.Logger; public class DBConnection { private static Logger log = Logger.getLogger(DBConnection.class); public static final String DEFAULT_DRIVER = "org.h2.Driver"; public static final String DEFAULT_USER = ""; public static final String DEFAULT_PASSWORD = ""; public static final String DEFAULT_DATABASE_FILE = "artifacts.db"; public static final String DEFAULT_URL = getDefaultURL(); public static final String getDefaultURL() { File configDir = Config.getConfigDirectory(); File databaseFile = new File(configDir, DEFAULT_DATABASE_FILE); return "jdbc:h2:" + databaseFile; } protected DataSource dataSource; protected String driver; protected String url; protected String user; protected String password; public DBConnection() { } public DBConnection( String driver, String url, String user, String password ) { this.driver = driver; this.url = url; this.user = user; this.password = password; } 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 String getDriver() { return driver; } public void setDriver(String driver) { this.driver = driver; } public String getUrl() { return url; } public void setUrl(String url) { this.url = url; } public synchronized DataSource getDataSource() { if (dataSource == null) { if (log.isDebugEnabled()) { log.debug("create new datasource:"); log.debug(" driver: " + driver); log.debug(" url : " + url); log.debug(" user : " + user); } try { synchronized (DBConnection.class) { Class.forName(driver); } } catch (ClassNotFoundException cnfe) { log.error("cannot load driver", cnfe); return null; } DriverManagerConnectionFactory dmcf = new DriverManagerConnectionFactory(url, user, password); ObjectPool cp = new GenericObjectPool(); PoolableConnectionFactory pcf = new PoolableConnectionFactory( dmcf, cp, null, null, false, false); dataSource = new PoolingDataSource(cp); } return dataSource; } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :