为了账号安全,请及时绑定邮箱和手机立即绑定

RefreshCommand.php

标签:
PHP

<?php

 

namespace Illuminate\Database\Console\Migrations;

 

use Illuminate\Console\Command;

use Illuminate\Console\ConfirmableTrait;

use Symfony\Component\Console\Input\InputOption;

 

class RefreshCommand extends Command

{// Refresh Command to extends Command

    use ConfirmableTrait;// use Confirm able Trait

 

    /**

     * The console command name.

     *

     * @var string

     */

    protected $name = 'migrate:refresh';// name

 

    /**

     * The console command description.

     *

     * @var string

     */

    protected $description = 'Reset and re-run all migrations';//description

 

    /**

     * Execute the console command.

     *

     * @return void

     */

    public function fire()

    {

        if (! $this->confirmToProceed()) {

            return;

        }// fire

 

        $database = $this->input->getOption('database');

 

        $force = $this->input->getOption('force');

 

        $path = $this->input->getOption('path');

// get base parameters

        $this->call('migrate:reset', [

            '--database' => $database, '--force' => $force,

        ]);// call them

 

        // 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,

            '--force' => $force,

            '--path' => $path,

        ]);// call class withe options

 

        if ($this->needsSeeding()) {

            $this->runSeeder($database);

        }// get the class

    }

 

    /**

     * Determine if the developer has requested database seeding.

     *

     * @return bool

     */

    protected function needsSeeding()

    {

        return $this->option('seed') || $this->option('seeder');

    }//Determine if the developer has requested database seeding.

 

    /**

     * Run the database seeder command.

     *

     * @param  string  $database

     * @return void

     */

    protected function runSeeder($database)

    {

        $class = $this->option('seeder') ?: 'DatabaseSeeder';

 

        $force = $this->input->getOption('force');

 

        $this->call('db:seed', [

            '--database' => $database, '--class' => $class, '--force' => $force,

        ]);

    }//Run the database seeder command

 

    /**

     * 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 of migrations files to be executed.'],

 

            ['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.'],

        ];

    }// get Options

}

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消