Merge pull request #23787 from nextcloud/backport/23783/stable20

[stable20] Fetch the logger and system config once for all query builder instances
This commit is contained in:
Morris Jobke 2020-10-30 11:03:33 +01:00 committed by GitHub
commit f2a0ba4b55
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 15 additions and 8 deletions

View File

@ -42,21 +42,25 @@ use Doctrine\DBAL\Exception\ConstraintViolationException;
use Doctrine\DBAL\Platforms\MySqlPlatform;
use Doctrine\DBAL\Schema\Schema;
use OC\DB\QueryBuilder\QueryBuilder;
use OC\SystemConfig;
use OCP\DB\QueryBuilder\IQueryBuilder;
use OCP\IDBConnection;
use OCP\ILogger;
use OCP\PreConditionNotMetException;
class Connection extends ReconnectWrapper implements IDBConnection {
/**
* @var string $tablePrefix
*/
/** @var string */
protected $tablePrefix;
/**
* @var \OC\DB\Adapter $adapter
*/
/** @var \OC\DB\Adapter $adapter */
protected $adapter;
/** @var SystemConfig */
private $systemConfig;
/** @var ILogger */
private $logger;
protected $lockedTable = null;
public function connect() {
@ -76,8 +80,8 @@ class Connection extends ReconnectWrapper implements IDBConnection {
public function getQueryBuilder() {
return new QueryBuilder(
$this,
\OC::$server->getSystemConfig(),
\OC::$server->getLogger()
$this->systemConfig,
$this->logger
);
}
@ -149,6 +153,9 @@ class Connection extends ReconnectWrapper implements IDBConnection {
parent::__construct($params, $driver, $config, $eventManager);
$this->adapter = new $params['adapter']($this);
$this->tablePrefix = $params['tablePrefix'];
$this->systemConfig = \OC::$server->getSystemConfig();
$this->logger = \OC::$server->getLogger();
}
/**