phrity / util-transformer
Type transformers, normalizers and resolvers.
1.0.0
2025-04-28 15:06 UTC
Requires
- php: ^8.1
Requires (Dev)
- php-coveralls/php-coveralls: ^2.0
- phpstan/phpstan: ^2.0
- phpunit/phpunit: ^10.0 | ^11.0 | ^12.0
- squizlabs/php_codesniffer: ^3.5
README
Introduction
Type transformers, normalizers and resolvers.
Installation
Install with Composer;
composer require phrity/util-transformer
How to use
All transformers exposes canTransform()
and transform()
methods.
This allows us to transform data of a certain type to another type. A specific transformer may not be able to transform all types.
$transformer = new BasicTypeConverter(); if ($transformer->canTransform($subject)) { $transformed = transformer->transform($subject); }
As option, a transformer can take a target type specifier as second argument.
$transformer = new BasicTypeConverter(); if ($transformer->canTransform($subject, Type::ARRAY)) { $transformed = transformer->transform($subject, Type::ARRAY); }
Utility resolvers enable stacking multiple transformers and performing other tasks.
$transformer = new RecursionResolver( new FirstMatchResolver([ new EnumConverter(), new ReadableConverter(), new ThrowableConverter(), new StringableConverter(), new BasicTypeConverter(), ]) ); if ($transformer->canTransform($subject, Type::STRING)) { $transformed = transformer->transform($subject, Type::STRING); }
List of transformers in this library
Type converters
- BasicTypeConverter - Support transforming all PHP types to all other types
- EnumConverter - Transform Enums to string
- ReadableConverter - Transform booleans and null to readable strings
- StringableConverter - Transform stringable objects to string
- ThrowableConverter - Transform throwable to object, array or string
Utility resolvers
- FirstMatchResolver - Collection of transformers that will use first compatible transformer for transformation
- RecursionResolver - Will apply transformer recursively
Versions
Version | PHP | |
---|---|---|
1.0 |
^8.1 |
Initial version |