Действия

Действия отвечают за 'бизнес-логику' модуля. Действие обычно состоит из controller и action view.

Модуль может:

  • Вызвать действия, которые уже определены в веб-интерфейсе Zabbix.
  • Переопределить действия по умолчанию настраиваемыми действиями.
  • Определить совершенно новые действия.

Чтобы переопределить поведение действия по умолчанию некоторым пользовательским поведением, определите действие с тем же именем в конфигурации модуля. При вызове действия вместо действия Zabbix по умолчанию будет выполнено действие модуля.

Файлы действий должны храниться в папке actions. Действия необходимо указать в файле manifest.json.

Контроллер

Рабочий процесс контроллера действий:

  1. Проверьте, что все параметры, переданные в HTTP-запросе, являются допустимыми:
  • Вызовите метод checkInput() контроллера
  • Используйте правила проверки, определенные в CNewValidator.php
  • Вызовите метод validateInput()
  1. Проверьте права пользователя.

  2. Подготовьте данные в соответствии с переданными параметрами: если checkInput() возвращает true, Zabbix вызывает метод doAction() контроллера.

  3. Подготовьте массив $data для представления. Используйте методы CControllerResponseData и setResponse() для сохранения ответа в массиве $data.

Пример:

/**
        * Validate input parameters.
        *
        * @return bool
        */
       protected function checkInput(): bool {
           $ret = $this->validateInput([
               'status' => 'in '.implode(',', [HOST_STATUS_MONITORED, HOST_STATUS_NOT_MONITORED])
           ]);
       
           if (!$ret) {
               $this->setResponse(new CControllerResponseFatal());
           }
       
           return $ret;
       }
       
       /**
        * Check user permissions.
        *
        * @return bool
        */
       protected function checkPermissions() {
           return $this->getUserType() >= USER_TYPE_ZABBIX_ADMIN;
       }
       
       /**
        * Execute action and generate response object.
        */
       protected function do Action(): void {
           $data = [ 
               'hosts_count' => API::Host()->get([
                   'countOutput' => true,
                   'filter' => [
                       'status' => $this->getInput('status')
                   ]
               ]) 
           ];
           
           $this->setResponse(new CControllerResponseData($data));
       }

Вы можете просмотреть полный список доступных классов контроллеров в Zabbix исходный код.