divix1988 / laminas-cli-commands
CLI commands for Laminas projects
Installs: 1 339
Dependents: 0
Suggesters: 0
Security: 0
Stars: 16
Watchers: 3
Forks: 4
Open Issues: 0
Requires
- php: ^7.1 || ^8.1
- laminas/laminas-cli: ^1.7
- laminas/laminas-code: ^4.7
README
CLI Commands for Laminas projects. WARNING, STILL IN BETA.
Official website: http://laminasstarterkit.omelak.com
Installation
Via Composer
Install the library using Composer:
$ composer require --dev divix1988/laminas-cli-commands
Setup
Add the following config into your config/local.php
file:
'laminas-cli' => [ 'commands' => [ 'mvc:controller' => \Divix\Laminas\Cli\Command\ControllerCommand::class, 'mvc:rowset' => \Divix\Laminas\Cli\Command\RowsetCommand::class, 'mvc:model' => \Divix\Laminas\Cli\Command\ModelCommand::class, 'mvc:form' => \Divix\Laminas\Cli\Command\FormCommand::class, 'mvc:view' => \Divix\Laminas\Cli\Command\ViewCommand::class, 'mvc:crud' => \Divix\Laminas\Cli\Command\CrudCommand::class, 'mvc:crud_controller' => \Divix\Laminas\Cli\Command\CrudControllerCommand::class, 'mvc:crud_view' => \Divix\Laminas\Cli\Command\CrudViewCommand::class, 'mvc:crud_config' => \Divix\Laminas\Cli\Command\CrudConfigCommand::class, 'mvc:login_registration' => \Divix\Laminas\Cli\Command\LoginRegistrationCommand::class, 'mvc:admin' => \Divix\Laminas\Cli\Command\AdminPanelCommand::class, 'mvc:navigation' => \Divix\Laminas\Cli\Command\NavigationCommand::class, 'mvc:sitemap' => \Divix\Laminas\Cli\Command\SitemapCommand::class, 'mvc:mariadb_database_connect' => \Divix\Laminas\Cli\Command\MariaDbCommand::class ], ],
Usage
$ vendor/bin/laminas [command-params] [command-name]
or for Windows users:
$ "vendor/bin/laminas.bat" [command-params] [command-name]
Available commands
Controller
Generate sample controller with a list of available actions:
"vendor/bin/laminas.bat" mvc:controller --actions=<action1> --actions=<action2> --module=ModuleName <name>
New file in: [root]/module/[moduleName]/src/Controller/[name].php
Sample output:
namespace ModuleName\Controller\ControllerNameController; class ControllerNameController extends \Laminas\Mvc\Controller\AbstractActionController { public function indexAction() { } public function action1Action() { } public function action2Action() { } }
Model
Generate sample model with a list of properties:
"vendor/bin/laminas.bat" mvc:model --properties=<property1> --properties=<property2> --module=ModuleName <name>
New file in: [root]/module/[moduleName]/src/Model/[name].php
Sample output:
namespace ModuleName\Model; class ModelNameTable extends AbstractTable { protected $resultsPerPage = 10; public function getBy(array $params = []) { $select = $this->tableGateway->getSql()->select(); if (isset($params['id'])) { $select->where(['id' => $params['id']]); $params['limit'] = 1; } if (isset($params['property1'])) { $select->where(['property1' => $params['property1']]); } if (isset($params['property2'])) { $select->where(['property2' => $params['property2']]); } if (isset($params['limit'])) { $select->limit($params['limit']); } if (!isset($params['page'])) { $params['page'] = 0; } $result = (isset($params['limit']) && $params['limit'] == 1) ? $this->fetchRow($select) : $this->fetchAll($select, ['limit' => $this->resultsPerPage, 'page' => $params['page']]); return $result; } public function patch(int $id, array $data) { if (empty($data)) { throw new \Exception('missing data to update'); } $passedData = []; if (!empty($data['property1'])) { $passedData['property1'] = $data['property1']; } if (!empty($data['property2'])) { $passedData['property2'] = $data['property2']; } $this->tableGateway->update($passedData, ['id' => $id]); } public function getById(\Rowset\ModelName $rowset) { return parent::saveRow($rowset); } public function delete($id) { if (empty($id)) { throw new \Exception('missing comics id to delete'); } parent::deleteRow($id); } }
Form
Generate sample model with a list of properties:
"vendor/bin/laminas.bat" mvc:form --properties=<property1> --properties=<property2> --module=<ModuleName> <name>
New file in: [root]/module/[moduleName]/src/Form/[name]Form.php
Sample output:
namespace ModuleName\Form; use \Laminas\Form\Element; class NewUserForm extends \Laminas\Form\Form implements \Laminas\InputFilter\InputFilterProviderInterface { const ELEMENT_PROPERTY1 = 'property1'; const ELEMENT_PROPERTY2 = 'property2'; public function __construct($name, array $params) { parent::__construct($name, $params); $this->setAttribute('class', 'styledForm'); $this->add([ 'name' => self::ELEMENT_PROPERTY1, 'type' => 'text', 'options' => [ 'label' => 'property1' ], 'attributes' => [ 'required' => true ] ]); $this->add([ 'name' => self::ELEMENT_PROPERTY2, 'type' => 'text', 'options' => [ 'label' => 'property2' ], 'attributes' => [ 'required' => true ] ]); $this->add([ 'name' => 'submit', 'type' => 'submit', 'attributes' => [ 'value' => 'Submit', 'class' => 'btn btn-primary' ] ]); } public function getInputFilterSpecification() { return []; } }
Rowset
Generate sample rowset with a list of params:
"vendor/bin/laminas.bat" mvc:rowset --properties=<property1> --properties=<property2> --module=ModuleName <name>
New file in: [root]/module/[moduleName]/src/Model/Rowset/[name].php
Sample output:
namespace ModuleName\Model; class RowsetName { public $property1 = null; public $property2 = null; public function getProperty1() { return $this->property1; } public function setProperty1($value) { $this->property1 = $value; return $this; } public function getProperty2() { return $this->property2; } public function setProperty2($value) { $this->property2 = $value; return $this; } }
View
Generate sample .phtml view file:
"vendor/bin/laminas-cli.bat" mvc:view --module=ModuleName <controllerName> <name>
New file in: [root]/module/[moduleName]/view/[controllerName]/[name].phtml
Sample output:
<p>ModuleName - ViewName</p>
CRUD
Generate a full working example with Form, Rowset, Model, View and Controller with given name:
"vendor/bin/laminas.bat" mvc:crud --properties=<property1> --properties=<property2> --module=ModuleName <name>
New files in:
[root]/module/[moduleName]/src/Controller/[name]Controller.php
[root]/module/[moduleName]/src/Model/[name]Model.php
[root]/module/[moduleName]/src/Model/AbstractTable.php
[root]/module/[moduleName]/src/Form/[name]Form.php
[root]/module/[moduleName]/src/Model/Rowset/[name].php
[root]/module/[moduleName]/src/Model/Rowset/AbstractModel.php
[root]/module/[moduleName]/view/[name]/index.phtml
[root]/module/[moduleName]/view/[name]/pagination.phtml
[root]/module/[moduleName]/view/[name]/add.phtml
[root]/module/[moduleName]/view/[name]/delete.phtml
[root]/module/[moduleName]/view/[name]/edit.phtml
[root]/module/[moduleName]/config/generated.crud.php
Configuration in:
config/generated.crud.php
Sample output for module: ModuleName
and name: NewUsers
:
namespace ModuleName; use Laminas\Router\Http\Segment; use Laminas\Db\ResultSet\ResultSet; use Laminas\Db\TableGateway\TableGateway; use ModuleName\Model\Rowset; use ModuleName\Model; use ModuleName\Controller; return [ 'router' => [ 'routes' => [ 'newUsers' => [ 'type' => Segment::class, 'options' => [ 'route' => '/newusers[/:action[/:id]]', 'defaults' => [ 'controller' => Controller\NewUsersController::class, 'action' => 'index', ], ], 'may_terminate' => true, 'child_routes' => [ 'paginator' => [ 'type' => 'segment', 'options' => [ 'route' => '/[page/:page]', 'defaults' => [ 'page' => 1 ] ] ], ] ] ] ], 'controllers' => [ 'factories' => [ Controller\NewUsersController::class => function($sm) { $postService = $sm->get(Model\NewUsersTable::class); return new Controller\NewUsersController($postService); }, ] ], 'service_manager' => [ 'factories' => [ 'NewUsersTableGateway' => function ($sm) { $dbAdapter = $sm->get('Laminas\Db\Adapter\Adapter'); $config = $sm->get('Config'); $baseUrl = $config['view_manager']['base_url']; $resultSetPrototype = new ResultSet(); $identity = new Rowset\NewUser($baseUrl); $resultSetPrototype->setArrayObjectPrototype($identity); return new TableGateway('newusers', $dbAdapter, null, $resultSetPrototype); }, Model\NewUsersTable::class => function($sm) { $tableGateway = $sm->get('NewUsersTableGateway'); $table = new Model\NewUsersTable($tableGateway); return $table; }, ] ], 'view_manager' => [ 'template_map' => [ 'module-name/new-users/index' => __DIR__ . '/../view/NewUsers/index.phtml', 'module-name/new-users/edit' => __DIR__ . '/../view/NewUsers/edit.phtml', 'module-name/new-users/add' => __DIR__ . '/../view/NewUsers/add.phtml', 'module-name/new-users/pagination' => __DIR__ . '/../view/NewUsers/pagination.phtml', ], ] ];
Users Login & Registration
Generate Users registration and login feature with custom user properties
"vendor/bin/laminas.bat" mvc:login-registration --properties=<property1> --properties=<property2> --module=ModuleName
New files in:
[root]/module/[moduleName]/src/Controller/LoginController.php
[root]/module/[moduleName]/src/Controller/RegisterController.php
[root]/module/[moduleName]/src/Model/UserModel.php
Configuration in:
config/module.config.php
src/Module.php
Admin Panel
Add an admin panel to your Laminas MVC project and provide Reports and Users managment tool.
"vendor/bin/laminas.bat" mvc:admin --module=ModuleName
New files in:
[root]/module/[moduleName]/src/Controller/AbstractController.php
[root]/module/[moduleName]/src/Controller/AdminController.php
[root]/module/[moduleName]/src/view/admin/admin/index.phtml
[root]/module/[moduleName]/src/view/admin/_shared/footer.phtml
[root]/module/[moduleName]/src/view/admin/_shared/menu.phtml
[root]/module/[moduleName]/src/view/layout/admin.phtml
[root]/module/[moduleName]/src/Model.php
Configuration in:
config/module.config.php
src/Module.php
Navigation
Add a default menu navigation specified with given items.
"vendor/bin/laminas.bat" mvc:navigation --items=<item1> --items=<item2> --module=ModuleName <name>
New files in:
[root]/module/[moduleName]/src/Controller/AbstractController.php
[root]/module/[moduleName]/src/Controller/AdminController.php
[root]/module/[moduleName]/src/view/[moduleName]/layout/layout.phtml
[root]/module/[moduleName]/src/view/_shared/menu.phtml
Configuration in:
config/autoload/global.php
Sitemap
Add a sitemap controller serving file in XML Google foramt.
"vendor/bin/laminas.bat" mvc:sitemap --module=ModuleName <name>
New files in:
[root]/module/[moduleName]/src/Controller/SitemapController.php
[root]/module/[moduleName]/src/view/[moduleName]/sitemap/index.phtml
Configuration in:
[root]/module/[moduleName]/config/module.config.php