Skip to content
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.

Module Structure

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 
        }
    }
}

Where can modules be placed?

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
Clone this wiki locally