Viewing file: MigrateCommand.php (3.02 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
namespace Nwidart\Modules\Commands;
use Illuminate\Console\Command; use Nwidart\Modules\Migrations\Migrator; use Nwidart\Modules\Module; use Symfony\Component\Console\Input\InputArgument; use Symfony\Component\Console\Input\InputOption;
class MigrateCommand extends Command { /** * The console command name. * * @var string */ protected $name = 'module:migrate';
/** * The console command description. * * @var string */ protected $description = 'Migrate the migrations from the specified module or from all modules.';
/** * @var \Nwidart\Modules\Contracts\RepositoryInterface */ protected $module;
/** * Execute the console command. * * @return mixed */ public function handle() : int { $this->module = $this->laravel['modules'];
$name = $this->argument('module');
if ($name) { $module = $this->module->findOrFail($name);
$this->migrate($module);
return 0; }
foreach ($this->module->getOrdered($this->option('direction')) as $module) { $this->line('Running for module: <info>' . $module->getName() . '</info>');
$this->migrate($module); }
return 0; }
/** * Run the migration from the specified module. * * @param Module $module */ protected function migrate(Module $module) { $path = str_replace(base_path(), '', (new Migrator($module, $this->getLaravel()))->getPath());
if ($this->option('subpath')) { $path = $path . "/" . $this->option("subpath"); }
$this->call('migrate', [ '--path' => $path, '--database' => $this->option('database'), '--pretend' => $this->option('pretend'), '--force' => $this->option('force'), ]);
if ($this->option('seed')) { $this->call('module:seed', ['module' => $module->getName(), '--force' => $this->option('force')]); } }
/** * Get the console command arguments. * * @return array */ protected function getArguments() { return [ ['module', InputArgument::OPTIONAL, 'The name of module will be used.'], ]; }
/** * Get the console command options. * * @return array */ protected function getOptions() { return [ ['direction', 'd', InputOption::VALUE_OPTIONAL, 'The direction of ordering.', 'asc'], ['database', null, InputOption::VALUE_OPTIONAL, 'The database connection to use.'], ['pretend', null, InputOption::VALUE_NONE, 'Dump the SQL queries that would be run.'], ['force', null, InputOption::VALUE_NONE, 'Force the operation to run when in production.'], ['seed', null, InputOption::VALUE_NONE, 'Indicates if the seed task should be re-run.'], ['subpath', null, InputOption::VALUE_OPTIONAL, 'Indicate a subpath to run your migrations from'], ]; } }
|