You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
134 lines
3.7 KiB
134 lines
3.7 KiB
<?php |
|
|
|
/** |
|
* This file is part of CodeIgniter 4 framework. |
|
* |
|
* (c) CodeIgniter Foundation <admin@codeigniter.com> |
|
* |
|
* For the full copyright and license information, please view |
|
* the LICENSE file that was distributed with this source code. |
|
*/ |
|
|
|
namespace CodeIgniter\Commands\Generators; |
|
|
|
use CodeIgniter\CLI\BaseCommand; |
|
use CodeIgniter\CLI\CLI; |
|
use CodeIgniter\CLI\GeneratorTrait; |
|
use CodeIgniter\Controller; |
|
use CodeIgniter\RESTful\ResourceController; |
|
use CodeIgniter\RESTful\ResourcePresenter; |
|
|
|
/** |
|
* Generates a skeleton controller file. |
|
*/ |
|
class ControllerGenerator extends BaseCommand |
|
{ |
|
use GeneratorTrait; |
|
|
|
/** |
|
* The Command's Group |
|
* |
|
* @var string |
|
*/ |
|
protected $group = 'Generators'; |
|
|
|
/** |
|
* The Command's Name |
|
* |
|
* @var string |
|
*/ |
|
protected $name = 'make:controller'; |
|
|
|
/** |
|
* The Command's Description |
|
* |
|
* @var string |
|
*/ |
|
protected $description = 'Generates a new controller file.'; |
|
|
|
/** |
|
* The Command's Usage |
|
* |
|
* @var string |
|
*/ |
|
protected $usage = 'make:controller <name> [options]'; |
|
|
|
/** |
|
* The Command's Arguments |
|
* |
|
* @var array<string, string> |
|
*/ |
|
protected $arguments = [ |
|
'name' => 'The controller class name.', |
|
]; |
|
|
|
/** |
|
* The Command's Options |
|
* |
|
* @var array<string, string> |
|
*/ |
|
protected $options = [ |
|
'--bare' => 'Extends from CodeIgniter\Controller instead of BaseController.', |
|
'--restful' => 'Extends from a RESTful resource, Options: [controller, presenter]. Default: "controller".', |
|
'--namespace' => 'Set root namespace. Default: "APP_NAMESPACE".', |
|
'--suffix' => 'Append the component title to the class name (e.g. User => UserController).', |
|
'--force' => 'Force overwrite existing file.', |
|
]; |
|
|
|
/** |
|
* Actually execute a command. |
|
*/ |
|
public function run(array $params) |
|
{ |
|
$this->component = 'Controller'; |
|
$this->directory = 'Controllers'; |
|
$this->template = 'controller.tpl.php'; |
|
|
|
$this->classNameLang = 'CLI.generator.className.controller'; |
|
$this->execute($params); |
|
} |
|
|
|
/** |
|
* Prepare options and do the necessary replacements. |
|
*/ |
|
protected function prepare(string $class): string |
|
{ |
|
$bare = $this->getOption('bare'); |
|
$rest = $this->getOption('restful'); |
|
|
|
$useStatement = trim(APP_NAMESPACE, '\\') . '\Controllers\BaseController'; |
|
$extends = 'BaseController'; |
|
|
|
// Gets the appropriate parent class to extend. |
|
if ($bare || $rest) { |
|
if ($bare) { |
|
$useStatement = Controller::class; |
|
$extends = 'Controller'; |
|
} elseif ($rest) { |
|
$rest = is_string($rest) ? $rest : 'controller'; |
|
|
|
if (! in_array($rest, ['controller', 'presenter'], true)) { |
|
// @codeCoverageIgnoreStart |
|
$rest = CLI::prompt(lang('CLI.generator.parentClass'), ['controller', 'presenter'], 'required'); |
|
CLI::newLine(); |
|
// @codeCoverageIgnoreEnd |
|
} |
|
|
|
if ($rest === 'controller') { |
|
$useStatement = ResourceController::class; |
|
$extends = 'ResourceController'; |
|
} elseif ($rest === 'presenter') { |
|
$useStatement = ResourcePresenter::class; |
|
$extends = 'ResourcePresenter'; |
|
} |
|
} |
|
} |
|
|
|
return $this->parseTemplate( |
|
$class, |
|
['{useStatement}', '{extends}'], |
|
[$useStatement, $extends], |
|
['type' => $rest] |
|
); |
|
} |
|
}
|
|
|