* * This source file is subject to the MIT license that is bundled * with this source code in the file LICENSE. */ /** * InsertSqlCommand. * * @author William DURAND */ class InsertSqlCommand extends PhingCommand { /** * @see Command */ protected function configure() { $this ->setDescription('Insert SQL for current model') ->addOption('force', null, InputOption::VALUE_NONE, 'Set this parameter to execute this action.') ->addOption('connection', null, InputOption::VALUE_OPTIONAL, 'Set this parameter to define a connection to use') ->setHelp(<<propel:insert-sql command connects to the database and executes all SQL statements found in app/propel/sql/*schema.sql. php app/console propel:insert-sql The --force parameter has to be used to actually insert SQL. The --connection parameter allows you to change the connection to use. The default connection is the active connection (propel.dbal.default_connection). EOT ) ->setName('propel:insert-sql') ; } /** * @see Command * * @throws \InvalidArgumentException When the target directory does not exist */ protected function execute(InputInterface $input, OutputInterface $output) { if ($input->getOption('force')) { $container = $this->getApplication()->getKernel()->getContainer(); $propelConfiguration = $container->get('propel.configuration'); $name = $input->getOption('connection') ? $input->getOption('connection') : $container->getParameter('propel.dbal.default_connection'); if (isset($propelConfiguration['datasources'][$name])) { $defaultConfig = $propelConfiguration['datasources'][$name]; } else { throw new \InvalidArgumentException(sprintf('Connection named %s doesn\'t exist', $name)); } $output->writeln(sprintf('Generate XML schema from connection named %s', $name)); $this->callPhing('insert-sql', array( 'propel.database.url' => $defaultConfig['connection']['dsn'], 'propel.database.database' => $defaultConfig['adapter'], 'propel.database.user' => $defaultConfig['connection']['user'], 'propel.database.password' => $defaultConfig['connection']['password'], 'propel.schema.dir' => $this->getApplication()->getKernel()->getRootDir() . '/propel/schema/', )); } else { $output->writeln('You have to use --force to execute all SQL statements.'); } } }