Description
For everyone who uses MongoDB or other NoSQL solution and cares about what client sends to his/her database and looking for validation library written in PHP. Volan validates array against given shema and provides you with full information about invalid nodes. Can be used with logging so you can see the whole validation process.
Volan alternatives and similar libraries
Based on the "Filtering and Validation" category.
Alternatively, view Volan alternatives based on common mentions on social networks and blogs.
-
ISO-codes
PHP library - Validators for standards from ISO, International Finance, Public Administrations, GS1, Manufacturing Industry, Phone numbers & Zipcodes for many countries -
PHP validate
Lightweight and feature-rich PHP validation and filtering library. Support scene grouping, pre-filtering, array checking, custom validators, custom messages. 轻量且功能丰富的PHP验证、过滤库。支持场景分组,前置过滤,数组检查,自定义验证器,自定义消息。 -
Linio Input
Abstracts HTTP request input handling, providing an easy interface for data hydration and validation -
Cake Validation
[READ-ONLY] Validation library from CakePHP. This repo is a split of the main code that can be found in https://github.com/cakephp/cakephp -
EU VAT Number Validator
:moneybag: A simple and clean PHP library that validates EU VAT registration numbers against the central ec.europa.eu database (using the official europa API) :eu: -
DMS Filter
Library that offers Input Filtering based on Annotations for use with Objects. Check out 2.dev for 2.0 pre-release. -
CSV Blueprint
Strict and automated line-by-line CSV validation tool based on customizable Yaml schemas -
Distributed locks with Redis and ReactPHP
:lock: Asynchronous distributed locks with Redis and ReactPHP
InfluxDB - Purpose built for real-time analytics at any scale.
* Code Quality Rankings and insights are calculated and provided by Lumnify.
They vary from L1 to L5 with "L5" being the highest.
Do you think we are missing an alternative of Volan or a related project?
Popular Comparisons
README
Light PHP validation library
For everyone who uses MongoDB or other NoSQL solution and cares about what client sends to his/her database and looking for validation library written in PHP.
Volan
validates array against given shema and provides you with full information about invalid nodes. Can be used with logging so you can see the whole validation process.
Installation
via Composer:
composer require serkin/volan dev-master
Usage
All you have to do is to specify _type
field for each node. _type
is a reference to a validation class
include 'vendor/autoload.php';
$schema = [
'root' => [ // Schema must begins with 'root'
'title' => [
'_type' => 'required_string'
],
'price' => [
'_type' => 'number'
],
'author' => [
'_type' => 'string'
],
'instock' => [
'_type' => 'required_boolean'
],
'info' => [
'_type' => 'array',
'isbn' => [
'_type' => 'string'
],
'pages' => [
'_type' => 'number'
]
],
'comments' => [
'_type' => 'nested_array',
'user_id' => [
'_type' => 'required_number'
],
'comment' => [
'_type' => 'required_string'
]
]
]
];
$book = [
'title' => 'The Idiot', // Cannot be omitted
'instock' => true, // Cannot be omitted and has to be bool type
'info' => ['isbn' => '978-0451531520'],
// 'price' can be omitted but if present has to be numeric type
'comments' => [ // Nested array check nested elements
[
'user_id' => 1,
'comment' => 'Good book',
// 'extra_field' => 'bad field'
// By default if key not present in schema validation stops and returns false
],
[
'user_id' => 2,
'comment' => 'I like it'
]
]
];
$validator = new \Volan\Volan($schema);
$result = $validator->validate($book);
// if $result->isValid() === false you can get full information about invalid node
var_dump($result->getErrorInfo());
Predefined validators
Strings
string
: stringrequired_string
: string that has to be present
Arrays
array
: arrayrequired_array
: array that has to be presentnested_array
: array with nested arraysrequired_nested_array
: array with nested arrays has to be present
Bool
boolean
: booleanrequired_boolean
: boolean that has to be present
Numbers
number
: int or floatrequired_number
: int or float that has to be present
Custom validators
If you need extra validators you can create them extending \Volan\Validator\AbstractValidator
class
- Create folder
src/Volan/Validator
in your library - Add your custom validator
src/Volan/Validator/mongoid_validator.php
. Example formongoid
validator:php namespace Volan\Validator; class MongoidValidator extends AbstractValidator { public function isValid($nodeData) { return ($nodeData instanceof \MongoId); } }
- Add autoload to composer.json
json "autoload": { "psr-4": { "Volan\\Validator\\": "src/Volan/Validator/" } }
Usage with other libraries
If you want to use other validation libraries with Volan
it is easy. Let's take a look how it works with Respect validation engine
namespace Volan\Validator;
use Respect\Validation\Validator as v;
class IntBetween10And20Validator extends AbstractValidator
{
public function isValid($nodeData)
{
return v::int()->between(10, 20)->validate($nodeData);
}
}
Tips
Allow extra keys in data
If you want allow extra keys in array you can define it in constructor
$validator = new \Volan\Volan($schema, $strictMode = false);
Allow required
fields be omitted
In mongoDB when you update just several fields in collection you cannot pass validation cause required fields may be missing. You can tell validator consider all required validation as optional.
$validator = new \Volan\Volan($schema);
$validator->setRequiredMode(false);
$result = $validator->validate($book);
Logging
If you want see validation process set logger
$validator = new \Volan\Volan($schema);
$result = $validator->validate($book);
$result->getLog();
PSR compatible class names
You can use PSR compatible names for validation classes.
Previous example with mongoid
validation class can be rewritten like:
namespace Volan\Validator;
class MongoidValidator extends AbstractValidator
{
public function isValid($nodeData)
{
return ($nodeData instanceof \MongoId);
}
}
Here we changed mongoid_validator
to MongoidValidator
.
Example with int_between_10_and_20_validator
be rewritten to IntBetween10And20Validator
Relational structure
Let's imagine we have field in our book data
...
'categories' => [new \MongoId('111111111111111111111111'),new \MongoId('111111111111111111111112')]
...
and we want ensure that all elements not only instances of MongoId
but actually present in our database.
It is easy. Our validator will be look like:
namespace Volan\Validator;
class ArrayOfMongoids extends AbstractValidator
{
public function isValid($nodeData)
{
foreach($nodeData as $id) {
if($id !instanceof \MongoId) || !$this->presentInCategoryCollection($id))
return false;
}
}
return true;
}
public function presentInCategoryCollection($id)
{
// Getting connection and so on
$collection = $db->selectCollection('categories');
return (bool)$collection->findOne(['_id' => $id]);
}
}
now in schema we add
...
'categories' => ['_type' => 'array_of_mongoids']
...
Dependencies
- PHP: >= 5.4
Contribution
Please see [CONTRIBUTING](CONTRIBUTING.md) for details.
Licence
The MIT License (MIT). Please see [License File](LICENSE.md) for more information.
Tests
phpunit
Or with Docker
docker run --rm -v "$PWD":/var/src/ serkin/php7 vendor/bin/phpunit --debug
Code style
docker run --rm -v "$PWD":/var/src/ serkin/php7 vendor/bin/php-cs-fixer fix src
*Note that all licence references and agreements mentioned in the Volan README section above
are relevant to that project's source code only.