The LaminasSymfonyConsole module allows to use the symfony console component with Laminas.
Install eth8505/laminas-symfony-console
package via composer.
$ composer require eth8505/laminas-symfony-console
Load the module in your application.config.php
file like so:
<?php
return [
'modules' => [
'LaminasSymfonyConsole',
// ...
],
];
You can use the vendor/bin/console
tool to run your commands. This tool may be in a different directory depending on
how your composers bin-dir
is configured.
Depending on how you did setup your Laminas project, you might need to modify public/index.php
.
For example this is neccassary if you did use the Laminas MVC Skeleton project.
Firstly that file has to return the Application
instance for this library to work.
Optionally you might only invoke the run()
method of Laminas\Mvc\Application
if public/index.php
has not
been called via the PHP CLI. This will avoid cluttering up your console with the view.
Create commands as described in the symfony console docs. Please note that if you're using a fully-fledged laminas framework, it won't be possible to use all the nice symfony service container logic.
You can either register your commands with the service manager via the config in your module.config.php
:
<?php
return [
'laminas_symfonyconsole_commands' => [
'invokables' => [
MyCommand::class
]
]
];
or register it in your module class using the ConsoleCommandProviderInterface
:
<?php
namespace MyModule;
use LaminasSymfonyConsole\ConsoleCommandProviderInterface;
class Module implements ConsoleCommandProviderInterface {
/**
* @inheritdoc
*/
public function getConsoleCommandConfig() {
return [
'invokables' => [
MyCommand::class
]
];
}
}
Your command will now show up when using the bin/console
utility and can be called with whatever you set up in the
commands configure
method.
Thanks to Rafi Adnan and his RDN Console module which this module is loosely based upon.