. */ /* */ /*************************************************************************************/ namespace Thelia\Action; use Symfony\Component\EventDispatcher\EventSubscriberInterface; use Thelia\Core\Event\Module\ModuleToggleActivationEvent; use Thelia\Core\Event\TheliaEvents; use Thelia\Model\ModuleQuery; use Thelia\Module\BaseModule; /** * Class Module * @package Thelia\Action * @author Manuel Raynaud */ class Module extends BaseAction implements EventSubscriberInterface { public function toggleActivation(ModuleToggleActivationEvent $event) { if (null !== $module = ModuleQuery::create()->findPk($event->getModuleId())) { $moduleClass = new \ReflectionClass($module->getFullNamespace()); $moduleInstance = $moduleClass->newInstance(); if( method_exists($moduleInstance, 'setContainer')) { $moduleInstance->setContainer($this->container); if($module->getActivate() == BaseModule::IS_ACTIVATED) { $moduleInstance->deActivate($module); } else { $moduleInstance->activate($module); } } if($module->isModified()) { $event->setModule($module); } } } /** * Returns an array of event names this subscriber wants to listen to. * * The array keys are event names and the value can be: * * * The method name to call (priority defaults to 0) * * An array composed of the method name to call and the priority * * An array of arrays composed of the method names to call and respective * priorities, or 0 if unset * * For instance: * * * array('eventName' => 'methodName') * * array('eventName' => array('methodName', $priority)) * * array('eventName' => array(array('methodName1', $priority), array('methodName2')) * * @return array The event names to listen to * * @api */ public static function getSubscribedEvents() { return array( TheliaEvents::MODULE_TOGGLE_ACTIVATION => array('toggleActivation', 128) ); } }