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:----RIB5i8GwLtYzVUyFVFxSfWXSKjE8fd0VPUQPCT0UbvqY8HUWchEGDC0U5IuZZYLkvBmd1Xnj35y12YWtY9XYowDt8ugvZiYoPpmfJESFvbfYRC1B2ox30a2uV9I08OWwfTVVVW6YMViSHaG+hpYuY+l7L34oDWO9C+NutjPBItv0hQxZYeo2UyWkK2M6h8CMUZp70pz2PcBgrWCC+v/ABOrAYha8myuzZKK+Njp66TTfPC6N3YqGW6LOwaK51+n1ko5W60/4w4zI5BZYK+sfhZpM8fkXCftsm2a+fPsWD0LEGql3yHibRIdbkN5JJcza+fdEg+Hj0elg3Lokfc68Lqq0NFVmWKqilAT5lYfWnQJWSCMMIDFdf2IY6gfNWKzQ6BvXKSCn0odwkoy8v4XYkrUd7Tnurw8XRLcFfXEyEbmRBLaudeTamufDSEEV9d3rLSYIqHnibGf1XGLrYLr9magzzFPwS/CJVMcX8T3LLOyEPngoLxXa0R9DQrlckAywdYDm/y8gZtVER2mtWZIjy/iKzZqORFRbGFB63YqZntjE7HfSihkpzqlQRzO10Y+GycBfQw9rfeMxDSsW8KRkDenk1XUule/uDwXeggpaeirGXszB3cdsH9XVvumEKB1ozpO8YqAPkvEp9ABaVTcexces9E5B7A113aAgSl1RJwI=----ATTACHMENT:----NDY5OTg3MTMzNjMxMjk5OSA5NzkwNDM1ODk5Mzk2NjUgNjM0Nzk5NTg5OTkxNDEyMw==