vypsen/sanitizer

sanitizer lib for php

dev-master 2023-01-15 13:26 UTC

This package is auto-updated.

Last update: 2024-09-15 16:56:46 UTC


README

Installation

composer require vypsen/sanitizer dev-master

Filters

Example

use Vypsen\Sanitizer\Sanitizer;

$jsonData = '{"arr": ["1", 2, "3"], "foo": "123", "bar": 123, "baz": "8 (950) 288-56-23", "qwe": {"123": "qwerty", "abc": 321}}';

$filters = [
    "arr" => ['array', 'int'],
    "foo" => 'int',
    "bar" => 'string',
    "baz" => 'ru_number_phone',
    "qwe" => 'structure'
];

$data = Sanitizer::applySanitizers($jsonData, $filters);
var_dump($data);

Result

[
    'arr' => [1, 2, 3],
    'foo' => 123,
    'bar' => '123',
    'baz' => '79502885623',
    'qwe' => ['123' => 'qwerty', 'abc' => 321],
];

Tests

To run tests

./vendor/bin/phpunit ./vendor/vypsen/sanitizer/tests

Custom filter

For a custom filter, you need to create a class that will implements Vypsen\Sanitizer\Interfaces\Filter

example

use Vypsen\Sanitizer\Interfaces\Filter;

class TestClass implements Filter
{
    public function sanitize($value, $option): string
    {
        return ucfirst($value);
    }

    public function validation($value): bool
    {
        return is_string($value);
    }

    public function errorMessageValid(): string
    {
        return 'value must be a string';
    }
}

to apply a filter

require_once('TestClass.php');

$jsonData = '{"arr": ["1", 2, "3"], "foo": "abs"}';

$filters = [
    "arr" => ['array', 'string'],
    "foo" => TestClass::class,
];

$data = Sanitizer::applySanitizers($jsonData, $filters);
var_dump($data);

result

[
    'arr' => ['1', '2', '3'],
    'foo' => 'Abs'
];