fmasa / doctrine-yaml-annotations

Support for custom Doctrine annotations in yaml

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

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

About

Support for custom Doctrine annotations in yaml

License:MIT License


Languages

Language:PHP 100.0%