Skip to content
This repository has been archived by the owner on Aug 29, 2023. It is now read-only.

fmasa/doctrine-yaml-annotations

Repository files navigation

Doctrine YAML annotations

Build Status Coverage Status

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

Installation

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" }