. */ namespace Fisharebest\Webtrees; /** * Provide an interface to the wt_site_setting table. */ class Site { /** * Everything from the wt_site_setting table. * * @var array */ private static $settings = null; /** * Get the site’s configuration settings * * @param string $setting_name * * @return string|null */ public static function getPreference($setting_name) { // There are lots of settings, and we need to fetch lots of them on every page // so it is quicker to fetch them all in one go. if (self::$settings === null) { self::$settings = Database::prepare( "SELECT SQL_CACHE setting_name, setting_value FROM `##site_setting`" )->fetchAssoc(); } // A setting that hasn't yet been set? if (!array_key_exists($setting_name, self::$settings)) { self::$settings[$setting_name] = null; } return self::$settings[$setting_name]; } /** * Set the site’s configuration settings. * * @param string $setting_name * @param string|int|bool $setting_value */ public static function setPreference($setting_name, $setting_value) { // Only need to update the database if the setting has actually changed. if (self::getPreference($setting_name) != $setting_value) { if ($setting_value === null) { Database::prepare( "DELETE FROM `##site_setting` WHERE setting_name = :setting_name" )->execute(array( 'setting_name' => $setting_name, )); } else { Database::prepare( "REPLACE INTO `##site_setting` (setting_name, setting_value)" . " VALUES (:setting_name, LEFT(:setting_value, 255))" )->execute(array( 'setting_name' => $setting_name, 'setting_value' => $setting_value, )); } self::$settings[$setting_name] = $setting_value; Log::addConfigurationLog('Site setting "' . $setting_name . '" set to "' . $setting_value . '"'); } } }