era269 / normalizable
OOP Normalization
Installs: 3 933
Dependents: 1
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 2
Open Issues: 2
pkg:composer/era269/normalizable
Requires
- php: ^8.0|^7.1
Requires (Dev)
- phpstan/phpstan: ^0.12.88
- phpunit/phpunit: ^9.5
This package is auto-updated.
Last update: 2025-10-20 18:19:33 UTC
README
The normalization which is under the object control.
- All private object properties should be ready for normalization. the normalization process is easy to customize by
adding or changing the sequence of the normalizers in the
NormalizationFacade - To allow the normalization customization Object has to implement the next interfaces:
NormalizableInterfaceNormalizationFacadeInterface
Description:
NormalizableInterface
The basic interface. Could be used separately to build fully manual normalization. How:
- any objet implements
NormalizableInterface - It is called object::normalize in
NormalizableInterface::normalizefor all required to be present in normalized view objects
NormalizableTrait
If it is needed to have all normalization happen automatically then NormalizableTrait has to be used
with NormalizableInterface. In that case all objects should be supported by the DefaultNormalizationFacade
DefaultNormalizationFacade
Will normalize all private object properties by the next rules:
AsIsKeyDecoratorthe property name will become the array key without any decorations- all properties will be processed by predefined normalizers:
NotObjectNormalizerwill return not objects as isListNormalizableToNormalizableAdapterNormalizerwill process the array of normalizable objects- all keys will be left as is
AsIsKeyDecorator - all values will be processed in according to the current rules by
DefaultNormalizationFacade
- all keys will be left as is
NormalizableNormalizerwill callNormalizableInterface::normalizeWithTypeNormalizableNormalizerDecoratoris decorates theNormalizableNormalizerto add@typefield with ShortClassName of normalized objectScalarableNormalizerwill get the scalar value in object implementsScalarableInterfaceStringableNormalizerwill get the scalar value in object implementsStringableInterface- and the last one is
FailNormalizerwhich wil throw an exception if no Normalizer was found
NormalizationFacadeAwareInterface
Should be implenented by all Normalizable objects to support the normalization customization. The normalization should
be initiated by the custom NormalizationFacade implementation and it will be set to all Normalizable objects
recursively