130 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			130 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
	
	
	
| <?php namespace Illuminate\Database\Console\Migrations;
 | |
| 
 | |
| use Illuminate\Console\ConfirmableTrait;
 | |
| use Illuminate\Database\Migrations\Migrator;
 | |
| use Symfony\Component\Console\Input\InputOption;
 | |
| 
 | |
| class MigrateCommand extends BaseCommand {
 | |
| 
 | |
| 	use ConfirmableTrait;
 | |
| 
 | |
| 	/**
 | |
| 	 * The console command name.
 | |
| 	 *
 | |
| 	 * @var string
 | |
| 	 */
 | |
| 	protected $name = 'migrate';
 | |
| 
 | |
| 	/**
 | |
| 	 * The console command description.
 | |
| 	 *
 | |
| 	 * @var string
 | |
| 	 */
 | |
| 	protected $description = 'Run the database migrations';
 | |
| 
 | |
| 	/**
 | |
| 	 * The migrator instance.
 | |
| 	 *
 | |
| 	 * @var \Illuminate\Database\Migrations\Migrator
 | |
| 	 */
 | |
| 	protected $migrator;
 | |
| 
 | |
| 	/**
 | |
| 	 * Create a new migration command instance.
 | |
| 	 *
 | |
| 	 * @param  \Illuminate\Database\Migrations\Migrator  $migrator
 | |
| 	 * @return void
 | |
| 	 */
 | |
| 	public function __construct(Migrator $migrator)
 | |
| 	{
 | |
| 		parent::__construct();
 | |
| 
 | |
| 		$this->migrator = $migrator;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Execute the console command.
 | |
| 	 *
 | |
| 	 * @return void
 | |
| 	 */
 | |
| 	public function fire()
 | |
| 	{
 | |
| 		if ( ! $this->confirmToProceed()) return;
 | |
| 
 | |
| 		$this->prepareDatabase();
 | |
| 
 | |
| 		// The pretend option can be used for "simulating" the migration and grabbing
 | |
| 		// the SQL queries that would fire if the migration were to be run against
 | |
| 		// a database for real, which is helpful for double checking migrations.
 | |
| 		$pretend = $this->input->getOption('pretend');
 | |
| 
 | |
| 		// Next, we will check to see if a path option has been defined. If it has
 | |
| 		// we will use the path relative to the root of this installation folder
 | |
| 		// so that migrations may be run for any path within the applications.
 | |
| 		if ( ! is_null($path = $this->input->getOption('path')))
 | |
| 		{
 | |
| 			$path = $this->laravel->basePath().'/'.$path;
 | |
| 		}
 | |
| 		else
 | |
| 		{
 | |
| 			$path = $this->getMigrationPath();
 | |
| 		}
 | |
| 
 | |
| 		$this->migrator->run($path, $pretend);
 | |
| 
 | |
| 		// Once the migrator has run we will grab the note output and send it out to
 | |
| 		// the console screen, since the migrator itself functions without having
 | |
| 		// any instances of the OutputInterface contract passed into the class.
 | |
| 		foreach ($this->migrator->getNotes() as $note)
 | |
| 		{
 | |
| 			$this->output->writeln($note);
 | |
| 		}
 | |
| 
 | |
| 		// Finally, if the "seed" option has been given, we will re-run the database
 | |
| 		// seed task to re-populate the database, which is convenient when adding
 | |
| 		// a migration and a seed at the same time, as it is only this command.
 | |
| 		if ($this->input->getOption('seed'))
 | |
| 		{
 | |
| 			$this->call('db:seed', ['--force' => true]);
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Prepare the migration database for running.
 | |
| 	 *
 | |
| 	 * @return void
 | |
| 	 */
 | |
| 	protected function prepareDatabase()
 | |
| 	{
 | |
| 		$this->migrator->setConnection($this->input->getOption('database'));
 | |
| 
 | |
| 		if ( ! $this->migrator->repositoryExists())
 | |
| 		{
 | |
| 			$options = array('--database' => $this->input->getOption('database'));
 | |
| 
 | |
| 			$this->call('migrate:install', $options);
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Get the console command options.
 | |
| 	 *
 | |
| 	 * @return array
 | |
| 	 */
 | |
| 	protected function getOptions()
 | |
| 	{
 | |
| 		return array(
 | |
| 			array('database', null, InputOption::VALUE_OPTIONAL, 'The database connection to use.'),
 | |
| 
 | |
| 			array('force', null, InputOption::VALUE_NONE, 'Force the operation to run when in production.'),
 | |
| 
 | |
| 			array('path', null, InputOption::VALUE_OPTIONAL, 'The path of migrations files to be executed.'),
 | |
| 
 | |
| 			array('pretend', null, InputOption::VALUE_NONE, 'Dump the SQL queries that would be run.'),
 | |
| 
 | |
| 			array('seed', null, InputOption::VALUE_NONE, 'Indicates if the seed task should be re-run.'),
 | |
| 		);
 | |
| 	}
 | |
| 
 | |
| }
 |