<?php /** * Elgg installation * Various functions to assist with installing and upgrading the system * * @package Elgg * @subpackage Core * @license http://www.gnu.org/licenses/old-licenses/gpl-2.0.html GNU Public License version 2 * @author Curverider Ltd * @copyright Curverider Ltd 2008-2009 * @link http://elgg.org/ */ /** * Check that the installed version of PHP meets the minimum requirements (currently 5.2 or greater). * * @return bool */ function php_check_version() { /* if ( // TODO: Remove this when Redhat pulls its finger out (version_compare(phpversion(), '5.1.6', '>=')) && (version_compare(phpversion(), '5.2.0', '<')) ) register_error(elgg_echo('configurationwarning:phpversion')); */ if (version_compare(phpversion(), '5.1.2', '>=')) return true; return false; } /** * Validate the platform Elgg is being installed on. * * @throws ConfigurationException if the validation fails. * @return bool */ function validate_platform() { // Get database version if (!db_check_version()) throw new ConfigurationException(elgg_echo('ConfigurationException:BadDatabaseVersion')); // Now check PHP if (!php_check_version()) throw new ConfigurationException(elgg_echo('ConfigurationException:BadPHPVersion')); // TODO: Consider checking for installed modules etc return true; } /** * Returns whether or not the database has been installed * * @return true|false Whether the database has been installed */ function is_db_installed() { global $CONFIG; if (isset($CONFIG->db_installed)) { return $CONFIG->db_installed; } $tables = get_db_tables(); if (!$tables) { return false; } $CONFIG->db_installed = true; // Set flag if db is installed (if false then we want to check every time) return true; } /** * Returns whether or not other settings have been set * * @return true|false Whether or not the rest of the installation has been followed through with */ function is_installed() { global $CONFIG; return datalist_get('installed'); } /** * Copy and create a new settings.php from settings.example.php, substituting the variables in * $vars where appropriate. * * $vars is an associate array of $key => $value, where $key is the variable text you wish to substitute (eg * CONFIG_DBNAME will replace {{CONFIG_DBNAME}} in the settings file. * * @param array $vars The array of vars * @param string $in_file Optional input file (if not settings.example.php) * @return string The file containing substitutions. */ function create_settings(array $vars, $in_file="engine/settings.example.php") { $file = file_get_contents($in_file); if (!$file) return false; foreach ($vars as $k => $v) $file = str_replace("{{".$k."}}", $v, $file); return $file; } /** * Initialisation for installation functions * */ function install_init() { register_action("systemsettings/install",true); } register_elgg_event_handler("boot","system","install_init"); ?>