2008-05-30 11:40:08 +00:00
< ? php
/**
2010-11-14 13:02:17 -05:00
* Configure class
2008-05-30 11:40:08 +00:00
*
2010-10-03 12:38:58 -04:00
* PHP 5
2008-05-30 11:40:08 +00:00
*
2009-11-06 17:46:59 +11:00
* CakePHP ( tm ) : Rapid Development Framework ( http :// cakephp . org )
2010-01-26 14:18:20 -05:00
* Copyright 2005 - 2010 , Cake Software Foundation , Inc . ( http :// cakefoundation . org )
2008-05-30 11:40:08 +00:00
*
* Licensed under The MIT License
* Redistributions of files must retain the above copyright notice .
*
2010-01-26 14:18:20 -05:00
* @ copyright Copyright 2005 - 2010 , Cake Software Foundation , Inc . ( http :// cakefoundation . org )
2009-11-06 17:00:11 +11:00
* @ link http :// cakephp . org CakePHP ( tm ) Project
2008-10-30 17:30:26 +00:00
* @ package cake
* @ subpackage cake . cake . libs
* @ since CakePHP ( tm ) v 1.0 . 0.2363
2009-11-06 17:51:51 +11:00
* @ license MIT License ( http :// www . opensource . org / licenses / mit - license . php )
2008-05-30 11:40:08 +00:00
*/
2009-07-25 15:57:49 -07:00
2008-05-30 11:40:08 +00:00
/**
2010-11-14 18:26:54 -05:00
* Configuration class . Used for managing runtime configuration information .
*
* Provides features for reading and writing to the runtime configuration , as well
* as methods for loading additional configuration files or storing runtime configuration
* for future use .
2008-05-30 11:40:08 +00:00
*
2008-10-30 17:30:26 +00:00
* @ package cake
* @ subpackage cake . cake . libs
2010-03-28 11:34:58 -04:00
* @ link http :// book . cakephp . org / view / 924 / The - Configuration - Class
2008-05-30 11:40:08 +00:00
*/
2010-07-05 21:50:36 -04:00
class Configure {
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
2010-07-04 22:00:49 -04:00
* Array of values currently stored in Configure .
2008-05-30 11:40:08 +00:00
*
2010-07-04 22:00:49 -04:00
* @ var array
2008-05-30 11:40:08 +00:00
*/
2010-07-05 21:50:36 -04:00
protected static $_values = array (
'debug' => 0
);
2010-07-04 22:00:49 -04:00
2010-12-04 00:09:11 -05:00
/**
* Configured reader classes , used to load config files from resources
*
* @ var array
* @ see Configure :: load ()
*/
protected static $_readers = array ();
2010-07-04 22:00:49 -04:00
/**
* Initializes configure and runs the bootstrap process .
2010-11-14 20:37:50 -05:00
* Bootstrapping includes the following steps :
*
* - Setup App array in Configure .
* - Include app / config / core . php .
* - Configure core cache configurations .
* - Load App cache files .
* - Include app / config / bootstrap . php .
* - Setup error / exception handlers .
2010-07-04 22:00:49 -04:00
*
* @ return void
*/
2010-07-04 22:03:25 -04:00
public static function bootstrap ( $boot = true ) {
2010-11-14 20:37:50 -05:00
if ( $boot ) {
2010-12-04 16:29:34 -05:00
self :: write ( 'App' , array (
'base' => false ,
'baseUrl' => false ,
'dir' => APP_DIR ,
'webroot' => WEBROOT_DIR ,
'www_root' => WWW_ROOT
));
2010-11-14 20:37:50 -05:00
if ( ! include ( CONFIGS . 'core.php' )) {
trigger_error ( sprintf ( __ ( " Can't find application core file. Please create %score.php, and make sure it is readable by PHP. " ), CONFIGS ), E_USER_ERROR );
}
2010-12-04 16:29:34 -05:00
if ( empty ( self :: $_values [ 'Cache' ][ 'disable' ])) {
2010-11-14 20:37:50 -05:00
$cache = Cache :: config ( 'default' );
if ( empty ( $cache [ 'settings' ])) {
trigger_error ( __ ( 'Cache not configured properly. Please check Cache::config(); in APP/config/core.php' ), E_USER_WARNING );
$cache = Cache :: config ( 'default' , array ( 'engine' => 'File' ));
}
$path = $prefix = $duration = null ;
if ( ! empty ( $cache [ 'settings' ][ 'path' ])) {
$path = realpath ( $cache [ 'settings' ][ 'path' ]);
} else {
$prefix = $cache [ 'settings' ][ 'prefix' ];
}
2010-12-04 16:29:34 -05:00
if ( self :: $_values [ 'debug' ] >= 1 ) {
2010-11-14 20:37:50 -05:00
$duration = '+10 seconds' ;
} else {
$duration = '+999 days' ;
}
if ( Cache :: config ( '_cake_core_' ) === false ) {
Cache :: config ( '_cake_core_' , array_merge (( array ) $cache [ 'settings' ], array (
'prefix' => $prefix . 'cake_core_' , 'path' => $path . DS . 'persistent' . DS ,
'serialize' => true , 'duration' => $duration
)));
}
if ( Cache :: config ( '_cake_model_' ) === false ) {
Cache :: config ( '_cake_model_' , array_merge (( array ) $cache [ 'settings' ], array (
'prefix' => $prefix . 'cake_model_' , 'path' => $path . DS . 'models' . DS ,
'serialize' => true , 'duration' => $duration
)));
}
}
App :: init ();
App :: build ();
if ( ! include ( CONFIGS . 'bootstrap.php' )) {
trigger_error ( sprintf ( __ ( " Can't find application bootstrap file. Please create %sbootstrap.php, and make sure it is readable by PHP. " ), CONFIGS ), E_USER_ERROR );
}
2010-11-27 14:32:43 -05:00
$level = - 1 ;
2010-11-14 20:56:03 -05:00
if ( isset ( self :: $_values [ 'Error' ][ 'level' ])) {
error_reporting ( self :: $_values [ 'Error' ][ 'level' ]);
2010-11-27 14:32:43 -05:00
$level = self :: $_values [ 'Error' ][ 'level' ];
}
if ( ! empty ( self :: $_values [ 'Error' ][ 'handler' ])) {
set_error_handler ( self :: $_values [ 'Error' ][ 'handler' ], $level );
2010-11-14 20:56:03 -05:00
}
2010-11-14 20:37:50 -05:00
if ( ! empty ( self :: $_values [ 'Exception' ][ 'handler' ])) {
set_exception_handler ( self :: $_values [ 'Exception' ][ 'handler' ]);
}
}
2008-05-30 11:40:08 +00:00
}
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
2010-11-14 18:26:54 -05:00
* Used to store a dynamic variable in Configure .
2008-05-30 11:40:08 +00:00
*
2009-02-04 05:00:59 +00:00
* Usage :
* {{{
2008-05-30 11:40:08 +00:00
* Configure :: write ( 'One.key1' , 'value of the Configure::One[key1]' );
* Configure :: write ( array ( 'One.key1' => 'value of the Configure::One[key1]' ));
2008-12-17 04:13:45 +00:00
* Configure :: write ( 'One' , array (
* 'key1' => 'value of the Configure::One[key1]' ,
* 'key2' => 'value of the Configure::One[key2]'
* );
2009-06-07 15:24:10 -07:00
*
2008-12-17 04:13:45 +00:00
* Configure :: write ( array (
* 'One.key1' => 'value of the Configure::One[key1]' ,
* 'One.key2' => 'value of the Configure::One[key2]'
* ));
2009-02-04 05:00:59 +00:00
* }}}
2008-05-30 11:40:08 +00:00
*
2010-03-28 11:34:58 -04:00
* @ link http :// book . cakephp . org / view / 926 / write
2008-05-30 11:40:08 +00:00
* @ param array $config Name of var to write
* @ param mixed $value Value to set for var
2010-03-04 10:20:15 +11:00
* @ return boolean True if write was successful
2008-05-30 11:40:08 +00:00
*/
2010-04-15 00:06:17 -04:00
public static function write ( $config , $value = null ) {
2008-05-30 11:40:08 +00:00
if ( ! is_array ( $config )) {
$config = array ( $config => $value );
}
2009-07-24 13:50:50 -07:00
foreach ( $config as $name => $value ) {
if ( strpos ( $name , '.' ) === false ) {
2010-07-04 22:00:49 -04:00
self :: $_values [ $name ] = $value ;
2009-07-24 13:50:50 -07:00
} else {
2009-11-21 19:57:04 -05:00
$names = explode ( '.' , $name , 4 );
switch ( count ( $names )) {
case 2 :
2010-07-04 22:00:49 -04:00
self :: $_values [ $names [ 0 ]][ $names [ 1 ]] = $value ;
2009-11-21 19:57:04 -05:00
break ;
case 3 :
2010-07-04 22:00:49 -04:00
self :: $_values [ $names [ 0 ]][ $names [ 1 ]][ $names [ 2 ]] = $value ;
2010-09-06 16:53:04 -04:00
break ;
2009-11-21 19:57:04 -05:00
case 4 :
$names = explode ( '.' , $name , 2 );
2010-07-04 22:00:49 -04:00
if ( ! isset ( self :: $_values [ $names [ 0 ]])) {
self :: $_values [ $names [ 0 ]] = array ();
2009-11-21 19:57:04 -05:00
}
2010-07-04 22:00:49 -04:00
self :: $_values [ $names [ 0 ]] = Set :: insert ( self :: $_values [ $names [ 0 ]], $names [ 1 ], $value );
2009-11-21 19:57:04 -05:00
break ;
2009-07-24 13:50:50 -07:00
}
2008-05-30 11:40:08 +00:00
}
}
2010-12-04 00:24:09 -05:00
if ( isset ( $config [ 'debug' ]) && function_exists ( 'ini_set' )) {
if ( self :: $_values [ 'debug' ]) {
ini_set ( 'display_errors' , 1 );
} else {
ini_set ( 'display_errors' , 0 );
2009-09-07 23:28:50 -04:00
}
2008-05-30 11:40:08 +00:00
}
2010-03-04 10:20:15 +11:00
return true ;
2008-05-30 11:40:08 +00:00
}
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
2010-11-14 18:26:54 -05:00
* Used to read information stored in Configure . Its not
2010-07-05 21:57:39 -04:00
* possible to store `null` values in Configure .
2008-05-30 11:40:08 +00:00
*
2009-11-15 18:09:04 -05:00
* Usage :
* {{{
2008-05-30 11:40:08 +00:00
* Configure :: read ( 'Name' ); will return all values for Name
* Configure :: read ( 'Name.key' ); will return only the value of Configure :: Name [ key ]
2009-11-15 18:09:04 -05:00
* }}}
2008-05-30 11:40:08 +00:00
*
2010-03-28 11:34:58 -04:00
* @ link http :// book . cakephp . org / view / 927 / read
2009-11-15 18:09:04 -05:00
* @ param string $var Variable to obtain . Use '.' to access array elements .
2010-07-05 21:57:39 -04:00
* @ return mixed value stored in configure , or null .
2008-05-30 11:40:08 +00:00
*/
2010-07-05 21:50:36 -04:00
public static function read ( $var = null ) {
if ( $var === null ) {
return self :: $_values ;
}
if ( isset ( self :: $_values [ $var ])) {
return self :: $_values [ $var ];
2008-05-30 11:40:08 +00:00
}
2009-07-24 13:50:50 -07:00
if ( strpos ( $var , '.' ) !== false ) {
2009-11-21 19:57:04 -05:00
$names = explode ( '.' , $var , 3 );
2009-07-24 13:50:50 -07:00
$var = $names [ 0 ];
2008-05-30 11:40:08 +00:00
}
2010-07-04 22:00:49 -04:00
if ( ! isset ( self :: $_values [ $var ])) {
2009-07-24 13:50:50 -07:00
return null ;
2008-05-30 11:40:08 +00:00
}
2009-11-21 19:57:04 -05:00
switch ( count ( $names )) {
case 2 :
2010-07-04 22:00:49 -04:00
if ( isset ( self :: $_values [ $var ][ $names [ 1 ]])) {
return self :: $_values [ $var ][ $names [ 1 ]];
2009-11-21 19:57:04 -05:00
}
break ;
case 3 :
2010-07-04 22:00:49 -04:00
if ( isset ( self :: $_values [ $var ][ $names [ 1 ]][ $names [ 2 ]])) {
return self :: $_values [ $var ][ $names [ 1 ]][ $names [ 2 ]];
2009-11-21 19:57:04 -05:00
}
2010-07-04 22:00:49 -04:00
if ( ! isset ( self :: $_values [ $var ][ $names [ 1 ]])) {
2009-11-21 19:57:04 -05:00
return null ;
}
2010-07-04 22:00:49 -04:00
return Set :: classicExtract ( self :: $_values [ $var ][ $names [ 1 ]], $names [ 2 ]);
2009-11-21 19:57:04 -05:00
break ;
}
return null ;
2008-05-30 11:40:08 +00:00
}
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
2010-11-14 18:26:54 -05:00
* Used to delete a variable from Configure .
2008-05-30 11:40:08 +00:00
*
* Usage :
2009-11-15 18:09:04 -05:00
* {{{
2008-05-30 11:40:08 +00:00
* Configure :: delete ( 'Name' ); will delete the entire Configure :: Name
* Configure :: delete ( 'Name.key' ); will delete only the Configure :: Name [ key ]
2009-11-15 18:09:04 -05:00
* }}}
2008-05-30 11:40:08 +00:00
*
2010-03-28 11:34:58 -04:00
* @ link http :// book . cakephp . org / view / 928 / delete
2008-05-30 11:40:08 +00:00
* @ param string $var the var to be deleted
2008-09-25 16:49:56 +00:00
* @ return void
2008-05-30 11:40:08 +00:00
*/
2010-04-15 00:06:17 -04:00
public static function delete ( $var = null ) {
2009-07-24 13:50:50 -07:00
if ( strpos ( $var , '.' ) === false ) {
2010-07-04 22:00:49 -04:00
unset ( self :: $_values [ $var ]);
2009-07-24 13:50:50 -07:00
return ;
2008-05-30 11:40:08 +00:00
}
2009-07-24 13:50:50 -07:00
$names = explode ( '.' , $var , 2 );
2010-07-04 22:00:49 -04:00
self :: $_values [ $names [ 0 ]] = Set :: remove ( self :: $_values [ $names [ 0 ]], $names [ 1 ]);
2008-05-30 11:40:08 +00:00
}
2009-07-24 21:18:37 +02:00
2010-12-04 00:09:11 -05:00
/**
* Add a new reader to Configure . Readers allow you to read configuration
* files in various formats / storage locations . CakePHP comes with two built - in readers
* PhpReader and IniReader . You can also implement your own reader classes in your application .
*
* To add a new reader to Configure :
*
2010-12-04 00:10:42 -05:00
* `Configure::config('ini', new IniReader());`
2010-12-04 00:09:11 -05:00
*
2010-12-04 00:14:55 -05:00
* @ param string $name The name of the reader being configured . This alias is used later to
2010-12-04 00:09:11 -05:00
* read values from a specific reader .
* @ param ConfigReaderInterface $reader The reader to append .
* @ return void
*/
2010-12-04 00:14:55 -05:00
public static function config ( $name , ConfigReaderInterface $reader ) {
self :: $_readers [ $name ] = $reader ;
2010-12-04 00:09:11 -05:00
}
/**
* Gets the names of the configured reader objects .
*
* @ return array Array of the configured reader objects .
*/
public static function configured () {
return array_keys ( self :: $_readers );
}
2010-12-04 00:14:55 -05:00
/**
* Remove a configured reader . This will unset the reader
* and make any future attempts to use it cause an Exception .
*
* @ param string $name Name of the reader to drop .
* @ return boolean Success
*/
public static function drop ( $name ) {
if ( ! isset ( self :: $_readers [ $name ])) {
return false ;
}
unset ( self :: $_readers [ $name ]);
return true ;
}
2008-05-30 11:40:08 +00:00
/**
2010-12-04 10:41:23 -05:00
* Loads stored configuration information from a resource . You can add
* config file resource readers with `Configure::config()` .
2010-11-14 18:26:54 -05:00
*
2010-12-04 10:41:23 -05:00
* Loaded configuration infomration will be merged with the current
* runtime configuration . You can load configuration files from plugins
* by preceeding the filename with the plugin name .
2008-05-30 11:40:08 +00:00
*
2010-12-04 10:41:23 -05:00
* `Configure::load('Users.user', 'default')`
*
* Would load the 'user' config file using the default config reader . You can load
* app config files by giving the name of the resource you want loaded .
*
* `Configure::load('setup', 'default');`
2008-05-30 11:40:08 +00:00
*
2010-03-28 11:34:58 -04:00
* @ link http :// book . cakephp . org / view / 929 / load
2010-12-04 12:15:47 -05:00
* @ param string $key name of configuration resource to load .
2010-12-04 01:05:12 -05:00
* @ param string $config Name of the configured reader to use to read the resource identfied by $key .
2010-12-04 12:15:47 -05:00
* @ return mixed false if file not found , void if load successful .
* @ throws Exception Will throw any exceptions the reader raises .
2008-05-30 11:40:08 +00:00
*/
2010-12-04 01:05:12 -05:00
public static function load ( $key , $config = 'default' ) {
if ( ! isset ( self :: $_readers [ $config ])) {
2008-05-30 11:40:08 +00:00
return false ;
}
2010-12-04 01:05:12 -05:00
$values = self :: $_readers [ $config ] -> read ( $key );
return self :: write ( $values );
2008-05-30 11:40:08 +00:00
}
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
2008-10-28 17:08:14 +00:00
* Used to determine the current version of CakePHP .
2008-05-30 11:40:08 +00:00
*
2009-11-15 18:09:04 -05:00
* Usage `Configure::version();`
2008-05-30 11:40:08 +00:00
*
2010-03-28 11:34:58 -04:00
* @ link http :// book . cakephp . org / view / 930 / version
2008-05-30 11:40:08 +00:00
* @ return string Current version of CakePHP
*/
2010-04-15 00:06:17 -04:00
public static function version () {
2010-07-04 22:00:49 -04:00
if ( ! isset ( self :: $_values [ 'Cake' ][ 'version' ])) {
2008-05-30 11:40:08 +00:00
require ( CORE_PATH . 'cake' . DS . 'config' . DS . 'config.php' );
2010-07-23 18:42:30 -04:30
self :: write ( $config );
2008-05-30 11:40:08 +00:00
}
2010-07-04 22:00:49 -04:00
return self :: $_values [ 'Cake' ][ 'version' ];
2008-05-30 11:40:08 +00:00
}
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
2008-10-28 17:08:14 +00:00
* Used to write a config file to disk .
2008-05-30 11:40:08 +00:00
*
2009-11-15 18:09:04 -05:00
* {{{
2009-11-15 19:55:20 -05:00
* Configure :: store ( 'Model' , 'class_paths' , array ( 'Users' => array (
2008-12-17 04:13:45 +00:00
* 'path' => 'users' , 'plugin' => true
* )));
2009-11-15 18:09:04 -05:00
* }}}
2008-05-30 11:40:08 +00:00
*
* @ param string $type Type of config file to write , ex : Models , Controllers , Helpers , Components
* @ param string $name file name .
* @ param array $data array of values to store .
2008-09-25 16:49:56 +00:00
* @ return void
2008-05-30 11:40:08 +00:00
*/
2010-04-15 00:06:17 -04:00
public static function store ( $type , $name , $data = array ()) {
2008-05-30 11:40:08 +00:00
$write = true ;
$content = '' ;
foreach ( $data as $key => $value ) {
2009-11-15 01:00:22 +05:30
$content .= " \$ config[' $type '][' $key '] = " . var_export ( $value , true ) . " ; \n " ;
2008-05-30 11:40:08 +00:00
}
if ( is_null ( $type )) {
$write = false ;
}
2010-07-23 18:42:30 -04:30
self :: __writeConfig ( $content , $name , $write );
2008-05-30 11:40:08 +00:00
}
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
* Creates a cached version of a configuration file .
* Appends values passed from Configure :: store () to the cached file
*
* @ param string $content Content to write on file
* @ param string $name Name to use for cache file
* @ param boolean $write true if content should be written , false otherwise
2008-09-25 16:49:56 +00:00
* @ return void
2008-05-30 11:40:08 +00:00
* @ access private
*/
2010-07-04 22:00:49 -04:00
private static function __writeConfig ( $content , $name , $write = true ) {
2008-05-30 11:40:08 +00:00
$file = CACHE . 'persistent' . DS . $name . '.php' ;
2010-07-23 18:42:30 -04:30
if ( self :: read ( 'debug' ) > 0 ) {
2008-05-30 11:40:08 +00:00
$expires = " +10 seconds " ;
} else {
$expires = " +999 days " ;
}
$cache = cache ( 'persistent' . DS . $name . '.php' , null , $expires );
if ( $cache === null ) {
cache ( 'persistent' . DS . $name . '.php' , " <?php \n \$ config = array(); \n " , $expires );
}
if ( $write === true ) {
2010-07-23 18:42:30 -04:30
$fileClass = new SplFileObject ( $file , 'a' );
if ( $fileClass -> isWritable ()) {
$fileClass -> fwrite ( $content );
2008-05-30 11:40:08 +00:00
}
}
}
2009-07-24 21:18:37 +02:00
2010-12-04 00:09:11 -05:00
}
/**
* An interface for creating objects compatible with Configure :: load ()
*
* @ package cake . libs
*/
interface ConfigReaderInterface {
/**
* Read method is used for reading configuration information from sources .
* These sources can either be static resources like files , or dynamic ones like
* a database , or other datasource .
*
* @ param string $key
* @ return array An array of data to merge into the runtime configuration
*/
function read ( $key );
2010-11-14 20:34:10 -05:00
}