<?php
/**
* Phinx
*
* (The MIT license)
* Copyright (c) 2015 Rob Morgan
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated * documentation files (the "Software"), to
* deal in the Software without restriction, including without limitation the
* rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
* sell copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
* IN THE SOFTWARE.
*
* @package Phinx
* @subpackage Phinx\Console
*/
namespace Phinx\Console\Command;
use Symfony\Component\Console\Command\Command;
use Symfony\Component\Console\Input\InputArgument;
use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Output\OutputInterface;
class Init extends Command
{
/**
* {@inheritdoc}
*/
protected function configure()
{
$this->setName('init')
->setDescription('Initialize the application for Phinx')
->addArgument('path', InputArgument::OPTIONAL, 'Which path should we initialize for Phinx?')
->setHelp(sprintf(
'%sInitializes the application for Phinx%s',
PHP_EOL,
PHP_EOL
));
}
/**
* Initializes the application.
*
* @param \Symfony\Component\Console\Input\InputInterface $input
* @param \Symfony\Component\Console\Output\OutputInterface $output
* @throws \RuntimeException
* @throws \InvalidArgumentException
* @return void
*/
protected function execute(InputInterface $input, OutputInterface $output)
{
// get the migration path from the config
$path = $input->getArgument('path');
if ($path === null) {
$path = getcwd();
}
$path = realpath($path);
if (!is_writable($path)) {
throw new \InvalidArgumentException(sprintf(
'The directory "%s" is not writable',
$path
));
}
// Compute the file path
$fileName = 'phinx.yml'; // TODO - maybe in the future we allow custom config names.
$filePath = $path . DIRECTORY_SEPARATOR . $fileName;
if (file_exists($filePath)) {
throw new \InvalidArgumentException(sprintf(
'The file "%s" already exists',
$filePath
));
}
// load the config template
if (is_dir(__DIR__ . '/../../../data/Phinx')) {
$contents = file_get_contents(__DIR__ . '/../../../data/Phinx/phinx.yml');
} else {
$contents = file_get_contents(__DIR__ . '/../../../../phinx.yml');
}
if (file_put_contents($filePath, $contents) === false) {
throw new \RuntimeException(sprintf(
'The file "%s" could not be written to',
$path
));
}
$output->writeln('<info>created</info> .' . str_replace(getcwd(), '', $filePath));
}
}