Table of Contents

动作

Actions负责模块的'业务逻辑'。一个action通常由controller动作视图组成。

模块可以:

  • 调用Zabbix前端已定义的actions
  • 用自定义actions覆盖默认actions
  • 定义全新的actions

要用自定义行为覆盖默认action行为,需在模块配置中定义同名action。 当该action被调用时,将执行模块action而非默认Zabbix action。

action文件应存放在actions文件夹中。这些actions需要在manifest.json中指定。

控制器

动作控制器工作流程:

  1. 检查HTTP请求中传递的所有参数是否有效:
  • 调用控制器的checkInput()方法
  • 使用CNewValidator.php中定义的验证规则
  • 调用validateInput()方法
  1. 检查用户权限.

  2. 根据传递的参数准备数据: 如果checkInput()返回true, Zabbix将调用控制器的doAction()方法.

  3. 为视图准备$data array. 使用CControllerResponseDatasetResponse()方法将响应存储在$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中查看可用控制器类的完整列表.