1
0
mirror of synced 2025-02-03 05:49:25 +03:00

91 lines
3.4 KiB
PHP
Raw Normal View History

2010-04-08 00:47:42 -03:00
<?php
/*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* This software consists of voluntary contributions made by many individuals
2012-05-26 14:37:00 +02:00
* and is licensed under the MIT license. For more information, see
2010-04-08 00:47:42 -03:00
* <http://www.doctrine-project.org>.
*/
namespace Doctrine\ORM\Tools\Console\Command\SchemaTool;
use Doctrine\ORM\Tools\SchemaTool;
use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Input\InputOption;
use Symfony\Component\Console\Output\OutputInterface;
2017-11-23 11:18:21 +01:00
use Symfony\Component\Console\Style\SymfonyStyle;
2010-04-08 00:47:42 -03:00
/**
* Command to create the database schema for a set of classes based on their mappings.
*
* @link www.doctrine-project.org
* @since 2.0
* @author Benjamin Eberlei <kontakt@beberlei.de>
* @author Guilherme Blanco <guilhermeblanco@hotmail.com>
* @author Jonathan Wage <jonwage@gmail.com>
* @author Roman Borschel <roman@code-factory.org>
*/
class CreateCommand extends AbstractCommand
2010-04-08 00:47:42 -03:00
{
/**
* {@inheritdoc}
2010-04-08 00:47:42 -03:00
*/
protected function configure()
{
$this->setName('orm:schema-tool:create')
->setDescription('Processes the schema and either create it directly on EntityManager Storage Connection or generate the SQL output')
->addOption('dump-sql', null, InputOption::VALUE_NONE, 'Instead of trying to apply generated SQLs into EntityManager Storage Connection, output them.')
->setHelp(<<<EOT
2010-04-08 00:47:42 -03:00
Processes the schema and either create it directly on EntityManager Storage Connection or generate the SQL output.
<comment>Hint:</comment> If you have a database with tables that should not be managed
by the ORM, you can use a DBAL functionality to filter the tables and sequences down
on a global level:
\$config->setFilterSchemaAssetsExpression(\$regexp);
2010-04-08 00:47:42 -03:00
EOT
);
2010-04-08 00:47:42 -03:00
}
/**
* {@inheritdoc}
*/
2017-11-23 11:18:21 +01:00
protected function executeSchemaCommand(InputInterface $input, OutputInterface $output, SchemaTool $schemaTool, array $metadatas, SymfonyStyle $ui)
2010-04-08 00:47:42 -03:00
{
2017-11-23 11:18:21 +01:00
$dumpSql = true === $input->getOption('dump-sql');
if ($dumpSql) {
$sqls = $schemaTool->getCreateSchemaSql($metadatas);
2017-11-23 11:18:21 +01:00
$ui->text('The following SQL statements will be executed:');
$ui->newLine();
foreach ($sqls as $sql) {
$ui->text(sprintf(' %s;', $sql));
}
2017-11-23 11:18:21 +01:00
return 0;
2010-04-08 00:47:42 -03:00
}
2013-02-03 01:31:56 +00:00
2017-11-23 11:18:21 +01:00
$ui->caution('This operation should not be executed in a production environment!');
$ui->text('Creating database schema...');
$ui->newLine();
$schemaTool->createSchema($metadatas);
$ui->success('Database schema created successfully!');
2013-02-03 01:31:56 +00:00
return 0;
2010-04-08 00:47:42 -03:00
}
}