setPostContentType(self::POST_CONTENT_TYPE_JSON); $this->disableCsrfValidation(); } protected function checkInput(): bool { $fields = [ 'actionid' => 'db actions.actionid', 'type' => 'required|in '.ZBX_POPUP_CONDITION_TYPE_ACTION_OPERATION, 'source' => 'db actions.eventsource|required|in '. EVENT_SOURCE_TRIGGERS, 'condition_type' => 'db opconditions.conditiontype|in '.CONDITION_TYPE_EVENT_ACKNOWLEDGED, 'operator' => 'db opconditions.conditiontype|in '.implode(',', [ CONDITION_OPERATOR_EQUAL, CONDITION_OPERATOR_NOT_EQUAL ]), 'value' => 'db opconditions.value|not_empty', 'row_index' => 'int32' ]; $ret = $this->validateInput($fields); if (!$ret) { $this->setResponse( new CControllerResponseData(['main_block' => json_encode([ 'error' => [ 'messages' => array_column(get_and_clear_messages(), 'message') ] ])]) ); } return $ret; } protected function checkPermissions(): bool { return $this->checkAccess(CRoleHelper::UI_CONFIGURATION_TRIGGER_ACTIONS); } /** * @throws JsonException */ protected function doAction(): void { $data = [ 'conditiontype' => $this->getInput('condition_type'), 'value' => $this->getInput('value'), 'operator' => $this->getInput('operator') ]; $this->setResponse(new CControllerResponseData(['main_block' => json_encode($data, JSON_THROW_ON_ERROR)])); } }