file_prefs.php 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259
  1. <?php
  2. /**
  3. * file_prefs.php
  4. *
  5. * Copyright (c) 1999-2003 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 = '';
  44. /* keep reading a pref until we reach an eol (\n (or \r for macs)) */
  45. while($read = fgets($file, 1024))
  46. {
  47. $pref .= $read;
  48. if(strpos($read,"\n") || strpos($read,"\r"))
  49. break;
  50. }
  51. $pref = trim($pref);
  52. $equalsAt = strpos($pref, '=');
  53. if ($equalsAt > 0) {
  54. $key = substr($pref, 0, $equalsAt);
  55. $value = substr($pref, $equalsAt + 1);
  56. /* this is to 'rescue' old-style highlighting rules. */
  57. if (substr($key, 0, 9) == 'highlight') {
  58. $key = 'highlight' . $highlight_num;
  59. $highlight_num ++;
  60. }
  61. if ($value != '') {
  62. $prefs_cache[$key] = $value;
  63. }
  64. }
  65. }
  66. fclose($file);
  67. $prefs_are_cached = TRUE;
  68. sqsession_register($prefs_cache, 'prefs_cache');
  69. sqsession_register($prefs_are_cached, 'prefs_are_cached');
  70. }
  71. /**
  72. * Return the value for the prefernce given by $string.
  73. */
  74. function getPref($data_dir, $username, $string, $default = '') {
  75. global $prefs_cache;
  76. $result = do_hook_function('get_pref_override',array($username,$string));
  77. if (!$result) {
  78. cachePrefValues($data_dir, $username);
  79. if (isset($prefs_cache[$string])) {
  80. $result = $prefs_cache[$string];
  81. } else {
  82. $result = do_hook_function('get_pref', array($username,$string));
  83. if (!$result) {
  84. $result = $default;
  85. }
  86. }
  87. }
  88. return ($result);
  89. }
  90. /**
  91. * Save the preferences for this user.
  92. */
  93. function savePrefValues($data_dir, $username) {
  94. global $prefs_cache;
  95. $filename = getHashedFile($username, $data_dir, "$username.pref");
  96. /* Open the file for writing, or else display an error to the user. */
  97. if(!$file = @fopen($filename.'.tmp', 'w'))
  98. {
  99. include_once(SM_PATH . 'functions/display_messages.php');
  100. logout_error( sprintf( _("Preference file, %s, could not be opened. Contact your system administrator to resolve this issue."), $filename.'.tmp') );
  101. exit;
  102. }
  103. foreach ($prefs_cache as $Key => $Value) {
  104. if (isset($Value)) {
  105. $tmpwrite = @fwrite($file, $Key . '=' . $Value . "\n");
  106. if ($tmpwrite == -1) {
  107. logout_error( sprintf( _("Preference file, %s, could not be written. Contact your system administrator to resolve this issue.") , $filename . '.tmp') );
  108. exit;
  109. }
  110. }
  111. }
  112. fclose($file);
  113. @copy($filename . '.tmp',$filename);
  114. @unlink($filename . '.tmp');
  115. chmod($filename, 0600);
  116. }
  117. /**
  118. * Remove a preference for the current user.
  119. */
  120. function removePref($data_dir, $username, $string) {
  121. global $prefs_cache;
  122. cachePrefValues($data_dir, $username);
  123. if (isset($prefs_cache[$string])) {
  124. unset($prefs_cache[$string]);
  125. }
  126. savePrefValues($data_dir, $username);
  127. }
  128. /**
  129. * Set a there preference $string to $value.
  130. */
  131. function setPref($data_dir, $username, $string, $value) {
  132. global $prefs_cache;
  133. cachePrefValues($data_dir, $username);
  134. if (isset($prefs_cache[$string]) && ($prefs_cache[$string] == $value)) {
  135. return;
  136. }
  137. if ($value === '') {
  138. removePref($data_dir, $username, $string);
  139. return;
  140. }
  141. $prefs_cache[$string] = $value;
  142. savePrefValues($data_dir, $username);
  143. }
  144. /**
  145. * Check for a preferences file. If one can not be found, create it.
  146. */
  147. function checkForPrefs($data_dir, $username, $filename = '') {
  148. /* First, make sure we have the filename. */
  149. if ($filename == '') {
  150. $filename = getHashedFile($username, $data_dir, "$username.pref");
  151. }
  152. /* Then, check if the file exists. */
  153. if (!@file_exists($filename) ) {
  154. /* First, check the $data_dir for the default preference file. */
  155. $default_pref = $data_dir . 'default_pref';
  156. /* If it is not there, check the internal data directory. */
  157. if (!@file_exists($default_pref)) {
  158. $default_pref = SM_PATH . 'data/default_pref';
  159. }
  160. /* Otherwise, report an error. */
  161. $errTitle = sprintf( _("Error opening %s"), $default_pref );
  162. if (!is_readable($default_pref)) {
  163. $errString = $errTitle . "<br>\n" .
  164. _("Default preference file not found or not readable!") . "<br>\n" .
  165. _("Please contact your system administrator and report this error.") . "<br>\n";
  166. include_once(SM_PATH . 'functions/display_messages.php' );
  167. logout_error( $errString, $errTitle );
  168. exit;
  169. } else if (!@copy($default_pref, $filename)) {
  170. $uid = 'httpd';
  171. if (function_exists('posix_getuid')){
  172. $user_data = posix_getpwuid(posix_getuid());
  173. $uid = $user_data['name'];
  174. }
  175. $errString = $errTitle . '<br>' .
  176. _("Could not create initial preference file!") . "<br>\n" .
  177. sprintf( _("%s should be writable by user %s"), $data_dir, $uid ) .
  178. "<br>\n" . _("Please contact your system administrator and report this error.") . "<br>\n";
  179. include_once(SM_PATH . 'functions/display_messages.php' );
  180. logout_error( $errString, $errTitle );
  181. exit;
  182. }
  183. }
  184. }
  185. /**
  186. * Write the User Signature.
  187. */
  188. function setSig($data_dir, $username, $number, $value) {
  189. $filename = getHashedFile($username, $data_dir, "$username.si$number");
  190. /* Open the file for writing, or else display an error to the user. */
  191. if(!$file = @fopen("$filename.tmp", 'w')) {
  192. include_once( '../functions/display_messages.php' );
  193. logout_error( sprintf( _("Signature file, %s, could not be opened. Contact your system administrator to resolve this issue."), $filename . '.tmp') );
  194. exit;
  195. }
  196. $tmpwrite = @fwrite($file, $value);
  197. if ($tmpwrite == -1) {
  198. include_once( '../functions/display_messages.php' );
  199. logout_error( sprintf( _("Signature file, %s, could not be written. Contact your system administrator to resolve this issue.") , $filename . '.tmp'));
  200. exit;
  201. }
  202. fclose($file);
  203. @copy($filename . '.tmp',$filename);
  204. @unlink($filename . '.tmp');
  205. chmod($filename, 0600);
  206. }
  207. /**
  208. * Get the signature.
  209. */
  210. function getSig($data_dir, $username, $number) {
  211. $filename = getHashedFile($username, $data_dir, "$username.si$number");
  212. $sig = '';
  213. if (file_exists($filename)) {
  214. /* Open the file, or else display an error to the user. */
  215. if(!$file = @fopen($filename, 'r'))
  216. {
  217. include_once(SM_PATH . 'functions/display_messages.php');
  218. logout_error( sprintf( _("Signature file, %s, could not be opened. Contact your system administrator to resolve this issue."), $filename) );
  219. exit;
  220. }
  221. while (!feof($file)) {
  222. $sig .= fgets($file, 1024);
  223. }
  224. fclose($file);
  225. }
  226. return $sig;
  227. }