<?php declare(strict_types = 0);
class CControllerActionOperationConditionCheck extends CController {
protected function init(): void {
$this->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 '.ZBX_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);
}
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)]));
}
}