/** * Copyright (C) 2000 - 2009 Silverpeas * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * As a special exception to the terms and conditions of version 3.0 of * the GPL, you may redistribute this Program in connection with Free/Libre * Open Source Software ("FLOSS") applications as described in Silverpeas's * FLOSS exception. You should have received a copy of the text describing * the FLOSS exception, and it is also available here: * "http://repository.silverpeas.com/legal/licensing" * * 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 Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. */ package org.silverpeas.dbbuilder.sql; import java.sql.Connection; import java.sql.DatabaseMetaData; import java.sql.SQLException; import javax.sql.DataSource; /** * Utility class for obtaining a connection to the database. * @author ehugonnet */ public class ConnectionFactory { private DataSource datasource; private static ConnectionFactory instance; private ConnectionFactory() { } public static ConnectionFactory getInstance() { synchronized (ConnectionFactory.class) { if (instance == null) { instance = new ConnectionFactory(); } } return instance; } /** * @param datasource the datasource to set */ public void setDatasource(DataSource datasource) { this.datasource = datasource; } public static Connection getConnection() throws SQLException { return getInstance().datasource.getConnection(); } public static String getConnectionInfo() throws SQLException { StringBuilder builder = new StringBuilder(); Connection connection = null; try { connection = getConnection(); DatabaseMetaData metaData = connection.getMetaData(); String newLine = System.getProperty("line.separator"); builder.append(newLine).append("\tRDBMS : ") .append(metaData.getDatabaseProductName()); builder.append(newLine).append("\tJdbcUrl : ").append(metaData.getURL()); builder.append(newLine).append("\tJdbcDriver : ").append(metaData.getDriverName()); builder.append(newLine).append("\tUserName : ").append(metaData.getUserName()); } finally { if (connection != null) { connection.close(); } } return builder.toString(); } }