/*
*
* SchemaCrawler
* http://sourceforge.net/projects/schemacrawler
* Copyright (c) 2000-2013, 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.tools.integration.spring;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.sql.DataSource;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.FileSystemXmlApplicationContext;
import schemacrawler.schemacrawler.SchemaCrawlerException;
import schemacrawler.tools.commandline.CommandLine;
import schemacrawler.tools.executable.Executable;
import sf.util.ObjectToString;
public class SchemaCrawlerSpringCommandLine
implements CommandLine
{
private static final Logger LOGGER = Logger
.getLogger(SchemaCrawlerSpringCommandLine.class.getName());
private final SpringOptions springOptions;
public SchemaCrawlerSpringCommandLine(final String[] args)
throws SchemaCrawlerException
{
final SpringOptionsParser springOptionsParser = new SpringOptionsParser();
final String[] remainingArgs = springOptionsParser.parse(args);
springOptions = springOptionsParser.getOptions();
if (remainingArgs.length > 0)
{
throw new SchemaCrawlerException("Too many command line arguments provided: "
+ ObjectToString.toString(remainingArgs));
}
}
@Override
public void execute()
throws Exception
{
Connection connection = null;
try
{
final ApplicationContext appContext = new FileSystemXmlApplicationContext(springOptions
.getContextFileName());
final DataSource dataSource = (DataSource) appContext
.getBean(springOptions.getDataSourceName());
connection = dataSource.getConnection();
LOGGER.log(Level.INFO, "Opened database connection, " + connection);
final Executable executable = (Executable) appContext
.getBean(springOptions.getExecutableName());
executable.execute(connection);
}
finally
{
try
{
if (connection != null)
{
connection.close();
LOGGER.log(Level.INFO, "Closed database connection, " + connection);
}
}
catch (final SQLException e)
{
final String errorMessage = e.getMessage();
LOGGER.log(Level.WARNING, "Could not close the connection: "
+ errorMessage);
}
}
}
}