1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125
|
<?php
/*
** Zabbix
** Copyright (C) 2001-2021 Zabbix SIA
**
** This program is free software; you can redistribute it and/or modify
** it under the terms of the GNU General Public License as published by
** the Free Software Foundation; either version 2 of the License, or
** (at your option) any later version.
**
** This program is distributed in the hope that it will be useful,
** but WITHOUT ANY WARRANTY; without even the implied warranty of
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
** GNU General Public License for more details.
**
** You should have received a copy of the GNU General Public License
** along with this program; if not, write to the Free Software
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
**/
require_once dirname(__FILE__).'/../../include/regexp.inc.php';
class CControllerRegExEdit extends CController {
protected function init() {
$this->disableSIDValidation();
}
protected function checkInput() {
$fields = [
'name' => 'db regexps.name',
'test_string' => 'db regexps.test_string',
'regexid' => 'db regexps.regexpid',
'expressions' => 'array',
'form_refresh' => ''
];
$ret = $this->validateInput($fields);
if (!$ret) {
$this->setResponse(new CControllerResponseFatal());
}
return $ret;
}
protected function checkPermissions() {
if ($this->getUserType() != USER_TYPE_SUPER_ADMIN) {
return false;
}
if ($this->hasInput('regexid')) {
$db_regex = DBfetch(DBSelect('SELECT * FROM regexps'.
' WHERE '.dbConditionInt('regexpid', (array) $this->getInput('regexid'))
));
if (!$db_regex) {
return false;
}
$this->regex = [
'name' => $this->getInput('name', $db_regex['name']),
'test_string' => $this->getInput('test_string', $db_regex['test_string']),
'regexid' => $this->getInput('regexid', $db_regex['regexpid'])
];
}
else {
$this->regex = [
'name' => $this->getInput('name', ''),
'test_string' => $this->getInput('test_string', ''),
'regexid' => 0
];
}
return true;
}
protected function doAction() {
$data = [
'regexid' => $this->regex['regexid'],
'expressions' => [],
'name' => $this->regex['name'],
'test_string' => $this->regex['test_string'],
'form_refresh' => $this->getInput('form_refresh', 0)
];
if ($data['form_refresh'] == 0) {
if ($this->regex['regexid'] == 0) {
$data['expressions'][] = [
'expression' => '',
'expression_type' => EXPRESSION_TYPE_INCLUDED,
'exp_delimiter' => ',',
'case_sensitive' => 0
];
}
else {
$data['expressions'] = DBfetchArray(DBselect(
'SELECT e.expressionid,e.expression,e.expression_type,e.exp_delimiter,e.case_sensitive'.
' FROM expressions e'.
' WHERE '.dbConditionInt('e.regexpid', (array) $this->regex['regexid']).
' ORDER BY e.expression_type'
));
}
}
else {
$data['expressions'] = $this->getInput('expressions', [[
'expression' => '',
'expression_type' => EXPRESSION_TYPE_INCLUDED,
'exp_delimiter' => ',',
'case_sensitive' => 0
]]);
foreach ($data['expressions'] as &$expression) {
if (!array_key_exists('case_sensitive', $expression)) {
$expression['case_sensitive'] = 0;
}
}
unset($expression);
}
$response = new CControllerResponseData($data);
$response->setTitle(_('Configuration of regular expressions'));
$this->setResponse($response);
}
}
|