1
0
mirror of synced 2025-01-10 02:57:10 +03:00
doctrine2/lib/Doctrine/EntityManagerFactory.php

204 lines
5.3 KiB
PHP

<?php
#namespace Doctrine::ORM;
#use Doctrine::DBAL::ConnectionFactory;
#use Doctrine::Common::Configuration;
#use Doctrine::Common::EventManager;
/**
* The EntityManagerFactory is responsible for bootstrapping EntityManager
* instances as well as keeping track of all created EntityManagers and
* hard bindings to Entities.
*
* @author Roman Borschel <roman@code-factory.org>
* @since 2.0
*/
class Doctrine_EntityManagerFactory
{
/**
* Map of all created EntityManagers, keys are the names.
*
* @var array
*/
private static $_ems = array();
/**
* EntityManager to Entity bindings.
*
* @var array
*/
private static $_emBindings = array();
/**
* The ConnectionFactory used to create DBAL connections.
*
* @var unknown_type
*/
private $_connFactory;
/**
* The EventManager that is injected into all created Connections
* and EntityManagers.
*
* @var EventManager
*/
private $_eventManager;
/**
* The Configuration that is injected into all creatd Connections
* and EntityManagers.
*
* @var Configuration
*/
private $_config;
/**
* Constructor.
* Creates a new EntityManagerFactory.
*/
public function __construct()
{
$this->_connFactory = new Doctrine_ConnectionFactory();
}
/**
* Sets the Configuration that is injected into all EntityManagers
* (and their Connections) that are created by this factory.
*
* @param Doctrine_Configuration $eventManager
*/
public function setConfiguration(Doctrine_Configuration $config)
{
$this->_config = $config;
}
/**
* Sets the EventManager that is injected into all EntityManagers
* (and their Connections) that are created by this factory.
*
* @param Doctrine_EventManager $eventManager
*/
public function setEventManager(Doctrine_EventManager $eventManager)
{
$this->_eventManager = $eventManager;
}
/**
* Creates an EntityManager.
*
* @param unknown_type $connParams
* @param unknown_type $name
* @return unknown
*/
public function createEntityManager($connParams, $name = null)
{
if ( ! $this->_config) {
$this->_config = new Doctrine_Configuration();
}
if ( ! $this->_eventManager) {
$this->_eventManager = new Doctrine_EventManager();
}
$conn = $this->_connFactory->createConnection($connParams);
$conn->setEventManager($this->_eventManager);
$conn->setConfiguration($this->_config);
$em = new Doctrine_EntityManager($conn);
$em->setEventManager($this->_eventManager);
$em->setConfiguration($this->_config);
if ($name !== null) {
self::$_ems[$name] = $em;
} else {
self::$_ems[] = $em;
}
return $em;
}
/**
* Gets the EntityManager that is responsible for the Entity.
* Static method, so that ActiveEntities can look up the right EntityManager
* without having a reference to the factory at hand.
*
* @param string $entityName
* @return EntityManager
* @throws Doctrine_EntityManager_Exception If a suitable manager can not be found.
*/
public static function getManager($entityName = null)
{
if ( ! is_null($entityName) && isset(self::$_emBindings[$entityName])) {
$emName = self::$_emBindings[$entityName];
if (isset(self::$_ems[$emName])) {
return self::$_ems[$emName];
} else {
throw Doctrine_EntityManagerFactory_Exception::noManagerWithName($emName);
}
} else if (self::$_ems) {
return current(self::$_ems);
} else {
throw Doctrine_EntityManagerFactory_Exception::noEntityManagerAvailable();
}
}
/**
* Gets the EntityManager that is responsible for the Entity.
*
* @param unknown_type $entityName
* @return unknown
*/
public function getEntityManager($entityName = null)
{
return self::getManager($entityName);
}
/**
* Binds an Entity to a specific EntityManager.
*
* @param string $entityName
* @param string $emName
*/
public function bindEntityToManager($entityName, $emName)
{
if (isset(self::$_emBindings[$entityName])) {
throw Doctrine_EntityManagerFactory_Exception::entityAlreadyBound($entityName);
}
self::$_emBindings[$entityName] = $emName;
}
/**
* Clears all bindings between Entities and EntityManagers.
*/
public function unbindAllManagers()
{
self::$_emBindings = array();
}
/**
* Releases all EntityManagers.
*
*/
public function releaseAllManagers()
{
self::unbindAllManagers();
self::$_ems = array();
}
public function releaseAllBindings()
{
self::$_emBindings = array();
}
public function releaseEntityManager($name)
{
if (isset(self::$_ems[$name])) {
unset(self::$_ems[$name]);
return true;
}
return false;
}
}
?>