* Calendar: fix holidays are displayed one day off for eg. Austria, Slovakia, Australia (from iCloud)

Caused by no real floating date support in EGroupware and defaulting to UTC, if no timezone specified, because Horde_Icalendar does not report datetimes postfixed with Z as UTC.
Fixed now by not using UTC workaround for date (not datetime) values.
Also implemented default duration of one day for dtstart as date and no dtend/duration given.
This commit is contained in:
Ralf Becker 2016-11-05 12:00:19 +01:00
parent 6f978c6a07
commit cb6121c41f

View File

@ -1791,7 +1791,7 @@ class calendar_ical extends calendar_boupdate
{ {
// calendar_ical overrides search(), which breaks conflict checking // calendar_ical overrides search(), which breaks conflict checking
// so we make sure to use the original from parent // so we make sure to use the original from parent
static $bo; static $bo = null;
if(!$bo) if(!$bo)
{ {
$bo = new calendar_boupdate(); $bo = new calendar_boupdate();
@ -2478,49 +2478,53 @@ class calendar_ical extends calendar_boupdate
$dtstart_ts = is_numeric($attributes['value']) ? $attributes['value'] : $this->date2ts($attributes['value']); $dtstart_ts = is_numeric($attributes['value']) ? $attributes['value'] : $this->date2ts($attributes['value']);
$vcardData['start'] = $dtstart_ts; $vcardData['start'] = $dtstart_ts;
if ($this->tzid) // set event timezone from dtstart, if specified there
if (!empty($attributes['params']['TZID']))
{ {
$event['tzid'] = $this->tzid; // import TZID, if PHP understands it (we only care about TZID of starttime,
} // as we store only a TZID for the whole event)
else try
{
if (!empty($attributes['params']['TZID']))
{ {
// import TZID, if PHP understands it (we only care about TZID of starttime, $tz = calendar_timezones::DateTimeZone($attributes['params']['TZID']);
// as we store only a TZID for the whole event) // sometimes we do not get an Api\DateTime object but no exception is thrown
try // may be php 5.2.x related. occurs when a NokiaE72 tries to open Outlook invitations
if ($tz instanceof DateTimeZone)
{ {
$tz = calendar_timezones::DateTimeZone($attributes['params']['TZID']); $event['tzid'] = $tz->getName();
// sometimes we do not get an Api\DateTime object but no exception is thrown
// may be php 5.2.x related. occurs when a NokiaE72 tries to open Outlook invitations
if ($tz instanceof DateTimeZone)
{
$event['tzid'] = $tz->getName();
}
else
{
error_log(__METHOD__ . '() unknown TZID='
. $attributes['params']['TZID'] . ', defaulting to timezone "'
. date_default_timezone_get() . '".'.array2string($tz));
$event['tzid'] = date_default_timezone_get(); // default to current timezone
}
} }
catch(Exception $e) else
{ {
error_log(__METHOD__ . '() unknown TZID=' error_log(__METHOD__ . '() unknown TZID='
. $attributes['params']['TZID'] . ', defaulting to timezone "' . $attributes['params']['TZID'] . ', defaulting to timezone "'
. date_default_timezone_get() . '".'.$e->getMessage()); . date_default_timezone_get() . '".'.array2string($tz));
$event['tzid'] = date_default_timezone_get(); // default to current timezone $event['tzid'] = date_default_timezone_get(); // default to current timezone
} }
} }
else catch(Exception $e)
{ {
// Horde seems not to distinguish between an explicit UTC time postfixed with Z and one without error_log(__METHOD__ . '() unknown TZID='
// assuming for now UTC to pass CalDAVTester tests . $attributes['params']['TZID'] . ', defaulting to timezone "'
// ToDo: fix Horde_Icalendar to return UTC for timestamp postfixed with Z . date_default_timezone_get() . '".'.$e->getMessage());
$event['tzid'] = 'UTC'; $event['tzid'] = date_default_timezone_get(); // default to current timezone
} }
} }
// if no timezone given and one is specified in class (never the case for CalDAV)
elseif ($this->tzid)
{
$event['tzid'] = $this->tzid;
}
// Horde seems not to distinguish between an explicit UTC time postfixed with Z and one without
// assuming for now UTC to pass CalDAVTester tests
// ToDo: fix Horde_Icalendar to return UTC for timestamp postfixed with Z
elseif (!$isDate)
{
$event['tzid'] = 'UTC';
}
// default to use timezone to better kope with floating time
else
{
$event['tzid'] = Api\DateTime::$user_timezone->getName();
}
break; break;
case 'DTEND': case 'DTEND':
@ -2553,6 +2557,13 @@ class calendar_ical extends calendar_boupdate
} }
return false; // not a valid entry return false; // not a valid entry
} }
// if neither duration nor dtend specified, default for dtstart as date is 1 day
if (!isset($vcardData['end']) && !$isDate)
{
$end = new Api\DateTime($vcardData['start']);
$end->add('1 day');
$vcardData['end'] = $end->format('ts');
}
// lets see what we can get from the vcard // lets see what we can get from the vcard
foreach ($component->getAllAttributes() as $attributes) foreach ($component->getAllAttributes() as $attributes)
{ {