/* * 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.io.File; import java.sql.Connection; 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 { final File contextFile = new File(springOptions.getContextFileName()); final ApplicationContext appContext = new FileSystemXmlApplicationContext(contextFile .toURI().toString()); final DataSource dataSource = (DataSource) appContext.getBean(springOptions .getDataSourceName()); try (Connection connection = dataSource.getConnection();) { LOGGER.log(Level.INFO, "Opened database connection, " + connection); final Executable executable = (Executable) appContext .getBean(springOptions.getExecutableName()); executable.execute(connection); } } }