Download the PHP package api-skeletons/zf-doctrine-repository without Composer
On this page you can find all versions of the php package api-skeletons/zf-doctrine-repository. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download api-skeletons/zf-doctrine-repository
More information about api-skeletons/zf-doctrine-repository
Files in api-skeletons/zf-doctrine-repository
Package zf-doctrine-repository
Short Description Plugin Architecture for Doctrine Repositories
License MIT
Informations about the package zf-doctrine-repository
zf-doctrine-repository
This is a replacement for the default repository structure of Doctrine ORM. This replacement implements a plugin architecture for extensisons to repositories.
For instance, if you need access to an encryption/decryption resource inside your repository you could implement it as a plugin accessible as
Why use this repository structure?
The default repository for Doctrine ORM gives no access to resources outside Doctrine. And the Doctrine ORM Object Manager does not give access to a dependency injection container. So when your applications require more from their repositories the only option is to write your own dependency injection enabled repository factory. To create a standard way to organize this dependency injection repository factory: this is an acceptable solution.
Installation
Installation of this module uses composer. For composer documentation, please refer to getcomposer.org.
Once installed, add ZF\Doctrine\Repository
to your list of modules inside
config/application.config.php
or config/modules.config.php
.
zf-component-installer
If you use zf-component-installer, that plugin will install zf-doctrine-repository as a module for you.
Configuration
No manual configuration is required to use this module.
This module makes these changes to your
doctrine.entitymanager.orm_default
configuration:
If your application already has a default repository class you can edit it to implement
ZF\Doctrine\Repository\ObjectRepositoryInterface
and the RepositoryFactory can use it.
Creating a Plugin
The config key for the repository plugin service locator is zf-doctrine-repository-plugin
.
Your plugin must implement ZF\Doctrine\Repository\Plugin\PluginInterface
The __construct
of your Plugin will take an array including the repository and any other parameters.
Access to the repository gives you access to the ObjectManager.
Use the testing boolean plugin and testing boolean plugin configuration as a template.
Available Plugins
zf-doctrine-repository-query-provider - zfcampus/zf-apigility-doctrine includes Query Providers which may take the current authenticated user and add complex filters to a a QueryBuilder object in order to filter whether the user has access to a given entity. This filtering mechanism can be used across a whole application whenever authorized access is needed to an entity.
Future Plugin Plans
This repository is forward-looking and architected to support the needs today and into the future. Here are examples of repository plugins to be developed:
zf-doctrine-repository-audit - A trigger-happy application will create a structure of triggers on all tables accessible as Doctrine entities. Data would be accessible directly or to access the audit data with a plugin:
All versions of zf-doctrine-repository with dependencies
doctrine/doctrine-orm-module Version ^1.2 || ^2.1
zendframework/zend-servicemanager Version ^3.0
gianarb/angry Version ^0.1.1