cuyz / valinor
Library that helps to map any input into a strongly-typed value object structure.
                                    Fund package maintenance!
                                                                            
                                                                                                                                        romm
                                                                                    
                                                                
Installs: 5 105 474
Dependents: 96
Suggesters: 0
Security: 2
Stars: 1 437
Watchers: 14
Forks: 80
Open Issues: 26
pkg:composer/cuyz/valinor
Requires
- php: ~8.1.0 || ~8.2.0 || ~8.3.0 || ~8.4.0 || ~8.5.0
- composer-runtime-api: ^2.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.4
- infection/infection: ^0.31
- marcocesarato/php-conventional-changelog: ^1.12
- mikey179/vfsstream: ^1.6.10
- phpbench/phpbench: ^1.3
- phpstan/phpstan: ^2.0
- phpstan/phpstan-phpunit: ^2.0
- phpstan/phpstan-strict-rules: ^2.0
- phpunit/phpunit: ^10.5
- rector/rector: ^2.0
- vimeo/psalm: ^6.0
Conflicts
- phpstan/phpstan: <1.0 || >= 3.0
- vimeo/psalm: <5.0 || >=7.0
- dev-master
- 2.3.1
- 2.3.0
- 2.2.2
- 2.2.1
- 2.2.0
- 2.1.2
- 2.1.1
- 2.1.0
- 2.0.0
- 1.x-dev
- 1.17.0
- 1.16.1
- 1.16.0
- 1.15.0
- 1.14.4
- 1.14.3
- 1.14.2
- 1.14.1
- 1.14.0
- 1.13.0
- 1.12.0
- 1.11.0
- 1.10.0
- 1.9.0
- 1.8.2
- 1.8.1
- 1.8.0
- 1.7.0
- 1.6.1
- 1.6.0
- 1.5.0
- 1.4.0
- 1.3.1
- 1.3.0
- 1.2.0
- 1.1.0
- 1.0.0
- 0.x-dev
- 0.17.1
- 0.17.0
- 0.16.0
- 0.15.0
- 0.14.0
- 0.13.0
- 0.12.0
- 0.11.0
- 0.10.0
- 0.9.0
- 0.8.0
- 0.7.0
- 0.6.0
- 0.5.0
- 0.4.0
- 0.3.0
- 0.2.0
- 0.1.1
- 0.1.0
- dev-feat/http-request-mapping-with-attributes
- dev-feat/http-request-mapping
This package is auto-updated.
Last update: 2025-10-24 08:29:22 UTC
README
— From boring old arrays to shiny typed objects —Valinor takes care of the construction and validation of raw inputs (JSON, plain arrays, etc.) into objects, ensuring a perfectly valid state. It allows the objects to be used without having to worry about their integrity during the whole application lifecycle.
The validation system will detect any incorrect value and help the developers by providing precise and human-readable error messages.
The mapper can handle native PHP types as well as other advanced types supported by PHPStan and Psalm like shaped arrays, generics, integer ranges and more.
The library also provides a normalization mechanism that can help transform any input into a data format (JSON, CSV, …), while preserving the original structure.
Installation
composer require cuyz/valinor
📔 Read more on the online documentation
Example
final class Country { public function __construct( /** @var non-empty-string */ public readonly string $name, /** @var list<City> */ public readonly array $cities, ) {} } final class City { public function __construct( /** @var non-empty-string */ public readonly string $name, public readonly DateTimeZone $timeZone, ) {} } $json = <<<JSON { "name": "France", "cities": [ {"name": "Paris", "timeZone": "Europe/Paris"}, {"name": "Lyon", "timeZone": "Europe/Paris"} ] } JSON; try { $country = (new \CuyZ\Valinor\MapperBuilder()) ->mapper() ->map(Country::class, \CuyZ\Valinor\Mapper\Source\Source::json($json)); echo $country->name; // France echo $country->cities[0]->name; // Paris } catch (\CuyZ\Valinor\Mapper\MappingError $error) { // Handle the error… }
Documentation
The full documentation is available on valinor.cuyz.io.
Credits & thank you
The development of this library is mainly motivated by the kind words and the help of many people. I am grateful to everyone, especially to the contributors of this repository who directly help to push the project forward:
Powered by
I have to give JetBrains credits for providing a free PhpStorm license for the development of this open-source package.
Special thanks
I also want to thank
 Blackfire
for providing a license of their awesome tool, leading to notable performance
gains when using this library.