Вход Регистрация
Файл: vendor/laravel/framework/src/Illuminate/Database/Console/Seeds/SeedCommand.php
Строк: 191
<?php

namespace IlluminateDatabaseConsoleSeeds;

use 
IlluminateConsoleCommand;
use 
IlluminateConsoleConfirmableTrait;
use 
IlluminateDatabaseConnectionResolverInterface as Resolver;
use 
IlluminateDatabaseEloquentModel;
use 
SymfonyComponentConsoleAttributeAsCommand;
use 
SymfonyComponentConsoleInputInputArgument;
use 
SymfonyComponentConsoleInputInputOption;

#[AsCommand(name: 'db:seed')]
class SeedCommand extends Command
{
    use 
ConfirmableTrait;

    
/**
     * The console command name.
     *
     * @var string
     */
    
protected $name 'db:seed';

    
/**
     * The name of the console command.
     *
     * This name is used to identify the command during lazy loading.
     *
     * @var string|null
     *
     * @deprecated
     */
    
protected static $defaultName 'db:seed';

    
/**
     * The console command description.
     *
     * @var string
     */
    
protected $description 'Seed the database with records';

    
/**
     * The connection resolver instance.
     *
     * @var IlluminateDatabaseConnectionResolverInterface
     */
    
protected $resolver;

    
/**
     * Create a new database seed command instance.
     *
     * @param  IlluminateDatabaseConnectionResolverInterface  $resolver
     * @return void
     */
    
public function __construct(Resolver $resolver)
    {
        
parent::__construct();

        
$this->resolver $resolver;
    }

    
/**
     * Execute the console command.
     *
     * @return int
     */
    
public function handle()
    {
        if (! 
$this->confirmToProceed()) {
            return 
1;
        }

        
$this->components->info('Seeding database.');

        
$previousConnection $this->resolver->getDefaultConnection();

        
$this->resolver->setDefaultConnection($this->getDatabase());

        
Model::unguarded(function () {
            
$this->getSeeder()->__invoke();
        });

        if (
$previousConnection) {
            
$this->resolver->setDefaultConnection($previousConnection);
        }

        return 
0;
    }

    
/**
     * Get a seeder instance from the container.
     *
     * @return IlluminateDatabaseSeeder
     */
    
protected function getSeeder()
    {
        
$class $this->input->getArgument('class') ?? $this->input->getOption('class');

        if (! 
str_contains($class'\')) {
            $class = '
Database\Seeders\'.$class;
        }

        if ($class === '
Database\Seeders\DatabaseSeeder' &&
            ! class_exists($class)) {
            $class = '
DatabaseSeeder';
        }

        return $this->laravel->make($class)
                        ->setContainer($this->laravel)
                        ->setCommand($this);
    }

    /**
     * Get the name of the database connection to use.
     *
     * @return string
     */
    protected function getDatabase()
    {
        $database = $this->input->getOption('
database');

        return $database ?: $this->laravel['
config']['database.default'];
    }

    /**
     * Get the console command arguments.
     *
     * @return array
     */
    protected function getArguments()
    {
        return [
            ['
class', InputArgument::OPTIONAL, 'The class name of the root seeder', null],
        ];
    }

    /**
     * Get the console command options.
     *
     * @return array
     */
    protected function getOptions()
    {
        return [
            ['
class', null, InputOption::VALUE_OPTIONAL, 'The class name of the root seeder', 'Database\Seeders\DatabaseSeeder'],
            ['
database', null, InputOption::VALUE_OPTIONAL, 'The database connection to seed'],
            ['
force', null, InputOption::VALUE_NONE, 'Force the operation to run when in production'],
        ];
    }
}
Онлайн: 1
Реклама