summaryrefslogtreecommitdiffstats
path: root/apps/dav/lib
diff options
context:
space:
mode:
authoreleith <eleith@users.noreply.github.com>2020-11-10 05:20:56 -0800
committerGitHub <noreply@github.com>2020-11-10 05:20:56 -0800
commit10aa22dd45c10b7d7729f648dc8e65efb0d937ec (patch)
tree29adb1dcec367c77678221ac1440d9d7b4c43b81 /apps/dav/lib
parentf63996f60fd362cb075e56ee7d61cbf00d1cc5d8 (diff)
parent8c1f17383bf4b58972c150b86b0753e65acdb704 (diff)
downloadnextcloud-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.php30
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 {