Skip to content
Snippets Groups Projects
Commit 86623358 authored by Thomas Müller's avatar Thomas Müller
Browse files

Merge pull request #8849 from owncloud/trash_expire_fix

get files in trash from file cache
parents 6b2b903e 9f3fcf03
Branches
No related tags found
No related merge requests found
......@@ -730,6 +730,8 @@ class Trashbin {
*/
private static function expire($trashbinSize, $user) {
$view = new \OC\Files\View('/' . $user . '/files_trashbin');
// let the admin disable auto expire
$autoExpire = \OC_Config::getValue('trashbin_auto_expire', true);
if ($autoExpire === false) {
......@@ -740,19 +742,18 @@ class Trashbin {
$availableSpace = self::calculateFreeSpace($trashbinSize);
$size = 0;
$query = \OC_DB::prepare('SELECT `location`,`type`,`id`,`timestamp` FROM `*PREFIX*files_trash` WHERE `user`=?');
$result = $query->execute(array($user))->fetchAll();
$retention_obligation = \OC_Config::getValue('trashbin_retention_obligation', self::DEFAULT_RETENTION_OBLIGATION);
$limit = time() - ($retention_obligation * 86400);
foreach ($result as $r) {
$timestamp = $r['timestamp'];
$filename = $r['id'];
if ($r['timestamp'] < $limit) {
$dirContent = $view->getDirectoryContent('/files');
foreach ($dirContent as $file) {
$timestamp = $file['mtime'];
$filename = pathinfo($file['name'], PATHINFO_FILENAME);
if ($timestamp < $limit) {
$size += self::delete($filename, $timestamp);
\OC_Log::write('files_trashbin', 'remove "' . $filename . '" fom trash bin because it is older than ' . $retention_obligation, \OC_log::INFO);
\OC_Log::write('files_trashbin', 'remove "' . $filename . '" from trash bin because it is older than ' . $retention_obligation, \OC_log::INFO);
}
}
$availableSpace += $size;
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please to comment