file_prefs.php 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251
  1. <?php
  2. /**
  3. * file_prefs.php
  4. *
  5. * Copyright (c) 1999-2002 The SquirrelMail Project Team
  6. * Licensed under the GNU GPL. For full terms see the file COPYING.
  7. *
  8. * This contains functions for manipulating user preferences in files
  9. *
  10. * $Id$
  11. */
  12. /**
  13. * Check the preferences into the session cache.
  14. */
  15. function cachePrefValues($data_dir, $username) {
  16. global $prefs_are_cached, $prefs_cache;
  17. if ( isset($prefs_are_cached) && $prefs_are_cached) {
  18. return;
  19. }
  20. sqsession_unregister('prefs_cache');
  21. sqsession_unregister('prefs_are_cached');
  22. /* Calculate the filename for the user's preference file */
  23. $filename = getHashedFile($username, $data_dir, "$username.pref");
  24. /* A call to checkForPrefs here should take eliminate the need for */
  25. /* this to be called throughout the rest of the SquirrelMail code. */
  26. checkForPrefs($data_dir, $username, $filename);
  27. /* Make sure that the preference file now DOES exist. */
  28. if (!file_exists($filename)) {
  29. include_once(SM_PATH . 'functions/display_messages.php');
  30. logout_error( sprintf( _("Preference file, %s, does not exist. Log out, and log back in to create a default preference file."), $filename) );
  31. exit;
  32. }
  33. /* Open the file, or else display an error to the user. */
  34. if(!$file = @fopen($filename, 'r'))
  35. {
  36. include_once(SM_PATH . 'functions/display_messages.php');
  37. logout_error( sprintf( _("Preference file, %s, could not be opened. Contact your system administrator to resolve this issue."), $filename) );
  38. exit;
  39. }
  40. /* Read in the preferences. */
  41. $highlight_num = 0;
  42. while (! feof($file)) {
  43. $pref = trim(fgets($file, 1024));
  44. $equalsAt = strpos($pref, '=');
  45. if ($equalsAt > 0) {
  46. $key = substr($pref, 0, $equalsAt);
  47. $value = substr($pref, $equalsAt + 1);
  48. /* this is to 'rescue' old-style highlighting rules. */
  49. if (substr($key, 0, 9) == 'highlight') {
  50. $key = 'highlight' . $highlight_num;
  51. $highlight_num ++;
  52. }
  53. if ($value != '') {
  54. $prefs_cache[$key] = $value;
  55. }
  56. }
  57. }
  58. fclose($file);
  59. $prefs_are_cached = TRUE;
  60. sqsession_register($prefs_cache, 'prefs_cache');
  61. sqsession_register($prefs_are_cached, 'prefs_are_cached');
  62. }
  63. /**
  64. * Return the value for the prefernce given by $string.
  65. */
  66. function getPref($data_dir, $username, $string, $default = '') {
  67. global $prefs_cache;
  68. $result = do_hook_function('get_pref_override',array($username,$string));
  69. if (!$result) {
  70. cachePrefValues($data_dir, $username);
  71. if (isset($prefs_cache[$string])) {
  72. $result = $prefs_cache[$string];
  73. } else {
  74. $result = do_hook_function('get_pref', array($username,$string));
  75. if (!$result) {
  76. $result = $default;
  77. }
  78. }
  79. }
  80. return ($result);
  81. }
  82. /**
  83. * Save the preferences for this user.
  84. */
  85. function savePrefValues($data_dir, $username) {
  86. global $prefs_cache;
  87. $filename = getHashedFile($username, $data_dir, "$username.pref");
  88. /* Open the file for writing, or else display an error to the user. */
  89. if(!$file = @fopen($filename.'.tmp', 'w'))
  90. {
  91. include_once(SM_PATH . 'functions/display_messages.php');
  92. logout_error( sprintf( _("Preference file, %s, could not be opened. Contact your system administrator to resolve this issue."), $filename.'.tmp') );
  93. exit;
  94. }
  95. foreach ($prefs_cache as $Key => $Value) {
  96. if (isset($Value)) {
  97. $tmpwrite = @fwrite($file, $Key . '=' . $Value . "\n");
  98. if ($tmpwrite == -1) {
  99. logout_error( sprintf( _("Preference file, %s, could not be written. Contact your system administrator to resolve this issue.") , $filename . '.tmp') );
  100. exit;
  101. }
  102. }
  103. }
  104. fclose($file);
  105. @copy($filename . '.tmp',$filename);
  106. @unlink($filename . '.tmp');
  107. chmod($filename, 0600);
  108. }
  109. /**
  110. * Remove a preference for the current user.
  111. */
  112. function removePref($data_dir, $username, $string) {
  113. global $prefs_cache;
  114. cachePrefValues($data_dir, $username);
  115. if (isset($prefs_cache[$string])) {
  116. unset($prefs_cache[$string]);
  117. }
  118. savePrefValues($data_dir, $username);
  119. }
  120. /**
  121. * Set a there preference $string to $value.
  122. */
  123. function setPref($data_dir, $username, $string, $value) {
  124. global $prefs_cache;
  125. cachePrefValues($data_dir, $username);
  126. if (isset($prefs_cache[$string]) && ($prefs_cache[$string] == $value)) {
  127. return;
  128. }
  129. if ($value === '') {
  130. removePref($data_dir, $username, $string);
  131. return;
  132. }
  133. $prefs_cache[$string] = $value;
  134. savePrefValues($data_dir, $username);
  135. }
  136. /**
  137. * Check for a preferences file. If one can not be found, create it.
  138. */
  139. function checkForPrefs($data_dir, $username, $filename = '') {
  140. /* First, make sure we have the filename. */
  141. if ($filename == '') {
  142. $filename = getHashedFile($username, $data_dir, "$username.pref");
  143. }
  144. /* Then, check if the file exists. */
  145. if (!@file_exists($filename) ) {
  146. /* First, check the $data_dir for the default preference file. */
  147. $default_pref = $data_dir . 'default_pref';
  148. /* If it is not there, check the internal data directory. */
  149. if (!@file_exists($default_pref)) {
  150. $default_pref = SM_PATH . 'data/default_pref';
  151. }
  152. /* Otherwise, report an error. */
  153. $errTitle = sprintf( _("Error opening %s"), $default_pref );
  154. if (!is_readable($default_pref)) {
  155. $errString = $errTitle . "<br>\n" .
  156. _("Default preference file not found or not readable!") . "<br>\n" .
  157. _("Please contact your system administrator and report this error.") . "<br>\n";
  158. include_once(SM_PATH . 'functions/display_messages.php' );
  159. logout_error( $errString, $errTitle );
  160. exit;
  161. } else if (!@copy($default_pref, $filename)) {
  162. $uid = 'httpd';
  163. if (function_exists('posix_getuid')){
  164. $user_data = posix_getpwuid(posix_getuid());
  165. $uid = $user_data['name'];
  166. }
  167. $errString = $errTitle . '<br>' .
  168. _("Could not create initial preference file!") . "<br>\n" .
  169. sprintf( _("%s should be writable by user %s"), $data_dir, $uid ) .
  170. "<br>\n" . _("Please contact your system administrator and report this error.") . "<br>\n";
  171. include_once(SM_PATH . 'functions/display_messages.php' );
  172. logout_error( $errString, $errTitle );
  173. exit;
  174. }
  175. }
  176. }
  177. /**
  178. * Write the User Signature.
  179. */
  180. function setSig($data_dir, $username, $number, $value) {
  181. $filename = getHashedFile($username, $data_dir, "$username.si$number");
  182. /* Open the file for writing, or else display an error to the user. */
  183. if(!$file = @fopen("$filename.tmp", 'w')) {
  184. include_once( '../functions/display_messages.php' );
  185. logout_error( sprintf( _("Signature file, %s, could not be opened. Contact your system administrator to resolve this issue."), $filename . '.tmp') );
  186. exit;
  187. }
  188. $tmpwrite = @fwrite($file, $value);
  189. if ($tmpwrite == -1) {
  190. include_once( '../functions/display_messages.php' );
  191. logout_error( sprintf( _("Signature file, %s, could not be written. Contact your system administrator to resolve this issue.") , $filename . '.tmp'));
  192. exit;
  193. }
  194. fclose($file);
  195. @copy($filename . '.tmp',$filename);
  196. @unlink($filename . '.tmp');
  197. chmod($filename, 0600);
  198. }
  199. /**
  200. * Get the signature.
  201. */
  202. function getSig($data_dir, $username, $number) {
  203. $filename = getHashedFile($username, $data_dir, "$username.si$number");
  204. $sig = '';
  205. if (file_exists($filename)) {
  206. /* Open the file, or else display an error to the user. */
  207. if(!$file = @fopen($filename, 'r'))
  208. {
  209. include_once(SM_PATH . 'functions/display_messages.php');
  210. logout_error( sprintf( _("Signature file, %s, could not be opened. Contact your system administrator to resolve this issue."), $filename) );
  211. exit;
  212. }
  213. while (!feof($file)) {
  214. $sig .= fgets($file, 1024);
  215. }
  216. fclose($file);
  217. }
  218. return $sig;
  219. }