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:
Ralf Becker 2008-05-10 20:10:45 +00:00
parent 798dd4fab0
commit 6ca9cecf01
2 changed files with 10 additions and 11 deletions

View File

@ -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'))

View File

@ -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