/*
*
* SchemaCrawler
* http://sourceforge.net/projects/schemacrawler
* Copyright (c) 2000-2009, Sualeh Fatehi.
*
* This library is free software; you can redistribute it and/or modify it under the terms
* of the GNU Lesser General Public License as published by the Free Software Foundation;
* either version 2.1 of the License, or (at your option) any later version.
*
* This library 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.
*
* You should have received a copy of the GNU Lesser General Public License along with this
* library; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330,
* Boston, MA 02111-1307, USA.
*
*/
package schemacrawler.main.dbconnector;
import java.util.Map;
/**
* Parses a command line, and creates a data-source.
*/
public final class PropertiesDataSourceDatabaseConnector
extends BaseDatabaseConnector
{
/**
* Parses a command line, and creates a data-source.
*
* @param args
* Command line arguments
* @param providedConfig
* Connection properties
* @throws DatabaseConnectorException
* On an exception
*/
public PropertiesDataSourceDatabaseConnector(final String[] args,
final Map<String, String> providedConfig)
throws DatabaseConnectorException
{
super(providedConfig);
final PropertiesDataSourceOptions options = new PropertiesDataSourceOptionsParser(args)
.getOptions();
if (options.isUseJdbcConnection())
{
final String dataSourceName = "PropertiesDataSourceConnection";
configPut("defaultconnection", dataSourceName);
configPut(dataSourceName + ".driver", options.getDriver());
configPut(dataSourceName + ".url", options.getConnectionUrl());
if (options.hasSchemaPattern())
{
configPut(dataSourceName + ".schemapattern", options.getSchemapattern());
}
configPut(dataSourceName + ".user", options.getUser());
configPut(dataSourceName + ".password", options.getPassword());
}
else
{
final String connectionName = options.getConnection();
// Use default connection if no connection is specified
if (!options.isUseDefaultConnection()
&& !schemacrawler.utility.Utility.isBlank(connectionName))
{
configPut("defaultconnection", connectionName);
}
}
if (!hasDataSourceName())
{
throw new DatabaseConnectorException("No datasource name provided");
}
}
}