view geo-backend/src/main/java/de/intevation/gnv/geobackend/base/connectionpool/ConnectionPoolFactory.java @ 887:b757def3ff55

Bring @author javadoc tags in form '@author <a href="john.doe@example.com">John Doe</a>' geo-backend/trunk@859 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author Sascha L. Teichmann <sascha.teichmann@intevation.de>
date Mon, 29 Mar 2010 09:45:05 +0000
parents 8b442223741c
children ebeb56428409
line wrap: on
line source
package de.intevation.gnv.geobackend.base.connectionpool;

import de.intevation.gnv.geobackend.sde.connectionpool.ArcSDEConnectionPool;

import java.util.Properties;

import org.apache.log4j.Logger;

/**
 * Factoryimplementation for the Interface ConnectionPool.
 * This factory delivers Instances of the Interface ConnectionPool.
 * @author <a href="mailto:tim.englich@intevation.de">Tim Englich</a>
 */
public class ConnectionPoolFactory {

    /**
     * the logger, used to log exceptions and additonaly information
     */
    private static Logger log = Logger.getLogger(ConnectionPoolFactory.class);


    /**
     * The singleton Instance of this Factory.
     */
    private static ConnectionPoolFactory instance = null;

    /**
     * The ConnectionPool providing the Connections to the DatabaseBackends
     */
    private ConnectionPool connectionPool = null;

    /**
     * Basic-Constructor of this Class
     */
    private ConnectionPoolFactory() {
    	super();
    }

    /**
     * This Method provides an singleton Instance of this Class.
     * @return an singleton Instance of this Class
     */
    public static ConnectionPoolFactory getInstance(){
        if (instance == null){
        	instance = new ConnectionPoolFactory();
        }
        return instance;
    }

    /**
     * Getting the ConnectionPool
     * @return the ConnectionPool
     */
    public ConnectionPool getConnectionPool(){
        return this.connectionPool;
    }

    /**
     * Initializes the ConnectionPool.
     * Should only be called once on system startup
     * @param properties the Properties for the Individual Configuration of the ConnectionPool
     */
    public void initializeConnectionPool(Properties properties){
        log.debug("ConnectionPoolFactory.initializeConnectionPool");
        if (this.connectionPool == null){
            //TODO: Here it might be possible to switch the ConnectionPoolInstance using a FLAG.
            this.connectionPool = new ArcSDEConnectionPool();
            this.connectionPool.initialize(properties);
        }else{
            log.warn("ConnectionPool already initialized");
        }
    }

    /**
     * Checks if the ConnectionPool has already been initialized.
     * @return true if the ConnectionPool is initialized.
     */
    public boolean isInitialized(){
        return this.connectionPool != null;
    }
}

http://dive4elements.wald.intevation.org