Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/proklung/controller.sanitizer.validator

Валидация и санация запроса посредством трэйтов для Symfony-ориентированных приложений
https://github.com/proklung/controller.sanitizer.validator

php7 sanatize symfony validation

Last synced: 23 days ago
JSON representation

Валидация и санация запроса посредством трэйтов для Symfony-ориентированных приложений

Awesome Lists containing this project

README

        

# Валидация и санация запроса посредством трэйтов для Symfony-ориентированных приложений

## Установка

`composer require proklung/controller-sanitizer-validator`

## Нюансы

Очищаются только GET и POST параметры запроса. Валидируются все типы запросов.

## Санитайзер

С помощью [https://github.com/Waavi/Sanitizer](). В контроллере может быть реализован метод `getSanitizingRules`,
описывающий правила санации. Или определено свойство типа массив `sanitizingRules`.

```php
use Prokl\RequestValidatorSanitizer\Sanitizing\SanitizableTrait;

class SimpleController extends AbstractController
{
use SanitizableTrait;

public function action(Request $request) {
// Санитизированный Request.
$requestSanitized = $this->sanitizeRequest(
$request,
$this->getSanitizingRules()
);

}

/**
* Правила санации.
*
* @return array
*/
private function getSanitizingRules(): array
{
return [
'id' => 'trim|escape|strip_tags|cast:string',
'url' => 'trim|escape|strip_tags|cast:string',
'name' => 'trim|escape|strip_tags|cast:string',
'email' => 'trim|escape|strip_tags|cast:string',
'phone' => 'trim|escape|strip_tags|cast:string'
];
}
}
```

## Валидатор

С помощью [https://github.com/illuminate/validation](). В контроллере может быть реализован метод `getRules`,
описывающий правила валидации в стадарте `Illuminate Validation`. Или определено свойство типа массив `rules`.

```php
use Prokl\RequestValidatorSanitizer\Validation\Custom\CustomEmailValidatorNullable;
use Prokl\RequestValidatorSanitizer\Validation\Custom\LaravelPhoneValidator;

class SimpleController extends AbstractController
{
use ValidateableTrait;

public function action(Request $request) {
$this->validateRequest(
$request,
$this->getRules()
);
}
/**
* Правила валидации.
*
* @return string[]
*/
private function getRules() : array
{
return [
'name' => 'required|string',
'id' => 'string|nullable|min:3|max:60',
'url' => 'string|nullable|url',
'email' => ['nullable', new CustomEmailValidatorNullable],
'phone' => ['required', 'string', new LaravelPhoneValidator]
];
}
}
```

## Кастомные валидаторы

- `CustomEmailValidator` - Email, при помощи [https://github.com/egulias/EmailValidator]()
- `CustomEmailValidatorNullable` - Email, может быть пустым
- `CyrillicAlphaValidator` - в параметре только символы и пробелы
- `CyrillicAlphaValidatorNullable` - в параметре только кириллические символы, может быть пустым
- `LaravelPhoneValidator` - телефонный номер, при помощи [https://github.com/giggsey/libphonenumber-for-php]()
- `LaravelPhoneValidatorNullable` - телефонный номер, может быть пустым
- `JsonValidator` - проверка на json