You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
116 lines
2.3 KiB
116 lines
2.3 KiB
1 year ago
|
<?php
|
||
|
/*
|
||
|
** Zabbix
|
||
|
** Copyright (C) 2001-2023 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.
|
||
|
**/
|
||
|
|
||
|
|
||
|
class CStringValidator extends CValidator {
|
||
|
|
||
|
/**
|
||
|
* If set to false, the string cannot be empty.
|
||
|
*
|
||
|
* @var bool
|
||
|
*/
|
||
|
public $empty = false;
|
||
|
|
||
|
/**
|
||
|
* Maximum string length.
|
||
|
*
|
||
|
* @var int
|
||
|
*/
|
||
|
public $maxLength;
|
||
|
|
||
|
/**
|
||
|
* Regex to match the string against.
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
public $regex;
|
||
|
|
||
|
/**
|
||
|
* Error message if the string is empty.
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
public $messageEmpty;
|
||
|
|
||
|
/**
|
||
|
* Error message if the string is too long.
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
public $messageMaxLength;
|
||
|
|
||
|
/**
|
||
|
* Error message if the string doesn't match the regex.
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
public $messageRegex;
|
||
|
|
||
|
/**
|
||
|
* Error message if not a string, integer or decimal is provided
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
public $messageInvalid;
|
||
|
|
||
|
/**
|
||
|
* Checks if the given string is:
|
||
|
* - empty
|
||
|
* - not too long
|
||
|
* - matches a certain regex
|
||
|
*
|
||
|
* @param string $value
|
||
|
*
|
||
|
* @return bool
|
||
|
*/
|
||
|
public function validate($value) {
|
||
|
if (!(is_string($value) || is_numeric($value))) {
|
||
|
$this->error($this->messageInvalid, $this->stringify($value));
|
||
|
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
if (zbx_empty($value)) {
|
||
|
if ($this->empty) {
|
||
|
return true;
|
||
|
}
|
||
|
else {
|
||
|
$this->error($this->messageEmpty);
|
||
|
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if ($this->maxLength && mb_strlen($value) > $this->maxLength) {
|
||
|
$this->error($this->messageMaxLength, $value, $this->maxLength);
|
||
|
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
if ($this->regex && !zbx_empty($value) && !preg_match($this->regex, $value)) {
|
||
|
$this->error($this->messageRegex, $value);
|
||
|
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
return true;
|
||
|
}
|
||
|
}
|