'fatal|required|db regexps.regexpid', 'name' => 'required|string|not_empty|db regexps.name', 'test_string' => 'string|db regexps.test_string', 'expressions' => 'required|array', 'form_refresh' => 'int32' ]; $ret = $this->validateInput($fields); if (!$ret) { switch ($this->getValidationError()) { case self::VALIDATION_ERROR: $response = new CControllerResponseRedirect( (new CUrl('zabbix.php')) ->setArgument('action', 'regex.edit') ->setArgument('regexid', $this->getInput('regexid')) ); $response->setFormData($this->getInputAll()); CMessageHelper::setErrorTitle(_('Cannot update regular expression')); $this->setResponse($response); break; case self::VALIDATION_FATAL_ERROR: $this->setResponse(new CControllerResponseFatal()); break; } } return $ret; } protected function checkPermissions() { return $this->checkAccess(CRoleHelper::UI_ADMINISTRATION_GENERAL); } protected function doAction() { $expressions = $this->getInput('expressions'); foreach ($expressions as &$expression) { if (!array_key_exists('case_sensitive', $expression)) { $expression['case_sensitive'] = 0; } } unset($expression); $result = API::Regexp()->update([ 'regexpid' => $this->getInput('regexid'), 'name' => $this->getInput('name'), 'test_string' => $this->getInput('test_string', ''), 'expressions' => $expressions ]); if ($result) { $response = new CControllerResponseRedirect((new CUrl('zabbix.php'))->setArgument('action', 'regex.list')); CMessageHelper::setSuccessTitle(_('Regular expression updated')); } else { $response = new CControllerResponseRedirect( (new CUrl('zabbix.php')) ->setArgument('action', 'regex.edit') ->setArgument('regexid', $this->getInput('regexid')) ); $response->setFormData($this->getInputAll()); CMessageHelper::setErrorTitle(_('Cannot update regular expression')); } $this->setResponse($response); } }