Акције
Акције су одговорне за 'business logic' модула. Радња се обично састоји од controller и action view. Модул може:
- Позивати акције које су већ дефинисане у Zabbix корисничком интерфејсу.
- Заменити подразумеване радње прилагођеним радњама.
- Дефинисати потпуно нове радње. Да бисте заменили подразумевано понашање радње неким прилагођеним понашањем, дефинишите радњу са истим именом у конфигурацији модула. Када се акција позове, акција модула ће бити извршена уместо подразумеване Zabbix акције. Датотеке акција треба да се чувају у датотеци actions. Радње треба да буду наведене у manifest.json.
Контролер
Ток рада контролера акција: 1) Проверите да ли су сви параметри прослеђени у HTTP захтеву важећи:
- Позовите метод контролера checkInput()
- Користите правила валидације дефинисана у CNewValidator.php
- Позовите метод validateInput()
2) Проверите корисничке дозволе.
3) Припремите податке према прослеђеним параметрима: ако checkInput() врати тачно, Zabbix позива метод doAction() контролера.
4) Припремите низ $data за приказ. Користите методе CControllerResponseData и setResponse() да бисте сачували одговор у низу $data.
Пример:
/** - Потврдите улазне параметре.
- @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; } /** - Проверите корисничке дозволе.
- @return bool */ protected function checkPermissions() { return $this->getUserType() >= USER_TYPE_ZABBIX_ADMIN; } /**
- Изврши акцију и генерише објекат одговора.
*/
protected function do Action(): void {
$data = [
'hosts_count' => API::Host()->get([
'countOutput' => true,
'filter' => [
'status' => $this->getInput('status')
]
])
];
$this->setResponse(new CControllerResponseData($data));
}
::: notetip Можете погледати комплетну листу доступних класа контролера у Zabbix -у [source code](https://git.zabbix.com/projects/ZBX/repos/zabbix/browse/ui/app/controllers). :::