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.
135 lines
3.7 KiB
135 lines
3.7 KiB
11 months ago
|
<?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]
|
||
|
);
|
||
|
}
|
||
|
}
|