231 lines
6.5 KiB
PHP
231 lines
6.5 KiB
PHP
<?php
|
|
|
|
/**
|
|
* Validate variables
|
|
*
|
|
* Standard: PSR-2
|
|
*
|
|
* @link http://www.php-fig.org/psr/psr-2
|
|
*
|
|
* @package Duplicator
|
|
* @subpackage classes/utilities
|
|
* @copyright (c) 2017, Snapcreek LLC
|
|
*/
|
|
|
|
// Exit if accessed directly
|
|
defined("ABSPATH") or die("");
|
|
class DUP_PRO_Validator
|
|
{
|
|
/** @var array<string,string> $patterns */
|
|
private static $patterns = array(
|
|
'fdir' => '/^([a-zA-Z]:[\\\\\/]|\/|\\\\\\\\|\/\/)[^<>\0]+$/',
|
|
'fdirwc' => '/^[\s\t]*?(#.*|[a-zA-Z]:[\\\\\/]|\/|\\\\\\\\|\/\/)[^<>\0]*$/',
|
|
'ffile' => '/^([a-zA-Z]:[\\\\\/]|\/|\\\\\\\\|\/\/)[^<>\0]+$/',
|
|
'ffilewc' => '/^[\s\t]*?(#.*|[a-zA-Z]:[\\\\\/]|\/|\\\\\\\\|\/\/)[^<>\0]*$/',
|
|
'fext' => '/^\.?[^\\\\\/*:<>\0?"|\s\.]+$/',
|
|
'email' => '/^[a-zA-Z0-9.!#$%&\'*+\/=?^_\`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*$/',
|
|
'empty' => '/^$/',
|
|
'nempty' => '/^.+$/',
|
|
);
|
|
const FILTER_VALIDATE_IS_EMPTY = 'empty';
|
|
const FILTER_VALIDATE_NOT_EMPTY = 'nempty';
|
|
const FILTER_VALIDATE_FILE = 'ffile';
|
|
const FILTER_VALIDATE_FILE_WITH_COMMENT = 'ffilewc';
|
|
const FILTER_VALIDATE_FOLDER = 'fdir';
|
|
const FILTER_VALIDATE_FOLDER_WITH_COMMENT = 'fdirwc';
|
|
const FILTER_VALIDATE_FILE_EXT = 'fext';
|
|
const FILTER_VALIDATE_EMAIL = 'email';
|
|
|
|
/** @var array<array{key:string,msg:string}> */
|
|
private $errors = array();
|
|
|
|
/**
|
|
* Class contructor
|
|
*/
|
|
public function __construct()
|
|
{
|
|
$this->errors = array();
|
|
}
|
|
|
|
/**
|
|
* @return void
|
|
*/
|
|
public function reset()
|
|
{
|
|
$this->errors = array();
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function isSuccess()
|
|
{
|
|
return empty($this->errors);
|
|
}
|
|
|
|
/**
|
|
* Return errors
|
|
*
|
|
* @return array<array{key:string,msg:string}>
|
|
*/
|
|
public function getErrors()
|
|
{
|
|
return $this->errors;
|
|
}
|
|
|
|
/**
|
|
* Return errors messages
|
|
*
|
|
* @return string[]
|
|
*/
|
|
public function getErrorsMsg()
|
|
{
|
|
$result = array();
|
|
foreach ($this->errors as $err) {
|
|
$result[] = $err['msg'];
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param string $format printf format message where %s is the variable content default "%s\n"
|
|
* @param bool $echo if false return string
|
|
*
|
|
* @return void|string
|
|
*/
|
|
public function getErrorsFormat($format = "%s\n", $echo = true)
|
|
{
|
|
$msgs = $this->getErrorsMsg();
|
|
ob_start();
|
|
foreach ($msgs as $msg) {
|
|
printf($format, esc_html($msg)); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
|
|
}
|
|
|
|
if ($echo) {
|
|
ob_end_flush();
|
|
} else {
|
|
return ob_get_clean();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @param string $key field key
|
|
* @param string $msg error message
|
|
*
|
|
* @return void
|
|
*/
|
|
public function addError($key, $msg)
|
|
{
|
|
$this->errors[] = array(
|
|
'key' => $key,
|
|
'msg' => $msg,
|
|
);
|
|
}
|
|
|
|
/**
|
|
* filter_var function wrapper see http://php.net/manual/en/function.filter-var.php
|
|
*
|
|
* additional options
|
|
* valkey => key of field
|
|
* errmsg => error message; % s will be replaced with the contents of the variable es. "<b>%s</b> isn't a valid field"
|
|
* acc_vals => array of accepted values that skip validation
|
|
*
|
|
* @param mixed $variable variable to validate
|
|
* @param int $filter filter name
|
|
* @param array<string,mixed> $options additional options for filter_var
|
|
*
|
|
* @return mixed
|
|
*/
|
|
public function filter_var($variable, $filter = FILTER_DEFAULT, $options = array())
|
|
{
|
|
$success = true;
|
|
$result = null;
|
|
if (isset($options['acc_vals']) && in_array($variable, $options['acc_vals'])) {
|
|
return $variable;
|
|
}
|
|
|
|
if ($filter === FILTER_VALIDATE_BOOLEAN) {
|
|
$options['flags'] = FILTER_NULL_ON_FAILURE;
|
|
/** @var null|bool */
|
|
$result = is_bool($variable) ? $variable : filter_var($variable, $filter, $options);
|
|
if (is_null($result)) {
|
|
$success = false;
|
|
}
|
|
} else {
|
|
$result = filter_var($variable, $filter, $options);
|
|
if ($result === false) {
|
|
$success = false;
|
|
}
|
|
}
|
|
|
|
if (!$success) {
|
|
$key = isset($options['valkey']) ? $options['valkey'] : '';
|
|
if (isset($options['errmsg'])) {
|
|
$msg = sprintf($options['errmsg'], esc_html($variable));
|
|
} else {
|
|
$msg = sprintf('%1$s isn\'t a valid value', $variable);
|
|
}
|
|
|
|
$this->addError($key, $msg);
|
|
}
|
|
|
|
return $result;
|
|
}
|
|
|
|
/**
|
|
* Validation of predefined regular expressions
|
|
*
|
|
* @param mixed $variable variable to validate
|
|
* @param string $filter filter name
|
|
* @param array<string, mixed> $options additional options for filter_var
|
|
*
|
|
* @return mixed
|
|
*/
|
|
public function filter_custom($variable, $filter, $options = array())
|
|
{
|
|
if (!isset(self::$patterns[$filter])) {
|
|
throw new Exception('Filter not valid');
|
|
}
|
|
|
|
$options = array_merge($options, array(
|
|
'options' => array(
|
|
'regexp' => self::$patterns[$filter],
|
|
),
|
|
));
|
|
//$options['regexp'] = self::$patterns[$filter];
|
|
|
|
return $this->filter_var($variable, FILTER_VALIDATE_REGEXP, $options);
|
|
}
|
|
|
|
/**
|
|
* it explodes a string with a delimiter and validates every element of the array
|
|
*
|
|
* @param string $variable string to explode
|
|
* @param string $delimiter delimiter
|
|
* @param string $filter filter name
|
|
* @param array<string, mixed> $options additional options for filter_var
|
|
*
|
|
* @return mixed[]
|
|
*/
|
|
public function explode_filter_custom($variable, $delimiter, $filter, $options = array())
|
|
{
|
|
if (empty($variable)) {
|
|
return array();
|
|
}
|
|
|
|
if (strlen($delimiter) == 0) {
|
|
throw new Exception('Delimiter can\'t be empty');
|
|
}
|
|
|
|
$vals = explode($delimiter, trim($variable, $delimiter));
|
|
$res = array();
|
|
foreach ($vals as $val) {
|
|
$res[] = $this->filter_custom($val, $filter, $options);
|
|
}
|
|
|
|
return $res;
|
|
}
|
|
}
|