$sqlr)); foreach ($dbquery1->fetchAll(PDO::FETCH_ASSOC) as $row){ $sroomID = $row['serverroomid']; $lastUpdate = $row['lastcalenderupdate']; $calendar = $row['calendar']; //Check if in cache if lastUpdate is null then it is interpreted as 1970 if(strtotime($lastUpdate) > strtotime("-".$this->getCacheTime()."seconds") && $this->getCacheTime()>0) { $result[$row['locationid']]=$calendar; } else { $sroomIDs[$row['locationid']] = $sroomID; } } //Check if we should refresh other rooms recently requested by front ends if ($this->getCacheTime()>0) { $dbquery4 = Database::simpleQuery("SELECT locationid ,serverroomid, lastcalenderupdate FROM location_info WHERE serverid= :id", array('id' => $this->serverID)); foreach($dbquery4->fetchAll(PDO::FETCH_COLUMN) as $row){ if($row['lastcalenderupdate']<$this->getRefreshTime()){ $sroomIDs[$row['locationid']] = $row['serverroomid']; } } } $results = $this->fetchSchedulesInternal($sroomIDs); foreach ($sroomIDs as $location => $serverroom){ $newresult[$location] = $results[$serverroom]; } if($this->getCacheTime()>0){ foreach ($newresult as $key => $value) { $now = strtotime('Now'); $dbquery1 = Database::simpleQuery("UPDATE location_info SET calendar = :ttable, lastcalenderupdate = :now WHERE locationid = :id ", array('id' => $key,'ttable' => $value,'now'=> $now)); } } //get all sheduls that are wanted from roomIDs foreach($roomIDs as $id){ $result[$id] = $newresult[$id]; } return $result[$roomID]; } }