diff options
Diffstat (limited to 'core')
-rw-r--r-- | core/Application.php | 7 | ||||
-rw-r--r-- | core/Command/Db/AddMissingColumns.php | 5 | ||||
-rw-r--r-- | core/Command/Db/AddMissingIndices.php | 5 | ||||
-rw-r--r-- | core/Command/Db/AddMissingPrimaryKeys.php | 5 | ||||
-rw-r--r-- | core/Command/Db/ConvertFilecacheBigInt.php | 8 | ||||
-rw-r--r-- | core/Command/Db/ConvertMysqlToMB4.php | 4 | ||||
-rw-r--r-- | core/Command/Db/ConvertType.php | 31 | ||||
-rw-r--r-- | core/Command/Db/Migrations/ExecuteCommand.php | 13 | ||||
-rw-r--r-- | core/Command/Db/Migrations/GenerateCommand.php | 8 | ||||
-rw-r--r-- | core/Command/Db/Migrations/GenerateFromSchemaFileCommand.php | 4 | ||||
-rw-r--r-- | core/Command/Db/Migrations/MigrateCommand.php | 8 | ||||
-rw-r--r-- | core/Command/Db/Migrations/StatusCommand.php | 9 | ||||
-rw-r--r-- | core/Migrations/Version16000Date20190427105638.php | 1 | ||||
-rw-r--r-- | core/Migrations/Version20000Date20201109081918.php | 10 | ||||
-rw-r--r-- | core/js/setupchecks.js | 1 | ||||
-rw-r--r-- | core/register_command.php | 18 |
16 files changed, 71 insertions, 66 deletions
diff --git a/core/Application.php b/core/Application.php index 987358b5b97..c3cb6f02ed5 100644 --- a/core/Application.php +++ b/core/Application.php @@ -41,6 +41,7 @@ use OC\Authentication\Listeners\UserDeletedStoreCleanupListener; use OC\Authentication\Listeners\UserDeletedTokenCleanupListener; use OC\Authentication\Notifications\Notifier as AuthenticationNotifier; use OC\Core\Notification\CoreNotifier; +use OC\DB\Connection; use OC\DB\MissingColumnInformation; use OC\DB\MissingIndexInformation; use OC\DB\MissingPrimaryKeyInformation; @@ -82,7 +83,7 @@ class Application extends App { /** @var MissingIndexInformation $subject */ $subject = $event->getSubject(); - $schema = new SchemaWrapper($container->query(IDBConnection::class)); + $schema = new SchemaWrapper($container->query(Connection::class)); if ($schema->hasTable('share')) { $table = $schema->getTable('share'); @@ -192,7 +193,7 @@ class Application extends App { /** @var MissingPrimaryKeyInformation $subject */ $subject = $event->getSubject(); - $schema = new SchemaWrapper($container->query(IDBConnection::class)); + $schema = new SchemaWrapper($container->query(Connection::class)); if ($schema->hasTable('federated_reshares')) { $table = $schema->getTable('federated_reshares'); @@ -249,7 +250,7 @@ class Application extends App { /** @var MissingColumnInformation $subject */ $subject = $event->getSubject(); - $schema = new SchemaWrapper($container->query(IDBConnection::class)); + $schema = new SchemaWrapper($container->query(Connection::class)); if ($schema->hasTable('comments')) { $table = $schema->getTable('comments'); diff --git a/core/Command/Db/AddMissingColumns.php b/core/Command/Db/AddMissingColumns.php index 3ace75b4eef..4b7fa039956 100644 --- a/core/Command/Db/AddMissingColumns.php +++ b/core/Command/Db/AddMissingColumns.php @@ -26,6 +26,7 @@ declare(strict_types=1); namespace OC\Core\Command\Db; +use OC\DB\Connection; use OC\DB\SchemaWrapper; use OCP\IDBConnection; use Symfony\Component\Console\Command\Command; @@ -44,13 +45,13 @@ use Symfony\Component\EventDispatcher\GenericEvent; */ class AddMissingColumns extends Command { - /** @var IDBConnection */ + /** @var Connection */ private $connection; /** @var EventDispatcherInterface */ private $dispatcher; - public function __construct(IDBConnection $connection, EventDispatcherInterface $dispatcher) { + public function __construct(Connection $connection, EventDispatcherInterface $dispatcher) { parent::__construct(); $this->connection = $connection; diff --git a/core/Command/Db/AddMissingIndices.php b/core/Command/Db/AddMissingIndices.php index 5cbd6ee405d..1acff55fa40 100644 --- a/core/Command/Db/AddMissingIndices.php +++ b/core/Command/Db/AddMissingIndices.php @@ -33,6 +33,7 @@ declare(strict_types=1); namespace OC\Core\Command\Db; +use OC\DB\Connection; use OC\DB\SchemaWrapper; use OCP\IDBConnection; use Symfony\Component\Console\Command\Command; @@ -51,13 +52,13 @@ use Symfony\Component\EventDispatcher\GenericEvent; */ class AddMissingIndices extends Command { - /** @var IDBConnection */ + /** @var Connection */ private $connection; /** @var EventDispatcherInterface */ private $dispatcher; - public function __construct(IDBConnection $connection, EventDispatcherInterface $dispatcher) { + public function __construct(Connection $connection, EventDispatcherInterface $dispatcher) { parent::__construct(); $this->connection = $connection; diff --git a/core/Command/Db/AddMissingPrimaryKeys.php b/core/Command/Db/AddMissingPrimaryKeys.php index ef3d6a05f2e..7113ecb210f 100644 --- a/core/Command/Db/AddMissingPrimaryKeys.php +++ b/core/Command/Db/AddMissingPrimaryKeys.php @@ -26,6 +26,7 @@ declare(strict_types=1); namespace OC\Core\Command\Db; +use OC\DB\Connection; use OC\DB\SchemaWrapper; use OCP\IDBConnection; use Symfony\Component\Console\Command\Command; @@ -44,13 +45,13 @@ use Symfony\Component\EventDispatcher\GenericEvent; */ class AddMissingPrimaryKeys extends Command { - /** @var IDBConnection */ + /** @var Connection */ private $connection; /** @var EventDispatcherInterface */ private $dispatcher; - public function __construct(IDBConnection $connection, EventDispatcherInterface $dispatcher) { + public function __construct(Connection $connection, EventDispatcherInterface $dispatcher) { parent::__construct(); $this->connection = $connection; diff --git a/core/Command/Db/ConvertFilecacheBigInt.php b/core/Command/Db/ConvertFilecacheBigInt.php index 77f5034315c..6001de6fb9e 100644 --- a/core/Command/Db/ConvertFilecacheBigInt.php +++ b/core/Command/Db/ConvertFilecacheBigInt.php @@ -34,8 +34,8 @@ namespace OC\Core\Command\Db; use Doctrine\DBAL\Platforms\SqlitePlatform; use Doctrine\DBAL\Types\Type; use Doctrine\DBAL\Types\Types; +use OC\DB\Connection; use OC\DB\SchemaWrapper; -use OCP\IDBConnection; use Symfony\Component\Console\Command\Command; use Symfony\Component\Console\Input\InputInterface; use Symfony\Component\Console\Output\OutputInterface; @@ -43,13 +43,13 @@ use Symfony\Component\Console\Question\ConfirmationQuestion; class ConvertFilecacheBigInt extends Command { - /** @var IDBConnection */ + /** @var Connection */ private $connection; /** - * @param IDBConnection $connection + * @param Connection $connection */ - public function __construct(IDBConnection $connection) { + public function __construct(Connection $connection) { $this->connection = $connection; parent::__construct(); } diff --git a/core/Command/Db/ConvertMysqlToMB4.php b/core/Command/Db/ConvertMysqlToMB4.php index 4305f446286..55633ea9941 100644 --- a/core/Command/Db/ConvertMysqlToMB4.php +++ b/core/Command/Db/ConvertMysqlToMB4.php @@ -24,7 +24,7 @@ namespace OC\Core\Command\Db; -use Doctrine\DBAL\Platforms\MySqlPlatform; +use Doctrine\DBAL\Platforms\MySQLPlatform; use OC\DB\MySqlTools; use OC\Migration\ConsoleOutput; use OC\Repair\Collation; @@ -70,7 +70,7 @@ class ConvertMysqlToMB4 extends Command { } protected function execute(InputInterface $input, OutputInterface $output): int { - if (!$this->connection->getDatabasePlatform() instanceof MySqlPlatform) { + if (!$this->connection->getDatabasePlatform() instanceof MySQLPlatform) { $output->writeln("This command is only valid for MySQL/MariaDB databases."); return 1; } diff --git a/core/Command/Db/ConvertType.php b/core/Command/Db/ConvertType.php index d89d57ff601..32b7492d967 100644 --- a/core/Command/Db/ConvertType.php +++ b/core/Command/Db/ConvertType.php @@ -33,9 +33,10 @@ namespace OC\Core\Command\Db; -use Doctrine\DBAL\DBALException; +use Doctrine\DBAL\Exception; +use Doctrine\DBAL\Schema\AbstractAsset; use Doctrine\DBAL\Schema\Table; -use Doctrine\DBAL\Types\Type; +use Doctrine\DBAL\Types\Types; use OC\DB\Connection; use OC\DB\ConnectionFactory; use OC\DB\MigrationService; @@ -52,6 +53,8 @@ use Symfony\Component\Console\Input\InputOption; use Symfony\Component\Console\Output\OutputInterface; use Symfony\Component\Console\Question\ConfirmationQuestion; use Symfony\Component\Console\Question\Question; +use function preg_match; +use function preg_quote; class ConvertType extends Command implements CompletionAwareInterface { /** @@ -192,7 +195,8 @@ class ConvertType extends Command implements CompletionAwareInterface { $this->validateInput($input, $output); $this->readPassword($input, $output); - $fromDB = \OC::$server->getDatabaseConnection(); + /** @var Connection $fromDB */ + $fromDB = \OC::$server->get(Connection::class); $toDB = $this->getToDBConnection($input, $output); if ($input->getOption('clear-schema')) { @@ -283,9 +287,14 @@ class ConvertType extends Command implements CompletionAwareInterface { } protected function getTables(Connection $db) { - $filterExpression = '/^' . preg_quote($this->config->getSystemValue('dbtableprefix', 'oc_')) . '/'; - $db->getConfiguration()-> - setFilterSchemaAssetsExpression($filterExpression); + $db->getConfiguration()->setSchemaAssetsFilter(function ($asset) { + /** @var string|AbstractAsset $asset */ + $filterExpression = '/^' . preg_quote($this->config->getSystemValue('dbtableprefix', 'oc_')) . '/'; + if ($asset instanceof AbstractAsset) { + return preg_match($filterExpression, $asset->getName()) !== false; + } + return preg_match($filterExpression, $asset) !== false; + }); return $db->getSchemaManager()->listTableNames(); } @@ -309,7 +318,7 @@ class ConvertType extends Command implements CompletionAwareInterface { $query->select($query->func()->count('*', 'num_entries')) ->from($table->getName()); $result = $query->execute(); - $count = $result->fetchColumn(); + $count = $result->fetchOne(); $result->closeCursor(); $numChunks = ceil($count / $chunkSize); @@ -330,7 +339,7 @@ class ConvertType extends Command implements CompletionAwareInterface { try { $orderColumns = $table->getPrimaryKeyColumns(); - } catch (DBALException $e) { + } catch (Exception $e) { $orderColumns = []; foreach ($table->getColumns() as $column) { $orderColumns[] = $column->getName(); @@ -384,11 +393,11 @@ class ConvertType extends Command implements CompletionAwareInterface { $type = $table->getColumn($columnName)->getType()->getName(); switch ($type) { - case Type::BLOB: - case Type::TEXT: + case Types::BLOB: + case Types::TEXT: $this->columnTypes[$tableName][$columnName] = IQueryBuilder::PARAM_LOB; break; - case Type::BOOLEAN: + case Types::BOOLEAN: $this->columnTypes[$tableName][$columnName] = IQueryBuilder::PARAM_BOOL; break; default: diff --git a/core/Command/Db/Migrations/ExecuteCommand.php b/core/Command/Db/Migrations/ExecuteCommand.php index 95f1acd14fe..cc3f7d67fc0 100644 --- a/core/Command/Db/Migrations/ExecuteCommand.php +++ b/core/Command/Db/Migrations/ExecuteCommand.php @@ -23,11 +23,10 @@ namespace OC\Core\Command\Db\Migrations; +use OC\DB\Connection; use OC\DB\MigrationService; use OC\Migration\ConsoleOutput; -use OCP\App\IAppManager; use OCP\IConfig; -use OCP\IDBConnection; use Stecman\Component\Symfony\Console\BashCompletion\Completion\CompletionAwareInterface; use Stecman\Component\Symfony\Console\BashCompletion\CompletionContext; use Symfony\Component\Console\Command\Command; @@ -37,23 +36,19 @@ use Symfony\Component\Console\Output\OutputInterface; class ExecuteCommand extends Command implements CompletionAwareInterface { - /** @var IDBConnection */ + /** @var Connection */ private $connection; /** @var IConfig */ private $config; - /** @var IAppManager */ - protected $appManager; - /** * ExecuteCommand constructor. * - * @param IDBConnection $connection + * @param Connection $connection * @param IConfig $config - * @param IAppManager $appManager */ - public function __construct(IDBConnection $connection, IAppManager $appManager, IConfig $config) { + public function __construct(Connection $connection, IConfig $config) { $this->connection = $connection; $this->config = $config; diff --git a/core/Command/Db/Migrations/GenerateCommand.php b/core/Command/Db/Migrations/GenerateCommand.php index fcafa9431c3..48fc59e77fb 100644 --- a/core/Command/Db/Migrations/GenerateCommand.php +++ b/core/Command/Db/Migrations/GenerateCommand.php @@ -25,10 +25,10 @@ namespace OC\Core\Command\Db\Migrations; +use OC\DB\Connection; use OC\DB\MigrationService; use OC\Migration\ConsoleOutput; use OCP\App\IAppManager; -use OCP\IDBConnection; use Stecman\Component\Symfony\Console\BashCompletion\Completion\CompletionAwareInterface; use Stecman\Component\Symfony\Console\BashCompletion\CompletionContext; use Symfony\Component\Console\Command\Command; @@ -83,17 +83,17 @@ class {{classname}} extends SimpleMigrationStep { } '; - /** @var IDBConnection */ + /** @var Connection */ protected $connection; /** @var IAppManager */ protected $appManager; /** - * @param IDBConnection $connection + * @param Connection $connection * @param IAppManager $appManager */ - public function __construct(IDBConnection $connection, IAppManager $appManager) { + public function __construct(Connection $connection, IAppManager $appManager) { $this->connection = $connection; $this->appManager = $appManager; diff --git a/core/Command/Db/Migrations/GenerateFromSchemaFileCommand.php b/core/Command/Db/Migrations/GenerateFromSchemaFileCommand.php index 71349c0fa51..9101957a97c 100644 --- a/core/Command/Db/Migrations/GenerateFromSchemaFileCommand.php +++ b/core/Command/Db/Migrations/GenerateFromSchemaFileCommand.php @@ -26,12 +26,12 @@ namespace OC\Core\Command\Db\Migrations; use Doctrine\DBAL\Schema\Schema; +use OC\DB\Connection; use OC\DB\MDB2SchemaReader; use OC\DB\MigrationService; use OC\Migration\ConsoleOutput; use OCP\App\IAppManager; use OCP\IConfig; -use OCP\IDBConnection; use Symfony\Component\Console\Input\InputInterface; use Symfony\Component\Console\Output\OutputInterface; @@ -40,7 +40,7 @@ class GenerateFromSchemaFileCommand extends GenerateCommand { /** @var IConfig */ protected $config; - public function __construct(IConfig $config, IAppManager $appManager, IDBConnection $connection) { + public function __construct(IConfig $config, IAppManager $appManager, Connection $connection) { parent::__construct($connection, $appManager); $this->config = $config; } diff --git a/core/Command/Db/Migrations/MigrateCommand.php b/core/Command/Db/Migrations/MigrateCommand.php index 229288c794a..218c8aaf518 100644 --- a/core/Command/Db/Migrations/MigrateCommand.php +++ b/core/Command/Db/Migrations/MigrateCommand.php @@ -22,9 +22,9 @@ namespace OC\Core\Command\Db\Migrations; +use OC\DB\Connection; use OC\DB\MigrationService; use OC\Migration\ConsoleOutput; -use OCP\IDBConnection; use Stecman\Component\Symfony\Console\BashCompletion\Completion\CompletionAwareInterface; use Stecman\Component\Symfony\Console\BashCompletion\CompletionContext; use Symfony\Component\Console\Command\Command; @@ -34,13 +34,13 @@ use Symfony\Component\Console\Output\OutputInterface; class MigrateCommand extends Command implements CompletionAwareInterface { - /** @var IDBConnection */ + /** @var Connection */ private $connection; /** - * @param IDBConnection $connection + * @param Connection $connection */ - public function __construct(IDBConnection $connection) { + public function __construct(Connection $connection) { $this->connection = $connection; parent::__construct(); } diff --git a/core/Command/Db/Migrations/StatusCommand.php b/core/Command/Db/Migrations/StatusCommand.php index 83763ee79b3..6c78bcd180c 100644 --- a/core/Command/Db/Migrations/StatusCommand.php +++ b/core/Command/Db/Migrations/StatusCommand.php @@ -24,9 +24,9 @@ namespace OC\Core\Command\Db\Migrations; +use OC\DB\Connection; use OC\DB\MigrationService; use OC\Migration\ConsoleOutput; -use OCP\IDBConnection; use Stecman\Component\Symfony\Console\BashCompletion\Completion\CompletionAwareInterface; use Stecman\Component\Symfony\Console\BashCompletion\CompletionContext; use Symfony\Component\Console\Command\Command; @@ -36,13 +36,10 @@ use Symfony\Component\Console\Output\OutputInterface; class StatusCommand extends Command implements CompletionAwareInterface { - /** @var IDBConnection */ + /** @var Connection */ private $connection; - /** - * @param IDBConnection $connection - */ - public function __construct(IDBConnection $connection) { + public function __construct(Connection $connection) { $this->connection = $connection; parent::__construct(); } diff --git a/core/Migrations/Version16000Date20190427105638.php b/core/Migrations/Version16000Date20190427105638.php index cf48108d9e9..a2a58c74495 100644 --- a/core/Migrations/Version16000Date20190427105638.php +++ b/core/Migrations/Version16000Date20190427105638.php @@ -60,7 +60,6 @@ class Version16000Date20190427105638 extends SimpleMigrationStep { * @param array $options * @return null|ISchemaWrapper * @throws \Doctrine\DBAL\Schema\SchemaException - * @throws \Doctrine\DBAL\DBALException */ public function changeSchema(IOutput $output, Closure $schemaClosure, array $options) { /** @var ISchemaWrapper $schema */ diff --git a/core/Migrations/Version20000Date20201109081918.php b/core/Migrations/Version20000Date20201109081918.php index 71c433a2138..c5a19d0cbfb 100644 --- a/core/Migrations/Version20000Date20201109081918.php +++ b/core/Migrations/Version20000Date20201109081918.php @@ -28,7 +28,7 @@ declare(strict_types=1); namespace OC\Core\Migrations; use Closure; -use Doctrine\DBAL\Types\Type; +use Doctrine\DBAL\Types\Types; use OCP\DB\ISchemaWrapper; use OCP\IDBConnection; use OCP\Migration\IOutput; @@ -55,20 +55,20 @@ class Version20000Date20201109081918 extends SimpleMigrationStep { if (!$schema->hasTable('storages_credentials')) { $table = $schema->createTable('storages_credentials'); - $table->addColumn('id', Type::BIGINT, [ + $table->addColumn('id', Types::BIGINT, [ 'autoincrement' => true, 'notnull' => true, 'length' => 64, ]); - $table->addColumn('user', Type::STRING, [ + $table->addColumn('user', Types::STRING, [ 'notnull' => false, 'length' => 64, ]); - $table->addColumn('identifier', Type::STRING, [ + $table->addColumn('identifier', Types::STRING, [ 'notnull' => true, 'length' => 64, ]); - $table->addColumn('credentials', Type::TEXT, [ + $table->addColumn('credentials', Types::TEXT, [ 'notnull' => false, ]); $table->setPrimaryKey(['id']); diff --git a/core/js/setupchecks.js b/core/js/setupchecks.js index 9d3f1ddc508..c483454cb91 100644 --- a/core/js/setupchecks.js +++ b/core/js/setupchecks.js @@ -513,6 +513,7 @@ OC.SetupChecks.addGenericSetupCheck(data, 'OCA\\Settings\\SetupChecks\\PhpOutputBuffering', messages) OC.SetupChecks.addGenericSetupCheck(data, 'OCA\\Settings\\SetupChecks\\LegacySSEKeyFormat', messages) OC.SetupChecks.addGenericSetupCheck(data, 'OCA\\Settings\\SetupChecks\\CheckUserCertificates', messages) + OC.SetupChecks.addGenericSetupCheck(data, 'OCA\\Settings\\SetupChecks\\SupportedDatabase', messages) } else { messages.push({ diff --git a/core/register_command.php b/core/register_command.php index fe998020d20..605c545554a 100644 --- a/core/register_command.php +++ b/core/register_command.php @@ -100,15 +100,15 @@ if (\OC::$server->getConfig()->getSystemValue('installed', false)) { $application->add(new OC\Core\Command\Db\ConvertType(\OC::$server->getConfig(), new \OC\DB\ConnectionFactory(\OC::$server->getSystemConfig()))); $application->add(new OC\Core\Command\Db\ConvertMysqlToMB4(\OC::$server->getConfig(), \OC::$server->getDatabaseConnection(), \OC::$server->getURLGenerator(), \OC::$server->getLogger())); - $application->add(new OC\Core\Command\Db\ConvertFilecacheBigInt(\OC::$server->getDatabaseConnection())); - $application->add(new OC\Core\Command\Db\AddMissingIndices(\OC::$server->getDatabaseConnection(), \OC::$server->getEventDispatcher())); - $application->add(new OC\Core\Command\Db\AddMissingColumns(\OC::$server->getDatabaseConnection(), \OC::$server->getEventDispatcher())); - $application->add(new OC\Core\Command\Db\AddMissingPrimaryKeys(\OC::$server->getDatabaseConnection(), \OC::$server->getEventDispatcher())); - $application->add(new OC\Core\Command\Db\Migrations\StatusCommand(\OC::$server->getDatabaseConnection())); - $application->add(new OC\Core\Command\Db\Migrations\MigrateCommand(\OC::$server->getDatabaseConnection())); - $application->add(new OC\Core\Command\Db\Migrations\GenerateCommand(\OC::$server->getDatabaseConnection(), \OC::$server->getAppManager())); - $application->add(new OC\Core\Command\Db\Migrations\GenerateFromSchemaFileCommand(\OC::$server->getConfig(), \OC::$server->getAppManager(), \OC::$server->getDatabaseConnection())); - $application->add(new OC\Core\Command\Db\Migrations\ExecuteCommand(\OC::$server->getDatabaseConnection(), \OC::$server->getAppManager(), \OC::$server->getConfig())); + $application->add(new OC\Core\Command\Db\ConvertFilecacheBigInt(\OC::$server->get(\OC\DB\Connection::class))); + $application->add(new OC\Core\Command\Db\AddMissingIndices(\OC::$server->get(\OC\DB\Connection::class), \OC::$server->getEventDispatcher())); + $application->add(new OC\Core\Command\Db\AddMissingColumns(\OC::$server->get(\OC\DB\Connection::class), \OC::$server->getEventDispatcher())); + $application->add(new OC\Core\Command\Db\AddMissingPrimaryKeys(\OC::$server->get(\OC\DB\Connection::class), \OC::$server->getEventDispatcher())); + $application->add(new OC\Core\Command\Db\Migrations\StatusCommand(\OC::$server->get(\OC\DB\Connection::class))); + $application->add(new OC\Core\Command\Db\Migrations\MigrateCommand(\OC::$server->get(\OC\DB\Connection::class))); + $application->add(new OC\Core\Command\Db\Migrations\GenerateCommand(\OC::$server->get(\OC\DB\Connection::class), \OC::$server->getAppManager())); + $application->add(new OC\Core\Command\Db\Migrations\GenerateFromSchemaFileCommand(\OC::$server->getConfig(), \OC::$server->getAppManager(), \OC::$server->get(\OC\DB\Connection::class))); + $application->add(new OC\Core\Command\Db\Migrations\ExecuteCommand(\OC::$server->get(\OC\DB\Connection::class), \OC::$server->getConfig())); $application->add(new OC\Core\Command\Encryption\Disable(\OC::$server->getConfig())); $application->add(new OC\Core\Command\Encryption\Enable(\OC::$server->getConfig(), \OC::$server->getEncryptionManager())); |