12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105 |
- <?php
- /**
- * @copyright Copyright (c) 2016, ownCloud, Inc.
- *
- * @author Björn Schießle <bjoern@schiessle.org>
- * @author Roeland Jago Douma <roeland@famdouma.nl>
- * @author Vincent Petry <pvince81@owncloud.com>
- *
- * @license AGPL-3.0
- *
- * This code is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License, version 3,
- * as published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License, version 3,
- * along with this program. If not, see <http://www.gnu.org/licenses/>
- *
- */
- namespace OCA\Files_Sharing\Tests\Controller;
- use OCP\AppFramework\Http\DataResponse;
- use OCP\AppFramework\OCS\OCSNotFoundException;
- use OCP\Files\Folder;
- use OCP\IL10N;
- use OCA\Files_Sharing\Controller\ShareAPIController;
- use OCP\Files\NotFoundException;
- use OCP\IGroupManager;
- use OCP\IUserManager;
- use OCP\IRequest;
- use OCP\IURLGenerator;
- use OCP\IUser;
- use OCP\Files\IRootFolder;
- use OCP\Lock\LockedException;
- use OCP\Share\IManager;
- use OCP\Share;
- /**
- * Class ShareAPIControllerTest
- *
- * @package OCA\Files_Sharing\Tests\Controller
- * @group DB
- */
- class ShareAPIControllerTest extends \Test\TestCase {
- /** @var string */
- private $appName = 'files_sharing';
- /** @var \OC\Share20\Manager|\PHPUnit_Framework_MockObject_MockObject */
- private $shareManager;
- /** @var IGroupManager|\PHPUnit_Framework_MockObject_MockObject */
- private $groupManager;
- /** @var IUserManager|\PHPUnit_Framework_MockObject_MockObject */
- private $userManager;
- /** @var IRequest|\PHPUnit_Framework_MockObject_MockObject */
- private $request;
- /** @var IRootFolder|\PHPUnit_Framework_MockObject_MockObject */
- private $rootFolder;
- /** @var IURLGenerator|\PHPUnit_Framework_MockObject_MockObject */
- private $urlGenerator;
- /** @var string|\PHPUnit_Framework_MockObject_MockObject */
- private $currentUser;
- /** @var ShareAPIController */
- private $ocs;
- /** @var IL10N|\PHPUnit_Framework_MockObject_MockObject */
- private $l;
- protected function setUp() {
- $this->shareManager = $this->createMock(IManager::class);
- $this->shareManager
- ->expects($this->any())
- ->method('shareApiEnabled')
- ->willReturn(true);
- $this->groupManager = $this->createMock(IGroupManager::class);
- $this->userManager = $this->createMock(IUserManager::class);
- $this->request = $this->createMock(IRequest::class);
- $this->rootFolder = $this->createMock(IRootFolder::class);
- $this->urlGenerator = $this->createMock(IURLGenerator::class);
- $this->currentUser = 'currentUser';
- $this->l = $this->createMock(IL10N::class);
- $this->l->method('t')
- ->will($this->returnCallback(function($text, $parameters = []) {
- return vsprintf($text, $parameters);
- }));
- $this->ocs = new ShareAPIController(
- $this->appName,
- $this->request,
- $this->shareManager,
- $this->groupManager,
- $this->userManager,
- $this->rootFolder,
- $this->urlGenerator,
- $this->currentUser,
- $this->l
- );
- }
- /**
- * @return ShareAPIController|\PHPUnit_Framework_MockObject_MockObject
- */
- private function mockFormatShare() {
- return $this->getMockBuilder(ShareAPIController::class)
- ->setConstructorArgs([
- $this->appName,
- $this->request,
- $this->shareManager,
- $this->groupManager,
- $this->userManager,
- $this->rootFolder,
- $this->urlGenerator,
- $this->currentUser,
- $this->l,
- ])->setMethods(['formatShare'])
- ->getMock();
- }
- private function newShare() {
- return \OC::$server->getShareManager()->newShare();
- }
- /**
- * @expectedException \OCP\AppFramework\OCS\OCSNotFoundException
- * @expectedExceptionMessage Wrong share ID, share doesn't exist
- */
- public function testDeleteShareShareNotFound() {
- $this->shareManager
- ->expects($this->exactly(2))
- ->method('getShareById')
- ->will($this->returnCallback(function($id) {
- if ($id === 'ocinternal:42' || $id === 'ocFederatedSharing:42') {
- throw new \OCP\Share\Exceptions\ShareNotFound();
- } else {
- throw new \Exception();
- }
- }));
- $this->shareManager->method('outgoingServer2ServerSharesAllowed')->willReturn(true);
- $this->ocs->deleteShare(42);
- }
- public function testDeleteShare() {
- $node = $this->getMockBuilder('\OCP\Files\File')->getMock();
- $share = $this->newShare();
- $share->setSharedBy($this->currentUser)
- ->setNode($node);
- $this->shareManager
- ->expects($this->once())
- ->method('getShareById')
- ->with('ocinternal:42')
- ->willReturn($share);
- $this->shareManager
- ->expects($this->once())
- ->method('deleteShare')
- ->with($share);
- $node->expects($this->once())
- ->method('lock')
- ->with(\OCP\Lock\ILockingProvider::LOCK_SHARED);
- $expected = new DataResponse();
- $result = $this->ocs->deleteShare(42);
- $this->assertInstanceOf(get_class($expected), $result);
- $this->assertEquals($expected->getData(), $result->getData());
- }
- /**
- * @expectedException \OCP\AppFramework\OCS\OCSNotFoundException
- * @expectedExceptionMessage could not delete share
- */
- public function testDeleteShareLocked() {
- $node = $this->getMockBuilder('\OCP\Files\File')->getMock();
- $share = $this->newShare();
- $share->setSharedBy($this->currentUser)
- ->setNode($node);
- $this->shareManager
- ->expects($this->once())
- ->method('getShareById')
- ->with('ocinternal:42')
- ->willReturn($share);
- $this->shareManager
- ->expects($this->never())
- ->method('deleteShare')
- ->with($share);
- $node->expects($this->once())
- ->method('lock')
- ->with(\OCP\Lock\ILockingProvider::LOCK_SHARED)
- ->will($this->throwException(new LockedException('mypath')));
- $this->ocs->deleteShare(42);
- }
- /*
- * FIXME: Enable once we have a federated Share Provider
- public function testGetGetShareNotExists() {
- $this->shareManager
- ->expects($this->once())
- ->method('getShareById')
- ->with('ocinternal:42')
- ->will($this->throwException(new \OC\Share20\Exception\ShareNotFound()));
- $expected = new \OC_OCS_Result(null, 404, 'wrong share ID, share doesn\'t exist.');
- $this->assertEquals($expected, $this->ocs->getShare(42));
- }
- */
- public function createShare($id, $shareType, $sharedWith, $sharedBy, $shareOwner, $path, $permissions,
- $shareTime, $expiration, $parent, $target, $mail_send, $token=null,
- $password=null) {
- $share = $this->getMockBuilder('\OCP\Share\IShare')->getMock();
- $share->method('getId')->willReturn($id);
- $share->method('getShareType')->willReturn($shareType);
- $share->method('getSharedWith')->willReturn($sharedWith);
- $share->method('getSharedBy')->willReturn($sharedBy);
- $share->method('getShareOwner')->willReturn($shareOwner);
- $share->method('getNode')->willReturn($path);
- $share->method('getPermissions')->willReturn($permissions);
- $time = new \DateTime();
- $time->setTimestamp($shareTime);
- $share->method('getShareTime')->willReturn($time);
- $share->method('getExpirationDate')->willReturn($expiration);
- $share->method('getTarget')->willReturn($target);
- $share->method('getMailSend')->willReturn($mail_send);
- $share->method('getToken')->willReturn($token);
- $share->method('getPassword')->willReturn($password);
- if ($shareType === \OCP\Share::SHARE_TYPE_USER ||
- $shareType === \OCP\Share::SHARE_TYPE_GROUP ||
- $shareType === \OCP\Share::SHARE_TYPE_LINK) {
- $share->method('getFullId')->willReturn('ocinternal:'.$id);
- }
- return $share;
- }
- public function dataGetShare() {
- $data = [];
- $cache = $this->getMockBuilder('OC\Files\Cache\Cache')
- ->disableOriginalConstructor()
- ->getMock();
- $cache->method('getNumericStorageId')->willReturn(101);
- $storage = $this->getMockBuilder('OC\Files\Storage\Storage')
- ->disableOriginalConstructor()
- ->getMock();
- $storage->method('getId')->willReturn('STORAGE');
- $storage->method('getCache')->willReturn($cache);
- $parentFolder = $this->getMockBuilder('OCP\Files\Folder')->getMock();
- $parentFolder->method('getId')->willReturn(3);
- $file = $this->getMockBuilder('OCP\Files\File')->getMock();
- $file->method('getId')->willReturn(1);
- $file->method('getPath')->willReturn('file');
- $file->method('getStorage')->willReturn($storage);
- $file->method('getParent')->willReturn($parentFolder);
- $file->method('getMimeType')->willReturn('myMimeType');
- $folder = $this->getMockBuilder('OCP\Files\Folder')->getMock();
- $folder->method('getId')->willReturn(2);
- $folder->method('getPath')->willReturn('folder');
- $folder->method('getStorage')->willReturn($storage);
- $folder->method('getParent')->willReturn($parentFolder);
- $folder->method('getMimeType')->willReturn('myFolderMimeType');
- // File shared with user
- $share = $this->createShare(
- 100,
- \OCP\Share::SHARE_TYPE_USER,
- 'userId',
- 'initiatorId',
- 'ownerId',
- $file,
- 4,
- 5,
- null,
- 6,
- 'target',
- 0
- );
- $expected = [
- 'id' => 100,
- 'share_type' => \OCP\Share::SHARE_TYPE_USER,
- 'share_with' => 'userId',
- 'share_with_displayname' => 'userDisplay',
- 'uid_owner' => 'initiatorId',
- 'displayname_owner' => 'initiatorDisplay',
- 'item_type' => 'file',
- 'item_source' => 1,
- 'file_source' => 1,
- 'file_target' => 'target',
- 'file_parent' => 3,
- 'token' => null,
- 'expiration' => null,
- 'permissions' => 4,
- 'stime' => 5,
- 'parent' => null,
- 'storage_id' => 'STORAGE',
- 'path' => 'file',
- 'storage' => 101,
- 'mail_send' => 0,
- 'uid_file_owner' => 'ownerId',
- 'displayname_file_owner' => 'ownerDisplay',
- 'mimetype' => 'myMimeType',
- ];
- $data[] = [$share, $expected];
- // Folder shared with group
- $share = $this->createShare(
- 101,
- \OCP\Share::SHARE_TYPE_GROUP,
- 'groupId',
- 'initiatorId',
- 'ownerId',
- $folder,
- 4,
- 5,
- null,
- 6,
- 'target',
- 0
- );
- $expected = [
- 'id' => 101,
- 'share_type' => \OCP\Share::SHARE_TYPE_GROUP,
- 'share_with' => 'groupId',
- 'share_with_displayname' => 'groupId',
- 'uid_owner' => 'initiatorId',
- 'displayname_owner' => 'initiatorDisplay',
- 'item_type' => 'folder',
- 'item_source' => 2,
- 'file_source' => 2,
- 'file_target' => 'target',
- 'file_parent' => 3,
- 'token' => null,
- 'expiration' => null,
- 'permissions' => 4,
- 'stime' => 5,
- 'parent' => null,
- 'storage_id' => 'STORAGE',
- 'path' => 'folder',
- 'storage' => 101,
- 'mail_send' => 0,
- 'uid_file_owner' => 'ownerId',
- 'displayname_file_owner' => 'ownerDisplay',
- 'mimetype' => 'myFolderMimeType',
- ];
- $data[] = [$share, $expected];
- // File shared by link with Expire
- $expire = \DateTime::createFromFormat('Y-m-d h:i:s', '2000-01-02 01:02:03');
- $share = $this->createShare(
- 101,
- \OCP\Share::SHARE_TYPE_LINK,
- null,
- 'initiatorId',
- 'ownerId',
- $folder,
- 4,
- 5,
- $expire,
- 6,
- 'target',
- 0,
- 'token',
- 'password'
- );
- $expected = [
- 'id' => 101,
- 'share_type' => \OCP\Share::SHARE_TYPE_LINK,
- 'share_with' => 'password',
- 'share_with_displayname' => 'password',
- 'uid_owner' => 'initiatorId',
- 'displayname_owner' => 'initiatorDisplay',
- 'item_type' => 'folder',
- 'item_source' => 2,
- 'file_source' => 2,
- 'file_target' => 'target',
- 'file_parent' => 3,
- 'token' => 'token',
- 'expiration' => '2000-01-02 00:00:00',
- 'permissions' => 4,
- 'stime' => 5,
- 'parent' => null,
- 'storage_id' => 'STORAGE',
- 'path' => 'folder',
- 'storage' => 101,
- 'mail_send' => 0,
- 'url' => 'url',
- 'uid_file_owner' => 'ownerId',
- 'displayname_file_owner' => 'ownerDisplay',
- 'mimetype' => 'myFolderMimeType',
- ];
- $data[] = [$share, $expected];
- return $data;
- }
- /**
- * @dataProvider dataGetShare
- */
- public function testGetShare(\OCP\Share\IShare $share, array $result) {
- /** @var ShareAPIController|\PHPUnit_Framework_MockObject_MockObject $ocs */
- $ocs = $this->getMockBuilder(ShareAPIController::class)
- ->setConstructorArgs([
- $this->appName,
- $this->request,
- $this->shareManager,
- $this->groupManager,
- $this->userManager,
- $this->rootFolder,
- $this->urlGenerator,
- $this->currentUser,
- $this->l,
- ])->setMethods(['canAccessShare'])
- ->getMock();
- $ocs->expects($this->any())
- ->method('canAccessShare')
- ->willReturn(true);
- $this->shareManager
- ->expects($this->once())
- ->method('getShareById')
- ->with($share->getFullId())
- ->willReturn($share);
- $userFolder = $this->getMockBuilder('OCP\Files\Folder')->getMock();
- $userFolder
- ->method('getRelativePath')
- ->will($this->returnArgument(0));
- $userFolder->method('getById')
- ->with($share->getNodeId())
- ->willReturn([$share->getNode()]);
- $this->rootFolder->method('getUserFolder')
- ->with($this->currentUser)
- ->willReturn($userFolder);
- $this->urlGenerator
- ->method('linkToRouteAbsolute')
- ->willReturn('url');
- $initiator = $this->getMockBuilder('OCP\IUser')->getMock();
- $initiator->method('getUID')->willReturn('initiatorId');
- $initiator->method('getDisplayName')->willReturn('initiatorDisplay');
- $owner = $this->getMockBuilder('OCP\IUser')->getMock();
- $owner->method('getUID')->willReturn('ownerId');
- $owner->method('getDisplayName')->willReturn('ownerDisplay');
- $user = $this->getMockBuilder('OCP\IUser')->getMock();
- $user->method('getUID')->willReturn('userId');
- $user->method('getDisplayName')->willReturn('userDisplay');
- $group = $this->getMockBuilder('OCP\IGroup')->getMock();
- $group->method('getGID')->willReturn('groupId');
- $this->userManager->method('get')->will($this->returnValueMap([
- ['userId', $user],
- ['initiatorId', $initiator],
- ['ownerId', $owner],
- ]));
- $this->groupManager->method('get')->will($this->returnValueMap([
- ['group', $group],
- ]));
- $this->assertEquals($result, $ocs->getShare($share->getId())->getData()[0]);
- }
- /**
- * @expectedException \OCP\AppFramework\OCS\OCSNotFoundException
- * @expectedExceptionMessage Wrong share ID, share doesn't exist
- */
- public function testGetShareInvalidNode() {
- $share = \OC::$server->getShareManager()->newShare();
- $share->setSharedBy('initiator')
- ->setSharedWith('recipient')
- ->setShareOwner('owner');
- $this->shareManager
- ->expects($this->once())
- ->method('getShareById')
- ->with('ocinternal:42')
- ->willReturn($share);
- $this->ocs->getShare(42);
- }
- public function testCanAccessShare() {
- $share = $this->getMockBuilder('OCP\Share\IShare')->getMock();
- $share->method('getShareOwner')->willReturn($this->currentUser);
- $this->assertTrue($this->invokePrivate($this->ocs, 'canAccessShare', [$share]));
- $share = $this->getMockBuilder('OCP\Share\IShare')->getMock();
- $share->method('getSharedBy')->willReturn($this->currentUser);
- $this->assertTrue($this->invokePrivate($this->ocs, 'canAccessShare', [$share]));
- $share = $this->getMockBuilder('OCP\Share\IShare')->getMock();
- $share->method('getShareType')->willReturn(\OCP\Share::SHARE_TYPE_USER);
- $share->method('getSharedWith')->willReturn($this->currentUser);
- $this->assertTrue($this->invokePrivate($this->ocs, 'canAccessShare', [$share]));
- $share = $this->getMockBuilder('OCP\Share\IShare')->getMock();
- $share->method('getShareType')->willReturn(\OCP\Share::SHARE_TYPE_USER);
- $share->method('getSharedWith')->willReturn($this->getMockBuilder('OCP\IUser')->getMock());
- $this->assertFalse($this->invokePrivate($this->ocs, 'canAccessShare', [$share]));
- $share = $this->getMockBuilder('OCP\Share\IShare')->getMock();
- $share->method('getShareType')->willReturn(\OCP\Share::SHARE_TYPE_GROUP);
- $share->method('getSharedWith')->willReturn('group');
- $user = $this->createMock(IUser::class);
- $this->userManager->method('get')
- ->with($this->currentUser)
- ->willReturn($user);
- $group = $this->getMockBuilder('OCP\IGroup')->getMock();
- $group->method('inGroup')->with($user)->willReturn(true);
- $group2 = $this->getMockBuilder('OCP\IGroup')->getMock();
- $group2->method('inGroup')->with($user)->willReturn(false);
- $this->groupManager->method('get')->will($this->returnValueMap([
- ['group', $group],
- ['group2', $group2],
- ]));
- $this->assertTrue($this->invokePrivate($this->ocs, 'canAccessShare', [$share]));
- $share = $this->getMockBuilder('OCP\Share\IShare')->getMock();
- $share->method('getShareType')->willReturn(\OCP\Share::SHARE_TYPE_GROUP);
- $share->method('getSharedWith')->willReturn('group2');
- $this->groupManager->method('get')->with('group2')->willReturn($group);
- $this->assertFalse($this->invokePrivate($this->ocs, 'canAccessShare', [$share]));
- $share = $this->getMockBuilder('OCP\Share\IShare')->getMock();
- $share->method('getShareType')->willReturn(\OCP\Share::SHARE_TYPE_LINK);
- $this->assertFalse($this->invokePrivate($this->ocs, 'canAccessShare', [$share]));
- }
- /**
- * @expectedException \OCP\AppFramework\OCS\OCSNotFoundException
- * @expectedExceptionMessage Please specify a file or folder path
- */
- public function testCreateShareNoPath() {
- $this->ocs->createShare();
- }
- /**
- * @expectedException \OCP\AppFramework\OCS\OCSNotFoundException
- * @expectedExceptionMessage Wrong path, file/folder doesn't exist
- */
- public function testCreateShareInvalidPath() {
- $userFolder = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $this->rootFolder->expects($this->once())
- ->method('getUserFolder')
- ->with('currentUser')
- ->willReturn($userFolder);
- $userFolder->expects($this->once())
- ->method('get')
- ->with('invalid-path')
- ->will($this->throwException(new \OCP\Files\NotFoundException()));
- $this->ocs->createShare('invalid-path');
- }
- /**
- * @expectedException \OCP\AppFramework\OCS\OCSNotFoundException
- * @expectedExceptionMessage invalid permissions
- */
- public function testCreateShareInvalidPermissions() {
- $share = $this->newShare();
- $this->shareManager->method('newShare')->willReturn($share);
- $userFolder = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $this->rootFolder->expects($this->once())
- ->method('getUserFolder')
- ->with('currentUser')
- ->willReturn($userFolder);
- $path = $this->getMockBuilder('\OCP\Files\File')->getMock();
- $userFolder->expects($this->once())
- ->method('get')
- ->with('valid-path')
- ->willReturn($path);
- $path->expects($this->once())
- ->method('lock')
- ->with(\OCP\Lock\ILockingProvider::LOCK_SHARED);
- $this->ocs->createShare('valid-path', 32);
- }
- /**
- * @expectedException \OCP\AppFramework\OCS\OCSNotFoundException
- * @expectedExceptionMessage Please specify a valid user
- */
- public function testCreateShareUserNoShareWith() {
- $share = $this->newShare();
- $this->shareManager->method('newShare')->willReturn($share);
- $userFolder = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $this->rootFolder->expects($this->once())
- ->method('getUserFolder')
- ->with('currentUser')
- ->willReturn($userFolder);
- $path = $this->getMockBuilder('\OCP\Files\File')->getMock();
- $storage = $this->getMockBuilder('OCP\Files\Storage')->getMock();
- $storage->method('instanceOfStorage')
- ->with('OCA\Files_Sharing\External\Storage')
- ->willReturn(false);
- $path->method('getStorage')->willReturn($storage);
- $userFolder->expects($this->once())
- ->method('get')
- ->with('valid-path')
- ->willReturn($path);
- $path->expects($this->once())
- ->method('lock')
- ->with(\OCP\Lock\ILockingProvider::LOCK_SHARED);
- $this->ocs->createShare('valid-path', \OCP\Constants::PERMISSION_ALL, \OCP\Share::SHARE_TYPE_USER);
- }
- /**
- * @expectedException \OCP\AppFramework\OCS\OCSNotFoundException
- * @expectedExceptionMessage Please specify a valid user
- */
- public function testCreateShareUserNoValidShareWith() {
- $share = $this->newShare();
- $this->shareManager->method('newShare')->willReturn($share);
- $userFolder = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $this->rootFolder->expects($this->once())
- ->method('getUserFolder')
- ->with('currentUser')
- ->willReturn($userFolder);
- $path = $this->getMockBuilder('\OCP\Files\File')->getMock();
- $storage = $this->getMockBuilder('OCP\Files\Storage')->getMock();
- $storage->method('instanceOfStorage')
- ->with('OCA\Files_Sharing\External\Storage')
- ->willReturn(false);
- $path->method('getStorage')->willReturn($storage);
- $userFolder->expects($this->once())
- ->method('get')
- ->with('valid-path')
- ->willReturn($path);
- $path->expects($this->once())
- ->method('lock')
- ->with(\OCP\Lock\ILockingProvider::LOCK_SHARED);
- $this->userManager->method('userExists')
- ->with('invalidUser')
- ->willReturn(false);
- $this->ocs->createShare('valid-path', \OCP\Constants::PERMISSION_ALL, \OCP\Share::SHARE_TYPE_USER, 'invalidUser');
- }
- public function testCreateShareUser() {
- $share = $this->newShare();
- $this->shareManager->method('newShare')->willReturn($share);
- /** @var \OCA\Files_Sharing\Controller\ShareAPIController $ocs */
- $ocs = $this->getMockBuilder(ShareAPIController::class)
- ->setConstructorArgs([
- $this->appName,
- $this->request,
- $this->shareManager,
- $this->groupManager,
- $this->userManager,
- $this->rootFolder,
- $this->urlGenerator,
- $this->currentUser,
- $this->l,
- ])->setMethods(['formatShare'])
- ->getMock();
- $userFolder = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $this->rootFolder->expects($this->once())
- ->method('getUserFolder')
- ->with('currentUser')
- ->willReturn($userFolder);
- $path = $this->getMockBuilder('\OCP\Files\File')->getMock();
- $storage = $this->getMockBuilder('OCP\Files\Storage')->getMock();
- $storage->method('instanceOfStorage')
- ->with('OCA\Files_Sharing\External\Storage')
- ->willReturn(false);
- $path->method('getStorage')->willReturn($storage);
- $userFolder->expects($this->once())
- ->method('get')
- ->with('valid-path')
- ->willReturn($path);
- $this->userManager->method('userExists')->with('validUser')->willReturn(true);
- $path->expects($this->once())
- ->method('lock')
- ->with(\OCP\Lock\ILockingProvider::LOCK_SHARED);
- $this->shareManager->method('createShare')
- ->with($this->callback(function (\OCP\Share\IShare $share) use ($path) {
- return $share->getNode() === $path &&
- $share->getPermissions() === (
- \OCP\Constants::PERMISSION_ALL &
- ~\OCP\Constants::PERMISSION_DELETE &
- ~\OCP\Constants::PERMISSION_CREATE
- ) &&
- $share->getShareType() === \OCP\Share::SHARE_TYPE_USER &&
- $share->getSharedWith() === 'validUser' &&
- $share->getSharedBy() === 'currentUser';
- }))
- ->will($this->returnArgument(0));
- $expected = new DataResponse(null);
- $result = $ocs->createShare('valid-path', \OCP\Constants::PERMISSION_ALL, \OCP\Share::SHARE_TYPE_USER, 'validUser');
- $this->assertInstanceOf(get_class($expected), $result);
- $this->assertEquals($expected->getData(), $result->getData());
- }
- /**
- * @expectedException \OCP\AppFramework\OCS\OCSNotFoundException
- * @expectedExceptionMessage Please specify a valid group
- */
- public function testCreateShareGroupNoValidShareWith() {
- $share = $this->newShare();
- $this->shareManager->method('newShare')->willReturn($share);
- $this->shareManager->method('createShare')->will($this->returnArgument(0));
- $this->shareManager->method('allowGroupSharing')->willReturn(true);
- $userFolder = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $this->rootFolder->expects($this->once())
- ->method('getUserFolder')
- ->with('currentUser')
- ->willReturn($userFolder);
- $path = $this->getMockBuilder('\OCP\Files\File')->getMock();
- $storage = $this->getMockBuilder('OCP\Files\Storage')->getMock();
- $storage->method('instanceOfStorage')
- ->with('OCA\Files_Sharing\External\Storage')
- ->willReturn(false);
- $path->method('getStorage')->willReturn($storage);
- $userFolder->expects($this->once())
- ->method('get')
- ->with('valid-path')
- ->willReturn($path);
- $path->expects($this->once())
- ->method('lock')
- ->with(\OCP\Lock\ILockingProvider::LOCK_SHARED);
- $this->ocs->createShare('valid-path', \OCP\Constants::PERMISSION_ALL, \OCP\Share::SHARE_TYPE_GROUP, 'invalidGroup');
- }
- public function testCreateShareGroup() {
- $share = $this->newShare();
- $this->shareManager->method('newShare')->willReturn($share);
- /** @var ShareAPIController|\PHPUnit_Framework_MockObject_MockObject $ocs */
- $ocs = $this->getMockBuilder(ShareAPIController::class)
- ->setConstructorArgs([
- $this->appName,
- $this->request,
- $this->shareManager,
- $this->groupManager,
- $this->userManager,
- $this->rootFolder,
- $this->urlGenerator,
- $this->currentUser,
- $this->l,
- ])->setMethods(['formatShare'])
- ->getMock();
- $this->request
- ->method('getParam')
- ->will($this->returnValueMap([
- ['path', null, 'valid-path'],
- ['permissions', null, \OCP\Constants::PERMISSION_ALL],
- ['shareType', '-1', \OCP\Share::SHARE_TYPE_GROUP],
- ['shareWith', null, 'validGroup'],
- ]));
- $userFolder = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $this->rootFolder->expects($this->once())
- ->method('getUserFolder')
- ->with('currentUser')
- ->willReturn($userFolder);
- $path = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $storage = $this->getMockBuilder('OCP\Files\Storage')->getMock();
- $storage->method('instanceOfStorage')
- ->with('OCA\Files_Sharing\External\Storage')
- ->willReturn(false);
- $path->method('getStorage')->willReturn($storage);
- $userFolder->expects($this->once())
- ->method('get')
- ->with('valid-path')
- ->willReturn($path);
- $this->groupManager->method('groupExists')->with('validGroup')->willReturn(true);
- $this->shareManager->expects($this->once())
- ->method('allowGroupSharing')
- ->willReturn(true);
- $path->expects($this->once())
- ->method('lock')
- ->with(\OCP\Lock\ILockingProvider::LOCK_SHARED);
- $this->shareManager->method('createShare')
- ->with($this->callback(function (\OCP\Share\IShare $share) use ($path) {
- return $share->getNode() === $path &&
- $share->getPermissions() === \OCP\Constants::PERMISSION_ALL &&
- $share->getShareType() === \OCP\Share::SHARE_TYPE_GROUP &&
- $share->getSharedWith() === 'validGroup' &&
- $share->getSharedBy() === 'currentUser';
- }))
- ->will($this->returnArgument(0));
- $expected = new DataResponse(null);
- $result = $ocs->createShare('valid-path', \OCP\Constants::PERMISSION_ALL, \OCP\Share::SHARE_TYPE_GROUP, 'validGroup');
- $this->assertInstanceOf(get_class($expected), $result);
- $this->assertEquals($expected->getData(), $result->getData());
- }
- /**
- * @expectedException \OCP\AppFramework\OCS\OCSNotFoundException
- * @expectedExceptionMessage Group sharing is disabled by the administrator
- */
- public function testCreateShareGroupNotAllowed() {
- $share = $this->newShare();
- $this->shareManager->method('newShare')->willReturn($share);
- $userFolder = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $this->rootFolder->expects($this->once())
- ->method('getUserFolder')
- ->with('currentUser')
- ->willReturn($userFolder);
- $path = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $storage = $this->getMockBuilder('OCP\Files\Storage')->getMock();
- $storage->method('instanceOfStorage')
- ->with('OCA\Files_Sharing\External\Storage')
- ->willReturn(false);
- $path->method('getStorage')->willReturn($storage);
- $userFolder->expects($this->once())
- ->method('get')
- ->with('valid-path')
- ->willReturn($path);
- $this->groupManager->method('groupExists')->with('validGroup')->willReturn(true);
- $this->shareManager->expects($this->once())
- ->method('allowGroupSharing')
- ->willReturn(false);
- $this->ocs->createShare('valid-path', \OCP\Constants::PERMISSION_ALL, \OCP\Share::SHARE_TYPE_GROUP, 'invalidGroup');
- }
- /**
- * @expectedException \OCP\AppFramework\OCS\OCSNotFoundException
- * @expectedExceptionMessage Public link sharing is disabled by the administrator
- */
- public function testCreateShareLinkNoLinksAllowed() {
- $this->request
- ->method('getParam')
- ->will($this->returnValueMap([
- ['path', null, 'valid-path'],
- ['shareType', '-1', \OCP\Share::SHARE_TYPE_LINK],
- ]));
- $path = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $storage = $this->getMockBuilder('OCP\Files\Storage')->getMock();
- $storage->method('instanceOfStorage')
- ->with('OCA\Files_Sharing\External\Storage')
- ->willReturn(false);
- $path->method('getStorage')->willReturn($storage);
- $this->rootFolder->method('getUserFolder')->with($this->currentUser)->will($this->returnSelf());
- $this->rootFolder->method('get')->with('valid-path')->willReturn($path);
- $this->shareManager->method('newShare')->willReturn(\OC::$server->getShareManager()->newShare());
- $this->ocs->createShare('valid-path', \OCP\Constants::PERMISSION_ALL, \OCP\Share::SHARE_TYPE_LINK);
- }
- /**
- * @expectedException \OCP\AppFramework\OCS\OCSForbiddenException
- * @expectedExceptionMessage Public upload disabled by the administrator
- */
- public function testCreateShareLinkNoPublicUpload() {
- $path = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $storage = $this->getMockBuilder('OCP\Files\Storage')->getMock();
- $storage->method('instanceOfStorage')
- ->with('OCA\Files_Sharing\External\Storage')
- ->willReturn(false);
- $path->method('getStorage')->willReturn($storage);
- $this->rootFolder->method('getUserFolder')->with($this->currentUser)->will($this->returnSelf());
- $this->rootFolder->method('get')->with('valid-path')->willReturn($path);
- $this->shareManager->method('newShare')->willReturn(\OC::$server->getShareManager()->newShare());
- $this->shareManager->method('shareApiAllowLinks')->willReturn(true);
- $this->ocs->createShare('valid-path', \OCP\Constants::PERMISSION_ALL, \OCP\Share::SHARE_TYPE_LINK, null, 'true');
- }
- /**
- * @expectedException \OCP\AppFramework\OCS\OCSNotFoundException
- * @expectedExceptionMessage Public upload is only possible for publicly shared folders
- */
- public function testCreateShareLinkPublicUploadFile() {
- $path = $this->getMockBuilder('\OCP\Files\File')->getMock();
- $storage = $this->getMockBuilder('OCP\Files\Storage')->getMock();
- $storage->method('instanceOfStorage')
- ->with('OCA\Files_Sharing\External\Storage')
- ->willReturn(false);
- $path->method('getStorage')->willReturn($storage);
- $this->rootFolder->method('getUserFolder')->with($this->currentUser)->will($this->returnSelf());
- $this->rootFolder->method('get')->with('valid-path')->willReturn($path);
- $this->shareManager->method('newShare')->willReturn(\OC::$server->getShareManager()->newShare());
- $this->shareManager->method('shareApiAllowLinks')->willReturn(true);
- $this->shareManager->method('shareApiLinkAllowPublicUpload')->willReturn(true);
- $this->ocs->createShare('valid-path', \OCP\Constants::PERMISSION_ALL, \OCP\Share::SHARE_TYPE_LINK, null, 'true');
- }
- public function testCreateShareLinkPublicUploadFolder() {
- $ocs = $this->mockFormatShare();
- $path = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $storage = $this->getMockBuilder('OCP\Files\Storage')->getMock();
- $storage->method('instanceOfStorage')
- ->with('OCA\Files_Sharing\External\Storage')
- ->willReturn(false);
- $path->method('getStorage')->willReturn($storage);
- $this->rootFolder->method('getUserFolder')->with($this->currentUser)->will($this->returnSelf());
- $this->rootFolder->method('get')->with('valid-path')->willReturn($path);
- $this->shareManager->method('newShare')->willReturn(\OC::$server->getShareManager()->newShare());
- $this->shareManager->method('shareApiAllowLinks')->willReturn(true);
- $this->shareManager->method('shareApiLinkAllowPublicUpload')->willReturn(true);
- $this->shareManager->expects($this->once())->method('createShare')->with(
- $this->callback(function (\OCP\Share\IShare $share) use ($path) {
- return $share->getNode() === $path &&
- $share->getShareType() === \OCP\Share::SHARE_TYPE_LINK &&
- $share->getPermissions() === (\OCP\Constants::PERMISSION_READ | \OCP\Constants::PERMISSION_CREATE | \OCP\Constants::PERMISSION_UPDATE | \OCP\Constants::PERMISSION_DELETE) &&
- $share->getSharedBy() === 'currentUser' &&
- $share->getPassword() === null &&
- $share->getExpirationDate() === null;
- })
- )->will($this->returnArgument(0));
- $expected = new DataResponse(null);
- $result = $ocs->createShare('valid-path', \OCP\Constants::PERMISSION_ALL, \OCP\Share::SHARE_TYPE_LINK, null, 'true', '', '');
- $this->assertInstanceOf(get_class($expected), $result);
- $this->assertEquals($expected->getData(), $result->getData());
- }
- public function testCreateShareLinkPassword() {
- $ocs = $this->mockFormatShare();
- $path = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $storage = $this->getMockBuilder('OCP\Files\Storage')->getMock();
- $storage->method('instanceOfStorage')
- ->with('OCA\Files_Sharing\External\Storage')
- ->willReturn(false);
- $path->method('getStorage')->willReturn($storage);
- $this->rootFolder->method('getUserFolder')->with($this->currentUser)->will($this->returnSelf());
- $this->rootFolder->method('get')->with('valid-path')->willReturn($path);
- $this->shareManager->method('newShare')->willReturn(\OC::$server->getShareManager()->newShare());
- $this->shareManager->method('shareApiAllowLinks')->willReturn(true);
- $this->shareManager->method('shareApiLinkAllowPublicUpload')->willReturn(true);
- $this->shareManager->expects($this->once())->method('createShare')->with(
- $this->callback(function (\OCP\Share\IShare $share) use ($path) {
- return $share->getNode() === $path &&
- $share->getShareType() === \OCP\Share::SHARE_TYPE_LINK &&
- $share->getPermissions() === \OCP\Constants::PERMISSION_READ &&
- $share->getSharedBy() === 'currentUser' &&
- $share->getPassword() === 'password' &&
- $share->getExpirationDate() === null;
- })
- )->will($this->returnArgument(0));
- $expected = new DataResponse(null);
- $result = $ocs->createShare('valid-path', \OCP\Constants::PERMISSION_ALL, \OCP\Share::SHARE_TYPE_LINK, null, 'false', 'password', '');
- $this->assertInstanceOf(get_class($expected), $result);
- $this->assertEquals($expected->getData(), $result->getData());
- }
- public function testCreateShareValidExpireDate() {
- $ocs = $this->mockFormatShare();
- $this->request
- ->method('getParam')
- ->will($this->returnValueMap([
- ['path', null, 'valid-path'],
- ['shareType', '-1', \OCP\Share::SHARE_TYPE_LINK],
- ['publicUpload', null, 'false'],
- ['expireDate', '', '2000-01-01'],
- ['password', '', ''],
- ]));
- $path = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $storage = $this->getMockBuilder('OCP\Files\Storage')->getMock();
- $storage->method('instanceOfStorage')
- ->with('OCA\Files_Sharing\External\Storage')
- ->willReturn(false);
- $path->method('getStorage')->willReturn($storage);
- $this->rootFolder->method('getUserFolder')->with($this->currentUser)->will($this->returnSelf());
- $this->rootFolder->method('get')->with('valid-path')->willReturn($path);
- $this->shareManager->method('newShare')->willReturn(\OC::$server->getShareManager()->newShare());
- $this->shareManager->method('shareApiAllowLinks')->willReturn(true);
- $this->shareManager->method('shareApiLinkAllowPublicUpload')->willReturn(true);
- $this->shareManager->expects($this->once())->method('createShare')->with(
- $this->callback(function (\OCP\Share\IShare $share) use ($path) {
- $date = new \DateTime('2000-01-01');
- $date->setTime(0,0,0);
- return $share->getNode() === $path &&
- $share->getShareType() === \OCP\Share::SHARE_TYPE_LINK &&
- $share->getPermissions() === \OCP\Constants::PERMISSION_READ &&
- $share->getSharedBy() === 'currentUser' &&
- $share->getPassword() === null &&
- $share->getExpirationDate() == $date;
- })
- )->will($this->returnArgument(0));
- $expected = new DataResponse(null);
- $result = $ocs->createShare('valid-path', \OCP\Constants::PERMISSION_ALL, \OCP\Share::SHARE_TYPE_LINK, null, 'false', '', '2000-01-01');
- $this->assertInstanceOf(get_class($expected), $result);
- $this->assertEquals($expected->getData(), $result->getData());
- }
- /**
- * @expectedException \OCP\AppFramework\OCS\OCSNotFoundException
- * @expectedExceptionMessage Invalid date, date format must be YYYY-MM-DD
- */
- public function testCreateShareInvalidExpireDate() {
- $ocs = $this->mockFormatShare();
- $path = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $storage = $this->getMockBuilder('OCP\Files\Storage')->getMock();
- $storage->method('instanceOfStorage')
- ->with('OCA\Files_Sharing\External\Storage')
- ->willReturn(false);
- $path->method('getStorage')->willReturn($storage);
- $this->rootFolder->method('getUserFolder')->with($this->currentUser)->will($this->returnSelf());
- $this->rootFolder->method('get')->with('valid-path')->willReturn($path);
- $this->shareManager->method('newShare')->willReturn(\OC::$server->getShareManager()->newShare());
- $this->shareManager->method('shareApiAllowLinks')->willReturn(true);
- $this->shareManager->method('shareApiLinkAllowPublicUpload')->willReturn(true);
- $ocs->createShare('valid-path', \OCP\Constants::PERMISSION_ALL, \OCP\Share::SHARE_TYPE_LINK, null, 'false', '', 'a1b2d3');
- }
- /**
- * Test for https://github.com/owncloud/core/issues/22587
- * TODO: Remove once proper solution is in place
- */
- public function testCreateReshareOfFederatedMountNoDeletePermissions() {
- $share = \OC::$server->getShareManager()->newShare();
- $this->shareManager->method('newShare')->willReturn($share);
- /** @var ShareAPIController|\PHPUnit_Framework_MockObject_MockObject $ocs */
- $ocs = $this->getMockBuilder(ShareAPIController::class)
- ->setConstructorArgs([
- $this->appName,
- $this->request,
- $this->shareManager,
- $this->groupManager,
- $this->userManager,
- $this->rootFolder,
- $this->urlGenerator,
- $this->currentUser,
- $this->l,
- ])->setMethods(['formatShare'])
- ->getMock();
- $userFolder = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $this->rootFolder->expects($this->once())
- ->method('getUserFolder')
- ->with('currentUser')
- ->willReturn($userFolder);
- $path = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $storage = $this->getMockBuilder('OCP\Files\Storage')->getMock();
- $storage->method('instanceOfStorage')
- ->with('OCA\Files_Sharing\External\Storage')
- ->willReturn(true);
- $path->method('getStorage')->willReturn($storage);
- $path->method('getPermissions')->willReturn(\OCP\Constants::PERMISSION_READ);
- $userFolder->expects($this->once())
- ->method('get')
- ->with('valid-path')
- ->willReturn($path);
- $this->userManager->method('userExists')->with('validUser')->willReturn(true);
- $this->shareManager
- ->expects($this->once())
- ->method('createShare')
- ->with($this->callback(function (\OCP\Share\IShare $share) {
- return $share->getPermissions() === \OCP\Constants::PERMISSION_READ;
- }))
- ->will($this->returnArgument(0));
- $ocs->createShare('valid-path', \OCP\Constants::PERMISSION_ALL, \OCP\Share::SHARE_TYPE_USER, 'validUser');
- }
- /**
- * @expectedException \OCP\AppFramework\OCS\OCSNotFoundException
- * @expectedExceptionMessage Wrong share ID, share doesn't exist
- */
- public function testUpdateShareCantAccess() {
- $node = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $share = $this->newShare();
- $share->setNode($node);
- $node->expects($this->once())
- ->method('lock')
- ->with(\OCP\Lock\ILockingProvider::LOCK_SHARED);
- $this->shareManager->method('getShareById')->with('ocinternal:42')->willReturn($share);
- $this->ocs->updateShare(42);
- }
- /**
- * @expectedException \OCP\AppFramework\OCS\OCSBadRequestException
- * @expectedExceptionMessage Wrong or no update parameter given
- */
- public function testUpdateNoParametersLink() {
- $node = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $share = $this->newShare();
- $share->setPermissions(\OCP\Constants::PERMISSION_ALL)
- ->setSharedBy($this->currentUser)
- ->setShareType(\OCP\Share::SHARE_TYPE_LINK)
- ->setNode($node);
- $node->expects($this->once())
- ->method('lock')
- ->with(\OCP\Lock\ILockingProvider::LOCK_SHARED);
- $this->shareManager->method('getShareById')->with('ocinternal:42')->willReturn($share);
- $this->ocs->updateShare(42);
- }
- /**
- * @expectedException \OCP\AppFramework\OCS\OCSBadRequestException
- * @expectedExceptionMessage Wrong or no update parameter given
- */
- public function testUpdateNoParametersOther() {
- $node = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $share = $this->newShare();
- $share->setPermissions(\OCP\Constants::PERMISSION_ALL)
- ->setSharedBy($this->currentUser)
- ->setShareType(\OCP\Share::SHARE_TYPE_GROUP)
- ->setNode($node);
- $node->expects($this->once())
- ->method('lock')
- ->with(\OCP\Lock\ILockingProvider::LOCK_SHARED);
- $this->shareManager->method('getShareById')->with('ocinternal:42')->willReturn($share);
- $this->ocs->updateShare(42);
- }
- public function testUpdateLinkShareClear() {
- $ocs = $this->mockFormatShare();
- $node = $this->getMockBuilder(Folder::class)->getMock();
- $share = $this->newShare();
- $share->setPermissions(\OCP\Constants::PERMISSION_ALL)
- ->setSharedBy($this->currentUser)
- ->setShareType(\OCP\Share::SHARE_TYPE_LINK)
- ->setPassword('password')
- ->setExpirationDate(new \DateTime())
- ->setPermissions(\OCP\Constants::PERMISSION_ALL)
- ->setNode($node);
- $node->expects($this->once())
- ->method('lock')
- ->with(\OCP\Lock\ILockingProvider::LOCK_SHARED);
- $this->shareManager->method('getShareById')->with('ocinternal:42')->willReturn($share);
- $this->shareManager->expects($this->once())->method('updateShare')->with(
- $this->callback(function (\OCP\Share\IShare $share) {
- return $share->getPermissions() === \OCP\Constants::PERMISSION_READ &&
- $share->getPassword() === null &&
- $share->getExpirationDate() === null;
- })
- )->will($this->returnArgument(0));
- $this->shareManager->method('getSharedWith')
- ->willReturn([]);
- $expected = new DataResponse(null);
- $result = $ocs->updateShare(42, null, '', 'false', '');
- $this->assertInstanceOf(get_class($expected), $result);
- $this->assertEquals($expected->getData(), $result->getData());
- }
- public function testUpdateLinkShareSet() {
- $ocs = $this->mockFormatShare();
- $folder = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $share = \OC::$server->getShareManager()->newShare();
- $share->setPermissions(\OCP\Constants::PERMISSION_ALL)
- ->setSharedBy($this->currentUser)
- ->setShareType(\OCP\Share::SHARE_TYPE_LINK)
- ->setNode($folder);
- $this->shareManager->method('getShareById')->with('ocinternal:42')->willReturn($share);
- $this->shareManager->method('shareApiLinkAllowPublicUpload')->willReturn(true);
- $this->shareManager->expects($this->once())->method('updateShare')->with(
- $this->callback(function (\OCP\Share\IShare $share) {
- $date = new \DateTime('2000-01-01');
- $date->setTime(0,0,0);
- return $share->getPermissions() === (\OCP\Constants::PERMISSION_READ | \OCP\Constants::PERMISSION_CREATE | \OCP\Constants::PERMISSION_UPDATE | \OCP\Constants::PERMISSION_DELETE) &&
- $share->getPassword() === 'password' &&
- $share->getExpirationDate() == $date;
- })
- )->will($this->returnArgument(0));
- $this->shareManager->method('getSharedWith')
- ->willReturn([]);
- $expected = new DataResponse(null);
- $result = $ocs->updateShare(42, null, 'password', 'true', '2000-01-01');
- $this->assertInstanceOf(get_class($expected), $result);
- $this->assertEquals($expected->getData(), $result->getData());
- }
- /**
- * @dataProvider publicUploadParamsProvider
- */
- public function testUpdateLinkShareEnablePublicUpload($permissions, $publicUpload, $expireDate, $password) {
- $ocs = $this->mockFormatShare();
- $folder = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $share = \OC::$server->getShareManager()->newShare();
- $share->setPermissions(\OCP\Constants::PERMISSION_ALL)
- ->setSharedBy($this->currentUser)
- ->setShareType(\OCP\Share::SHARE_TYPE_LINK)
- ->setPassword('password')
- ->setNode($folder);
- $this->shareManager->method('getShareById')->with('ocinternal:42')->willReturn($share);
- $this->shareManager->method('shareApiLinkAllowPublicUpload')->willReturn(true);
- $this->shareManager->method('getSharedWith')->willReturn([]);
- $this->shareManager->expects($this->once())->method('updateShare')->with(
- $this->callback(function (\OCP\Share\IShare $share) {
- return $share->getPermissions() === (\OCP\Constants::PERMISSION_READ | \OCP\Constants::PERMISSION_CREATE | \OCP\Constants::PERMISSION_UPDATE | \OCP\Constants::PERMISSION_DELETE) &&
- $share->getPassword() === 'password' &&
- $share->getExpirationDate() === null;
- })
- )->will($this->returnArgument(0));
- $expected = new DataResponse(null);
- $result = $ocs->updateShare(42, $permissions, $password, $publicUpload, $expireDate);
- $this->assertInstanceOf(get_class($expected), $result);
- $this->assertEquals($expected->getData(), $result->getData());
- }
- /**
- * @expectedException \OCP\AppFramework\OCS\OCSBadRequestException
- * @expectedExceptionMessage Invalid date. Format must be YYYY-MM-DD
- */
- public function testUpdateLinkShareInvalidDate() {
- $ocs = $this->mockFormatShare();
- $folder = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $share = \OC::$server->getShareManager()->newShare();
- $share->setPermissions(\OCP\Constants::PERMISSION_ALL)
- ->setSharedBy($this->currentUser)
- ->setShareType(\OCP\Share::SHARE_TYPE_LINK)
- ->setNode($folder);
- $this->shareManager->method('getShareById')->with('ocinternal:42')->willReturn($share);
- $this->shareManager->method('shareApiLinkAllowPublicUpload')->willReturn(true);
- $ocs->updateShare(42, null, 'password', 'true', '2000-01-a');
- }
- public function publicUploadParamsProvider() {
- return [
- [null, 'true', null, 'password'],
- // legacy had no delete
- [
- \OCP\Constants::PERMISSION_READ | \OCP\Constants::PERMISSION_CREATE | \OCP\Constants::PERMISSION_UPDATE,
- null, null, 'password'
- ],
- // correct
- [
- \OCP\Constants::PERMISSION_READ | \OCP\Constants::PERMISSION_CREATE | \OCP\Constants::PERMISSION_UPDATE | \OCP\Constants::PERMISSION_DELETE,
- null, null, 'password'
- ],
- ];
- }
- /**
- * @dataProvider publicUploadParamsProvider
- * @expectedException \OCP\AppFramework\OCS\OCSForbiddenException
- * @expectedExceptionMessage Public upload disabled by the administrator
- */
- public function testUpdateLinkSharePublicUploadNotAllowed($permissions, $publicUpload, $expireDate, $password) {
- $ocs = $this->mockFormatShare();
- $folder = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $share = \OC::$server->getShareManager()->newShare();
- $share->setPermissions(\OCP\Constants::PERMISSION_ALL)
- ->setSharedBy($this->currentUser)
- ->setShareType(\OCP\Share::SHARE_TYPE_LINK)
- ->setNode($folder);
- $this->shareManager->method('getShareById')->with('ocinternal:42')->willReturn($share);
- $this->shareManager->method('shareApiLinkAllowPublicUpload')->willReturn(false);
- $ocs->updateShare(42, $permissions, $password, $publicUpload, $expireDate);
- }
- /**
- * @expectedException \OCP\AppFramework\OCS\OCSBadRequestException
- * @expectedExceptionMessage Public upload is only possible for publicly shared folders
- */
- public function testUpdateLinkSharePublicUploadOnFile() {
- $ocs = $this->mockFormatShare();
- $file = $this->getMockBuilder('\OCP\Files\File')->getMock();
- $share = \OC::$server->getShareManager()->newShare();
- $share->setPermissions(\OCP\Constants::PERMISSION_ALL)
- ->setSharedBy($this->currentUser)
- ->setShareType(\OCP\Share::SHARE_TYPE_LINK)
- ->setNode($file);
- $this->shareManager->method('getShareById')->with('ocinternal:42')->willReturn($share);
- $this->shareManager->method('shareApiLinkAllowPublicUpload')->willReturn(true);
- $ocs->updateShare(42, null, 'password', 'true', '');
- }
- public function testUpdateLinkSharePasswordDoesNotChangeOther() {
- $ocs = $this->mockFormatShare();
- $date = new \DateTime('2000-01-01');
- $date->setTime(0,0,0);
- $node = $this->getMockBuilder('\OCP\Files\File')->getMock();
- $share = $this->newShare();
- $share->setPermissions(\OCP\Constants::PERMISSION_ALL)
- ->setSharedBy($this->currentUser)
- ->setShareType(\OCP\Share::SHARE_TYPE_LINK)
- ->setPassword('password')
- ->setExpirationDate($date)
- ->setPermissions(\OCP\Constants::PERMISSION_ALL)
- ->setNode($node);
- $node->expects($this->once())
- ->method('lock')
- ->with(\OCP\Lock\ILockingProvider::LOCK_SHARED);
- $this->shareManager->method('getShareById')->with('ocinternal:42')->willReturn($share);
- $this->shareManager->expects($this->once())->method('updateShare')->with(
- $this->callback(function (\OCP\Share\IShare $share) use ($date) {
- return $share->getPermissions() === \OCP\Constants::PERMISSION_ALL &&
- $share->getPassword() === 'newpassword' &&
- $share->getExpirationDate() === $date;
- })
- )->will($this->returnArgument(0));
- $expected = new DataResponse(null);
- $result = $ocs->updateShare(42, null, 'newpassword', null, null);
- $this->assertInstanceOf(get_class($expected), $result);
- $this->assertEquals($expected->getData(), $result->getData());
- }
- public function testUpdateLinkShareExpireDateDoesNotChangeOther() {
- $ocs = $this->mockFormatShare();
- $node = $this->getMockBuilder('\OCP\Files\File')->getMock();
- $share = $this->newShare();
- $share->setPermissions(\OCP\Constants::PERMISSION_ALL)
- ->setSharedBy($this->currentUser)
- ->setShareType(\OCP\Share::SHARE_TYPE_LINK)
- ->setPassword('password')
- ->setExpirationDate(new \DateTime())
- ->setPermissions(\OCP\Constants::PERMISSION_ALL)
- ->setNode($node);
- $node->expects($this->once())
- ->method('lock')
- ->with(\OCP\Lock\ILockingProvider::LOCK_SHARED);
- $this->shareManager->method('getShareById')->with('ocinternal:42')->willReturn($share);
- $this->shareManager->expects($this->once())->method('updateShare')->with(
- $this->callback(function (\OCP\Share\IShare $share) {
- $date = new \DateTime('2010-12-23');
- $date->setTime(0,0,0);
- return $share->getPermissions() === \OCP\Constants::PERMISSION_ALL &&
- $share->getPassword() === 'password' &&
- $share->getExpirationDate() == $date;
- })
- )->will($this->returnArgument(0));
- $expected = new DataResponse(null);
- $result = $ocs->updateShare(42, null, null, null, '2010-12-23');
- $this->assertInstanceOf(get_class($expected), $result);
- $this->assertEquals($expected->getData(), $result->getData());
- }
- public function testUpdateLinkSharePublicUploadDoesNotChangeOther() {
- $ocs = $this->mockFormatShare();
- $date = new \DateTime('2000-01-01');
- $folder = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $share = \OC::$server->getShareManager()->newShare();
- $share->setPermissions(\OCP\Constants::PERMISSION_ALL)
- ->setSharedBy($this->currentUser)
- ->setShareType(\OCP\Share::SHARE_TYPE_LINK)
- ->setPassword('password')
- ->setExpirationDate($date)
- ->setPermissions(\OCP\Constants::PERMISSION_ALL)
- ->setNode($folder);
- $this->shareManager->method('getShareById')->with('ocinternal:42')->willReturn($share);
- $this->shareManager->method('shareApiLinkAllowPublicUpload')->willReturn(true);
- $this->shareManager->expects($this->once())->method('updateShare')->with(
- $this->callback(function (\OCP\Share\IShare $share) use ($date) {
- return $share->getPermissions() === (\OCP\Constants::PERMISSION_READ | \OCP\Constants::PERMISSION_CREATE | \OCP\Constants::PERMISSION_UPDATE | \OCP\Constants::PERMISSION_DELETE) &&
- $share->getPassword() === 'password' &&
- $share->getExpirationDate() === $date;
- })
- )->will($this->returnArgument(0));
- $this->shareManager->method('getSharedWith')
- ->willReturn([]);
- $expected = new DataResponse(null);
- $result = $ocs->updateShare(42, null, null, 'true', null);
- $this->assertInstanceOf(get_class($expected), $result);
- $this->assertEquals($expected->getData(), $result->getData());
- }
- public function testUpdateLinkSharePermissions() {
- $ocs = $this->mockFormatShare();
- $date = new \DateTime('2000-01-01');
- $folder = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $share = \OC::$server->getShareManager()->newShare();
- $share->setPermissions(\OCP\Constants::PERMISSION_ALL)
- ->setSharedBy($this->currentUser)
- ->setShareType(\OCP\Share::SHARE_TYPE_LINK)
- ->setPassword('password')
- ->setExpirationDate($date)
- ->setPermissions(\OCP\Constants::PERMISSION_ALL)
- ->setNode($folder);
- $this->shareManager->method('getShareById')->with('ocinternal:42')->willReturn($share);
- $this->shareManager->method('shareApiLinkAllowPublicUpload')->willReturn(true);
- $this->shareManager->expects($this->once())->method('updateShare')->with(
- $this->callback(function (\OCP\Share\IShare $share) use ($date) {
- return $share->getPermissions() === (\OCP\Constants::PERMISSION_READ | \OCP\Constants::PERMISSION_CREATE | \OCP\Constants::PERMISSION_UPDATE | \OCP\Constants::PERMISSION_DELETE) &&
- $share->getPassword() === 'password' &&
- $share->getExpirationDate() === $date;
- })
- )->will($this->returnArgument(0));
- $this->shareManager->method('getSharedWith')->willReturn([]);
- $expected = new DataResponse(null);
- $result = $ocs->updateShare(42, 7, null, null, null);
- $this->assertInstanceOf(get_class($expected), $result);
- $this->assertEquals($expected->getData(), $result->getData());
- }
- /**
- * @expectedException \OCP\AppFramework\OCS\OCSBadRequestException
- * @expectedExceptionMessage Can't change permissions for public share links
- */
- public function testUpdateLinkShareInvalidPermissions() {
- $ocs = $this->mockFormatShare();
- $date = new \DateTime('2000-01-01');
- $folder = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $share = \OC::$server->getShareManager()->newShare();
- $share->setPermissions(\OCP\Constants::PERMISSION_ALL)
- ->setSharedBy($this->currentUser)
- ->setShareType(\OCP\Share::SHARE_TYPE_LINK)
- ->setPassword('password')
- ->setExpirationDate($date)
- ->setPermissions(\OCP\Constants::PERMISSION_ALL)
- ->setNode($folder);
- $this->shareManager->method('getShareById')->with('ocinternal:42')->willReturn($share);
- $this->shareManager->method('shareApiLinkAllowPublicUpload')->willReturn(true);
- $ocs->updateShare(42, 31);
- }
- public function testUpdateOtherPermissions() {
- $ocs = $this->mockFormatShare();
- $file = $this->getMockBuilder('\OCP\Files\File')->getMock();
- $share = \OC::$server->getShareManager()->newShare();
- $share->setPermissions(\OCP\Constants::PERMISSION_ALL)
- ->setSharedBy($this->currentUser)
- ->setShareType(\OCP\Share::SHARE_TYPE_USER)
- ->setNode($file);
- $this->shareManager->method('getShareById')->with('ocinternal:42')->willReturn($share);
- $this->shareManager->method('shareApiLinkAllowPublicUpload')->willReturn(true);
- $this->shareManager->expects($this->once())->method('updateShare')->with(
- $this->callback(function (\OCP\Share\IShare $share) {
- return $share->getPermissions() === \OCP\Constants::PERMISSION_ALL;
- })
- )->will($this->returnArgument(0));
- $this->shareManager->method('getSharedWith')->willReturn([]);
- $expected = new DataResponse(null);
- $result = $ocs->updateShare(42, 31, null, null, null);
- $this->assertInstanceOf(get_class($expected), $result);
- $this->assertEquals($expected->getData(), $result->getData());
- }
- public function testUpdateShareCannotIncreasePermissions() {
- $ocs = $this->mockFormatShare();
- $folder = $this->createMock(Folder::class);
- $share = \OC::$server->getShareManager()->newShare();
- $share
- ->setId(42)
- ->setSharedBy($this->currentUser)
- ->setShareOwner('anotheruser')
- ->setShareType(\OCP\Share::SHARE_TYPE_GROUP)
- ->setSharedWith('group1')
- ->setPermissions(\OCP\Constants::PERMISSION_READ)
- ->setNode($folder);
- // note: updateShare will modify the received instance but getSharedWith will reread from the database,
- // so their values will be different
- $incomingShare = \OC::$server->getShareManager()->newShare();
- $incomingShare
- ->setId(42)
- ->setSharedBy($this->currentUser)
- ->setShareOwner('anotheruser')
- ->setShareType(\OCP\Share::SHARE_TYPE_GROUP)
- ->setSharedWith('group1')
- ->setPermissions(\OCP\Constants::PERMISSION_READ)
- ->setNode($folder);
- $this->request
- ->method('getParam')
- ->will($this->returnValueMap([
- ['permissions', null, '31'],
- ]));
- $this->shareManager->method('getShareById')->with('ocinternal:42')->willReturn($share);
- $this->shareManager->expects($this->any())
- ->method('getSharedWith')
- ->will($this->returnValueMap([
- ['currentUser', \OCP\Share::SHARE_TYPE_USER, $share->getNode(), -1, 0, []],
- ['currentUser', \OCP\Share::SHARE_TYPE_GROUP, $share->getNode(), -1, 0, [$incomingShare]]
- ]));
- $this->shareManager->expects($this->never())->method('updateShare');
- try {
- $ocs->updateShare(42, 31);
- $this->fail();
- } catch (OCSNotFoundException $e) {
- $this->assertEquals('Cannot increase permissions', $e->getMessage());
- }
- }
- public function testUpdateShareCannotIncreasePermissionsLinkShare() {
- $ocs = $this->mockFormatShare();
- $folder = $this->createMock(Folder::class);
- $share = \OC::$server->getShareManager()->newShare();
- $share
- ->setId(42)
- ->setSharedBy($this->currentUser)
- ->setShareOwner('anotheruser')
- ->setShareType(\OCP\Share::SHARE_TYPE_LINK)
- ->setPermissions(\OCP\Constants::PERMISSION_READ)
- ->setNode($folder);
- // note: updateShare will modify the received instance but getSharedWith will reread from the database,
- // so their values will be different
- $incomingShare = \OC::$server->getShareManager()->newShare();
- $incomingShare
- ->setId(42)
- ->setSharedBy($this->currentUser)
- ->setShareOwner('anotheruser')
- ->setShareType(\OCP\Share::SHARE_TYPE_USER)
- ->setSharedWith('currentUser')
- ->setPermissions(\OCP\Constants::PERMISSION_READ)
- ->setNode($folder);
- $this->shareManager->method('getShareById')->with('ocinternal:42')->willReturn($share);
- $this->shareManager->expects($this->any())
- ->method('getSharedWith')
- ->will($this->returnValueMap([
- ['currentUser', \OCP\Share::SHARE_TYPE_USER, $share->getNode(), -1, 0, [$incomingShare]],
- ['currentUser', \OCP\Share::SHARE_TYPE_GROUP, $share->getNode(), -1, 0, []]
- ]));
- $this->shareManager->expects($this->never())->method('updateShare');
- $this->shareManager->method('shareApiLinkAllowPublicUpload')->willReturn(true);
- try {
- $ocs->updateShare(42, null, null, 'true');
- $this->fail();
- } catch (OCSNotFoundException $e) {
- $this->assertEquals('Cannot increase permissions', $e->getMessage());
- }
- }
- public function testUpdateShareCanIncreasePermissionsIfOwner() {
- $ocs = $this->mockFormatShare();
- $folder = $this->createMock(Folder::class);
- $share = \OC::$server->getShareManager()->newShare();
- $share
- ->setId(42)
- ->setSharedBy($this->currentUser)
- ->setShareOwner($this->currentUser)
- ->setShareType(\OCP\Share::SHARE_TYPE_GROUP)
- ->setSharedWith('group1')
- ->setPermissions(\OCP\Constants::PERMISSION_READ)
- ->setNode($folder);
- // note: updateShare will modify the received instance but getSharedWith will reread from the database,
- // so their values will be different
- $incomingShare = \OC::$server->getShareManager()->newShare();
- $incomingShare
- ->setId(42)
- ->setSharedBy($this->currentUser)
- ->setShareOwner($this->currentUser)
- ->setShareType(\OCP\Share::SHARE_TYPE_GROUP)
- ->setSharedWith('group1')
- ->setPermissions(\OCP\Constants::PERMISSION_READ)
- ->setNode($folder);
- $this->shareManager->method('getShareById')->with('ocinternal:42')->willReturn($share);
- $this->shareManager->expects($this->any())
- ->method('getSharedWith')
- ->will($this->returnValueMap([
- ['currentUser', \OCP\Share::SHARE_TYPE_USER, $share->getNode(), -1, 0, []],
- ['currentUser', \OCP\Share::SHARE_TYPE_GROUP, $share->getNode(), -1, 0, [$incomingShare]]
- ]));
- $this->shareManager->expects($this->once())
- ->method('updateShare')
- ->with($share)
- ->willReturn($share);
- $result = $ocs->updateShare(42, 31);
- $this->assertInstanceOf(DataResponse::class, $result);
- }
- public function dataFormatShare() {
- $file = $this->getMockBuilder('\OCP\Files\File')->getMock();
- $folder = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $parent = $this->getMockBuilder('\OCP\Files\Folder')->getMock();
- $file->method('getMimeType')->willReturn('myMimeType');
- $folder->method('getMimeType')->willReturn('myFolderMimeType');
- $file->method('getPath')->willReturn('file');
- $folder->method('getPath')->willReturn('folder');
- $parent->method('getId')->willReturn(1);
- $folder->method('getId')->willReturn(2);
- $file->method('getId')->willReturn(3);
- $file->method('getParent')->willReturn($parent);
- $folder->method('getParent')->willReturn($parent);
- $cache = $this->getMockBuilder('OCP\Files\Cache\ICache')->getMock();
- $cache->method('getNumericStorageId')->willReturn(100);
- $storage = $this->getMockBuilder('\OCP\Files\Storage')->getMock();
- $storage->method('getId')->willReturn('storageId');
- $storage->method('getCache')->willReturn($cache);
- $file->method('getStorage')->willReturn($storage);
- $folder->method('getStorage')->willReturn($storage);
- $owner = $this->getMockBuilder('\OCP\IUser')->getMock();
- $owner->method('getDisplayName')->willReturn('ownerDN');
- $initiator = $this->getMockBuilder('\OCP\IUser')->getMock();
- $initiator->method('getDisplayName')->willReturn('initiatorDN');
- $recipient = $this->getMockBuilder('\OCP\IUser')->getMock();
- $recipient->method('getDisplayName')->willReturn('recipientDN');
- $result = [];
- $share = \OC::$server->getShareManager()->newShare();
- $share->setShareType(\OCP\Share::SHARE_TYPE_USER)
- ->setSharedWith('recipient')
- ->setSharedBy('initiator')
- ->setShareOwner('owner')
- ->setPermissions(\OCP\Constants::PERMISSION_READ)
- ->setNode($file)
- ->setShareTime(new \DateTime('2000-01-01T00:01:02'))
- ->setTarget('myTarget')
- ->setId(42);
- /* User backend down */
- $result[] = [
- [
- 'id' => 42,
- 'share_type' => \OCP\Share::SHARE_TYPE_USER,
- 'uid_owner' => 'initiator',
- 'displayname_owner' => 'initiator',
- 'permissions' => 1,
- 'stime' => 946684862,
- 'parent' => null,
- 'expiration' => null,
- 'token' => null,
- 'uid_file_owner' => 'owner',
- 'displayname_file_owner' => 'owner',
- 'path' => 'file',
- 'item_type' => 'file',
- 'storage_id' => 'storageId',
- 'storage' => 100,
- 'item_source' => 3,
- 'file_source' => 3,
- 'file_parent' => 1,
- 'file_target' => 'myTarget',
- 'share_with' => 'recipient',
- 'share_with_displayname' => 'recipient',
- 'mail_send' => 0,
- 'mimetype' => 'myMimeType',
- ], $share, [], false
- ];
- /* User backend up */
- $result[] = [
- [
- 'id' => 42,
- 'share_type' => \OCP\Share::SHARE_TYPE_USER,
- 'uid_owner' => 'initiator',
- 'displayname_owner' => 'initiatorDN',
- 'permissions' => 1,
- 'stime' => 946684862,
- 'parent' => null,
- 'expiration' => null,
- 'token' => null,
- 'uid_file_owner' => 'owner',
- 'displayname_file_owner' => 'ownerDN',
- 'path' => 'file',
- 'item_type' => 'file',
- 'storage_id' => 'storageId',
- 'storage' => 100,
- 'item_source' => 3,
- 'file_source' => 3,
- 'file_parent' => 1,
- 'file_target' => 'myTarget',
- 'share_with' => 'recipient',
- 'share_with_displayname' => 'recipientDN',
- 'mail_send' => 0,
- 'mimetype' => 'myMimeType',
- ], $share, [
- ['owner', $owner],
- ['initiator', $initiator],
- ['recipient', $recipient],
- ], false
- ];
- $share = \OC::$server->getShareManager()->newShare();
- $share->setShareType(\OCP\Share::SHARE_TYPE_USER)
- ->setSharedWith('recipient')
- ->setSharedBy('initiator')
- ->setShareOwner('owner')
- ->setPermissions(\OCP\Constants::PERMISSION_READ)
- ->setNode($file)
- ->setShareTime(new \DateTime('2000-01-01T00:01:02'))
- ->setTarget('myTarget')
- ->setId(42);
- /* User backend down */
- $result[] = [
- [
- 'id' => 42,
- 'share_type' => \OCP\Share::SHARE_TYPE_USER,
- 'uid_owner' => 'initiator',
- 'displayname_owner' => 'initiator',
- 'permissions' => 1,
- 'stime' => 946684862,
- 'parent' => null,
- 'expiration' => null,
- 'token' => null,
- 'uid_file_owner' => 'owner',
- 'displayname_file_owner' => 'owner',
- 'path' => 'file',
- 'item_type' => 'file',
- 'storage_id' => 'storageId',
- 'storage' => 100,
- 'item_source' => 3,
- 'file_source' => 3,
- 'file_parent' => 1,
- 'file_target' => 'myTarget',
- 'share_with' => 'recipient',
- 'share_with_displayname' => 'recipient',
- 'mail_send' => 0,
- 'mimetype' => 'myMimeType',
- ], $share, [], false
- ];
- // with existing group
- $share = \OC::$server->getShareManager()->newShare();
- $share->setShareType(\OCP\Share::SHARE_TYPE_GROUP)
- ->setSharedWith('recipientGroup')
- ->setSharedBy('initiator')
- ->setShareOwner('owner')
- ->setPermissions(\OCP\Constants::PERMISSION_READ)
- ->setNode($file)
- ->setShareTime(new \DateTime('2000-01-01T00:01:02'))
- ->setTarget('myTarget')
- ->setId(42);
- $result[] = [
- [
- 'id' => 42,
- 'share_type' => \OCP\Share::SHARE_TYPE_GROUP,
- 'uid_owner' => 'initiator',
- 'displayname_owner' => 'initiator',
- 'permissions' => 1,
- 'stime' => 946684862,
- 'parent' => null,
- 'expiration' => null,
- 'token' => null,
- 'uid_file_owner' => 'owner',
- 'displayname_file_owner' => 'owner',
- 'path' => 'file',
- 'item_type' => 'file',
- 'storage_id' => 'storageId',
- 'storage' => 100,
- 'item_source' => 3,
- 'file_source' => 3,
- 'file_parent' => 1,
- 'file_target' => 'myTarget',
- 'share_with' => 'recipientGroup',
- 'share_with_displayname' => 'recipientGroupDisplayName',
- 'mail_send' => 0,
- 'mimetype' => 'myMimeType',
- ], $share, [], false
- ];
- // with unknown group / no group backend
- $share = \OC::$server->getShareManager()->newShare();
- $share->setShareType(Share::SHARE_TYPE_GROUP)
- ->setSharedWith('recipientGroup2')
- ->setSharedBy('initiator')
- ->setShareOwner('owner')
- ->setPermissions(\OCP\Constants::PERMISSION_READ)
- ->setNode($file)
- ->setShareTime(new \DateTime('2000-01-01T00:01:02'))
- ->setTarget('myTarget')
- ->setId(42);
- $result[] = [
- [
- 'id' => 42,
- 'share_type' => Share::SHARE_TYPE_GROUP,
- 'uid_owner' => 'initiator',
- 'displayname_owner' => 'initiator',
- 'permissions' => 1,
- 'stime' => 946684862,
- 'parent' => null,
- 'expiration' => null,
- 'token' => null,
- 'uid_file_owner' => 'owner',
- 'displayname_file_owner' => 'owner',
- 'path' => 'file',
- 'item_type' => 'file',
- 'storage_id' => 'storageId',
- 'storage' => 100,
- 'item_source' => 3,
- 'file_source' => 3,
- 'file_parent' => 1,
- 'file_target' => 'myTarget',
- 'share_with' => 'recipientGroup2',
- 'share_with_displayname' => 'recipientGroup2',
- 'mail_send' => 0,
- 'mimetype' => 'myMimeType',
- ], $share, [], false
- ];
- $share = \OC::$server->getShareManager()->newShare();
- $share->setShareType(\OCP\Share::SHARE_TYPE_LINK)
- ->setSharedBy('initiator')
- ->setShareOwner('owner')
- ->setPermissions(\OCP\Constants::PERMISSION_READ)
- ->setNode($file)
- ->setShareTime(new \DateTime('2000-01-01T00:01:02'))
- ->setTarget('myTarget')
- ->setPassword('mypassword')
- ->setExpirationDate(new \DateTime('2001-01-02T00:00:00'))
- ->setToken('myToken')
- ->setId(42);
- $result[] = [
- [
- 'id' => 42,
- 'share_type' => \OCP\Share::SHARE_TYPE_LINK,
- 'uid_owner' => 'initiator',
- 'displayname_owner' => 'initiator',
- 'permissions' => 1,
- 'stime' => 946684862,
- 'parent' => null,
- 'expiration' => '2001-01-02 00:00:00',
- 'token' => 'myToken',
- 'uid_file_owner' => 'owner',
- 'displayname_file_owner' => 'owner',
- 'path' => 'file',
- 'item_type' => 'file',
- 'storage_id' => 'storageId',
- 'storage' => 100,
- 'item_source' => 3,
- 'file_source' => 3,
- 'file_parent' => 1,
- 'file_target' => 'myTarget',
- 'share_with' => 'mypassword',
- 'share_with_displayname' => 'mypassword',
- 'mail_send' => 0,
- 'url' => 'myLink',
- 'mimetype' => 'myMimeType',
- ], $share, [], false
- ];
- $share = \OC::$server->getShareManager()->newShare();
- $share->setShareType(\OCP\Share::SHARE_TYPE_REMOTE)
- ->setSharedBy('initiator')
- ->setSharedWith('user@server.com')
- ->setShareOwner('owner')
- ->setPermissions(\OCP\Constants::PERMISSION_READ)
- ->setNode($folder)
- ->setShareTime(new \DateTime('2000-01-01T00:01:02'))
- ->setTarget('myTarget')
- ->setId(42);
- $result[] = [
- [
- 'id' => 42,
- 'share_type' => \OCP\Share::SHARE_TYPE_REMOTE,
- 'uid_owner' => 'initiator',
- 'displayname_owner' => 'initiator',
- 'permissions' => 1,
- 'stime' => 946684862,
- 'parent' => null,
- 'expiration' => null,
- 'token' => null,
- 'uid_file_owner' => 'owner',
- 'displayname_file_owner' => 'owner',
- 'path' => 'folder',
- 'item_type' => 'folder',
- 'storage_id' => 'storageId',
- 'storage' => 100,
- 'item_source' => 2,
- 'file_source' => 2,
- 'file_parent' => 1,
- 'file_target' => 'myTarget',
- 'share_with' => 'user@server.com',
- 'share_with_displayname' => 'user@server.com',
- 'mail_send' => 0,
- 'mimetype' => 'myFolderMimeType',
- ], $share, [], false
- ];
- $share = \OC::$server->getShareManager()->newShare();
- $share->setShareType(\OCP\Share::SHARE_TYPE_USER)
- ->setSharedBy('initiator')
- ->setSharedWith('recipient')
- ->setShareOwner('owner')
- ->setPermissions(\OCP\Constants::PERMISSION_READ)
- ->setShareTime(new \DateTime('2000-01-01T00:01:02'))
- ->setTarget('myTarget')
- ->setId(42);
- $result[] = [
- [], $share, [], true
- ];
- return $result;
- }
- /**
- * @dataProvider dataFormatShare
- *
- * @param array $expects
- * @param \OCP\Share\IShare $share
- * @param array $users
- * @param $exception
- */
- public function testFormatShare(array $expects, \OCP\Share\IShare $share, array $users, $exception) {
- $this->userManager->method('get')->will($this->returnValueMap($users));
- $recipientGroup = $this->createMock('\OCP\IGroup');
- $recipientGroup->method('getDisplayName')->willReturn('recipientGroupDisplayName');
- $this->groupManager->method('get')->will($this->returnValueMap([
- ['recipientGroup', $recipientGroup],
- ]));
- $this->urlGenerator->method('linkToRouteAbsolute')
- ->with('files_sharing.sharecontroller.showShare', ['token' => 'myToken'])
- ->willReturn('myLink');
- $this->rootFolder->method('getUserFolder')
- ->with($this->currentUser)
- ->will($this->returnSelf());
- if (!$exception) {
- $this->rootFolder->method('getById')
- ->with($share->getNodeId())
- ->willReturn([$share->getNode()]);
- $this->rootFolder->method('getRelativePath')
- ->with($share->getNode()->getPath())
- ->will($this->returnArgument(0));
- }
- try {
- $result = $this->invokePrivate($this->ocs, 'formatShare', [$share]);
- $this->assertFalse($exception);
- $this->assertEquals($expects, $result);
- } catch (NotFoundException $e) {
- $this->assertTrue($exception);
- }
- }
- }
|