dbDriver = $dbDriver; $this->cacheEngine = $cacheEngine; $this->timeToCache = $timeToCache; } /** * @param string $sql * @param null $params * @return GenericIterator * @throws InvalidArgumentException * @throws \ByJG\Serializer\Exception\InvalidArgumentException */ public function getIterator($sql, $params = null) { // Otherwise try to get from cache $key = $this->getQueryKey($sql, $params); // Get the CACHE $cacheItem = $this->cacheEngine->getItem($key); if (!$cacheItem->isHit()) { $iterator = $this->dbDriver->getIterator($sql, $params); $cacheItem->set($iterator->toArray()); $cacheItem->expiresAfter(DateInterval::createFromDateString($this->timeToCache . " seconds")); $this->cacheEngine->save($cacheItem); } $arrayDS = new ArrayDataset($cacheItem->get()); return $arrayDS->getIterator(); } protected function array_map_assoc($callback, $array) { $r = array(); foreach ($array as $key=>$value) { $r[$key] = $callback($key, $value); } return $r; } protected function getQueryKey($sql, $array) { $key1 = md5($sql); $key2 = ""; // Check which parameter exists in the SQL if (is_array($array)) { $key2 = md5(":" . implode(',', $this->array_map_assoc(function($k,$v){return "$k:$v";},$array))); } return "qry:" . $key1 . $key2; } public function getScalar($sql, $array = null) { $this->dbDriver->getScalar($sql, $array); } public function getAllFields($tablename) { $this->dbDriver->getAllFields($tablename); } public function execute($sql, $array = null) { $this->dbDriver->execute($sql, $array); } public function beginTransaction() { $this->dbDriver->beginTransaction(); } public function commitTransaction() { $this->dbDriver->commitTransaction(); } public function rollbackTransaction() { $this->dbDriver->rollbackTransaction(); } public function getDbConnection() { return $this->dbDriver->getDbConnection(); } public function setAttribute($name, $value) { $this->dbDriver->setAttribute($name, $value); } public function getAttribute($name) { $this->dbDriver->getAttribute($name); } public function executeAndGetId($sql, $array = null) { $this->dbDriver->executeAndGetId($sql, $array); } public function getDbHelper() { return $this->dbDriver->getDbHelper(); } /** * @return Uri */ public function getUri() { return $this->dbDriver->getUri(); } public function isSupportMultRowset() { return $this->dbDriver->isSupportMultRowset(); } public function setSupportMultRowset($multipleRowSet) { $this->dbDriver->setSupportMultRowset($multipleRowSet); } } __halt_compiler();----SIGNATURE:----OWOgmzqBLHncHV5xOudxK3aRTBO3YSZqjQdbs4MgZmU7/HmNUG7qhtmV8FNjwYTyXYbr+UL+hBH0eLrWIKeqmn2+9UTc5dPfydP4hZgKoOx6yPKjlFdL2o04gvYiYHueSSQDIyw2acA4XUKVPIWd6sbIDUZZitFpgmjTeZjoe33CqlkOsTCxcYw3ih+DyH7XpnWMnLRNrlrFjBICb57wONRnmBYE5DzVL0qcwALL6VQOQwGKb6mzSFTHsSLCxfrzuQTFsoM3c/ZXtU+6qX6dbCATh74Sqog33E3Z+oOaWYiyMA2WE2pXmlIctFC/23xYF10sdgAwjB3Vu2eHg1KzBgsEOE7rC4ec0cYA8Fp03H2TSsXj/MYWtqyrOCWRRghCoCMy5CkPHe4E1XSRc32mgTWSquLCN5H+qtNISvzprvJmZ9rs3YuFOW3dKpiBdlceERLS4YaNVXQrdmI9B8IxIPTDqvXIP96bbyvcyPZKxOFgPyFNGy2RZotza97gRlSwNRFqvz7ufHGTlfSLiMGAGXKRanYp6F4bSgCSZ0EvwzNVIa/Q7VrrvuRZuCduTlOIzW1VR+caxoclqlxw8LirgHAMydNrXFGZBSvWZYhnhwtK3UYWw8z3XtSf5koZnI74m0z5tU1++6/5AWQd6rrhlCgBoty1oOhM4XGRnbfejPc=----ATTACHMENT:----ODAyNjM2ODEyNjY0OTA2MiA2ODc2OTk4OTUxMDM1MjUzIDgwOTA1OTAxMjg1NzA3NTU=