north / schema
A simple schema validation package
v1.0.0
2019-02-08 10:00 UTC
Requires
- php: ^7.1
Requires (Dev)
- phpunit/phpunit: ^6.3
- squizlabs/php_codesniffer: ^3.4
This package is auto-updated.
Last update: 2024-11-08 22:34:46 UTC
README
A simple schema validation package.
Installation
composer require north/schema
Examples
Basic validation of an array.
use North\Schema\Schema; $schema = new Schema([ 'name' => 'string', 'age' => 'int', ]); // validate input against schema. // returns bool or throws exception. $schema->valid([ 'name' => 'fredrik', 'age' => 27, ]);
Class validation converts class to array and validates public properties.
use North\Schema\Schema; class User { public $name = ''; public function __construct($o) { foreach ($o as $k => $v) { $this->$k = $v; } } } $schema = new Schema([ 'name' => 'string', ]); // validate input against schema. // returns bool or throws exception. $schema->valid( new User([ 'name' => 'fredrik', ]), );
Types
- array
- bool/boolean
- callable
- closure
- function
- implements (implements:INTERFACE)
- int/integer
- iterable
- float
- string
- object
- resources
- type (type:CLASS)
Types can take arguments, for example for implements and type:
[ 'person' => 'type:Person', 'implements' => 'implements:Stringable', ]
Custom types
$schema->addType('custom_string', function($value) { return is_string($value); });
When using extra arguments for types you just takes in more arguments.
$schema->addType('type', function ($t, string $expected) { return get_class($t) === $expected; });
More examples in the tests/SchemaTest.php
License
MIT © Fredrik Forsmo