1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
|
<?php namespace Illuminate\Database\Console\Migrations;
use Illuminate\Console\Command; use Symfony\Component\Console\Input\InputOption;
class RefreshCommand extends Command {
/** * The console command name. * * @var string */ protected $name = 'migrate:refresh';
/** * The console command description. * * @var string */ protected $description = 'Reset and re-run all migrations';
/** * Execute the console command. * * @return void */ public function fire() { $database = $this->input->getOption('database');
$this->call('migrate:reset', array('--database' => $database));
// 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', array('--database' => $database));
if ($this->needsSeeding()) { $this->runSeeder($database); } }
/** * 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) { $class = $this->option('seeder') ?: 'DatabaseSeeder';
$this->call('db:seed', array('--database' => $database, '--class' => $class)); }
/** * Get the console command options. * * @return array */ protected function getOptions() { return array( array('database', null, InputOption::VALUE_OPTIONAL, 'The database connection to use.'),
array('seed', null, InputOption::VALUE_NONE, 'Indicates if the seed task should be re-run.'),
array('seeder', null, InputOption::VALUE_OPTIONAL, 'The class name of the root seeder.'), ); }
}
|