diff options
Diffstat (limited to 'engine/lib/configuration.php')
| -rw-r--r-- | engine/lib/configuration.php | 105 | 
1 files changed, 50 insertions, 55 deletions
| diff --git a/engine/lib/configuration.php b/engine/lib/configuration.php index 3fade8155..9bf1529d6 100644 --- a/engine/lib/configuration.php +++ b/engine/lib/configuration.php @@ -3,8 +3,9 @@   * Elgg configuration procedural code.   *   * Includes functions for manipulating the configuration values stored in the database - * Plugin authors should use the {@link get_config()}, {@link set_config()}, - * and {@unset_config()} functions to access or update config values. + * Plugin authors should use the {@link elgg_get_config()}, {@link elgg_set_config()}, + * {@link elgg_save_config()}, and {@unset_config()} functions to access or update + * config values.   *   * Elgg's configuration is split among 2 tables and 1 file:   * - dbprefix_config @@ -302,7 +303,7 @@ function datalist_set($name, $value) {  		. " set name = '{$sanitised_name}', value = '{$sanitised_value}'"  		. " ON DUPLICATE KEY UPDATE value='{$sanitised_value}'"); -	if ($success) { +	if ($success !== FALSE) {  		$DATALIST_CACHE[$name] = $value;  		return true;  	} else { @@ -517,10 +518,10 @@ function get_all_config($site_guid = 0) {  	$site_guid = (int) $site_guid;  	if ($site_guid == 0) { -		$site_guid = (int) $CONFIG->site_id; +		$site_guid = (int) $CONFIG->site_guid;  	} -	if ($result = get_data("SELECT * from {$CONFIG->dbprefix}config where site_guid = {$site_guid}")) { +	if ($result = get_data("SELECT * FROM {$CONFIG->dbprefix}config WHERE site_guid = $site_guid")) {  		foreach ($result as $r) {  			$name = $r->name;  			$value = $r->value; @@ -533,37 +534,49 @@ function get_all_config($site_guid = 0) {  }  /** - * Sets defaults for or attempts to autodetect some common config values and - * loads them into $CONFIG. + * Loads configuration related to this site   * - * @return true + * This loads from the config database table and the site entity   * @access private   */ -function set_default_config() { +function _elgg_load_site_config() {  	global $CONFIG; -	$install_root = str_replace("\\", "/", dirname(dirname(dirname(__FILE__)))); - -	// @todo this seldom works right. -	$pathpart = str_replace("//", "/", str_replace($_SERVER['DOCUMENT_ROOT'], "", $install_root)); -	if (substr($pathpart, 0, 1) != "/") { -		$pathpart = "/" . $pathpart; +	$CONFIG->site_guid = (int) datalist_get('default_site'); +	$CONFIG->site_id = $CONFIG->site_guid; +	$CONFIG->site = get_entity($CONFIG->site_guid); +	if (!$CONFIG->site) { +		throw new InstallationException(elgg_echo('InstallationException:SiteNotInstalled'));  	} -	$www_root = "http://" . $_SERVER['HTTP_HOST'] . $pathpart; +	$CONFIG->wwwroot = $CONFIG->site->url; +	$CONFIG->sitename = $CONFIG->site->name; +	$CONFIG->sitedescription = $CONFIG->site->description; +	$CONFIG->siteemail = $CONFIG->site->email; +	$CONFIG->url = $CONFIG->wwwroot; + +	get_all_config(); +} + +/** + * Loads configuration related to Elgg as an application + * + * This loads from the datalists database table + * @access private + */ +function _elgg_load_application_config() { +	global $CONFIG; + +	$install_root = str_replace("\\", "/", dirname(dirname(dirname(__FILE__))));  	$defaults = array(  		'path'			=>	"$install_root/",  		'view_path'		=>	"$install_root/views/",  		'plugins_path'	=>	"$install_root/mod/", -		'wwwroot'		=>	$www_root, -		'url'			=>	$www_root, -		'site_name'		=>	'New Elgg site',  		'language'		=>	'en', -		// compatibility with old names for ppl not using get_config() +		// compatibility with old names for plugins not using elgg_get_config()  		'viewpath'		=>	"$install_root/views/",  		'pluginspath'	=>	"$install_root/mod/", -		'sitename'		=>	'New Elgg site',  	);  	foreach ($defaults as $name => $value) { @@ -572,25 +585,6 @@ function set_default_config() {  		}  	} -	$CONFIG->context = array(); - -	return true; -} - -/** - * Loads values into $CONFIG. - * - * If Elgg is installed, this function pulls all rows from dbprefix_config - * and cherry picks some values from dbprefix_datalists.  This also extracts - * some commonly used values from the default site object. - * - * @elgg_event boot system - * @return true|null - * @access private - */ -function configuration_boot() { -	global $CONFIG; -  	$path = datalist_get('path');  	if (!empty($path)) {  		$CONFIG->path = $path; @@ -605,22 +599,23 @@ function configuration_boot() {  	} else {  		$CONFIG->simplecache_enabled = 1;  	} -	$viewpath_cache_enabled = datalist_get('viewpath_cache_enabled'); -	if ($viewpath_cache_enabled !== false) { -		$CONFIG->viewpath_cache_enabled = $viewpath_cache_enabled; +	$system_cache_enabled = datalist_get('system_cache_enabled'); +	if ($system_cache_enabled !== false) { +		$CONFIG->system_cache_enabled = $system_cache_enabled;  	} else { -		$CONFIG->viewpath_cache_enabled = 1; +		$CONFIG->system_cache_enabled = 1;  	} -	if (isset($CONFIG->site) && ($CONFIG->site instanceof ElggSite)) { -		$CONFIG->wwwroot = $CONFIG->site->url; -		$CONFIG->sitename = $CONFIG->site->name; -		$CONFIG->sitedescription = $CONFIG->site->description; -		$CONFIG->siteemail = $CONFIG->site->email; -	} -	$CONFIG->url = $CONFIG->wwwroot; -	// Load default settings from database -	get_all_config(); -} +	// initialize context here so it is set before the get_input call +	$CONFIG->context = array(); + +	// needs to be set before system, init for links in html head +	$viewtype = get_input('view', 'default'); +	$lastcached = datalist_get("simplecache_lastcached_$viewtype"); +	$CONFIG->lastcache = $lastcached; -elgg_register_event_handler('boot', 'system', 'configuration_boot', 10); +	$CONFIG->i18n_loaded_from_cache = false; + +	// this must be synced with the enum for the entities table +	$CONFIG->entity_types = array('group', 'object', 'site', 'user'); +} | 
