/** * Execute the console command. * * @return mixed */ 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'); $opts = ["pretend" => $pretend]; $path = database_path(config('smart-seeder.seedDir')); $env = $this->option('env'); $this->migrator->setEnv($env); $single = $this->option('file'); if ($single) { $this->migrator->runSingleFile("{$path}/{$single}", $pretend); } else { $this->migrator->run($path, $opts); } // 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); } }
/** * Execute the console command. * * @return mixed */ public function fire() { if (!$this->confirmToProceed()) { return; } $this->prepareDatabase(); $env = $this->option('env'); if ($this->files->exists(database_path(config('smart-seeder.seedsDir')))) { $this->migrator->setEnv($env); } //otherwise use the default environment $this->migrator->setConnection($this->input->getOption('database')); $pretend = $this->input->getOption('pretend'); while (true) { $count = $this->migrator->rollback($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); } if ($count == 0) { break; } } $this->line("Seeds reset for {$env}"); }
/** * Execute the console command. * * @return mixed */ public function fire() { if (!$this->confirmToProceed()) { return; } $this->migrator->setConnection($this->input->getOption('database')); $env = $this->option('env'); if ($this->files->exists(database_path(config('smart-seeder.seedsDir')))) { $this->migrator->setEnv($env); } $pretend = $this->input->getOption('pretend'); $this->migrator->rollback($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); } }