One of the great features of Doctrine 2 is extensibility. Doctrine offers multiple ways to specify mapping information, but the most of the extensions only supports Annotations configuration.
This package adds custom annotations to your YAML mapping files.
What is currently supported:
- property annotations (fields and embeddables)
- class annotations
The best way to install fmasa/doctrine-yaml-annotations is using Composer:
$ composer require fmasa/doctrine-yaml-annotations
For example let's configure the Consistence extension for Doctrine.
First we have to create annotation reader:
use Fmasa\DoctrineYamlAnnotations\YamlReader;
$configuration = $entityManager->getConfiguration();
$reader = new YamlReader($configuration, [
'enum' => EnumAnnotation::class
]);
Second argument for AnnotationReader is optional map with entity aliases.
Add annotations to your mapping files:
Some\Entity:
...
fields:
state:
type: enum_string
annotations:
Consistence\Doctrine\Enum\EnumAnnotation: # or just enum
class: StateEnum
Now you can read annotations just using Doctrine\Common\Annotations\Reader
API:
$reader->getPropertyAnnotation(
(new \ReflectionClass(Some\Entity::class))->getProperty('state'),
EnumAnnotation::class
); // returns instance of EnumAnnotation { class => "StateEnum" }