mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-05 13:39:23 +01:00
making the event cache static, to use it in all instances of the bocal class, otherwise different instances use old etags
This commit is contained in:
parent
798dd4fab0
commit
6ca9cecf01
@ -128,11 +128,10 @@ class bocal
|
|||||||
*/
|
*/
|
||||||
var $resources;
|
var $resources;
|
||||||
/**
|
/**
|
||||||
* @internal
|
|
||||||
* @var array $cached_event here we do some caching to read single events only once
|
* @var array $cached_event here we do some caching to read single events only once
|
||||||
*/
|
*/
|
||||||
var $cached_event = array();
|
protected static $cached_event = array();
|
||||||
var $cached_event_date_format = false;
|
protected static $cached_event_date_format = false;
|
||||||
/**
|
/**
|
||||||
* @var array $cached_holidays holidays plus birthdays (gets cached in the session for performance reasons)
|
* @var array $cached_holidays holidays plus birthdays (gets cached in the session for performance reasons)
|
||||||
*/
|
*/
|
||||||
@ -648,9 +647,9 @@ class bocal
|
|||||||
|
|
||||||
if ($ignore_acl || is_array($ids) || ($return = $this->check_perms(EGW_ACL_READ,$ids,0,$date_format,$date)))
|
if ($ignore_acl || is_array($ids) || ($return = $this->check_perms(EGW_ACL_READ,$ids,0,$date_format,$date)))
|
||||||
{
|
{
|
||||||
if (is_array($ids) || !isset($this->cached_event['id']) || $this->cached_event['id'] != $ids ||
|
if (is_array($ids) || !isset(self::$cached_event['id']) || self::$cached_event['id'] != $ids ||
|
||||||
$this->cached_event_date_format != $date_format ||
|
self::$cached_event_date_format != $date_format ||
|
||||||
$this->cached_event['recur_type'] != MCAL_RECUR_NONE && !is_null($date) && (!$date || $this->cached_event['start'] < $date))
|
self::$cached_event['recur_type'] != MCAL_RECUR_NONE && !is_null($date) && (!$date || self::$cached_event['start'] < $date))
|
||||||
{
|
{
|
||||||
$events = $this->so->read($ids,$date ? $this->date2ts($date,true) : 0);
|
$events = $this->so->read($ids,$date ? $this->date2ts($date,true) : 0);
|
||||||
|
|
||||||
@ -664,15 +663,15 @@ class bocal
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$this->cached_event = array_shift($events);
|
self::$cached_event = array_shift($events);
|
||||||
$this->cached_event_date_format = $date_format;
|
self::$cached_event_date_format = $date_format;
|
||||||
$return =& $this->cached_event;
|
$return =& self::$cached_event;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$return =& $this->cached_event;
|
$return =& self::$cached_event;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if ($this->debug && ($this->debug > 1 || $this->debug == 'read'))
|
if ($this->debug && ($this->debug > 1 || $this->debug == 'read'))
|
||||||
|
@ -695,7 +695,7 @@ class bocalupdate extends bocal
|
|||||||
}
|
}
|
||||||
|
|
||||||
// invalidate the read-cache if it contains the event we store now
|
// invalidate the read-cache if it contains the event we store now
|
||||||
if ($event['id'] && $event['id'] == $this->cached_event['id']) $this->cached_event = array();
|
if ($event['id'] && $event['id'] == self::$cached_event['id']) self::$cached_event = array();
|
||||||
|
|
||||||
$save_event = $event;
|
$save_event = $event;
|
||||||
// we run all dates through date2ts, to adjust to server-time and the possible date-formats
|
// we run all dates through date2ts, to adjust to server-time and the possible date-formats
|
||||||
|
Loading…
Reference in New Issue
Block a user