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.'), ); } }