관리-도구
편집 파일: ResourceMakeCommand.php
<?php namespace Illuminate\Foundation\Console; use Illuminate\Console\GeneratorCommand; use Illuminate\Support\Str; use Symfony\Component\Console\Input\InputOption; class ResourceMakeCommand extends GeneratorCommand { /** * The console command name. * * @var string */ protected $name = 'make:resource'; /** * The console command description. * * @var string */ protected $description = 'Create a new resource'; /** * The type of class being generated. * * @var string */ protected $type = 'Resource'; /** * Execute the console command. * * @return void */ public function handle() { if ($this->collection()) { $this->type = 'Resource collection'; } parent::handle(); } /** * Get the stub file for the generator. * * @return string */ protected function getStub() { return $this->collection() ? $this->resolveStubPath('/stubs/resource-collection.stub') : $this->resolveStubPath('/stubs/resource.stub'); } /** * Determine if the command is generating a resource collection. * * @return bool */ protected function collection() { return $this->option('collection') || Str::endsWith($this->argument('name'), 'Collection'); } /** * Resolve the fully-qualified path to the stub. * * @param string $stub * @return string */ protected function resolveStubPath($stub) { return file_exists($customPath = $this->laravel->basePath(trim($stub, '/'))) ? $customPath : __DIR__.$stub; } /** * Get the default namespace for the class. * * @param string $rootNamespace * @return string */ protected function getDefaultNamespace($rootNamespace) { return $rootNamespace.'\Http\Resources'; } /** * Get the console command options. * * @return array */ protected function getOptions() { return [ ['collection', 'c', InputOption::VALUE_NONE, 'Create a resource collection'], ]; } }