Actions负责模块的'业务逻辑'。一个action通常由controller和动作视图组成。
模块可以:
要用自定义行为覆盖默认action行为,需在模块配置中定义同名action。 当该action被调用时,将执行模块action而非默认Zabbix action。
action文件应存放在actions文件夹中。这些actions需要在manifest.json中指定。
动作控制器工作流程:
检查用户权限.
根据传递的参数准备数据: 如果checkInput()返回true, Zabbix将调用控制器的doAction()方法.
为视图准备$data array. 使用CControllerResponseData和setResponse()方法将响应存储在$data array中.
示例:
/**
* 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 source code中查看可用控制器类的完整列表.