X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=functions%2Fprefs.php;h=10ea919a3d78f2e76454382eb9e66ca8f959dff4;hb=ba0d44609ab8bc4e5ec05d0846dfa055705ee039;hp=35e7860717d9859ca3f8129efd0adfb6e9b6b9e8;hpb=3392dc867232037b2c6e2089ebcab9d64e154db7;p=squirrelmail.git diff --git a/functions/prefs.php b/functions/prefs.php index 35e78607..10ea919a 100644 --- a/functions/prefs.php +++ b/functions/prefs.php @@ -3,7 +3,7 @@ /** * prefs.php * - * Copyright (c) 1999-2001 The SquirrelMail Development Team + * Copyright (c) 1999-2003 The SquirrelMail Project Team * Licensed under the GNU GPL. For full terms see the file COPYING. * * This contains functions for manipulating user preferences @@ -11,185 +11,54 @@ * $Id$ */ -global $prefs_are_cached, $prefs_cache; -if (!session_is_registered('prefs_are_cached')) { - $prefs_are_cached = false; - $prefs_cache = array(); -} - -/** - * Check the preferences into the session cache. - */ -function cachePrefValues($data_dir, $username) { - global $prefs_are_cached, $prefs_cache; - - if ($prefs_are_cached) { - return; - } - - $filename = getHashedFile($username, $data_dir, "$username.pref"); - - if (!file_exists($filename)) { - printf (_("Preference file, %s, does not exist. Log out, and log back in to create a default preference file."), $filename); - exit; - } - - $file = fopen($filename, 'r'); - - /* Read in the preferences. */ - $highlight_num = 0; - while (! feof($file)) { - $pref = trim(fgets($file, 1024)); - $equalsAt = strpos($pref, '='); - if ($equalsAt > 0) { - $key = substr($pref, 0, $equalsAt); - $value = substr($pref, $equalsAt + 1); - if (substr($key, 0, 9) == 'highlight') { - $key = 'highlight' . $highlight_num; - $highlight_num ++; - } - - if ($value != '') { - $prefs_cache[$key] = $value; - } - } - } - fclose($file); - - session_unregister('prefs_cache'); - session_register('prefs_cache'); - - $prefs_are_cached = true; - session_unregister('prefs_are_cached'); - session_register('prefs_are_cached'); -} - -/** - * Return the value for the prefernce given by $string. - */ -function getPref($data_dir, $username, $string, $default = '') { - global $prefs_cache; - $result = ''; - - cachePrefValues($data_dir, $username); +require_once(SM_PATH . 'functions/global.php'); - if (isset($prefs_cache[$string])) { - $result = $prefs_cache[$string]; - } else { - $result = $default; - } +sqgetGlobalVar('prefs_cache', $prefs_cache, SQ_SESSION ); +sqgetGlobalVar('prefs_are_cached', $prefs_are_cached, SQ_SESSION ); - return ($result); -} +$rg = ini_get('register_globals'); -/** - * Save the preferences for this user. - */ -function savePrefValues($data_dir, $username) { - global $prefs_cache; - - $filename = getHashedFile($username, $data_dir, "$username.pref"); - - $file = fopen($filename, 'w'); - foreach ($prefs_cache as $Key => $Value) { - if (isset($Value)) { - fwrite($file, $Key . '=' . $Value . "\n"); - } - } - fclose($file); -} - -/** - * Remove a preference for the current user. - */ -function removePref($data_dir, $username, $string) { - global $prefs_cache; - - cachePrefValues($data_dir, $username); - - if (isset($prefs_cache[$string])) { - unset($prefs_cache[$string]); - } - - savePrefValues($data_dir, $username); -} - -/** - * Set a there preference $string to $value. - */ -function setPref($data_dir, $username, $string, $value) { - global $prefs_cache; - - cachePrefValues($data_dir, $username); - if (isset($prefs_cache[$string]) && ($prefs_cache[$string] == $value)) { - return; - } - - if ($value === '') { - removePref($data_dir, $username, $string); - return; - } - - $prefs_cache[$string] = $value; - savePrefValues($data_dir, $username); -} - -/** - * Check for a preferences file. If one can not be found, create it. - */ -function checkForPrefs($data_dir, $username) { - $filename = getHashedFile($username, $data_dir, "$username.pref"); - if (!file_exists($filename) ) { - if (!copy($data_dir . 'default_pref', $filename)) { - echo _("Error opening ") . $filename; - exit; - } - } +/* if php version >= 4.1 OR (4.0 AND $rg = off) */ +if ( !sqsession_is_registered('prefs_are_cached') || + !isset( $prefs_cache) || + !is_array( $prefs_cache) || + check_php_version(4,1) || + empty($rg) + ) { + $prefs_are_cached = false; + $prefs_cache = array(); } -/** - * Write the User Signature. - */ -function setSig($data_dir, $username, $value) { - $filename = getHashedFile($username, $data_dir, "$username.sig"); - $file = fopen($filename, 'w'); - fwrite($file, $value); - fclose($file); +if (isset($prefs_dsn) && !empty($prefs_dsn)) { + require_once(SM_PATH . 'functions/db_prefs.php'); +} else { + require_once(SM_PATH . 'functions/file_prefs.php'); } -/** - * Get the signature. - */ -function getSig($data_dir, $username) { - #$filename = $data_dir . $username . '.sig'; - $filename = getHashedFile($username, $data_dir, "$username.sig"); - $sig = ''; - if (file_exists($filename)) { - $file = fopen($filename, 'r'); - while (!feof($file)) { - $sig .= fgets($file, 1024); - } - fclose($file); - } - return $sig; -} +/* Hashing functions */ function getHashedFile($username, $dir, $datafile, $hash_search = true) { global $dir_hash_level; + /* Remove trailing slash from $dir if found */ + if (substr($dir, -1) == '/') { + $dir = substr($dir, 0, strlen($dir) - 1); + } + /* Compute the hash for this user and extract the hash directories. */ $hash_dirs = computeHashDirs($username); /* First, get and make sure the full hash directory exists. */ $real_hash_dir = getHashedDir($username, $dir, $hash_dirs); - /* Set the value of our real data file. */ + /* Set the value of our real data file, after we've removed unwanted characters. */ + $datafile = str_replace('/', '_', $datafile); $result = "$real_hash_dir/$datafile"; /* Check for this file in the real hash directory. */ - if ($hash_search && !file_exists($result)) { + if ($hash_search && !@file_exists($result)) { /* First check the base directory, the most common location. */ - if (file_exists("$dir/$datafile")) { + if (@file_exists("$dir/$datafile")) { rename("$dir/$datafile", $result); /* Then check the full range of possible hash directories. */ @@ -197,7 +66,7 @@ function getHashedFile($username, $dir, $datafile, $hash_search = true) { $check_hash_dir = $dir; for ($h = 0; $h < 4; ++$h) { $check_hash_dir .= '/' . $hash_dirs[$h]; - if (is_readable("$check_hash_dir/$datafile")) { + if (@is_readable("$check_hash_dir/$datafile")) { rename("$check_hash_dir/$datafile", $result); break; } @@ -212,6 +81,11 @@ function getHashedFile($username, $dir, $datafile, $hash_search = true) { function getHashedDir($username, $dir, $hash_dirs = '') { global $dir_hash_level; + /* Remove trailing slash from $dir if found */ + if (substr($dir, -1) == '/') { + $dir = substr($dir, 0, strlen($dir) - 1); + } + /* If necessary, populate the hash dir variable. */ if ($hash_dirs == '') { $hash_dirs = computeHashDirs($username); @@ -221,8 +95,13 @@ function getHashedDir($username, $dir, $hash_dirs = '') { $real_hash_dir = $dir; for ($h = 0; $h < $dir_hash_level; ++$h) { $real_hash_dir .= '/' . $hash_dirs[$h]; - if (!is_dir($real_hash_dir)) { - mkdir($real_hash_dir, 0770); + if (!@is_dir($real_hash_dir)) { + if (!@mkdir($real_hash_dir, 0770)) { + echo sprintf(_("Error creating directory %s."), $real_hash_dir) . '
' . + _("Could not create hashed directory structure!") . "
\n" . + _("Please contact your system administrator and report this error.") . "
\n"; + exit; + } } }