diff options
author | Vincent Petry <pvince81@owncloud.com> | 2016-05-31 10:13:23 +0200 |
---|---|---|
committer | Vincent Petry <pvince81@owncloud.com> | 2016-05-31 10:13:23 +0200 |
commit | ba6226259d79900c1830f9d7460910bee0a44fcc (patch) | |
tree | e303317d8d79e2dcfd0bea1ded11576041ea5c6a | |
parent | 235f03da646032629ae1fb31d307a5f5c99ad2a0 (diff) | |
parent | 4da5a741927e512464358f1d717019389e350e66 (diff) | |
download | nextcloud-server-ba6226259d79900c1830f9d7460910bee0a44fcc.tar.gz nextcloud-server-ba6226259d79900c1830f9d7460910bee0a44fcc.zip |
Merge pull request #24889 from owncloud/add-warning-wrong-transaction-isolation-level
Add a warning when the transaction isolation level is not READ_COMMITED
-rw-r--r-- | settings/admin.php | 13 | ||||
-rw-r--r-- | settings/templates/admin.php | 9 |
2 files changed, 22 insertions, 0 deletions
diff --git a/settings/admin.php b/settings/admin.php index 5bddd4bc5e5..6fb65b013e6 100644 --- a/settings/admin.php +++ b/settings/admin.php @@ -103,6 +103,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 6cf4b43c162..0cdefe10083 100644 --- a/settings/templates/admin.php +++ b/settings/templates/admin.php @@ -97,6 +97,15 @@ if (!$_['isAnnotationsWorking']) { <?php } +// Is the Transaction isolation level READ_COMMITED? +if ($_['invalidTransactionIsolationLevel']) { + ?> + <li> + <?php p($l->t('Your database does not run with "READ COMMITED" transaction isolation level. This can cause problems when multiple actions are executed in parallel.')); ?> + </li> +<?php +} + // Windows Warning if ($_['WindowsWarning']) { ?> |