summaryrefslogtreecommitdiffstatshomepage
path: root/core/modules
diff options
context:
space:
mode:
Diffstat (limited to 'core/modules')
-rw-r--r--core/modules/field_ui/field_ui.module3
-rw-r--r--core/modules/mysqli/mysqli.install78
-rw-r--r--core/modules/mysqli/src/Hook/MysqliHooks.php70
-rw-r--r--core/modules/package_manager/tests/src/Build/PackageInstallSubmoduleTest.php6
-rw-r--r--core/modules/package_manager/tests/src/Build/PackageInstallTest.php6
-rw-r--r--core/modules/package_manager/tests/src/Build/PackageUpdateTest.php5
-rw-r--r--core/modules/system/src/Hook/PageAttachmentsHook.php2
-rw-r--r--core/modules/system/templates/image.html.twig2
-rw-r--r--core/modules/system/templates/install-page.html.twig2
-rw-r--r--core/modules/system/templates/item-list.html.twig2
-rw-r--r--core/modules/system/templates/maintenance-page.html.twig2
-rw-r--r--core/modules/system/templates/menu-local-action.html.twig2
-rw-r--r--core/modules/system/templates/menu-local-task.html.twig2
-rw-r--r--core/modules/system/templates/region.html.twig2
-rw-r--r--core/modules/system/templates/table.html.twig2
15 files changed, 92 insertions, 94 deletions
diff --git a/core/modules/field_ui/field_ui.module b/core/modules/field_ui/field_ui.module
index 8904dd925e57..67c049fa5057 100644
--- a/core/modules/field_ui/field_ui.module
+++ b/core/modules/field_ui/field_ui.module
@@ -5,6 +5,7 @@
*/
use Drupal\Core\Form\FormStateInterface;
+use Drupal\Core\Theme\ThemePreprocess;
use Drupal\field_ui\FieldUI;
/**
@@ -18,7 +19,7 @@ use Drupal\field_ui\FieldUI;
* rendered as a table.
*/
function template_preprocess_field_ui_table(&$variables): void {
- template_preprocess_table($variables);
+ \Drupal::service(ThemePreprocess::class)->preprocessTable($variables);
}
/**
diff --git a/core/modules/mysqli/mysqli.install b/core/modules/mysqli/mysqli.install
deleted file mode 100644
index 7f1147d63adb..000000000000
--- a/core/modules/mysqli/mysqli.install
+++ /dev/null
@@ -1,78 +0,0 @@
-<?php
-
-/**
- * @file
- * Install, update and uninstall functions for the mysqli module.
- */
-
-use Drupal\Core\Database\Database;
-use Drupal\Core\Extension\Requirement\RequirementSeverity;
-use Drupal\Core\Render\Markup;
-
-/**
- * Implements hook_requirements().
- */
-function mysqli_requirements($phase): array {
- $requirements = [];
-
- if ($phase === 'runtime') {
- // Test with MySql databases.
- if (Database::isActiveConnection()) {
- $connection = Database::getConnection();
- // Only show requirements when MySQLi is the default database connection.
- if (!($connection->driver() === 'mysqli' && $connection->getProvider() === 'mysqli')) {
- return [];
- }
-
- $query = $connection->isMariaDb() ? 'SELECT @@SESSION.tx_isolation' : 'SELECT @@SESSION.transaction_isolation';
-
- $isolation_level = $connection->query($query)->fetchField();
-
- $tables_missing_primary_key = [];
- $tables = $connection->schema()->findTables('%');
- foreach ($tables as $table) {
- $primary_key_column = Database::getConnection()->query("SHOW KEYS FROM {" . $table . "} WHERE Key_name = 'PRIMARY'")->fetchAllAssoc('Column_name');
- if (empty($primary_key_column)) {
- $tables_missing_primary_key[] = $table;
- }
- }
-
- $description = [];
- if ($isolation_level == 'READ-COMMITTED') {
- if (empty($tables_missing_primary_key)) {
- $severity_level = RequirementSeverity::OK;
- }
- else {
- $severity_level = RequirementSeverity::Error;
- }
- }
- else {
- if ($isolation_level == 'REPEATABLE-READ') {
- $severity_level = RequirementSeverity::Warning;
- }
- else {
- $severity_level = RequirementSeverity::Error;
- $description[] = t('This is not supported by Drupal.');
- }
- $description[] = t('The recommended level for Drupal is "READ COMMITTED".');
- }
-
- if (!empty($tables_missing_primary_key)) {
- $description[] = t('For this to work correctly, all tables must have a primary key. The following table(s) do not have a primary key: @tables.', ['@tables' => implode(', ', $tables_missing_primary_key)]);
- }
-
- $description[] = t('See the <a href=":performance_doc">setting MySQL transaction isolation level</a> page for more information.', [
- ':performance_doc' => 'https://www.drupal.org/docs/system-requirements/setting-the-mysql-transaction-isolation-level',
- ]);
-
- $requirements['mysql_transaction_level'] = [
- 'title' => t('Transaction isolation level'),
- 'severity' => $severity_level,
- 'value' => $isolation_level,
- 'description' => Markup::create(implode(' ', $description)),
- ];
- }
- }
-
- return $requirements;
-}
diff --git a/core/modules/mysqli/src/Hook/MysqliHooks.php b/core/modules/mysqli/src/Hook/MysqliHooks.php
index 5fae187d16c7..340b17373a12 100644
--- a/core/modules/mysqli/src/Hook/MysqliHooks.php
+++ b/core/modules/mysqli/src/Hook/MysqliHooks.php
@@ -2,7 +2,10 @@
namespace Drupal\mysqli\Hook;
+use Drupal\Core\Database\Database;
+use Drupal\Core\Extension\Requirement\RequirementSeverity;
use Drupal\Core\Hook\Attribute\Hook;
+use Drupal\Core\Render\Markup;
use Drupal\Core\Routing\RouteMatchInterface;
use Drupal\Core\StringTranslation\StringTranslationTrait;
@@ -29,4 +32,71 @@ class MysqliHooks {
return NULL;
}
+ /**
+ * Implements hook_runtime_requirements().
+ */
+ #[Hook('runtime_requirements')]
+ public function runtimeRequirements(): array {
+ $requirements = [];
+
+ // Test with MySql databases.
+ if (Database::isActiveConnection()) {
+ $connection = Database::getConnection();
+ // Only show requirements when MySQLi is the default database connection.
+ if (!($connection->driver() === 'mysqli' && $connection->getProvider() === 'mysqli')) {
+ return [];
+ }
+
+ $query = $connection->isMariaDb() ? 'SELECT @@SESSION.tx_isolation' : 'SELECT @@SESSION.transaction_isolation';
+
+ $isolation_level = $connection->query($query)->fetchField();
+
+ $tables_missing_primary_key = [];
+ $tables = $connection->schema()->findTables('%');
+ foreach ($tables as $table) {
+ $primary_key_column = Database::getConnection()->query("SHOW KEYS FROM {" . $table . "} WHERE Key_name = 'PRIMARY'")->fetchAllAssoc('Column_name');
+ if (empty($primary_key_column)) {
+ $tables_missing_primary_key[] = $table;
+ }
+ }
+
+ $description = [];
+ if ($isolation_level == 'READ-COMMITTED') {
+ if (empty($tables_missing_primary_key)) {
+ $severity_level = RequirementSeverity::OK;
+ }
+ else {
+ $severity_level = RequirementSeverity::Error;
+ }
+ }
+ else {
+ if ($isolation_level == 'REPEATABLE-READ') {
+ $severity_level = RequirementSeverity::Warning;
+ }
+ else {
+ $severity_level = RequirementSeverity::Error;
+ $description[] = $this->t('This is not supported by Drupal.');
+ }
+ $description[] = $this->t('The recommended level for Drupal is "READ COMMITTED".');
+ }
+
+ if (!empty($tables_missing_primary_key)) {
+ $description[] = $this->t('For this to work correctly, all tables must have a primary key. The following table(s) do not have a primary key: @tables.', ['@tables' => implode(', ', $tables_missing_primary_key)]);
+ }
+
+ $description[] = $this->t('See the <a href=":performance_doc">setting MySQL transaction isolation level</a> page for more information.', [
+ ':performance_doc' => 'https://www.drupal.org/docs/system-requirements/setting-the-mysql-transaction-isolation-level',
+ ]);
+
+ $requirements['mysql_transaction_level'] = [
+ 'title' => $this->t('Transaction isolation level'),
+ 'severity' => $severity_level,
+ 'value' => $isolation_level,
+ 'description' => Markup::create(implode(' ', $description)),
+ ];
+ }
+
+ return $requirements;
+ }
+
}
diff --git a/core/modules/package_manager/tests/src/Build/PackageInstallSubmoduleTest.php b/core/modules/package_manager/tests/src/Build/PackageInstallSubmoduleTest.php
index 18c87b11956b..4cc4405d4c81 100644
--- a/core/modules/package_manager/tests/src/Build/PackageInstallSubmoduleTest.php
+++ b/core/modules/package_manager/tests/src/Build/PackageInstallSubmoduleTest.php
@@ -4,13 +4,15 @@ declare(strict_types=1);
namespace Drupal\Tests\package_manager\Build;
+use PHPUnit\Framework\Attributes\Group;
+
/**
* Tests installing packages in a stage directory.
*
- * @group package_manager
- * @group #slow
* @internal
*/
+#[Group('package_manager')]
+#[Group('#slow')]
class PackageInstallSubmoduleTest extends TemplateProjectTestBase {
/**
diff --git a/core/modules/package_manager/tests/src/Build/PackageInstallTest.php b/core/modules/package_manager/tests/src/Build/PackageInstallTest.php
index 362343eaa91a..283c6aefa2cf 100644
--- a/core/modules/package_manager/tests/src/Build/PackageInstallTest.php
+++ b/core/modules/package_manager/tests/src/Build/PackageInstallTest.php
@@ -4,13 +4,15 @@ declare(strict_types=1);
namespace Drupal\Tests\package_manager\Build;
+use PHPUnit\Framework\Attributes\Group;
+
/**
* Tests installing packages in a stage directory.
*
- * @group package_manager
- * @group #slow
* @internal
*/
+#[Group('package_manager')]
+#[Group('#slow')]
class PackageInstallTest extends TemplateProjectTestBase {
/**
diff --git a/core/modules/package_manager/tests/src/Build/PackageUpdateTest.php b/core/modules/package_manager/tests/src/Build/PackageUpdateTest.php
index 2b9ef4aa894e..da6fc5eae320 100644
--- a/core/modules/package_manager/tests/src/Build/PackageUpdateTest.php
+++ b/core/modules/package_manager/tests/src/Build/PackageUpdateTest.php
@@ -5,14 +5,15 @@ declare(strict_types=1);
namespace Drupal\Tests\package_manager\Build;
use Drupal\package_manager_test_api\ControllerSandboxManager;
+use PHPUnit\Framework\Attributes\Group;
/**
* Tests updating packages in a stage directory.
*
- * @group package_manager
- * @group #slow
* @internal
*/
+#[Group('package_manager')]
+#[Group('#slow')]
class PackageUpdateTest extends TemplateProjectTestBase {
/**
diff --git a/core/modules/system/src/Hook/PageAttachmentsHook.php b/core/modules/system/src/Hook/PageAttachmentsHook.php
index fb6335f90c31..3f271571ede1 100644
--- a/core/modules/system/src/Hook/PageAttachmentsHook.php
+++ b/core/modules/system/src/Hook/PageAttachmentsHook.php
@@ -19,7 +19,7 @@ final class PageAttachmentsHook {
/**
* Implements hook_page_attachments().
*
- * @see template_preprocess_maintenance_page()
+ * @see \Drupal\Core\Theme\ThemePreprocess::preprocessMaintenancePage()
* @see \Drupal\Core\EventSubscriber\ActiveLinkResponseFilter
*/
#[Hook('page_attachments')]
diff --git a/core/modules/system/templates/image.html.twig b/core/modules/system/templates/image.html.twig
index 6411eaa3d07b..1f6d19d6c3e7 100644
--- a/core/modules/system/templates/image.html.twig
+++ b/core/modules/system/templates/image.html.twig
@@ -7,7 +7,7 @@
* - attributes: HTML attributes for the img tag.
* - style_name: (optional) The name of the image style applied.
*
- * @see template_preprocess_image()
+ * @see \Drupal\Core\Theme\ImagePreprocess::preprocessImage()
*
* @ingroup themeable
*/
diff --git a/core/modules/system/templates/install-page.html.twig b/core/modules/system/templates/install-page.html.twig
index f6091fd3b956..d9144e6a154b 100644
--- a/core/modules/system/templates/install-page.html.twig
+++ b/core/modules/system/templates/install-page.html.twig
@@ -6,7 +6,7 @@
* All available variables are mirrored in page.html.twig.
* Some may be blank but they are provided for consistency.
*
- * @see template_preprocess_install_page()
+ * @see \Drupal\Core\Theme\ThemePreprocess::preprocessInstallPage()
*
* @ingroup themeable
*/
diff --git a/core/modules/system/templates/item-list.html.twig b/core/modules/system/templates/item-list.html.twig
index 1462cf41ae0f..c2babdab978e 100644
--- a/core/modules/system/templates/item-list.html.twig
+++ b/core/modules/system/templates/item-list.html.twig
@@ -16,7 +16,7 @@
* - context: A list of contextual data associated with the list. May contain:
* - list_style: The custom list style.
*
- * @see template_preprocess_item_list()
+ * @see \Drupal\Core\Theme\ThemePreprocess::preprocessItemList()
*
* @ingroup themeable
*/
diff --git a/core/modules/system/templates/maintenance-page.html.twig b/core/modules/system/templates/maintenance-page.html.twig
index 748ed5a3aa4a..06fb6065f7a4 100644
--- a/core/modules/system/templates/maintenance-page.html.twig
+++ b/core/modules/system/templates/maintenance-page.html.twig
@@ -6,7 +6,7 @@
* All available variables are mirrored in page.html.twig.
* Some may be blank but they are provided for consistency.
*
- * @see template_preprocess_maintenance_page()
+ * @see \Drupal\Core\Theme\ThemePreprocess::preprocessMaintenancePage()
*
* @ingroup themeable
*/
diff --git a/core/modules/system/templates/menu-local-action.html.twig b/core/modules/system/templates/menu-local-action.html.twig
index 0eb03a9534ab..e0280d5fcbc0 100644
--- a/core/modules/system/templates/menu-local-action.html.twig
+++ b/core/modules/system/templates/menu-local-action.html.twig
@@ -7,7 +7,7 @@
* - attributes: HTML attributes for the wrapper element.
* - link: A rendered link element.
*
- * @see template_preprocess_menu_local_action()
+ * @see \Drupal\Core\Menu\MenuPreprocess::preprocessMenuLocalAction()
*
* @ingroup themeable
*/
diff --git a/core/modules/system/templates/menu-local-task.html.twig b/core/modules/system/templates/menu-local-task.html.twig
index ec02a8d530c4..b2a743940a77 100644
--- a/core/modules/system/templates/menu-local-task.html.twig
+++ b/core/modules/system/templates/menu-local-task.html.twig
@@ -11,7 +11,7 @@
* Note: This template renders the content for each task item in
* menu-local-tasks.html.twig.
*
- * @see template_preprocess_menu_local_task()
+ * @see \Drupal\Core\Menu\MenuPreprocess::preprocessMenuLocalTask()
*
* @ingroup themeable
*/
diff --git a/core/modules/system/templates/region.html.twig b/core/modules/system/templates/region.html.twig
index 219e14b0a4be..ddcaaa192df4 100644
--- a/core/modules/system/templates/region.html.twig
+++ b/core/modules/system/templates/region.html.twig
@@ -9,7 +9,7 @@
* - region: The name of the region variable as defined in the theme's
* .info.yml file.
*
- * @see template_preprocess_region()
+ * @see \Drupal\Core\Theme\ThemePreprocess::preprocessRegion()
*
* @ingroup themeable
*/
diff --git a/core/modules/system/templates/table.html.twig b/core/modules/system/templates/table.html.twig
index cfcb0bf976c0..6a73cc1152a8 100644
--- a/core/modules/system/templates/table.html.twig
+++ b/core/modules/system/templates/table.html.twig
@@ -38,7 +38,7 @@
* - no_striping: A boolean indicating that the row should receive no striping.
* - header_columns: The number of columns in the header.
*
- * @see template_preprocess_table()
+ * @see \Drupal\Core\Theme\ThemePreprocess::preprocessTable()
*
* @ingroup themeable
*/