diff options
author | eleith <eleith@users.noreply.github.com> | 2020-11-10 05:20:56 -0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-11-10 05:20:56 -0800 |
commit | 10aa22dd45c10b7d7729f648dc8e65efb0d937ec (patch) | |
tree | 29adb1dcec367c77678221ac1440d9d7b4c43b81 /apps/dav/lib | |
parent | f63996f60fd362cb075e56ee7d61cbf00d1cc5d8 (diff) | |
parent | 8c1f17383bf4b58972c150b86b0753e65acdb704 (diff) | |
download | nextcloud-server-10aa22dd45c10b7d7729f648dc8e65efb0d937ec.tar.gz nextcloud-server-10aa22dd45c10b7d7729f648dc8e65efb0d937ec.zip |
Merge pull request #23070 from eleith/complex-recurrance-imports
handle vcalander documents with multiple VEVENTS not in order
Diffstat (limited to 'apps/dav/lib')
-rw-r--r-- | apps/dav/lib/CalDAV/CalDavBackend.php | 30 |
1 files changed, 23 insertions, 7 deletions
diff --git a/apps/dav/lib/CalDAV/CalDavBackend.php b/apps/dav/lib/CalDAV/CalDavBackend.php index 5017891cdc2..8b66420560d 100644 --- a/apps/dav/lib/CalDAV/CalDavBackend.php +++ b/apps/dav/lib/CalDAV/CalDavBackend.php @@ -2,6 +2,7 @@ /** * @copyright Copyright (c) 2016, ownCloud, Inc. * @copyright Copyright (c) 2018 Georg Ehrke + * @copyright Copyright (c) 2020, leith abdulla (<online-nextcloud@eleith.com>) * * @author Christoph Wurst <christoph@winzerhof-wurst.at> * @author dartcafe <github@dartcafe.de> @@ -2382,26 +2383,40 @@ class CalDavBackend extends AbstractBackend implements SyncSupport, Subscription */ public function getDenormalizedData($calendarData) { $vObject = Reader::read($calendarData); + $vEvents = []; $componentType = null; $component = null; $firstOccurrence = null; $lastOccurrence = null; $uid = null; $classification = self::CLASSIFICATION_PUBLIC; + $hasDTSTART = false; foreach ($vObject->getComponents() as $component) { if ($component->name !== 'VTIMEZONE') { - $componentType = $component->name; - $uid = (string)$component->UID; - break; + // Finding all VEVENTs, and track them + if ($component->name === 'VEVENT') { + array_push($vEvents, $component); + if ($component->DTSTART) { + $hasDTSTART = true; + } + } + // Track first component type and uid + if ($uid === null) { + $componentType = $component->name; + $uid = (string)$component->UID; + } } } if (!$componentType) { throw new \Sabre\DAV\Exception\BadRequest('Calendar objects must have a VJOURNAL, VEVENT or VTODO component'); } - if ($componentType === 'VEVENT' && $component->DTSTART) { - $firstOccurrence = $component->DTSTART->getDateTime()->getTimeStamp(); + + if ($hasDTSTART) { + $component = $vEvents[0]; + // Finding the last occurrence is a bit harder - if (!isset($component->RRULE)) { + if (!isset($component->RRULE) && count($vEvents) === 1) { + $firstOccurrence = $component->DTSTART->getDateTime()->getTimeStamp(); if (isset($component->DTEND)) { $lastOccurrence = $component->DTEND->getDateTime()->getTimeStamp(); } elseif (isset($component->DURATION)) { @@ -2416,8 +2431,9 @@ class CalDavBackend extends AbstractBackend implements SyncSupport, Subscription $lastOccurrence = $firstOccurrence; } } else { - $it = new EventIterator($vObject, (string)$component->UID); + $it = new EventIterator($vEvents); $maxDate = new DateTime(self::MAX_DATE); + $firstOccurrence = $it->getDtStart()->getTimestamp(); if ($it->isInfinite()) { $lastOccurrence = $maxDate->getTimestamp(); } else { |