summaryrefslogtreecommitdiffstats
path: root/apps/files_versions
diff options
context:
space:
mode:
authorLouis Chemineau <louis@chmn.me>2022-12-12 18:27:50 +0100
committerLouis (Rebase PR Action) <artonge@users.noreply.github.com>2023-01-26 10:12:23 +0000
commit53d736207c87485763f5cbfd04a4ea3067b6606d (patch)
tree55027bdce4f1d1307b3fc52ad961eaa45fe3737f /apps/files_versions
parent2ce4ac4aa4495712692a8c7e02318c8735f8465f (diff)
downloadnextcloud-server-53d736207c87485763f5cbfd04a4ea3067b6606d.tar.gz
nextcloud-server-53d736207c87485763f5cbfd04a4ea3067b6606d.zip
Adapt files_versions tests to modernized hooks
Signed-off-by: Louis Chemineau <louis@chmn.me>
Diffstat (limited to 'apps/files_versions')
-rw-r--r--apps/files_versions/lib/Listener/FileEventsListener.php53
-rw-r--r--apps/files_versions/tests/StorageTest.php2
-rw-r--r--apps/files_versions/tests/VersioningTest.php2
3 files changed, 47 insertions, 10 deletions
diff --git a/apps/files_versions/lib/Listener/FileEventsListener.php b/apps/files_versions/lib/Listener/FileEventsListener.php
index 12bc8b03fe9..c28a5a4c999 100644
--- a/apps/files_versions/lib/Listener/FileEventsListener.php
+++ b/apps/files_versions/lib/Listener/FileEventsListener.php
@@ -11,6 +11,7 @@
* @author Robin Appelman <robin@icewind.nl>
* @author Robin McCorkell <robin@mccorkell.me.uk>
* @author Sam Tuke <mail@samtuke.com>
+ * @author Louis Chmn <louis@chmn.me>
*
* @license AGPL-3.0
*
@@ -58,6 +59,10 @@ class FileEventsListener implements IEventListener {
* @var array<int, bool>
*/
private array $versionsCreated = [];
+ /**
+ * @var array<string, Node>
+ */
+ private array $versionsDeleted = [];
private IMimeTypeLoader $mimeTypeLoader;
public function __construct(
@@ -108,12 +113,17 @@ class FileEventsListener implements IEventListener {
* listen to write event.
*/
public function write_hook(Node $node): void {
- // Prevent exception during installation.
+ // $node is be nonexisting on file creation.
if ($node instanceof NonExistingFolder || $node instanceof NonExistingFile) {
return;
}
- $userFolder = $this->rootFolder->getUserFolder($node->getOwner()->getUID());
+ $owner = $node->getOwner();
+ // if ($owner === null) {
+ // return;
+ // }
+ $userFolder = $this->rootFolder->getUserFolder($owner->getUID());
+
$path = $userFolder->getRelativePath($node->getPath());
$result = Storage::store($path);
@@ -151,9 +161,15 @@ class FileEventsListener implements IEventListener {
* cleanup the versions directory if the actual file gets deleted
*/
public function remove_hook(Node $node): void {
+ $path = Filesystem::normalizePath($node->getPath());
+ if (!array_key_exists($path, $this->versionsDeleted)) {
+ return;
+ }
+ $node = $this->versionsDeleted[$path];
$userFolder = $this->rootFolder->getUserFolder($node->getOwner()->getUID());
- $path = $userFolder->getRelativePath($node->getPath());
- Storage::delete($path);
+ $relativePath = $userFolder->getRelativePath($node->getPath());
+ unset($this->versionsDeleted[$path]);
+ Storage::delete($relativePath);
$this->versionsMapper->deleteAllVersionsForFileId($node->getId());
}
@@ -161,9 +177,15 @@ class FileEventsListener implements IEventListener {
* mark file as "deleted" so that we can clean up the versions if the file is gone
*/
public function pre_remove_hook(Node $node): void {
- $userFolder = $this->rootFolder->getUserFolder($node->getOwner()->getUID());
+ $owner = $node->getOwner();
+ // if ($owner === null) {
+ // return;
+ // }
+ $userFolder = $this->rootFolder->getUserFolder($owner->getUID());
+
$path = $userFolder->getRelativePath($node->getPath());
Storage::markDeletedFile($path);
+ $this->versionsDeleted[$node->getPath()] = $node;
}
/**
@@ -173,7 +195,12 @@ class FileEventsListener implements IEventListener {
* of the stored versions along the actual file
*/
public function rename_hook(Node $source, Node $target): void {
- $userFolder = $this->rootFolder->getUserFolder($target->getOwner()->getUID());
+ $owner = $target->getOwner();
+ // if ($owner === null) {
+ // return;
+ // }
+ $userFolder = $this->rootFolder->getUserFolder($owner->getUID());
+
$oldPath = $userFolder->getRelativePath($source->getPath());
$newPath = $userFolder->getRelativePath($target->getPath());
Storage::renameOrCopy($oldPath, $newPath, 'rename');
@@ -186,7 +213,12 @@ class FileEventsListener implements IEventListener {
* the stored versions to the new location
*/
public function copy_hook(Node $source, Node $target): void {
- $userFolder = $this->rootFolder->getUserFolder($target->getOwner()->getUID());
+ $owner = $target->getOwner();
+ // if ($owner === null) {
+ // return;
+ // }
+ $userFolder = $this->rootFolder->getUserFolder($owner->getUID());
+
$oldPath = $userFolder->getRelativePath($source->getPath());
$newPath = $userFolder->getRelativePath($target->getPath());
Storage::renameOrCopy($oldPath, $newPath, 'copy');
@@ -202,7 +234,12 @@ class FileEventsListener implements IEventListener {
public function pre_renameOrCopy_hook(Node $source, Node $target): void {
// if we rename a movable mount point, then the versions don't have
// to be renamed
- $userFolder = $this->rootFolder->getUserFolder($source->getOwner()->getUID());
+ $owner = $source->getOwner();
+ // if ($owner === null) {
+ // return;
+ // }
+ $userFolder = $this->rootFolder->getUserFolder($owner->getUID());
+
$oldPath = $userFolder->getRelativePath($source->getPath());
$newPath = $userFolder->getRelativePath($target->getPath());
$absOldPath = Filesystem::normalizePath('/' . \OC_User::getUser() . '/files' . $oldPath);
diff --git a/apps/files_versions/tests/StorageTest.php b/apps/files_versions/tests/StorageTest.php
index d16b9ecdfd8..ef599a3e479 100644
--- a/apps/files_versions/tests/StorageTest.php
+++ b/apps/files_versions/tests/StorageTest.php
@@ -51,7 +51,7 @@ class StorageTest extends TestCase {
});
$this->overwriteService(Expiration::class, $expiration);
- Hooks::connectHooks();
+ // Hooks::connectHooks();
$this->createUser('version_test', '');
$this->loginAsUser('version_test');
diff --git a/apps/files_versions/tests/VersioningTest.php b/apps/files_versions/tests/VersioningTest.php
index b8f58ecff2b..15173dac902 100644
--- a/apps/files_versions/tests/VersioningTest.php
+++ b/apps/files_versions/tests/VersioningTest.php
@@ -100,7 +100,7 @@ class VersioningTest extends \Test\TestCase {
// clear hooks
\OC_Hook::clear();
\OC::registerShareHooks(\OC::$server->getSystemConfig());
- \OCA\Files_Versions\Hooks::connectHooks();
+ // \OCA\Files_Versions\Hooks::connectHooks();
self::loginHelper(self::TEST_VERSIONS_USER);
$this->rootView = new \OC\Files\View();