Configuration File Overview
- Sample Configuration
- Entity Manager
- Extensions
- Custom Types
- Custom Functions
- Logger
- Cache
- Gedmo Extensions
This page provides a quick overview of all of the options provided in doctrine.php
, the configuration file for Laravel Doctrine.
Sample Configuration
<?php
return [
/*
|--------------------------------------------------------------------------
| Entity Mangers
|--------------------------------------------------------------------------
|
| Configure your Entity Managers here. You can set a different connection
| and driver per manager and configure events and filters. Change the
| paths setting to the appropriate path and replace App namespace
| by your own namespace.
|
| Available meta drivers: annotations|yaml|xml|config|static_php
|
| Available connections: mysql|oracle|pgsql|sqlite|sqlsrv
| (Connections can be configured in the database config)
|
| --> Warning: Proxy auto generation should only be enabled in dev!
|
*/
'managers' => [
'default' => [
'dev' => env('APP_DEBUG'),
'meta' => env('DOCTRINE_METADATA', 'annotations'),
'connection' => env('DB_CONNECTION', 'mysql'),
'namespaces' => [
'App'
],
'paths' => [
base_path('app')
],
'repository' => Doctrine\ORM\EntityRepository::class,
'proxies' => [
'namespace' => false,
'path' => storage_path('proxies'),
'auto_generate' => env('DOCTRINE_PROXY_AUTOGENERATE', false)
],
/*
|--------------------------------------------------------------------------
| Doctrine events
|--------------------------------------------------------------------------
|
| The listener array expects the key to be a Doctrine event
| e.g. Doctrine\ORM\Events::onFlush
|
*/
'events' => [
'listeners' => [],
'subscribers' => []
],
'filters' => [],
/*
|--------------------------------------------------------------------------
| Doctrine mapping types
|--------------------------------------------------------------------------
|
| Link a Database Type to a Local Doctrine Type
|--------------------------------------------------------------------------
*/
'mapping_types' => [
//'enum' => 'string'
]
]
],
/*
|--------------------------------------------------------------------------
| Doctrine Extensions
|--------------------------------------------------------------------------
|
| Enable/disable Doctrine Extensions by adding or removing them from the list
|
| If you want to require custom extensions you will have to require
| laravel-doctrine/extensions in your composer.json
|
*/
'extensions' => [
//LaravelDoctrine\ORM\Extensions\TablePrefix\TablePrefixExtension::class,
//LaravelDoctrine\Extensions\Timestamps\TimestampableExtension::class,
//LaravelDoctrine\Extensions\SoftDeletes\SoftDeleteableExtension::class,
//LaravelDoctrine\Extensions\Sluggable\SluggableExtension::class,
//LaravelDoctrine\Extensions\Sortable\SortableExtension::class,
//LaravelDoctrine\Extensions\Tree\TreeExtension::class,
//LaravelDoctrine\Extensions\Loggable\LoggableExtension::class,
//LaravelDoctrine\Extensions\Blameable\BlameableExtension::class,
//LaravelDoctrine\Extensions\IpTraceable\IpTraceableExtension::class,
//LaravelDoctrine\Extensions\Translatable\TranslatableExtension::class
],
/*
|--------------------------------------------------------------------------
| Doctrine custom types
|--------------------------------------------------------------------------
*/
'custom_types' => [
'json' => LaravelDoctrine\ORM\Types\Json::class
],
/*
|--------------------------------------------------------------------------
| DQL custom datetime functions
|--------------------------------------------------------------------------
*/
'custom_datetime_functions' => [],
/*
|--------------------------------------------------------------------------
| DQL custom numeric functions
|--------------------------------------------------------------------------
*/
'custom_numeric_functions' => [],
/*
|--------------------------------------------------------------------------
| DQL custom string functions
|--------------------------------------------------------------------------
*/
'custom_string_functions' => [],
/*
|--------------------------------------------------------------------------
| Enable query logging with laravel file logging,
| debugbar, clockwork or an own implementation.
| Setting it to false, will disable logging
|
| Available:
| - LaravelDoctrine\ORM\Loggers\LaravelDebugbarLogger
| - LaravelDoctrine\ORM\Loggers\ClockworkLogger
| - LaravelDoctrine\ORM\Loggers\FileLogger
|--------------------------------------------------------------------------
*/
'logger' => env('DOCTRINE_LOGGER', false),
/*
|--------------------------------------------------------------------------
| Cache
|--------------------------------------------------------------------------
|
| Configure meta-data, query and result caching here.
| Optionally you can enable second level caching.
|
| Available: acp|array|file|memcached|redis
|
*/
'cache' => [
'default' => env('DOCTRINE_CACHE', 'array'),
'namespace' => null,
'second_level' => false,
],
/*
|--------------------------------------------------------------------------
| Gedmo extensions
|--------------------------------------------------------------------------
|
| Settings for Gedmo extensions
| If you want to use this you will have to require
| laravel-doctrine/extensions in your composer.json
|
*/
'gedmo' => [
'all_mappings' => false
]
];
Entity Manager
An Entity Manager (EM) contains all of the information Doctrine needs to understand, retrieve, and manipulate a set of entities (models).
You must have at least one EM in order to use Laravel Doctrine.
To use more than one EM simply create another entry in the managers
array.
Property | Explanation |
---|---|
EM Name | In the sample below the EM we have configured is named default . This is the EM that Laravel Doctrine will attempt to use if no argument is provided to ManagerRegistry . |
dev | Whether this EM is in development mode. |
meta | The metadata driver to use. Built-in options are annotations|yaml|xml|config|static_php |
connection | The connection drier to use. Built-in options are mysql|oracle|pgsql|sqlite|sqlsrv |
namespaces | (Optional) If your entities are not located in the configured app namespace you can specify a different one here. |
paths | An paths where the mapping configurations for your entities is located. |
repository | (Optional) The default repository to use for this EM. |
decorator | (Optional) Your custom EM decorator to overwrite the default EM. |
proxies.namespace | Namespace (if different) specified for proxy classes |
proxies.path | The path where proxy classes should be generated. |
proxies.auto_generate | Should proxy classes be generated every time an EM is created? (Turn off production) |
events.subscribers | Subscribers should implement Doctrine\Common\EventSubscriber |
events.listeners | Key should be event type. E.g. Doctrine\ORM\Events::onFlush . Value should be the listener class |
filters | Filter system that allows the developer to add SQL to the conditional clauses of queries, regardless the place where the SQL is generated |
'managers' => [
'default' => [
'dev' => env('APP_DEBUG'),
'meta' => env('DOCTRINE_METADATA', 'annotations'),
'connection' => env('DB_CONNECTION', 'mysql'),
'namespaces' => [
'App'
],
'paths' => [
base_path('app')
],
'repository' => Doctrine\ORM\EntityRepository::class,
'proxies' => [
'namespace' => false,
'path' => storage_path('proxies'),
'auto_generate' => env('DOCTRINE_PROXY_AUTOGENERATE', false)
],
'events' => ...
'filters' => ...,
/*
|--------------------------------------------------------------------------
| Doctrine mapping types
|--------------------------------------------------------------------------
|
| Link a Database Type to a Local Doctrine Type
|--------------------------------------------------------------------------
*/
'mapping_types' => ...
]
]
Namespace Alias
To use namespace alias, you just have to specify then as key of each namespace.
Example:
'managers' => [
'default' => [
...
'connection' => env('DB_CONNECTION', 'mysql'),
'namespaces' => [
'Foo' => 'App\Model\Foo\Entities',
'Bar' => 'App\Model\Bar\Entities',
],
'paths' => [
base_path('app')
],
...
]
]
Whenever you need to specify entities in these namespaces, you can simple use the alias as follow:
SELECT f FROM Foo:SomeEntity
or
\EntityManager::getRepository('Bar:SomeEntity');
Mapping Types
To convert the underlying database type to a doctrine when performing schema operations, the type has to be registered with the database platform:
In the following example we will convert a database type called enum to string.
'managers' => [
'default' => [
...
'filters' => ...,
/*
|--------------------------------------------------------------------------
| Doctrine mapping types
|--------------------------------------------------------------------------
|
| Link a Database Type to a Local Doctrine Type
|--------------------------------------------------------------------------
*/
'mapping_types' => [
'enum' => 'string'
]
]
]
Extensions
Extensions can be enabled by adding them to this array. They provide additional functionality Entities (Timestamps, Loggable, etc.)
To use the extensions in this sample you must install the extensions package:
require laravel-doctrine/extensions
and follow the installation instructions.
'extensions' => [
//LaravelDoctrine\ORM\Extensions\TablePrefix\TablePrefixExtension::class,
//LaravelDoctrine\Extensions\Timestamps\TimestampableExtension::class,
//LaravelDoctrine\Extensions\SoftDeletes\SoftDeleteableExtension::class,
//LaravelDoctrine\Extensions\Sluggable\SluggableExtension::class,
//LaravelDoctrine\Extensions\Sortable\SortableExtension::class,
//LaravelDoctrine\Extensions\Tree\TreeExtension::class,
//LaravelDoctrine\Extensions\Loggable\LoggableExtension::class,
//LaravelDoctrine\Extensions\Blameable\BlameableExtension::class,
//LaravelDoctrine\Extensions\IpTraceable\IpTraceableExtension::class,
//LaravelDoctrine\Extensions\Translatable\TranslatableExtension::class
],
Custom Types
Custom types are classes that allow Doctrine to marshal data to/from the data source in a custom format.
To register a custom type simple add the class to this list. For more information on custom types refer to the Doctrine documentation.
Custom Functions
These are classes that extend the functionality of Doctrine's DQL language. More information on what functions are available visit the repository.
To use the extensions in this sample you must install the extensions package:
require laravel-doctrine/extensions
and follow the installation instructions.
If you include BeberleiExtensionsServiceProvider
all custom functions will automatically be registered.
To add a function simply add it to the correct list using this format:
'FUNCTION_NAME' => 'Path\To\Class'
/*
|--------------------------------------------------------------------------
| DQL custom datetime functions
|--------------------------------------------------------------------------
*/
'custom_datetime_functions' => [],
/*
|--------------------------------------------------------------------------
| DQL custom numeric functions
|--------------------------------------------------------------------------
*/
'custom_numeric_functions' => [],
/*
|--------------------------------------------------------------------------
| DQL custom string functions
|--------------------------------------------------------------------------
*/
'custom_string_functions' => [],
Logger
Enable logging of Laravel Doctrine and Doctrine by using the logger functionality.
Available loggers |
---|
LaravelDoctrine\ORM\Loggers\LaravelDebugbarLogger |
LaravelDoctrine\ORM\Loggers\ClockworkLogger |
LaravelDoctrine\ORM\Loggers\FileLogger |
'logger' => env('DOCTRINE_LOGGER', false),
Cache
Cache will be used to cache metadata, results and queries.
Available cache providers:
- apc
- array
- file
- memcached
- redis
Config settings:
Property | Explanation |
---|---|
cache.default | The default cache provider to use. |
cache.namespace | Will add namespace to the cache key. This is useful if you need extra control over handling key names collisions in your Cache solution. |
cache.second_level | The Second Level Cache is designed to reduce the amount of necessary database access. It sits between your application and the database to avoid the number of database hits as much as possible. |
When turned on, entities will be first searched in cache and if they are not found, a database query will be fired an then the entity result will be stored in a cache provider. When used, READ_ONLY is mostly used. ReadOnly cache can do reads, inserts and deletes, cannot perform updates|
Gedmo
This is an option for use with Extensions
To use this option you must first install the extensions package:
require laravel-doctrine/extensions
and follow the installation instructions.