From 0a49fcf9d19ba8752fe3100ca8374dc611389d3e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bj=C3=B6rn=20Schie=C3=9Fle?= Date: Mon, 17 Dec 2012 13:28:40 +0100 Subject: [PATCH] update files history according the given intervals --- apps/files_versions/lib/versions.php | 80 +++++++++++++++++----------- 1 file changed, 49 insertions(+), 31 deletions(-) diff --git a/apps/files_versions/lib/versions.php b/apps/files_versions/lib/versions.php index 7c6138c467..10208dbf1c 100644 --- a/apps/files_versions/lib/versions.php +++ b/apps/files_versions/lib/versions.php @@ -32,8 +32,15 @@ class Storage { const DEFAULTENABLED=true; const DEFAULTBLACKLIST='avi mp3 mpg mp4 ctmp'; const DEFAULTMAXFILESIZE=10485760; // 10MB - const DEFAULTMININTERVAL=1; // 1 min const DEFAULTMAXVERSIONS=50; + + var $MAX_VERSIONS_PER_INTERVAL = array(1 => array('intervalEndsAfter' => 3600, //first hour, one version every 10sec + 'step' => 10), + 2 => array('intervalEndsAfter' => 86400, //next 24h, one version every hour + 'step' => 3600), + 3 => array('intervalEndsAfter' => -1, //until the end one version per day + 'step' => 86400), + ); private static function getUidAndFilename($filename) { @@ -100,7 +107,7 @@ class Storage { $matches=glob($versionsName.'.v*'); sort($matches); $parts=explode('.v', end($matches)); - if((end($parts)+Storage::DEFAULTMININTERVAL)>time()) { + if((end($parts)+Storage::$MAX_VERSIONS_PER_INTERVAL[1]['step'])>time()) { return false; } } @@ -248,45 +255,56 @@ class Storage { if(\OCP\Config::getSystemValue('files_versions', Storage::DEFAULTENABLED)=='true') { list($uid, $filename) = self::getUidAndFilename($filename); $versions_fileview = new \OC_FilesystemView('/'.$uid.'/files_versions'); + + // get available disk space for user $quota = \OCP\Util::computerFileSize(\OC_Preferences::getValue($uid, 'files', 'quota')); if ( $quota == null ) { $quota = \OCP\Util::computerFileSize(\OC_Appconfig::getValue('files', 'default_quota')); - } else if ( $quota == null ) { + } + if ( $quota == null ) { $quota = \OC_Filesystem::free_space('/'); } $rootInfo = \OC_FileCache::get('', '/'. $uid . '/files'); - $free = $quota-$rootInfo['size']; - + $free = $quota-$rootInfo['size']; // remaining free space for user + if ( $free > 0 ) { $availableSpace = 5000 / ($quota-$rootInfo['size']); // 50% of free space can be used for versions - } else { - $availableSpace = 0; - } + } // otherwise available space negative and we need to reach at least 0 at the end of the expiration process; - $versions = Storage::getVersions($filename); - - foreach ( $versions as $v ) error_log("version: " . $v['version'] . " - size: " . $v['size']); - - //day interval - - //week interval - - //month interval - - //delete oldest - - if( count( $matches ) > \OCP\Config::getSystemValue( 'files_versionmaxversions', Storage::DEFAULTMAXVERSIONS ) ) { - - $numberToDelete = count($matches) - \OCP\Config::getSystemValue( 'files_versionmaxversions', Storage::DEFAULTMAXVERSIONS ); - - // delete old versions of a file - $deleteItems = array_slice( $matches, 0, $numberToDelete ); - - foreach( $deleteItems as $de ) { - - unlink( $versionsName.'.v'.$de ); - + $versions = Storage::getVersions($filename); + $versions = array_reverse($versions); // newest version first + + $time = time(); + $numOfVersions = count($versions); + + $interval = 1; + $step = Storage::$MAX_VERSIONS_PER_INTERVAL[$interval]['step']; + if (Storage::$MAX_VERSIONS_PER_INTERVAL[$interval]['intervalEndsAfter'] == -1) { + $nextInterval = -1; + } else { + $nextInterval = $time - Storage::$MAX_VERSIONS_PER_INTERVAL[$interval]['intervalEndsAfter']; + } + + $nextVersion = $versions[0]['versions'] - $step; + + for ($i=1; $i<$numOfVersions; $i++) { + if ( $nextInterval == -1 || $versions[$i]['version'] >= $nextInterval ) { + if ( $versions[$i]['version'] > $nextVersion ) { + //distance between two version to small, delete version (TODO) + $availableSpace += $versions[$i]['size']; + } else { + $nextVersion = $versions[$i]['version'] - $step; + } + } else { // time to move on to the next interval + $interval++; + $step = Storage::$MAX_VERSIONS_PER_INTERVAL[$interval]['step']; + $nextVersion = $version[$i]['version'] - $step; + if ( Storage::$MAX_VERSIONS_PER_INTERVAL[$interval]['intervalEndsAfter'] == -1 ) { + $nextInterval = -1; + } else { + $nextInterval = $time - Storage::$MAX_VERSIONS_PER_INTERVAL[$interval]['intervalEndsAfter']; + } } } }