mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-14 09:58:16 +01:00
fixed alarm handling: dont touch / ignore alarms being set for all users or alarms of other users since most clients do not know specific owners for alarms
This commit is contained in:
parent
e1ae046c49
commit
bbe301095e
@ -686,6 +686,12 @@ class calendar_ical extends calendar_boupdate
|
|||||||
}
|
}
|
||||||
foreach($event['alarm'] as $alarmID => $alarmData)
|
foreach($event['alarm'] as $alarmID => $alarmData)
|
||||||
{
|
{
|
||||||
|
// skip alarms being set for all users or alarms owned by other users
|
||||||
|
if($alarmData['all'] == true || $alarmData['owner'] != $GLOBALS['egw_info']['user']['account_id'])
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
if ($version == '1.0')
|
if ($version == '1.0')
|
||||||
{
|
{
|
||||||
if ($servertime)
|
if ($servertime)
|
||||||
@ -1028,20 +1034,25 @@ class calendar_ical extends calendar_boupdate
|
|||||||
}
|
}
|
||||||
|
|
||||||
// update alarms depending on the given event type
|
// update alarms depending on the given event type
|
||||||
switch($event_info['type'])
|
if(isset($this->supportedFields['alarm'])
|
||||||
|
&& is_array($event_info['stored_event']) // alarm update requires a stored event
|
||||||
|
)
|
||||||
{
|
{
|
||||||
case 'SINGLE':
|
switch($event_info['type'])
|
||||||
case 'SERIES-MASTER':
|
{
|
||||||
case 'SERIES-EXCEPTION':
|
case 'SINGLE':
|
||||||
if(is_array($event_info['stored_event'])) // alarm update requires a stored event
|
case 'SERIES-MASTER':
|
||||||
{
|
case 'SERIES-EXCEPTION':
|
||||||
// delete old alarms
|
// delete old alarms
|
||||||
if(count($event['alarm']) > 0
|
if(count($event_info['stored_event']['alarm']) > 0)
|
||||||
|| (isset($this->supportedFields['alarms']) && count($event['alarm']) == 0))
|
|
||||||
{
|
{
|
||||||
foreach ($event_info['stored_event']['alarm'] as $alarm_id => $alarm_data)
|
foreach ($event_info['stored_event']['alarm'] as $alarm_id => $alarm_data)
|
||||||
{
|
{
|
||||||
$this->delete_alarm($alarm_id);
|
// only touch own alarms
|
||||||
|
if($alarm_data['all'] == false && $alarm_data['owner'] == $GLOBALS['egw_info']['user']['account_id'])
|
||||||
|
{
|
||||||
|
$this->delete_alarm($alarm_id);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1059,16 +1070,16 @@ class calendar_ical extends calendar_boupdate
|
|||||||
$alarm['time'] = $event['start'] - $alarm['offset'];
|
$alarm['time'] = $event['start'] - $alarm['offset'];
|
||||||
}
|
}
|
||||||
$alarm['owner'] = $GLOBALS['egw_info']['user']['account_id'];
|
$alarm['owner'] = $GLOBALS['egw_info']['user']['account_id'];
|
||||||
$alarm['all'] = true;
|
$alarm['all'] = false;
|
||||||
$this->save_alarm($event_info['stored_event']['id'], $alarm);
|
$this->save_alarm($event_info['stored_event']['id'], $alarm);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
break;
|
||||||
break;
|
|
||||||
|
|
||||||
case 'SERIES-EXCEPTION-STATUS':
|
case 'SERIES-EXCEPTION-STATUS':
|
||||||
// nothing to do here
|
// nothing to do here
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// choose which id to return to the client
|
// choose which id to return to the client
|
||||||
@ -1091,7 +1102,7 @@ class calendar_ical extends calendar_boupdate
|
|||||||
error_log(__LINE__.__METHOD__.__FILE__.array2string($egw_event)."\n",3,$this->logfile);
|
error_log(__LINE__.__METHOD__.__FILE__.array2string($egw_event)."\n",3,$this->logfile);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return $return_id;
|
return $return_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user