. */ namespace Doctrine\ORM; /** * Configuration container for all configuration options of Doctrine. * It combines all configuration options from DBAL & ORM. * * @author Roman Borschel * @since 2.0 * @internal When adding a new configuration option just write a getter/setter * pair and add the option to the _attributes array with a proper default value. */ class Configuration extends \Doctrine\DBAL\Configuration { /** * Creates a new configuration that can be used for Doctrine. */ public function __construct() { parent::__construct(); $this->_attributes = array_merge($this->_attributes, array( 'resultCacheImpl' => null, 'queryCacheImpl' => null, 'metadataCacheImpl' => null, 'metadataDriverImpl' => null, 'cacheDir' => null, 'allowPartialObjects' => true, 'useCExtension' => false, 'namedQueries' => array(), 'namedNativeQueries' => array() )); //TODO: Move this to client code to avoid unnecessary work when a different metadata // driver is used. $reader = new \Doctrine\Common\Annotations\AnnotationReader(new \Doctrine\Common\Cache\ArrayCache); $reader->setDefaultAnnotationNamespace('Doctrine\ORM\Mapping\\'); $this->_attributes['metadataDriverImpl'] = new \Doctrine\ORM\Mapping\Driver\AnnotationDriver($reader); } /** * Gets a boolean flag that indicates whether partial objects are allowed. * * If partial objects are allowed, Doctrine will never use proxies or lazy loading * and you always only get what you explicitly query for. * * @return boolean Whether partial objects are allowed. */ public function getAllowPartialObjects() { return $this->_attributes['allowPartialObjects']; } /** * Sets a boolean flag that specifies whether partial objects are allowed. * * If partial objects are allowed, Doctrine will never use proxies or lazy loading * and you always only get what you explicitly query for. * * @param boolean $allowed Whether partial objects are allowed. */ public function setAllowPartialObjects($allowed) { $this->_attributes['allowPartialObjects'] = $allowed; } /** * Sets the directory where Doctrine writes any necessary cache files. * * @param string $dir */ public function setCacheDir($dir) { $this->_attributes['cacheDir'] = $dir; } /** * Gets the directory where Doctrine writes any necessary cache files. * * @return string */ public function getCacheDir() { return $this->_attributes['cacheDir']; } /** * Sets the cache driver implementation that is used for metadata caching. * * @param object $driverImpl */ public function setMetadataDriverImpl($driverImpl) { $this->_attributes['metadataDriverImpl'] = $driverImpl; } /** * Gets the cache driver implementation that is used for the mapping metadata. * * @return object */ public function getMetadataDriverImpl() { return $this->_attributes['metadataDriverImpl']; } /** * Gets the cache driver implementation that is used for query result caching. * * @return object */ public function getResultCacheImpl() { return $this->_attributes['resultCacheImpl']; } /** * Sets the cache driver implementation that is used for query result caching. * * @param object $cacheImpl */ public function setResultCacheImpl($cacheImpl) { $this->_attributes['resultCacheImpl'] = $cacheImpl; } /** * Gets the cache driver implementation that is used for the query cache (SQL cache). * * @return object */ public function getQueryCacheImpl() { return $this->_attributes['queryCacheImpl']; } /** * Sets the cache driver implementation that is used for the query cache (SQL cache). * * @param object $cacheImpl */ public function setQueryCacheImpl($cacheImpl) { $this->_attributes['queryCacheImpl'] = $cacheImpl; } /** * Gets the cache driver implementation that is used for metadata caching. * * @return object */ public function getMetadataCacheImpl() { return $this->_attributes['metadataCacheImpl']; } /** * Sets the cache driver implementation that is used for metadata caching. * * @param object $cacheImpl */ public function setMetadataCacheImpl($cacheImpl) { $this->_attributes['metadataCacheImpl'] = $cacheImpl; } /** * Gets a boolean flag that indicates whether Doctrine should make use of the * C extension. * * @return boolean TRUE if Doctrine is configured to use the C extension, FALSE otherwise. */ public function getUseCExtension() { return $this->_attributes['useCExtension']; } /** * Sets a boolean flag that indicates whether Doctrine should make use of the * C extension. * * @param boolean $boolean Whether to make use of the C extension or not. */ public function setUseCExtension($boolean) { $this->_attributes['useCExtension'] = $boolean; } /** * Adds a named DQL query to the configuration. * * @param string $name The name of the query. * @param string $dql The DQL query string. */ public function addNamedQuery($name, $dql) { $this->_attributes['namedQueries'][$name] = $dql; } /** * Gets a previously registered named DQL query. * * @param string $name The name of the query. * @return string The DQL query. */ public function getNamedQuery($name) { return $this->_attributes['namedQueries'][$name]; } /** * Adds a named native query to the configuration. * * @param string $name The name of the query. * @param string $sql The native SQL query string. * @param ResultSetMapping $rsm The ResultSetMapping used for the results of the SQL query. */ public function addNamedNativeQuery($name, $sql, Query\ResultSetMapping $rsm) { $this->_attributes['namedNativeQueries'][$name] = array($sql, $rsm); } /** * Gets the components of a previously registered named native query. * * @param string $name The name of the query. * @return array A tuple with the first element being the SQL string and the second * element being the ResultSetMapping. */ public function getNamedNativeQuery($name) { return $this->_attributes['namedNativeQueries'][$name]; } }