Download the PHP package datasage/laminas-doctrine-hydration-module without Composer
On this page you can find all versions of the php package datasage/laminas-doctrine-hydration-module. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Informations about the package laminas-doctrine-hydration-module
Repository abandoned
This repo has been updated to support PHP 7.4 and 8+ as well as converted to use Laminas packages. These upgrades where done to address a dependency with an upstream package.
Feel free to use it AS-IS, we won't be providing any support anymore.
Doctrine Hydration Module
Supported features
- 5.0.x: Upgrade to Laminas and requires PHP 7.4+
- 4.0.x: Contains zend-servicemanager >=3.3.2 support requiring PHP 5.6+.
- 3.0.x: Contains zend-servicemanager >=3 support requiring PHP 5.6+.
- 2.0.x: Contains zend-hydrator support requiring PHP 5.6+.
- 1.0.x: Contains zend-stdlib <2.7 support requiring PHP 5.4+.
Make sure to commit on the correct branch if you want your changes to get merged into the project.
Installation
Add to composer.json
Add to application config
Hydrator configuration
entity_class
This property is used to specify the class of the entity that will be hydrated. You need to make sure that this entity is a mapped doctrine class.
object_manager
You can specify which object manager you want to use for the hydrator. The value is the key of the desired object manager in the service manager.
by_value
Specify if you want the hydrator to hydrate the entity by value or by reference.
use_generated_hydrator
This property will only be used with mongoDB ODM and will use the generated hydrators instead of the Doctrine Module Hydrator.
Strategies will not work when this option is set to true
.
naming_strategy
You can use a custom naming strategy for the hydrator. Specify the key of the naming strategy in the service manager.
Note that this naming strategy needs to implement NamingStrategyInterface
.
hydrator
You can use a custom hydrator instead of the default DoctrineObject
hydrator.
Make sure this hydrator implements HydratorInterface
.
strategies
It is possible to customize the hydration strategy of specific properties.
Configure the property you want to customize with the key of the strategy in the service manager;
Note that this strategy needs to implement StrategyInterface
.
filters
This property can be used to apply filters on the Hydrator.
You can specify a list of custom filters by defining the key of the filter in the service manager and the filter condition as described in the hydrator filter documentation.
Note that this filter needs to implement FilterInterface
.
From here on, you can get the hydrator by calling get('hydrator-manager-key')
on the HydratorManager.
Custom strategies:
MongoDB ODM
- DateTimeField: Used for DateTime objects
- DefaultRelation: Leave the relation AS-IS. Does not perform any modifications on the field.
- EmbeddedCollection: Used for embedded collections
- EmbeddedField: Used for embedded fields
- ReferencedCollection: Used for referenced collections
- ReferencedField: Used for referenced fields.
- EmbeddedReferenceCollection: This is a custom strategy that can be used in an API to display all fields in a referenced object. The hydration works as a regular referenced object.
- EmbeddedReferenceField: This is a custom strategy that can be used in an API to display all fields in a referenced object. The hydration works as a regular referenced object.
Custom Filters
Custom filters allow you to fine-tune the results of the hydrator's extract
functionality by determining which fields should be extracted.
To configure custom filters:
In this example configuration, the hydrator factory will retrieve custom.filter
from the Service Manager and inject it as a filter into the hydrator. The filter must implement Zend\Hydrator\Filter\FilterInterface
.
The service's filter($fieldName)
function will be called by the hydrator during extract
and the field name being extracted will be passed as an argument. The filter()
function must return a truthy value: if true
then the field will NOT be extracted.
Override hydrator:
If the standard DoctrineHydrator is not flexible enough, you can set a custom hydrator
. This allows you to use an extended DoctrineHydrator or another existing hydrator, and configure it with this module. This setting will override use_generated_hydrator
.
Testing
This package is fully tested with Cs fixer and PhpUnit. The MongoDB tests require mongodb to be installed on your machine. You can skip these tests by adding a testsuite to the command:
All versions of laminas-doctrine-hydration-module with dependencies
doctrine/persistence Version ^2.0.0 || ^3.0.0
doctrine/doctrine-module Version ^3.0.0 || ^4.0.0 || ^5.0.0
doctrine/instantiator Version ^1.0.5
laminas/laminas-servicemanager Version ^3.3.2
laminas/laminas-hydrator Version ^3.0.0 || ^4.0.0
doctrine/doctrine-laminas-hydrator Version ^3.2