Система Событий (Event) в OpenCart. Часть 1 из 3 - Обработка Событий.

Sorry for my English! English is not my native language. One of the reasons to create this blog is to improve my English writing. So I will be highly obliged if you will help me with this. If you find a grammar error on this page, please select it with your mouse and press Ctrl+Enter.

Как я уже писал ранее, наиболее интерестным новшеством в OpenCart 2.0 стало появление в этой версии Событий (Event). 
Так что же это?

Что такое События (Event) в OpenCart?
 
Система Событий OpenCart это инструмент, с помощью которого можно изменить логику работы OpenCart из своего модуля не изменяя при этом код самого OpenCart. Подобные инструменты есть во всех серьезных системах: в Drupal есть система хуков, в Sypfony те же События. Такой системы просто катастрофически не хватало в OpenCart, так как единственным способом что-то изменить из своего модуля до недавнего времени был vQmod который является причиной огромного количества конфликтов и одним из самых больших недостатков OpenCart.
 
Важное замечание! Система Событий только появилась в OpenCart 2.0 и находится в разработке, поэтому со временем может немного измениться. Если вы обнаружили такие изменения  - напишите об этом в комментариях, добавлю в статью.
 
Регистрация Событий
 
Класс, который отвечает за регистрацию Событий и запуск Обработчиков этих Событий находится в system/engine/event.php
Он подключается, как обычно, через system/startup.php:

require_once(modification(DIR_SYSTEM . 'engine/event.php'));

 
который вызывается в index.php:

// Startup
require_once(DIR_SYSTEM . 'startup.php');

 
Этот класс небольшой, можно привести весь его код:

class Event {
    private $data = array();
 
    public function __construct($registry) {
        $this->registry = $registry;
    }
 
    public function register($key, $action) {
        $this->data[$key][] = $action;
    }
 
    public function unregister($key, $action) {
        unset($this->data[$key]);
    }
 
    public function trigger($key, &$arg = array()) {
        if (isset($this->data[$key])) {
            foreach ($this->data[$key] as $event) {
                $action = new Action($event, $arg);
                $action->execute($this->registry);
            }
        }
    }
}

 
Мы видим, что в классе Event содержится 3 метода: 
1. register для регистрации новых Событий
2. unregister для удаления событий из реестра. Этот метод на данный момент нигде не используется.
3. trigger для запуска Обработчиков Событий. Метод получает аргументы $arg по ссылке, это значит что мы их можем изменить в Обработчике. На одно событие могут быть 
добавлены несколько Обработчиков. Например, 2 модуля могут обрабатывать одно Событие по очереди.
 
Сами События добавляются в OpenCart в index.php:

// Event
$event = new Event($registry);
$registry->set('event', $event);
 
$query = $db->query("SELECT * FROM " . DB_PREFIX . "event");
 
foreach ($query->rows as $result) {
    $event->register($result['trigger'], $result['action']);
}

 
Мы видим, что сначала создается объект Event, добавляется в реестр, после чего с базы данных получаются все События и регистрируются.
 
Запуск Обработчиков Событий
 
Каждый раз, когда в коде встретится:

$this->event->trigger('event_name', $args);

 
будут вызываться Обработчики, которые привязаны к этому Событию.
например в catalog/model/checkout/order.php в методе addOrder есть код:

$this->event->trigger('pre.order.add', $data);

 
Это значит, что мы можем в своем модуле создать Обработчик для этого События 'pre.order.add', в котором можем изменить все переменные из $data как нам угодно.
 
"Как добавить новый Обработчик События в своем модуле" читайте во второй части этой статьи.
 

Add new comment

CAPTCHA
Spam protection
Target Image