ModuleValidate_EntityValidatorUrl
Package | engine.modules.validate |
---|---|
Inheritance | class ModuleValidate_EntityValidatorUrl » ModuleValidate_EntityValidator » Entity » LsObject |
Since | 1.0 |
Source Code | /engine/modules/validate/entity/ValidatorUrl.entity.class.php |
Валидатор URL адресов
Public Properties
Property | Type | Description | Defined By |
---|---|---|---|
allowEmpty | bool | Допускать или нет пустое значение | ModuleValidate_EntityValidatorUrl |
bSkipOnError | bool | Пропускать или нет ошибку | ModuleValidate_EntityValidator |
defaultScheme | null|string | Дефолтная схема, которая добавляется к URL при ее отсутствии. | ModuleValidate_EntityValidatorUrl |
fields | array | Список полей сущности для валидации | ModuleValidate_EntityValidator |
label | null|string | Название поля сущности для отображения в тексте ошибки | ModuleValidate_EntityValidator |
msg | null|string | Текст ошибки валидации, переопределяет текст валидатора | ModuleValidate_EntityValidator |
on | null|array | Список сценариев в которых участвует валидатор | ModuleValidate_EntityValidator |
pattern | string | Патерн проверки URL с учетом схемы | ModuleValidate_EntityValidatorUrl |
validSchemes | array | Список допустимых схем | ModuleValidate_EntityValidatorUrl |
Protected Properties
Property | Type | Description | Defined By |
---|---|---|---|
_aData | array | Данные сущности, на этот массив мапятся методы set* и get* | Entity |
aValidateErrors | array | Список ошибок валидации в разрезе полей, например | Entity |
aValidateRules | array | Список правил валидации полей | Entity |
oEntityCurrent | null|Entity | Объект текущей сущности, которая проходит валидацию | ModuleValidate_EntityValidator |
sFieldCurrent | null|string | Объект текущей сущности, которая проходит валидацию | ModuleValidate_EntityValidator |
sPrimaryKey | null|string | Имя поля с первичным ключом в БД | Entity |
sValidateScenario | string | Сценарий валиадции полей | Entity |
Public Methods
Method | Description | Defined By |
---|---|---|
Init() | Метод инициализации сущности, вызывается при её создании | Entity |
_Validate() | Выполняет валидацию данных сущности | Entity |
__call() | Ставим хук на вызов неизвестного метода и считаем что хотели вызвать метод какого либо модуля | Entity |
__construct() | Если передать в конструктор ассоциативный массив свойств и их значений, то они автоматом загрузятся в сущность | Entity |
_addValidateError() | Добавляет для поля ошибку в список ошибок | Entity |
_clearValidateErrors() | Очищает список всех ошибок или для конкретного поля | Entity |
_createValidators() | Создает и возвращает список валидаторов для сущности | Entity |
_getData() | Получает массив данных сущности | Entity |
_getDataArray() | Рекурсивное преобразование объекта и вложенных объектов в массив | Entity |
_getDataOne() | Возвращает данные по конкретному полю | Entity |
_getPrimaryKey() | Получение первичного ключа сущности (ключ, а не значение!) | Entity |
_getPrimaryKeyValue() | Возвращает значение первичного ключа/поля | Entity |
_getValidateError() | Возвращает первую ошибку для поля или среди всех полей | Entity |
_getValidateErrors() | Возвращает список ошибок для всех полей или одного поля | Entity |
_getValidateScenario() | Возвращает текущий сценарий валидации | Entity |
_getValidators() | Возвращает список валидаторов с учетом текущего сценария | Entity |
_hasValidateErrors() | Проверяет есть ли ошибки валидации | Entity |
_setData() | Устанавливает данные сущности | Entity |
_setValidateScenario() | Устанавливает сценарий валидации | Entity |
applyTo() | Применять или нет сценарий к текущему валидатору | ModuleValidate_EntityValidator |
validate() | Запуск валидации | ModuleValidate_EntityValidatorUrl |
validateEntity() | Запускает валидацию полей сущности | ModuleValidate_EntityValidator |
validateEntityField() | Запускает валидацию конкретного поля сущности | ModuleValidate_EntityValidator |
validateValue() | Проверка URL на корректность | ModuleValidate_EntityValidatorUrl |
Protected Methods
Method | Description | Defined By |
---|---|---|
getMessage() | Возвращает сообщение, используется для получения сообщения об ошибке валидатора | ModuleValidate_EntityValidator |
getValueOfCurrentEntity() | Возвращает значение поля текущей сущности | ModuleValidate_EntityValidator |
isEmpty() | Проверяет данные на пустое значение | ModuleValidate_EntityValidator |
setValueOfCurrentEntity() | Устанавливает значение поля текущей сущности | ModuleValidate_EntityValidator |
Property Details
allowEmpty
property
public bool $allowEmpty;
Допускать или нет пустое значение
defaultScheme
property
public null|string $defaultScheme;
Дефолтная схема, которая добавляется к URL при ее отсутствии. Если null, то URL должен уже содержать схему
pattern
property
public string $pattern;
Патерн проверки URL с учетом схемы
validSchemes
property
public array $validSchemes;
Список допустимых схем
Method Details
validate()
method
public bool|string validate(mixed $sValue)
| ||
$sValue | mixed | Данные для валидации |
{return} | bool|string |
Source Code: /engine/modules/validate/entity/ValidatorUrl.entity.class.php#66 (show)
public function validate($sValue) {
if (is_array($sValue)) {
return $this->getMessage($this->Lang_Get('validate_url_not_valid',null,false),'msg');
}
if($this->allowEmpty && $this->isEmpty($sValue)) {
return true;
}
if(($sValue=$this->validateValue($sValue))!==false) {
/**
* Если проверка от сущности, то возвращаем обновленное значение
*/
if ($this->oEntityCurrent) {
$this->setValueOfCurrentEntity($this->sFieldCurrent,$sValue);
}
} else {
return $this->getMessage($this->Lang_Get('validate_url_not_valid',null,false),'msg');
}
return true;
}
Запуск валидации
validateValue()
method
public bool validateValue(string $sValue)
| ||
$sValue | string | Данные для валидации |
{return} | bool |
Source Code: /engine/modules/validate/entity/ValidatorUrl.entity.class.php#93 (show)
public function validateValue($sValue) {
if(is_string($sValue) && strlen($sValue)<2000) {
if($this->defaultScheme!==null && strpos($sValue,'://')===false) {
$sValue=$this->defaultScheme.'://'.$sValue;
}
if(strpos($this->pattern,'{schemes}')!==false) {
$sPattern=str_replace('{schemes}','('.implode('|',$this->validSchemes).')',$this->pattern);
} else {
$sPattern=$this->pattern;
}
if(preg_match($sPattern,$sValue)) {
return $sValue;
}
}
return false;
}
Проверка URL на корректность