3 * Smarty write file plugin
6 * @subpackage PluginsInternal
11 * Smarty Internal Write File Class
14 * @subpackage PluginsInternal
16 class Smarty_Internal_Write_File {
19 * Writes file in a safe way to disk
21 * @param string $_filepath complete filepath
22 * @param string $_contents file content
23 * @param Smarty $smarty smarty instance
24 * @return boolean true
26 public static function writeFile($_filepath, $_contents, Smarty $smarty)
28 $_error_reporting = error_reporting();
29 error_reporting($_error_reporting & ~E_NOTICE & ~E_WARNING);
30 if ($smarty->_file_perms !== null) {
31 $old_umask = umask(0);
34 $_dirpath = dirname($_filepath);
35 // if subdirs, create dir structure
36 if ($_dirpath !== '.' && !file_exists($_dirpath)) {
37 mkdir($_dirpath, $smarty->_dir_perms === null ? 0777 : $smarty->_dir_perms, true);
40 // write to tmp file, then move to overt file lock race condition
41 $_tmp_file = $_dirpath . DS . uniqid('wrt', true);
42 if (!file_put_contents($_tmp_file, $_contents)) {
43 error_reporting($_error_reporting);
44 throw new SmartyException("unable to write file {$_tmp_file}");
49 * Windows' rename() fails if the destination exists,
50 * Linux' rename() properly handles the overwrite.
51 * Simply unlink()ing a file might cause other processes
52 * currently reading that file to fail, but linux' rename()
53 * seems to be smart enough to handle that for us.
55 if (Smarty::$_IS_WINDOWS) {
56 // remove original file
59 $success = @rename($_tmp_file, $_filepath);
62 $success = @rename($_tmp_file, $_filepath);
64 // remove original file
67 $success = @rename($_tmp_file, $_filepath);
72 error_reporting($_error_reporting);
73 throw new SmartyException("unable to write file {$_filepath}");
77 if ($smarty->_file_perms !== null) {
78 // set file permissions
79 chmod($_filepath, $smarty->_file_perms);
82 error_reporting($_error_reporting);