2006-12-29 14:01:31 +00:00
< ? php
/*
* $Id $
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* " AS IS " AND ANY EXPRESS OR IMPLIED WARRANTIES , INCLUDING , BUT NOT
* LIMITED TO , THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED . IN NO EVENT SHALL THE COPYRIGHT
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT , INDIRECT , INCIDENTAL ,
* SPECIAL , EXEMPLARY , OR CONSEQUENTIAL DAMAGES ( INCLUDING , BUT NOT
* LIMITED TO , PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES ; LOSS OF USE ,
* DATA , OR PROFITS ; OR BUSINESS INTERRUPTION ) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY , WHETHER IN CONTRACT , STRICT LIABILITY , OR TORT
* ( INCLUDING NEGLIGENCE OR OTHERWISE ) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE , EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE .
*
* This software consists of voluntary contributions made by many individuals
* and is licensed under the LGPL . For more information , see
* < http :// www . phpdoctrine . com >.
*/
/**
* Doctrine_Configurable
* the base for Doctrine_Table , Doctrine_Manager and Doctrine_Connection
*
*
* @ package Doctrine
* @ license http :// www . opensource . org / licenses / lgpl - license . php LGPL
* @ category Object Relational Mapping
* @ link www . phpdoctrine . com
* @ since 1.0
* @ version $Revision $
* @ author Konsta Vesterinen < kvesteri @ cc . hut . fi >
*/
2006-12-29 14:40:47 +00:00
abstract class Doctrine_Configurable
{
2006-12-29 14:01:31 +00:00
/**
* @ var array $attributes an array of containing all attributes
*/
2007-06-12 19:45:28 +00:00
protected $attributes = array ();
2006-12-29 14:01:31 +00:00
/**
* @ var $parent the parents of this component
*/
2007-06-12 19:45:28 +00:00
protected $parent ;
2006-12-29 14:01:31 +00:00
/**
* setAttribute
* sets a given attribute
*
* < code >
* $manager -> setAttribute ( Doctrine :: ATTR_PORTABILITY , Doctrine :: PORTABILITY_ALL );
*
* // or
*
* $manager -> setAttribute ( 'portability' , Doctrine :: PORTABILITY_ALL );
* </ code >
*
* @ param mixed $attribute either a Doctrine :: ATTR_ * integer constant or a string
* corresponding to a constant
* @ param mixed $value the value of the attribute
* @ see Doctrine :: ATTR_ * constants
* @ throws Doctrine_Exception if the value is invalid
* @ return void
*/
2006-12-29 14:40:47 +00:00
public function setAttribute ( $attribute , $value )
{
2006-12-29 14:01:31 +00:00
switch ( $attribute ) {
2006-12-29 21:30:37 +00:00
case Doctrine :: ATTR_FETCHMODE :
if ( $value < 0 ) {
throw new Doctrine_Exception ( " Unknown fetchmode. See Doctrine::FETCH_* constants. " );
2006-12-29 14:01:31 +00:00
}
2006-12-29 21:30:37 +00:00
break ;
case Doctrine :: ATTR_LISTENER :
$this -> setEventListener ( $value );
break ;
case Doctrine :: ATTR_LOCKMODE :
if ( $this instanceof Doctrine_Connection ) {
if ( $this -> transaction -> getState () != Doctrine_Transaction :: STATE_SLEEP ) {
2006-12-29 14:01:31 +00:00
throw new Doctrine_Exception ( " Couldn't set lockmode. There are transactions open. " );
}
2006-12-29 21:30:37 +00:00
} elseif ( $this instanceof Doctrine_Manager ) {
foreach ( $this as $connection ) {
if ( $connection -> transaction -> getState () != Doctrine_Transaction :: STATE_SLEEP ) {
throw new Doctrine_Exception ( " Couldn't set lockmode. There are transactions open. " );
}
}
} else {
throw new Doctrine_Exception ( " Lockmode attribute can only be set at the global or connection level. " );
2006-12-29 14:01:31 +00:00
}
2006-12-29 21:30:37 +00:00
break ;
case Doctrine :: ATTR_CREATE_TABLES :
2007-03-23 16:31:35 +00:00
$attribute = Doctrine :: ATTR_EXPORT ;
if ( $value ) {
2007-04-03 17:41:02 +00:00
$value = Doctrine :: EXPORT_TABLES ;
2007-03-23 16:31:35 +00:00
} else {
$value = Doctrine :: EXPORT_NONE ;
}
2006-12-29 21:30:37 +00:00
break ;
case Doctrine :: ATTR_ACCESSORS :
2007-05-31 20:13:04 +00:00
throw new Doctrine_Exception ( " Get / Set filtering is deprecated (slowed down Doctrine too much). " );
2006-12-29 21:30:37 +00:00
break ;
case Doctrine :: ATTR_COLL_LIMIT :
if ( $value < 1 ) {
throw new Doctrine_Exception ( " Collection limit should be a value greater than or equal to 1. " );
}
break ;
case Doctrine :: ATTR_COLL_KEY :
if ( ! ( $this instanceof Doctrine_Table )) {
throw new Doctrine_Exception ( " This attribute can only be set at table level. " );
}
2007-01-21 22:26:38 +00:00
if ( $value !== null && ! $this -> hasColumn ( $value )) {
2006-12-29 21:30:37 +00:00
throw new Doctrine_Exception ( " Couldn't set collection key attribute. No such column ' $value ' " );
}
break ;
2007-05-24 16:53:51 +00:00
case Doctrine :: ATTR_DQL_CACHE :
case Doctrine :: ATTR_DQL_PARSER_CACHE :
case Doctrine :: ATTR_SQL_CACHE :
if ( $value !== null ) {
if ( ! ( $value instanceof Doctrine_Cache_Interface )) {
throw new Doctrine_Exception ( 'Cache driver should implement Doctrine_Cache_Interface' );
}
}
break ;
2006-12-29 21:30:37 +00:00
case Doctrine :: ATTR_VLD :
case Doctrine :: ATTR_AUTO_LENGTH_VLD :
case Doctrine :: ATTR_AUTO_TYPE_VLD :
case Doctrine :: ATTR_QUERY_LIMIT :
case Doctrine :: ATTR_QUOTE_IDENTIFIER :
case Doctrine :: ATTR_PORTABILITY :
case Doctrine :: ATTR_DEFAULT_TABLE_TYPE :
case Doctrine :: ATTR_ACCESSOR_PREFIX_GET :
case Doctrine :: ATTR_ACCESSOR_PREFIX_SET :
2007-01-24 22:50:49 +00:00
case Doctrine :: ATTR_EMULATE_DATABASE :
2007-03-02 20:47:17 +00:00
case Doctrine :: ATTR_DEFAULT_SEQUENCE :
2007-03-21 22:11:18 +00:00
case Doctrine :: ATTR_EXPORT :
2007-05-11 19:08:16 +00:00
case Doctrine :: ATTR_DECIMAL_PLACES :
2007-05-30 10:20:21 +00:00
case Doctrine :: ATTR_LOAD_REFERENCES :
2006-12-29 21:46:14 +00:00
2006-12-29 21:30:37 +00:00
break ;
case Doctrine :: ATTR_SEQCOL_NAME :
if ( ! is_string ( $value )) {
throw new Doctrine_Exception ( 'Sequence column name attribute only accepts string values' );
}
break ;
case Doctrine :: ATTR_FIELD_CASE :
if ( $value != 0 && $value != CASE_LOWER && $value != CASE_UPPER )
throw new Doctrine_Exception ( 'Field case attribute should be either 0, CASE_LOWER or CASE_UPPER constant.' );
break ;
case Doctrine :: ATTR_SEQNAME_FORMAT :
case Doctrine :: ATTR_IDXNAME_FORMAT :
if ( $this instanceof Doctrine_Table ) {
throw new Doctrine_Exception ( 'Sequence / index name format attributes cannot be set'
. 'at table level (only at connection or global level).' );
}
break ;
default :
throw new Doctrine_Exception ( " Unknown attribute. " );
2006-12-29 14:01:31 +00:00
};
$this -> attributes [ $attribute ] = $value ;
}
/**
* @ param Doctrine_EventListener $listener
* @ return void
*/
2006-12-29 14:40:47 +00:00
public function setEventListener ( $listener )
{
2006-12-29 14:01:31 +00:00
return $this -> setListener ( $listener );
}
/**
* addListener
*
2007-06-25 17:48:44 +00:00
* @ param Doctrine_EventListener_Interface | Doctrine_Overloadable $listener
* @ return Doctrine_Connection_Informix | Doctrine_Connection_Mssql | Doctrine_Connection_Oracle |
* Doctrine_Connection_Db2 | Doctrine_Connection_Firebird | Doctrine_Connection_Common |
* Doctrine_Manager | Doctrine_Connection | Doctrine_Table
2006-12-29 14:01:31 +00:00
*/
2006-12-29 14:40:47 +00:00
public function addListener ( $listener , $name = null )
{
2007-06-12 19:45:28 +00:00
if ( ! isset ( $this -> attributes [ Doctrine :: ATTR_LISTENER ]) ||
2007-06-07 18:21:07 +00:00
! ( $this -> attributes [ Doctrine :: ATTR_LISTENER ] instanceof Doctrine_EventListener_Chain )) {
2006-12-29 14:01:31 +00:00
$this -> attributes [ Doctrine :: ATTR_LISTENER ] = new Doctrine_EventListener_Chain ();
}
$this -> attributes [ Doctrine :: ATTR_LISTENER ] -> add ( $listener , $name );
return $this ;
}
/**
* getListener
*
2007-06-25 17:48:44 +00:00
* @ return Doctrine_EventListener_Interface | Doctrine_Overloadable
2006-12-29 14:01:31 +00:00
*/
2006-12-29 14:40:47 +00:00
public function getListener ()
{
2006-12-29 14:01:31 +00:00
if ( ! isset ( $this -> attributes [ Doctrine :: ATTR_LISTENER ])) {
if ( isset ( $this -> parent )) {
return $this -> parent -> getListener ();
}
return null ;
}
return $this -> attributes [ Doctrine :: ATTR_LISTENER ];
}
/**
* setListener
*
2007-06-25 17:48:44 +00:00
* @ param Doctrine_EventListener_Interface | Doctrine_Overloadable $listener
* @ return Doctrine_Connection_Informix | Doctrine_Connection_Mssql | Doctrine_Connection_Oracle |
* Doctrine_Connection_Db2 | Doctrine_Connection_Firebird | Doctrine_Connection_Common |
* Doctrine_Manager | Doctrine_Connection | Doctrine_Table
2006-12-29 14:01:31 +00:00
*/
2006-12-29 14:40:47 +00:00
public function setListener ( $listener )
{
2006-12-29 14:01:31 +00:00
if ( ! ( $listener instanceof Doctrine_EventListener_Interface )
&& ! ( $listener instanceof Doctrine_Overloadable )
) {
2007-06-19 23:33:04 +00:00
throw new Doctrine_EventListener_Exception ( " Couldn't set eventlistener. EventListeners should implement either Doctrine_EventListener_Interface or Doctrine_Overloadable " );
2006-12-29 14:01:31 +00:00
}
$this -> attributes [ Doctrine :: ATTR_LISTENER ] = $listener ;
return $this ;
}
/**
* returns the value of an attribute
*
* @ param integer $attribute
* @ return mixed
*/
2006-12-29 14:40:47 +00:00
public function getAttribute ( $attribute )
{
2006-12-29 14:01:31 +00:00
$attribute = ( int ) $attribute ;
2007-05-24 16:53:51 +00:00
if ( $attribute < 0 ) {
2006-12-29 14:01:31 +00:00
throw new Doctrine_Exception ( 'Unknown attribute.' );
2007-05-24 16:53:51 +00:00
}
2006-12-29 14:01:31 +00:00
if ( ! isset ( $this -> attributes [ $attribute ])) {
if ( isset ( $this -> parent )) {
return $this -> parent -> getAttribute ( $attribute );
}
return null ;
}
return $this -> attributes [ $attribute ];
}
/**
* getAttributes
* returns all attributes as an array
*
* @ return array
*/
2006-12-29 14:40:47 +00:00
public function getAttributes ()
{
2006-12-29 14:01:31 +00:00
return $this -> attributes ;
}
/**
* sets a parent for this configurable component
* the parent must be configurable component itself
*
* @ param Doctrine_Configurable $component
* @ return void
*/
2006-12-29 14:40:47 +00:00
public function setParent ( Doctrine_Configurable $component )
{
2006-12-29 14:01:31 +00:00
$this -> parent = $component ;
}
/**
* getParent
* returns the parent of this component
*
* @ return Doctrine_Configurable
*/
2006-12-29 14:40:47 +00:00
public function getParent ()
{
2006-12-29 14:01:31 +00:00
return $this -> parent ;
}
}