aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRoeland Jago Douma <rullzer@users.noreply.github.com>2019-02-19 11:25:13 +0100
committerGitHub <noreply@github.com>2019-02-19 11:25:13 +0100
commita2cddf259ce3a936c719d23b8939c73e2ec2f8e4 (patch)
treea839f029f381512a410f8386825ca4b022251eee
parent736d4ee9978e35faf76325b3de40cfa56e456959 (diff)
parent5823cd652c62cff882232b5b61b5fd54c2dcaa2a (diff)
downloadnextcloud-server-a2cddf259ce3a936c719d23b8939c73e2ec2f8e4.tar.gz
nextcloud-server-a2cddf259ce3a936c719d23b8939c73e2ec2f8e4.zip
Merge pull request #14283 from nextcloud/backport/14194/stable15
[stable15] Correctly determinate the owner in case of shared external storages
-rw-r--r--lib/private/Share20/Manager.php6
-rw-r--r--tests/lib/Share20/ManagerTest.php46
2 files changed, 34 insertions, 18 deletions
diff --git a/lib/private/Share20/Manager.php b/lib/private/Share20/Manager.php
index b04f1acbd87..884ab4754f5 100644
--- a/lib/private/Share20/Manager.php
+++ b/lib/private/Share20/Manager.php
@@ -1419,10 +1419,12 @@ class Manager implements IManager {
return $al;
}
- //Get node for the owner
+ //Get node for the owner and correct the owner in case of external storages
$userFolder = $this->rootFolder->getUserFolder($owner);
if ($path->getId() !== $userFolder->getId() && !$userFolder->isSubNode($path)) {
- $path = $userFolder->getById($path->getId())[0];
+ $nodes = $userFolder->getById($path->getId());
+ $path = array_shift($nodes);
+ $owner = $path->getOwner()->getUID();
}
$providers = $this->factory->getAllProviders();
diff --git a/tests/lib/Share20/ManagerTest.php b/tests/lib/Share20/ManagerTest.php
index 1125cae9565..3387c6b7cdd 100644
--- a/tests/lib/Share20/ManagerTest.php
+++ b/tests/lib/Share20/ManagerTest.php
@@ -3431,15 +3431,15 @@ class ManagerTest extends \Test\TestCase {
$extraProvider = $this->createMock(IShareProvider::class);
$factory->setSecondProvider($extraProvider);
- $owner = $this->createMock(IUser::class);
- $owner->expects($this->once())
+ $nodeOwner = $this->createMock(IUser::class);
+ $nodeOwner->expects($this->once())
->method('getUID')
- ->willReturn('owner');
+ ->willReturn('user1');
$node = $this->createMock(Node::class);
$node->expects($this->once())
->method('getOwner')
- ->willReturn($owner);
+ ->willReturn($nodeOwner);
$node->method('getId')
->willReturn(42);
@@ -3447,10 +3447,17 @@ class ManagerTest extends \Test\TestCase {
$file = $this->createMock(File::class);
$folder = $this->createMock(Folder::class);
+ $owner = $this->createMock(IUser::class);
+ $owner->expects($this->once())
+ ->method('getUID')
+ ->willReturn('owner');
+
$file->method('getParent')
->willReturn($folder);
$file->method('getPath')
->willReturn('/owner/files/folder/file');
+ $file->method('getOwner')
+ ->willReturn($owner);
$file->method('getId')
->willReturn(23);
$folder->method('getParent')
@@ -3459,12 +3466,12 @@ class ManagerTest extends \Test\TestCase {
->willReturn('/owner/files/folder');
$userFolder->method('getById')
->with($this->equalTo(42))
- ->willReturn([$file]);
+ ->willReturn([12 => $file]);
$userFolder->method('getPath')
- ->willReturn('/owner/files');
+ ->willReturn('/user1/files');
$this->userManager->method('userExists')
- ->with($this->equalTo('owner'))
+ ->with($this->equalTo('user1'))
->willReturn(true);
$this->defaultProvider->method('getAccessList')
@@ -3498,7 +3505,7 @@ class ManagerTest extends \Test\TestCase {
]);
$this->rootFolder->method('getUserFolder')
- ->with($this->equalTo('owner'))
+ ->with($this->equalTo('user1'))
->willReturn($userFolder);
$expected = [
@@ -3540,26 +3547,33 @@ class ManagerTest extends \Test\TestCase {
$extraProvider = $this->createMock(IShareProvider::class);
$factory->setSecondProvider($extraProvider);
- $owner = $this->createMock(IUser::class);
- $owner->expects($this->once())
+ $nodeOwner = $this->createMock(IUser::class);
+ $nodeOwner->expects($this->once())
->method('getUID')
- ->willReturn('owner');
+ ->willReturn('user1');
$node = $this->createMock(Node::class);
$node->expects($this->once())
->method('getOwner')
- ->willReturn($owner);
+ ->willReturn($nodeOwner);
$node->method('getId')
->willReturn(42);
$userFolder = $this->createMock(Folder::class);
$file = $this->createMock(File::class);
+
+ $owner = $this->createMock(IUser::class);
+ $owner->expects($this->once())
+ ->method('getUID')
+ ->willReturn('owner');
$folder = $this->createMock(Folder::class);
$file->method('getParent')
->willReturn($folder);
$file->method('getPath')
->willReturn('/owner/files/folder/file');
+ $file->method('getOwner')
+ ->willReturn($owner);
$file->method('getId')
->willReturn(23);
$folder->method('getParent')
@@ -3568,12 +3582,12 @@ class ManagerTest extends \Test\TestCase {
->willReturn('/owner/files/folder');
$userFolder->method('getById')
->with($this->equalTo(42))
- ->willReturn([$file]);
+ ->willReturn([42 => $file]);
$userFolder->method('getPath')
- ->willReturn('/owner/files');
+ ->willReturn('/user1/files');
$this->userManager->method('userExists')
- ->with($this->equalTo('owner'))
+ ->with($this->equalTo('user1'))
->willReturn(true);
$this->defaultProvider->method('getAccessList')
@@ -3609,7 +3623,7 @@ class ManagerTest extends \Test\TestCase {
]);
$this->rootFolder->method('getUserFolder')
- ->with($this->equalTo('owner'))
+ ->with($this->equalTo('user1'))
->willReturn($userFolder);
$expected = [