]> source.dussan.org Git - nextcloud-server.git/commitdiff
Use the TempManager to handle temporary files
authorRobin Appelman <icewind@owncloud.com>
Wed, 22 Oct 2014 15:36:52 +0000 (17:36 +0200)
committerRobin Appelman <icewind@owncloud.com>
Thu, 8 Jan 2015 15:22:14 +0000 (16:22 +0100)
Conflicts:
lib/private/helper.php

cron.php
lib/base.php
lib/private/helper.php

index f0acd2f04920ad00221403659c2ed9525896430b..5c2cb208139b0631cbfbfe23fd886d6eaefc8755 100644 (file)
--- a/cron.php
+++ b/cron.php
@@ -71,8 +71,7 @@ try {
        // Handle unexpected errors
        register_shutdown_function('handleUnexpectedShutdown');
 
-       // Delete temp folder
-       OC_Helper::cleanTmpNoClean();
+       \OC::$server->getTempManager()->cleanOld();
 
        // Exit if background jobs are disabled!
        $appmode = OC_BackgroundJob::getExecutionType();
index d653e0684348aff2e278dacf39244c6c0ae2db4d..495d753476107ff9b567a6892903555a04a2ae51 100644 (file)
@@ -563,7 +563,8 @@ class OC {
                self::registerLocalAddressBook();
 
                //make sure temporary files are cleaned up
-               register_shutdown_function(array('OC_Helper', 'cleanTmp'));
+               $tmpManager = \OC::$server->getTempManager();
+               register_shutdown_function(array($tmpManager, 'clean'));
 
                if (OC_Config::getValue('installed', false) && !self::checkUpgrade(false)) {
                        if (OC_Appconfig::getValue('core', 'backgroundjobs_mode', 'ajax') == 'ajax') {
index 15cf81962432435ea8e6e67be1e9e1b48b64a1f6..d57373e69cb3f1ce804b92a5d470dd79f820000e 100644 (file)
@@ -25,7 +25,6 @@
  * Collection of useful functions
  */
 class OC_Helper {
-       private static $tmpFiles = array();
        private static $mimetypeIcons = array();
        private static $mimetypeDetector;
        private static $templateManager;
@@ -572,136 +571,24 @@ class OC_Helper {
         *
         * @param string $postfix
         * @return string
+        * @deprecated Use the TempManager instead
         *
         * temporary files are automatically cleaned up after the script is finished
         */
        public static function tmpFile($postfix = '') {
-               $file = get_temp_dir() . '/' . md5(time() . rand()) . $postfix;
-               $fh = fopen($file, 'w');
-               if ($fh!==false){
-                       fclose($fh);
-                       self::$tmpFiles[] = $file;
-               } else {
-                       OC_Log::write(
-                               'OC_Helper',
-                               sprintf(
-                                       'Can not create a temporary file in directory %s. Check it exists and has correct permissions',
-                                       get_temp_dir()
-                               ),
-                               OC_Log::WARN
-                       );
-                       $file = false;
-               }
-               return $file;
-       }
-
-       /**
-        * move a file to oc-noclean temp dir
-        *
-        * @param string $filename
-        * @return mixed
-        *
-        */
-       public static function moveToNoClean($filename = '') {
-               if ($filename == '') {
-                       return false;
-               }
-               $tmpDirNoClean = get_temp_dir() . '/oc-noclean/';
-               if (!file_exists($tmpDirNoClean) || !is_dir($tmpDirNoClean)) {
-                       if (file_exists($tmpDirNoClean)) {
-                               unlink($tmpDirNoClean);
-                       }
-                       mkdir($tmpDirNoClean);
-               }
-               $newname = $tmpDirNoClean . basename($filename);
-               if (rename($filename, $newname)) {
-                       return $newname;
-               } else {
-                       return false;
-               }
+               return \OC::$server->getTempManager()->getTemporaryFile($postfix);
        }
 
        /**
         * create a temporary folder with an unique filename
         *
         * @return string
+        * @deprecated Use the TempManager instead
         *
         * temporary files are automatically cleaned up after the script is finished
         */
        public static function tmpFolder() {
-               $path = get_temp_dir() . '/' . md5(time() . rand());
-               mkdir($path);
-               self::$tmpFiles[] = $path;
-               return $path . '/';
-       }
-
-       /**
-        * remove all files created by self::tmpFile
-        */
-       public static function cleanTmp() {
-               $leftoversFile = get_temp_dir() . '/oc-not-deleted';
-               if (file_exists($leftoversFile)) {
-                       $leftovers = file($leftoversFile);
-                       foreach ($leftovers as $file) {
-                               try {
-                                       self::rmdirr($file);
-                               } catch (UnexpectedValueException $ex) {
-                                       // not really much we can do here anymore
-                                       if (!is_null(\OC::$server)) {
-                                               $message = $ex->getMessage();
-                                               \OC::$server->getLogger()->error("Error deleting file/folder: $file - Reason: $message",
-                                                       array('app' => 'core'));
-                                       }
-                               }
-                       }
-                       unlink($leftoversFile);
-               }
-
-               foreach (self::$tmpFiles as $file) {
-                       if (file_exists($file)) {
-                               try {
-                                       if (!self::rmdirr($file)) {
-                                               file_put_contents($leftoversFile, $file . "\n", FILE_APPEND);
-                                       }
-                               } catch (UnexpectedValueException $ex) {
-                                       // not really much we can do here anymore
-                                       if (!is_null(\OC::$server)) {
-                                               $message = $ex->getMessage();
-                                               \OC::$server->getLogger()->error("Error deleting file/folder: $file - Reason: $message",
-                                                       array('app' => 'core'));
-                                       }
-                               }
-                       }
-               }
-       }
-
-       /**
-        * remove all files in PHP /oc-noclean temp dir
-        */
-       public static function cleanTmpNoClean() {
-               $tmpDirNoCleanName=get_temp_dir() . '/oc-noclean/';
-               if(file_exists($tmpDirNoCleanName) && is_dir($tmpDirNoCleanName)) {
-                       $files=scandir($tmpDirNoCleanName);
-                       foreach($files as $file) {
-                               $fileName = $tmpDirNoCleanName . $file;
-                               if (!\OC\Files\Filesystem::isIgnoredDir($file) && filemtime($fileName) + 600 < time()) {
-                                       unlink($fileName);
-                               }
-                       }
-                       // if oc-noclean is empty delete it
-                       $isTmpDirNoCleanEmpty = true;
-                       $tmpDirNoClean = opendir($tmpDirNoCleanName);
-                       if(is_resource($tmpDirNoClean)) {
-                               while (false !== ($file = readdir($tmpDirNoClean))) {
-                                       if (!\OC\Files\Filesystem::isIgnoredDir($file)) {
-                                               $isTmpDirNoCleanEmpty = false;
-                                       }
-                               }
-                       }
-                       if ($isTmpDirNoCleanEmpty) {
-                               rmdir($tmpDirNoCleanName);
-                       }
-               }
+               return \OC::$server->getTempManager()->getTemporaryFolder();
        }
 
        /**