<?php declare(strict_types = 0);
require_once __DIR__.'/../../include/actions.inc.php';
class CControllerPopupActionConditionEdit extends CController {
protected function init() {
$this->disableCsrfValidation();
protected function checkInput(): bool {
'actionid' => 'db actions.actionid',
'type' => 'required|in '.ZBX_POPUP_CONDITION_TYPE_ACTION,
'source' => 'required|in '.implode(',', [
EVENT_SOURCE_TRIGGERS, EVENT_SOURCE_DISCOVERY, EVENT_SOURCE_AUTOREGISTRATION,
EVENT_SOURCE_INTERNAL, EVENT_SOURCE_SERVICE
'condition_type' => 'db conditions.conditiontype|in '.implode(',', array_keys(condition_type2str())),
'operator' => 'db conditions.operator|in '.implode(',', array_keys(condition_operator2str())),
'trigger_context' => 'in '.implode(',', ['host', 'template']),
'row_index' => 'required|int32'
$ret = $this->validateInput($fields);
$this->setResponse(new CControllerResponseFatal());
protected function checkPermissions(): bool {
switch ($this->getInput('source')) {
case EVENT_SOURCE_TRIGGERS:
return $this->checkAccess(CRoleHelper::UI_CONFIGURATION_TRIGGER_ACTIONS);
case EVENT_SOURCE_DISCOVERY:
return $this->checkAccess(CRoleHelper::UI_CONFIGURATION_DISCOVERY_ACTIONS);
case EVENT_SOURCE_AUTOREGISTRATION:
return $this->checkAccess(CRoleHelper::UI_CONFIGURATION_AUTOREGISTRATION_ACTIONS);
case EVENT_SOURCE_INTERNAL:
return $this->checkAccess(CRoleHelper::UI_CONFIGURATION_INTERNAL_ACTIONS);
case EVENT_SOURCE_SERVICE:
return $this->checkAccess(CRoleHelper::UI_CONFIGURATION_SERVICE_ACTIONS);