confirmToProceed()) { return; } // Next we'll gather some of the options so that we can have the right options // to pass to the commands. This includes options such as which database to // use and the path to use for the migration. Then we'll run the command. $database = $this->input->getOption('database'); $path = $this->input->getOption('path'); $force = $this->input->getOption('force'); // If the "step" option is specified it means we only want to rollback a small // number of migrations before migrating again. For example, the user might // only rollback and remigrate the latest four migrations instead of all. $step = $this->input->getOption('step') ?: 0; if ($step > 0) { $this->runRollback($database, $path, $step, $force); } else { $this->runReset($database, $path, $force); } // The refresh command is essentially just a brief aggregate of a few other of // the migration commands and just provides a convenient wrapper to execute // them in succession. We'll also see if we need to re-seed the database. $this->call('migrate', [ '--database' => $database, '--path' => $path, '--force' => $force, ]); if ($this->needsSeeding()) { $this->runSeeder($database); } } /** * Run the rollback command. * * @param string $database * @param string $path * @param bool $step * @param bool $force * @return void */ protected function runRollback($database, $path, $step, $force) { $this->call('migrate:rollback', [ '--database' => $database, '--path' => $path, '--step' => $step, '--force' => $force, ]); } /** * Run the reset command. * * @param string $database * @param string $path * @param bool $force * @return void */ protected function runReset($database, $path, $force) { $this->call('migrate:reset', [ '--database' => $database, '--path' => $path, '--force' => $force, ]); } /** * Determine if the developer has requested database seeding. * * @return bool */ protected function needsSeeding() { return $this->option('seed') || $this->option('seeder'); } /** * Run the database seeder command. * * @param string $database * @return void */ protected function runSeeder($database) { $this->call('db:seed', [ '--database' => $database, '--class' => $this->option('seeder') ?: 'DatabaseSeeder', '--force' => $this->option('force'), ]); } /** * Get the console command options. * * @return array */ protected function getOptions() { return [ ['database', null, InputOption::VALUE_OPTIONAL, 'The database connection to use.'], ['force', null, InputOption::VALUE_NONE, 'Force the operation to run when in production.'], ['path', null, InputOption::VALUE_OPTIONAL, 'The path to the migrations files to be executed.'], ['realpath', null, InputOption::VALUE_NONE, 'Indicate any provided migration file paths are pre-resolved absolute paths.'], ['seed', null, InputOption::VALUE_NONE, 'Indicates if the seed task should be re-run.'], ['seeder', null, InputOption::VALUE_OPTIONAL, 'The class name of the root seeder.'], ['step', null, InputOption::VALUE_OPTIONAL, 'The number of migrations to be reverted & re-run.'], ]; } }