From 9070fd2c03c2c922065baa7cd903ed6e97c2d514 Mon Sep 17 00:00:00 2001 From: Joas Schilling Date: Tue, 31 May 2016 16:11:51 +0200 Subject: [PATCH] Add a warning when the transaction isolation level is not READ_COMMITED (#24915) --- settings/admin.php | 13 +++++++++++++ settings/templates/admin.php | 9 +++++++++ 2 files changed, 22 insertions(+) diff --git a/settings/admin.php b/settings/admin.php index e0d3a907f4..42ca7e3525 100644 --- a/settings/admin.php +++ b/settings/admin.php @@ -100,6 +100,19 @@ $externalBackends = (count($backends) > 1) ? true : false; $template->assign('encryptionReady', \OC::$server->getEncryptionManager()->isReady()); $template->assign('externalBackendsEnabled', $externalBackends); +/** @var \Doctrine\DBAL\Connection $connection */ +$connection = \OC::$server->getDatabaseConnection(); +try { + if ($connection->getDatabasePlatform() instanceof \Doctrine\DBAL\Platforms\SqlitePlatform) { + $template->assign('invalidTransactionIsolationLevel', false); + } else { + $template->assign('invalidTransactionIsolationLevel', $connection->getTransactionIsolation() !== \Doctrine\DBAL\Connection::TRANSACTION_READ_COMMITTED); + } +} catch (\Doctrine\DBAL\DBALException $e) { + // ignore + $template->assign('invalidTransactionIsolationLevel', false); +} + $encryptionModules = \OC::$server->getEncryptionManager()->getEncryptionModules(); $defaultEncryptionModuleId = \OC::$server->getEncryptionManager()->getDefaultEncryptionModuleId(); diff --git a/settings/templates/admin.php b/settings/templates/admin.php index 2f4461589d..616ac2ab85 100644 --- a/settings/templates/admin.php +++ b/settings/templates/admin.php @@ -97,6 +97,15 @@ if (!$_['isAnnotationsWorking']) { +
  • + t('Your database does not run with "READ COMMITED" transaction isolation level. This can cause problems when multiple actions are executed in parallel.')); ?> +
  • +