Действия
Действия отвечают за 'бизнес-логику' модуля. Действие обычно состоит из controller и action view.
Модуль может:
- Вызвать действия, которые уже определены в веб-интерфейсе Zabbix.
- Переопределить действия по умолчанию настраиваемыми действиями.
- Определить совершенно новые действия.
Чтобы переопределить поведение действия по умолчанию некоторым пользовательским поведением, определите действие с тем же именем в конфигурации модуля. При вызове действия вместо действия Zabbix по умолчанию будет выполнено действие модуля.
Файлы действий должны храниться в папке actions. Действия необходимо указать в файле manifest.json.
Контроллер
Рабочий процесс контроллера действий:
1) Проверьте, что все параметры, переданные в HTTP-запросе, являются допустимыми:
- Вызовите метод checkInput() контроллера
- Используйте правила проверки, определенные в CNewValidator.php
- Вызовите метод validateInput()
2) Проверьте права пользователя.
3) Подготовьте данные в соответствии с переданными параметрами: если checkInput() возвращает true, Zabbix вызывает метод doAction() контроллера.
4) Подготовьте массив $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 исходный код.