-
-
Notifications
You must be signed in to change notification settings - Fork 399
Modules
Christian Münch edited this page Jul 24, 2013
·
8 revisions
Modules are a simple ways to add new commands to the system. With modules it's also easy to share commands within your developer team.
A module is a folder with at least a config file with the name n98-magerun.yaml
.
Inside your config you can define a command by using the same structure as defining a single custom command.
See Add-custom-commands.
Example n98-magerun.yaml:
autoloaders:
MyNamespace: %module%/src
commands:
customCommands:
- MyNamespace\FooCommand
- MyNamespace\BarCommand
%module% will be replaced with your current module folder path. It's not possible to place modules inside of modules.
.
└── test-module
├── n98-magerun.yaml
└── src
└── MyNamespace
├── BarCommand.php
└── FooCommand.php
Example Command:
<?php
namespace MyNamespace;
use N98\Magento\Command\AbstractMagentoCommand;
use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Output\OutputInterface;
class FooCommand extends AbstractMagentoCommand
{
protected function configure()
{
$this
->setName('mynamespace:foo')
->setDescription('Test command registered in a module')
;
}
/**
* @param \Symfony\Component\Console\Input\InputInterface $input
* @param \Symfony\Component\Console\Output\OutputInterface $output
* @return int|void
*/
protected function execute(InputInterface $input, OutputInterface $output)
{
$this->detectMagento($output);
if ($this->initMagento()) {
// .. do something
}
}
}
There are currently three possible base folders where you can place your modules.
- /usr/local/share/n98-magerun/modules
- ~/.n98-magerun/modules
- <MAGENTO_ROOT>/lib/n98-magerun/modules