benjaminmal / parity-checker
Parity checker
Installs: 106
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 0
Open Issues: 2
pkg:composer/benjaminmal/parity-checker
Requires
- php: ^8.0
- phpdocumentor/reflection-docblock: ^5.3
- symfony/options-resolver: ^5.4 || ^6.0
- symfony/property-access: ^5.4 || ^6.0
- symfony/property-info: ^5.4 || ^6.0
- webmozart/assert: ^1.10
Requires (Dev)
- benjaminmal/coding-standard: ^1.0
- php-parallel-lint/php-var-dump-check: ^0.5.0
- phpstan/extension-installer: ^1.1
- phpstan/phpstan: ^1.1
- phpstan/phpstan-phpunit: ^1.0
- phpstan/phpstan-symfony: ^1.0
- phpstan/phpstan-webmozart-assert: ^1.0
- phpunit/phpunit: ^9.5
- symfony/var-dumper: ^5.4 || ^6.0
This package is auto-updated.
Last update: 2025-10-15 15:30:47 UTC
README
A PHP parity checker. Useful when you want to check if many objects are having the same datas. It has many options so you can configure the behavior you need, especially speaking of object recursion.
Installation
$ composer require benjaminmal/parity-checker
Getting started
Create the Parity checker using the factory:
$parityChecker = ParityChecker::create();
Or using your implementations using Symfony PropertyAccess & PropertyInfo components
/** @var PropertyAccessorInterface $propertyAccessor */ /** @var PropertyInfoExtractorInterface $propertyInfoExtractor */ $parityChecker = new ParityChecker($propertyAccessor, $propertyInfoExtractor);
Check your objects
$errors = $parityChecker->checkParity([$object1, $object2]); if (! $errors->hasErrors()) { // You're all set ! }
Usages
Options
$errors = $parityChecker->checkParity([$object1, $object2], [ // Do not perform check on these types 'ignore_types' => ['object', 'resource', \DateTimeInterface::class, '$objectProperty1'], // Perform check only on these types 'only_types' => ['string', 'float'], // Perform a loose check ('==' instead of '===') on theses types 'loose_types' => 'array', // Set the recursion limit for objects 'deep_object_limit' => 0, // Set DateTime format to check 'datetime_check_format' => false, // Set DateInterval format to check 'date_interval_format' => '%R %Y %M %D %H %I %S %F', // Set DateTime zone mapping to name 'datetime_zone' => true, // Set a data mapper closure 'data_mapper' => [ 'my-mapper' => new ParityCheckerCallback( 'array', fn ($value, string $property, array $options): mixed => $value['something'], ), ], // Custom checkers. You can set you own checker which replace other. 'custom_checkers' => [ 'my-checker' => new ParityCheckerCallback( ['$property'], fn ($value1, $value2, string $property, array $options): bool => true, ), ], ]);
| Option | Description | Accepted types | Default values | 
|---|---|---|---|
| ignore_types | Do not perform check on these types | string[]|string. Can be any types. Checked by theis_functions, classes/interfaces names or object properties (must be prefixed by$) | object | 
| only_types | Perform checks only on these types. ignore_typesis evaluated before, so if you set the same type in bothignore_typesandonly_types, the type will be ignored. | string[]|string. Can be any types. Checked by theis_functions, classes/interfaces names or object properties (must be prefixed by$) | none | 
| loose_types | On which type to perform loose check ( ==) instead of (===) | string[]|string. Can be any types. Checked by theis_functions, classes/interfaces names or object properties (must be prefixed by$) | none | 
| deep_object_limit | The object recursion limit | int | 0 | 
| data_mapper | Replace value before checking by your closure | ParityCheckCallbackInterface[] | datetime_check_format,date_interval_format,datetime_zonemappers | 
| datetime_check_format | The format that DateTimemust be check with | bool|string. Has to be a valid DateTime format. If it'strue,Y-m-d H:i:sis used. | true | 
| date_interval_format | The format that DateIntervalmust be check with | bool|string. Has to be a valid DateInterval format. If it's true,%R %Y %M %D %H %I %S %Fis used. | true | 
| datetime_zone | Map DateTimeZoneobjects to its timezone name in order to check it. E.gEurope/Paris | bool | true | 
| custom_checkers | You can set you own checker which replace other | ParityCheckCallbackInterface[] | none | 
Errors
$errors = $parityChecker->checkParity([$object1, $object2], $options); if ($errors->hasError()) { foreach ($errors as $error) { $property = $error->getProperty(); $object1 = $error->getObject1(); $object2 = $error->getObject2(); $errorValue1 = $error->getObject1Value(); $errorValue2 = $error->getObject2Value(); } }