wrapped = $wrapped; $this->archivingLock = $archivingLock; $this->logger = $logger; $this->maxExecutionTime = (float) Config::getInstance()->General['archiving_query_max_execution_time']; } public function __call($name, $arguments) { return call_user_func_array([$this->wrapped, $name], $arguments); } public function exec($sql) { $this->reexpireLock(); $sql = DbHelper::addMaxExecutionTimeHintToQuery($sql, $this->maxExecutionTime); $this->logSql($sql); return call_user_func_array([$this->wrapped, __FUNCTION__], func_get_args()); } public function query($sql) { $this->reexpireLock(); $sql = DbHelper::addMaxExecutionTimeHintToQuery($sql, $this->maxExecutionTime); $this->logSql($sql); return call_user_func_array([$this->wrapped, __FUNCTION__], func_get_args()); } public function fetchAll($sql) { $this->reexpireLock(); $sql = DbHelper::addMaxExecutionTimeHintToQuery($sql, $this->maxExecutionTime); $this->logSql($sql); return call_user_func_array([$this->wrapped, __FUNCTION__], func_get_args()); } public function fetchRow($sql) { $this->reexpireLock(); $sql = DbHelper::addMaxExecutionTimeHintToQuery($sql, $this->maxExecutionTime); $this->logSql($sql); return call_user_func_array([$this->wrapped, __FUNCTION__], func_get_args()); } public function fetchOne($sql) { $this->reexpireLock(); $sql = DbHelper::addMaxExecutionTimeHintToQuery($sql, $this->maxExecutionTime); $this->logSql($sql); return call_user_func_array([$this->wrapped, __FUNCTION__], func_get_args()); } public function fetchAssoc($sql) { $this->reexpireLock(); $sql = DbHelper::addMaxExecutionTimeHintToQuery($sql, $this->maxExecutionTime); $this->logSql($sql); return call_user_func_array([$this->wrapped, __FUNCTION__], func_get_args()); } private function logSql($sql) { // Log on DEBUG level all SQL archiving queries if ($this->logger) { $this->logger->debug($sql); } } private function reexpireLock() { if ($this->archivingLock) { $this->archivingLock->reexpireLock(); } } }