file_prefs.php 8.2 KB

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