SinSquare/silex-doctrine-orm-provider

View on GitHub
README.md

Summary

Maintainability
Test Coverage
Doctrine ORM provider for Silex 2.x framework
=======

| Code quality | Tests | Issues |
|--------------|-------|--------|
| [![SensioLabsInsight](https://insight.sensiolabs.com/projects/73087558-245f-4598-826a-30e24a03e880/big.png)](https://insight.sensiolabs.com/projects/73087558-245f-4598-826a-30e24a03e880) | [![Build Status](https://travis-ci.org/SinSquare/silex-doctrine-orm-provider.svg?branch=master)](https://travis-ci.org/SinSquare/silex-doctrine-orm-provider) | [![Issue Count](https://codeclimate.com/github/SinSquare/silex-doctrine-orm-provider/badges/issue_count.svg)](https://codeclimate.com/github/SinSquare/silex-doctrine-orm-provider/issues) |
| [![Codacy Badge](https://api.codacy.com/project/badge/Grade/9d24d9a01c994a5e940cdf64defa8cf5)](https://www.codacy.com/app/SinSquare/silex-doctrine-orm-provider?utm_source=github.com&utm_medium=referral&utm_content=SinSquare/silex-doctrine-orm-provider&utm_campaign=Badge_Grade) | [![Test Coverage](https://codeclimate.com/github/SinSquare/silex-doctrine-orm-provider/badges/coverage.svg)](https://codeclimate.com/github/SinSquare/silex-doctrine-orm-provider/coverage) |     |
| [![Code Climate](https://codeclimate.com/github/SinSquare/silex-doctrine-orm-provider/badges/gpa.svg)](https://codeclimate.com/github/SinSquare/silex-doctrine-orm-provider) |   |   |


Installation
============

With composer :

``` json
{
    "require": {
        "sinsquare/silex-doctrine-orm-provider": "1.*"
    }
}
```
Registering the providers
====

- If you only need the ORM without validation and web profiler

```php
use Silex\Provider\DoctrineServiceProvider;
use SinSquare\Cache\DoctrineCacheServiceProvider;
use SinSquare\Doctrine\DoctrineOrmServiceProvider;

...

$application['doctrine.orm.options'] = array(<config>);

$application->register(new DoctrineServiceProvider());
$application->register(new DoctrineCacheServiceProvider());
$application->register(new DoctrineOrmServiceProvider());
```

- If you only need the ORM validation (UniqueEntity)
```php
//Register all the providers for the ORM

use Silex\Provider\ValidatorServiceProvider;
use SinSquare\Doctrine\DoctrineOrmValidatorProvider;

...

$application->register(new ValidatorServiceProvider());
$application->register(new DoctrineOrmValidatorProvider());
```

- If you only need the the ORM web profiler
```php
//Register all the providers for the ORM

use SinSquare\Doctrine\DoctrineOrmWebProfilerProvider;

...

$application->register(new DoctrineOrmWebProfilerProvider());
```

Configuration
====

The configuration of the ORM must be set in $application['doctrine.orm.options'], and it must exist before registering the provider.

A basic configuration scheme:
```php
$application['doctrine.orm.options'] = array(
    'default_entity_manager' => 'default',
    'auto_generate_proxy_classes' => true,
    'proxy_dir' => __DIR__.'/Resources/Proxy',
    'proxy_namespace' => 'Proxies',

    'entity_managers' => array(
        'default' => array(
            'query_cache_driver' => array(
                'type' => 'array',
            ),
            'metadata_cache_driver' => array(
                'type' => 'array',
            ),
            'result_cache_driver' => array(
                'type' => 'array',
            ),
            'connection' => 'db1',
            'mappings' => array(
                array(
                    'type' => 'annotation',
                    'namespace' => 'SinSquare\\Doctrine\\Tests\\Resources\\Entity',
                    'alias' => 'TestBundle',
                    'path' => __DIR__.'/Resources/Entity',
                    'use_simple_annotation_reader' => false,
                ),
            ),
        ),
    ),
);
```

The configuration scheme is similar to the one used in Smyfony [(read more here)](https://symfony.com/doc/current/reference/configuration/doctrine.html).

- default_entity_manager: Name of the default entity manager. If not set the first one will be the default.

- connection: Name of the DBAL connection to use. Read more at the DoctrineServiceProvider help [here](https://silex.sensiolabs.org/doc/2.0/providers/doctrine.html).

- mapping: Currently only the annotation type is supported by default, but you can extend the functionality. Look for $app['doctrine.orm.mappingdriver.locator'] in the DoctrineOrmServiceProvider.

- cache: The project uses SinSquare/silex-doctrine-orm-provider for cacheing, which is a wrapper for Doctrine Cache.

* Using anonym cache:
```php
'query_cache_driver' => array(
    'type' => 'array',
),
```
You can change the cache type, for more info check the Doctrine Cache component.
*Using named cache:
```php
$application['doctrine.cache.options'] = array(
    'providers' => array(
        'cache_1' => array(
            'type' => 'void',
        )
    ),
);

$application['doctrine.orm.options'] = array(
    ...
    'result_cache_driver' => array(
        'name' => 'cache_1',
    ),
    ...
);
```

You can create new types of caches, please read how to [here](https://github.com/SinSquare/silex-doctrine-orm-provider);

Retrieving the EntityManager
=====

* The default entity manager:
```php
$em = $application['doctrine.orm.em'];
```
* A named entity manager:
```php
$em = $application['doctrine.orm.ems']['named_em'];
//OR
$em = $application['doctrine.orm.em.named_em'];
```

Using the validator
=====

```php
    $entity = new Entity();
    
    //modify the entity

    $validator = $application['validator'];
    $errors = $validator->validate($entity);
    if(count($errors)) {
        //there was an error
    }
```

Adding custom subscribers to the EntityManager
=====

If you need to attach subscriber to the EntityManager you should use the $application['doctrine.orm.em_factory.postinit'] as it runs only once after the fist call on the manager. 

```php
$application['doctrine.orm.em_factory.postinit'] = $this->application->protect(function ($name, $options, $manager) use ($application) {
        
    $eventManager = $manager->getEventManager();
    $eventManager->addEventSubscriber($subscriber);

    return $manager;
});
```