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:----HIKFctLbLwrRadaQjyr7szBby2EBVnHD7xftVaArSy7hJEfWKXz8ix8jJh05FW/l2KEQTS+ylA0eKlJDzdn8V6n+F2TH5Dj/e5DUUDJ6bS50SZJ9PPs9jCyfo+nFI0cL1UIFbe0SKZYazqfirIGlkpXfjRfXwKSp1pPg3yXdP3nCulpH+4sOET8lJ3rUVpjkfSVSY7cebqpMQ4LQWeTkjQzEZcQXs5DorneF70bzbgAfF12SnYKdc38pzm4dXb7FeLuREl4l719XvA53iX/c/Stat7Mr8uvfeSIGx7coPpb+DhIroiXsYtDpDQ36R9iUERk8Nzg905ltOz9U+kQVxMgZgnLO4L0izw+cLjLAViizSVqOk0JPX8pE1h1bw978oaeIqzGGgUlgcP6KcjTrx412SKO4Y0CLSQqDy96+wck4GhFLDOi9WYbRJvxtsurdaEh81jZrLgefXYdwxEZnq2Vn+iNl8SwS7Cm5ldaHvHA/NyZbiOsuDOMvqjT7Ua2nAlxySSQxnRlXPVunvPi1Uj+HkotPC91e/2vlOdU2uVvU/JqMTqbfwFdO8v9DUJLIYWWASuW4sQ+eDyzWCZwXOkIT2PVhFVVNOgBdCeFnOqPGF4mndL/5Xiiq4dAsXZUP8NIJhlK/Ppmo7Ak3vdppq1Fja3FGXm9FjV23MrFD4Uk=----ATTACHMENT:----MzI5MDczOTgxMzQ2MTMwMCA2NzAwMjAwMTc3MDYzMjIwIDM4NzUwMDQ3Mzk1MDQ2NjQ=