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.
133 lines
3.6 KiB
133 lines
3.6 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; |
|
|
|
/** |
|
* Generates a skeleton Model file. |
|
*/ |
|
class ModelGenerator extends BaseCommand |
|
{ |
|
use GeneratorTrait; |
|
|
|
/** |
|
* The Command's Group |
|
* |
|
* @var string |
|
*/ |
|
protected $group = 'Generators'; |
|
|
|
/** |
|
* The Command's Name |
|
* |
|
* @var string |
|
*/ |
|
protected $name = 'make:model'; |
|
|
|
/** |
|
* The Command's Description |
|
* |
|
* @var string |
|
*/ |
|
protected $description = 'Generates a new model file.'; |
|
|
|
/** |
|
* The Command's Usage |
|
* |
|
* @var string |
|
*/ |
|
protected $usage = 'make:model <name> [options]'; |
|
|
|
/** |
|
* The Command's Arguments |
|
* |
|
* @var array<string, string> |
|
*/ |
|
protected $arguments = [ |
|
'name' => 'The model class name.', |
|
]; |
|
|
|
/** |
|
* The Command's Options |
|
* |
|
* @var array<string, string> |
|
*/ |
|
protected $options = [ |
|
'--table' => 'Supply a table name. Default: "the lowercased plural of the class name".', |
|
'--dbgroup' => 'Database group to use. Default: "default".', |
|
'--return' => 'Return type, Options: [array, object, entity]. Default: "array".', |
|
'--namespace' => 'Set root namespace. Default: "APP_NAMESPACE".', |
|
'--suffix' => 'Append the component title to the class name (e.g. User => UserModel).', |
|
'--force' => 'Force overwrite existing file.', |
|
]; |
|
|
|
/** |
|
* Actually execute a command. |
|
*/ |
|
public function run(array $params) |
|
{ |
|
$this->component = 'Model'; |
|
$this->directory = 'Models'; |
|
$this->template = 'model.tpl.php'; |
|
|
|
$this->classNameLang = 'CLI.generator.className.model'; |
|
$this->execute($params); |
|
} |
|
|
|
/** |
|
* Prepare options and do the necessary replacements. |
|
*/ |
|
protected function prepare(string $class): string |
|
{ |
|
$table = $this->getOption('table'); |
|
$dbGroup = $this->getOption('dbgroup'); |
|
$return = $this->getOption('return'); |
|
|
|
$baseClass = class_basename($class); |
|
|
|
if (preg_match('/^(\S+)Model$/i', $baseClass, $match) === 1) { |
|
$baseClass = $match[1]; |
|
} |
|
|
|
$table = is_string($table) ? $table : plural(strtolower($baseClass)); |
|
$return = is_string($return) ? $return : 'array'; |
|
|
|
if (! in_array($return, ['array', 'object', 'entity'], true)) { |
|
// @codeCoverageIgnoreStart |
|
$return = CLI::prompt(lang('CLI.generator.returnType'), ['array', 'object', 'entity'], 'required'); |
|
CLI::newLine(); |
|
// @codeCoverageIgnoreEnd |
|
} |
|
|
|
if ($return === 'entity') { |
|
$return = str_replace('Models', 'Entities', $class); |
|
|
|
if (preg_match('/^(\S+)Model$/i', $return, $match) === 1) { |
|
$return = $match[1]; |
|
|
|
if ($this->getOption('suffix')) { |
|
$return .= 'Entity'; |
|
} |
|
} |
|
|
|
$return = '\\' . trim($return, '\\') . '::class'; |
|
$this->call('make:entity', array_merge([$baseClass], $this->params)); |
|
} else { |
|
$return = "'{$return}'"; |
|
} |
|
|
|
return $this->parseTemplate($class, ['{dbGroup}', '{table}', '{return}'], [$dbGroup, $table, $return], compact('dbGroup')); |
|
} |
|
}
|
|
|