diff options
author | Roeland Jago Douma <rullzer@users.noreply.github.com> | 2020-04-04 10:33:46 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-04-04 10:33:46 +0200 |
commit | 28bac958fa2852428c9724fbd05ce668b2298074 (patch) | |
tree | 09752738abe59f04b3ae1ec85a8ea27a5138f581 /apps/dav | |
parent | 4d9fa0213b84291954849fed983777dc1a15d0cd (diff) | |
parent | a2622e6e894c9a1b32d555c66c052d228183abd4 (diff) | |
download | nextcloud-server-28bac958fa2852428c9724fbd05ce668b2298074.tar.gz nextcloud-server-28bac958fa2852428c9724fbd05ce668b2298074.zip |
Merge pull request #20148 from nextcloud/backport/19986/stable18
[stable18] RefreshWebcalService: randomly generate calendar-object uri
Diffstat (limited to 'apps/dav')
-rw-r--r-- | apps/dav/lib/CalDAV/WebcalCaching/RefreshWebcalService.php | 14 | ||||
-rw-r--r-- | apps/dav/tests/unit/CalDAV/WebcalCaching/RefreshWebcalServiceTest.php | 12 |
2 files changed, 20 insertions, 6 deletions
diff --git a/apps/dav/lib/CalDAV/WebcalCaching/RefreshWebcalService.php b/apps/dav/lib/CalDAV/WebcalCaching/RefreshWebcalService.php index beab0271d8f..a057e29eb2c 100644 --- a/apps/dav/lib/CalDAV/WebcalCaching/RefreshWebcalService.php +++ b/apps/dav/lib/CalDAV/WebcalCaching/RefreshWebcalService.php @@ -47,6 +47,7 @@ use Sabre\VObject\InvalidDataException; use Sabre\VObject\ParseException; use Sabre\VObject\Reader; use Sabre\VObject\Splitter\ICalendar; +use Sabre\VObject\UUIDUtil; use function count; class RefreshWebcalService { @@ -113,7 +114,6 @@ class RefreshWebcalService { while ($vObject = $splitter->getNext()) { /** @var Component $vObject */ - $uid = null; $compName = null; foreach ($vObject->getComponents() as $component) { @@ -121,7 +121,6 @@ class RefreshWebcalService { continue; } - $uid = $component->{'UID'}->getValue(); $compName = $component->name; if ($stripAlarms) { @@ -136,7 +135,7 @@ class RefreshWebcalService { continue; } - $uri = $uid . '.ics'; + $uri = $this->getRandomCalendarObjectUri(); $calendarData = $vObject->serialize(); try { $this->calDavBackend->createCalendarObject($subscription['id'], $uri, $calendarData, CalDavBackend::CALENDAR_TYPE_SUBSCRIPTION); @@ -413,4 +412,13 @@ class RefreshWebcalService { return $cleanURL; } + + /** + * Returns a random uri for a calendar-object + * + * @return string + */ + public function getRandomCalendarObjectUri():string { + return UUIDUtil::getUUID() . '.ics'; + } } diff --git a/apps/dav/tests/unit/CalDAV/WebcalCaching/RefreshWebcalServiceTest.php b/apps/dav/tests/unit/CalDAV/WebcalCaching/RefreshWebcalServiceTest.php index 01e541ec20e..b1d341c2e4e 100644 --- a/apps/dav/tests/unit/CalDAV/WebcalCaching/RefreshWebcalServiceTest.php +++ b/apps/dav/tests/unit/CalDAV/WebcalCaching/RefreshWebcalServiceTest.php @@ -69,8 +69,14 @@ class RefreshWebcalServiceTest extends TestCase { * @dataProvider runDataProvider */ public function testRun(string $body, string $contentType, string $result) { - $refreshWebcalService = new RefreshWebcalService($this->caldavBackend, - $this->clientService, $this->config, $this->logger); + $refreshWebcalService = $this->getMockBuilder(RefreshWebcalService::class) + ->setMethods(['getRandomCalendarObjectUri']) + ->setConstructorArgs([$this->caldavBackend, $this->clientService, $this->config, $this->logger]) + ->getMock(); + + $refreshWebcalService + ->method('getRandomCalendarObjectUri') + ->willReturn('uri-1.ics'); $this->caldavBackend->expects($this->once()) ->method('getSubscriptionsForUser') @@ -130,7 +136,7 @@ class RefreshWebcalServiceTest extends TestCase { $this->caldavBackend->expects($this->once()) ->method('createCalendarObject') - ->with(42, '12345.ics', $result, 1); + ->with(42, 'uri-1.ics', $result, 1); $refreshWebcalService->refreshSubscription('principals/users/testuser', 'sub123'); } |