diff --git a/composer.json b/composer.json index e676386da3dfd17e7825531b10924a1741333020..914a188cac20e7e1eb756451954ba1acb3e8407f 100644 --- a/composer.json +++ b/composer.json @@ -47,7 +47,9 @@ "symfony/polyfill-php73": "*", "symfony/polyfill-php74": "*", "symfony/polyfill-php80": "*", - "symfony/polyfill-php81": "*" + "symfony/polyfill-php81": "*", + "symfony/polyfill-php82": "*", + "symfony/polyfill-php83": "*" }, "minimum-stability": "dev", "prefer-stable": true, @@ -55,7 +57,7 @@ "preferred-install": "dist", "sort-packages": true, "platform": { - "php": "8.1.0" + "php": "8.3.0" }, "allow-plugins": { "composer/installers": true, diff --git a/composer.lock b/composer.lock index 74d95e19bb0f1f54bbbe678cd0438ecd7481a4f3..bd50d7a5dc7121c4cc427b27e1041b45e4a61932 100644 --- a/composer.lock +++ b/composer.lock @@ -4,7 +4,7 @@ "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies", "This file is @generated automatically" ], - "content-hash": "479da193f70d9ec14eb448a2d7360a05", + "content-hash": "335c0228fb93c94583fe0750ff7a37ab", "packages": [ { "name": "asm89/stack-cors", @@ -495,7 +495,7 @@ "dist": { "type": "path", "url": "core", - "reference": "45312e105697022dac062ee5a5fd7a4a0ad4162c" + "reference": "be48b81e356839257d4e279060da3dd05a009da1" }, "require": { "asm89/stack-cors": "^2.1", @@ -522,9 +522,9 @@ "masterminds/html5": "^2.7", "mck89/peast": "^1.14", "pear/archive_tar": "^1.4.14", - "php": ">=8.1.0", + "php": ">=8.3.0", "psr/log": "^3.0", - "sebastian/diff": "^4", + "sebastian/diff": "^4|^5", "symfony/console": "^6.4", "symfony/dependency-injection": "^6.4", "symfony/event-dispatcher": "^6.4", @@ -3387,86 +3387,6 @@ ], "time": "2023-07-28T09:04:16+00:00" }, - { - "name": "symfony/polyfill-php83", - "version": "v1.28.0", - "source": { - "type": "git", - "url": "https://github.com/symfony/polyfill-php83.git", - "reference": "b0f46ebbeeeda3e9d2faebdfbf4b4eae9b59fa11" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/symfony/polyfill-php83/zipball/b0f46ebbeeeda3e9d2faebdfbf4b4eae9b59fa11", - "reference": "b0f46ebbeeeda3e9d2faebdfbf4b4eae9b59fa11", - "shasum": "" - }, - "require": { - "php": ">=7.1", - "symfony/polyfill-php80": "^1.14" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-main": "1.28-dev" - }, - "thanks": { - "name": "symfony/polyfill", - "url": "https://github.com/symfony/polyfill" - } - }, - "autoload": { - "files": [ - "bootstrap.php" - ], - "psr-4": { - "Symfony\\Polyfill\\Php83\\": "" - }, - "classmap": [ - "Resources/stubs" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Nicolas Grekas", - "email": "p@tchwork.com" - }, - { - "name": "Symfony Community", - "homepage": "https://symfony.com/contributors" - } - ], - "description": "Symfony polyfill backporting some PHP 8.3+ features to lower PHP versions", - "homepage": "https://symfony.com", - "keywords": [ - "compatibility", - "polyfill", - "portable", - "shim" - ], - "support": { - "source": "https://github.com/symfony/polyfill-php83/tree/v1.28.0" - }, - "funding": [ - { - "url": "https://symfony.com/sponsor", - "type": "custom" - }, - { - "url": "https://github.com/fabpot", - "type": "github" - }, - { - "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", - "type": "tidelift" - } - ], - "time": "2023-08-16T06:22:46+00:00" - }, { "name": "symfony/process", "version": "v6.4.0", @@ -9378,85 +9298,6 @@ ], "time": "2023-12-01T09:25:07+00:00" }, - { - "name": "symfony/polyfill-php82", - "version": "v1.28.0", - "source": { - "type": "git", - "url": "https://github.com/symfony/polyfill-php82.git", - "reference": "7716bea9c86776fb3362d6b52fe1fc9471056a49" - }, - "dist": { - "type": "zip", - "url": "https://api.github.com/repos/symfony/polyfill-php82/zipball/7716bea9c86776fb3362d6b52fe1fc9471056a49", - "reference": "7716bea9c86776fb3362d6b52fe1fc9471056a49", - "shasum": "" - }, - "require": { - "php": ">=7.1" - }, - "type": "library", - "extra": { - "branch-alias": { - "dev-main": "1.28-dev" - }, - "thanks": { - "name": "symfony/polyfill", - "url": "https://github.com/symfony/polyfill" - } - }, - "autoload": { - "files": [ - "bootstrap.php" - ], - "psr-4": { - "Symfony\\Polyfill\\Php82\\": "" - }, - "classmap": [ - "Resources/stubs" - ] - }, - "notification-url": "https://packagist.org/downloads/", - "license": [ - "MIT" - ], - "authors": [ - { - "name": "Nicolas Grekas", - "email": "p@tchwork.com" - }, - { - "name": "Symfony Community", - "homepage": "https://symfony.com/contributors" - } - ], - "description": "Symfony polyfill backporting some PHP 8.2+ features to lower PHP versions", - "homepage": "https://symfony.com", - "keywords": [ - "compatibility", - "polyfill", - "portable", - "shim" - ], - "support": { - "source": "https://github.com/symfony/polyfill-php82/tree/v1.28.0" - }, - "funding": [ - { - "url": "https://symfony.com/sponsor", - "type": "custom" - }, - { - "url": "https://github.com/fabpot", - "type": "github" - }, - { - "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", - "type": "tidelift" - } - ], - "time": "2023-08-25T17:27:25+00:00" - }, { "name": "theseer/tokenizer", "version": "1.2.2", @@ -9622,7 +9463,7 @@ "platform": [], "platform-dev": [], "platform-overrides": { - "php": "8.1.0" + "php": "8.3.0" }, "plugin-api-version": "2.6.0" } diff --git a/composer/Metapackage/CoreRecommended/composer.json b/composer/Metapackage/CoreRecommended/composer.json index 1979056e3f2ab3feb7a3ebcb5ae3bb923b3064be..a9b40b7cf9cdaa35e4520c5a9d04289ff310f580 100644 --- a/composer/Metapackage/CoreRecommended/composer.json +++ b/composer/Metapackage/CoreRecommended/composer.json @@ -49,7 +49,6 @@ "symfony/polyfill-intl-idn": "~v1.28.0", "symfony/polyfill-intl-normalizer": "~v1.28.0", "symfony/polyfill-mbstring": "~v1.28.0", - "symfony/polyfill-php83": "~v1.28.0", "symfony/process": "~v6.4.0", "symfony/psr-http-message-bridge": "~v6.4.0", "symfony/routing": "~v6.4.1", diff --git a/composer/Metapackage/PinnedDevDependencies/composer.json b/composer/Metapackage/PinnedDevDependencies/composer.json index 755744e6652cb26128e9d2b12e206d36d2331ac8..269433bfa47f225bc9400fa08913966b15590fd5 100644 --- a/composer/Metapackage/PinnedDevDependencies/composer.json +++ b/composer/Metapackage/PinnedDevDependencies/composer.json @@ -85,7 +85,6 @@ "symfony/dom-crawler": "v6.4.0", "symfony/lock": "v6.4.0", "symfony/phpunit-bridge": "v6.4.1", - "symfony/polyfill-php82": "v1.28.0", "theseer/tokenizer": "1.2.2", "webflo/drupal-finder": "1.2.2", "webmozart/assert": "1.11.0" diff --git a/core/INSTALL.txt b/core/INSTALL.txt index 9e1f2e5a924a0f48cce94438502669fb88b21d3e..a484cc10793d6131f2a1fd63e963b7771352a0f9 100644 --- a/core/INSTALL.txt +++ b/core/INSTALL.txt @@ -15,7 +15,7 @@ QUICKSTART ---------------------- Prerequisites: -- PHP 8.1.0 (or greater) (https://php.net). +- PHP 8.3.0 (or greater) (https://php.net). In the instructions below, replace the version x.y.z with the specific version you wish to download. Example: 8.6.0.zip. You can find the latest stable version @@ -48,7 +48,7 @@ Drupal requires: - A web server with PHP support, for example: - Apache 2.4.7 (or greater) (http://httpd.apache.org/). - Nginx 1.1 (or greater) (http://nginx.com/). -- PHP 8.1.0 (or greater) (http://php.net/). +- PHP 8.3.0 (or greater) (http://php.net/). - One of the following databases: - MySQL 5.7.8 (or greater) (http://www.mysql.com/). - MariaDB 10.3.7 (or greater) (https://mariadb.org/). MariaDB is a fully diff --git a/core/composer.json b/core/composer.json index b3467458517fdb2fbf83734aaccf1fa3fcff4786..af803fa74f156871169515e5facfac7ea829a771 100644 --- a/core/composer.json +++ b/core/composer.json @@ -17,7 +17,7 @@ "ext-SPL": "*", "ext-tokenizer": "*", "ext-xml": "*", - "php": ">=8.1.0", + "php": ">=8.3.0", "symfony/console": "^6.4", "symfony/dependency-injection": "^6.4", "symfony/event-dispatcher": "^6.4", @@ -47,7 +47,7 @@ "pear/archive_tar": "^1.4.14", "psr/log": "^3.0", "mck89/peast": "^1.14", - "sebastian/diff": "^4" + "sebastian/diff": "^4|^5" }, "conflict": { "drush/drush": "<12.4.3" diff --git a/core/lib/Drupal.php b/core/lib/Drupal.php index c42f5043d3481cef31bf4d0a354b9458e714b21c..ceb4c53d5ec955e28a812c15d4a16985800947a8 100644 --- a/core/lib/Drupal.php +++ b/core/lib/Drupal.php @@ -113,7 +113,7 @@ class Drupal { * - Once in the error message printed to the user immediately after. * Remember to update both whenever this constant is updated. */ - const MINIMUM_PHP = '8.1.0'; + const MINIMUM_PHP = '8.3.0'; /** * Minimum recommended value of PHP memory_limit. @@ -131,7 +131,7 @@ class Drupal { * message, but Drupal can still be installed. Used for (e.g.) PHP versions * that have reached their EOL or will in the near future. */ - const RECOMMENDED_PHP = '8.2.0'; + const RECOMMENDED_PHP = '8.3.0'; /** * The currently active container object, or NULL if not initialized yet. diff --git a/core/lib/Drupal/Component/Annotation/composer.json b/core/lib/Drupal/Component/Annotation/composer.json index 7aaffc37748e1cbd88b71b8374ec5dedc3224883..3575798a7c159c7f66f951a203d5368e3dd51a6f 100644 --- a/core/lib/Drupal/Component/Annotation/composer.json +++ b/core/lib/Drupal/Component/Annotation/composer.json @@ -7,7 +7,7 @@ "homepage": "https://www.drupal.org/project/drupal", "license": "GPL-2.0-or-later", "require": { - "php": ">=8.1.0", + "php": ">=8.3.0", "doctrine/annotations": "^2.0", "doctrine/lexer": "^2.0", "drupal/core-class-finder": "11.x-dev", diff --git a/core/lib/Drupal/Component/Assertion/composer.json b/core/lib/Drupal/Component/Assertion/composer.json index 49e2e0e75bbc248d93cf53b88de427eb407f7d5d..e68799602875e2b27314755939c2dc4926bd3ee1 100644 --- a/core/lib/Drupal/Component/Assertion/composer.json +++ b/core/lib/Drupal/Component/Assertion/composer.json @@ -7,7 +7,7 @@ "homepage": "https://www.drupal.org/project/drupal", "license": "GPL-2.0-or-later", "require": { - "php": ">=8.1.0" + "php": ">=8.3.0" }, "autoload": { "psr-4": { diff --git a/core/lib/Drupal/Component/ClassFinder/composer.json b/core/lib/Drupal/Component/ClassFinder/composer.json index d31e53402777a16980504b7807c8861769431699..9d0355af9245d44b0aef872600f58e84763179e4 100644 --- a/core/lib/Drupal/Component/ClassFinder/composer.json +++ b/core/lib/Drupal/Component/ClassFinder/composer.json @@ -7,7 +7,7 @@ "homepage": "https://www.drupal.org/project/drupal", "license": "GPL-2.0-or-later", "require": { - "php": ">=8.1.0" + "php": ">=8.3.0" }, "autoload": { "psr-4": { diff --git a/core/lib/Drupal/Component/Datetime/composer.json b/core/lib/Drupal/Component/Datetime/composer.json index 91bd608f5570c559da95bee80c2aa924234caaa8..3f99849600c572a81f5c34695fa73a1a0046f894 100644 --- a/core/lib/Drupal/Component/Datetime/composer.json +++ b/core/lib/Drupal/Component/Datetime/composer.json @@ -7,7 +7,7 @@ "homepage": "https://www.drupal.org/project/drupal", "license": "GPL-2.0-or-later", "require": { - "php": ">=8.1.0", + "php": ">=8.3.0", "drupal/core-utility": "11.x-dev" }, "autoload": { diff --git a/core/lib/Drupal/Component/DependencyInjection/composer.json b/core/lib/Drupal/Component/DependencyInjection/composer.json index 9558355aeea468c4dfebc7562095654d5831e032..d6a847a80c40d269754c05d069c378055d788158 100644 --- a/core/lib/Drupal/Component/DependencyInjection/composer.json +++ b/core/lib/Drupal/Component/DependencyInjection/composer.json @@ -13,7 +13,7 @@ "source": "https://www.drupal.org/project/drupal/git-instructions" }, "require": { - "php": ">=8.1.0", + "php": ">=8.3.0", "symfony/dependency-injection": "^6.4", "symfony/service-contracts": "v3.4.0" }, diff --git a/core/lib/Drupal/Component/Diff/composer.json b/core/lib/Drupal/Component/Diff/composer.json index 57a07592ff8586cc8f34f58cea7d27e545f7cd1d..3fd31e6c78fb2601b17510af6ee9349f742b72b7 100644 --- a/core/lib/Drupal/Component/Diff/composer.json +++ b/core/lib/Drupal/Component/Diff/composer.json @@ -7,8 +7,8 @@ "homepage": "https://www.drupal.org/project/drupal", "license": "GPL-2.0-or-later", "require": { - "php": ">=8.1.0", - "sebastian/diff": "^4" + "php": ">=8.3.0", + "sebastian/diff": "^4|^5" }, "autoload": { "psr-4": { diff --git a/core/lib/Drupal/Component/Discovery/composer.json b/core/lib/Drupal/Component/Discovery/composer.json index 4a9343967682b60fc6e33c276d411a1f80a6c365..8bc8d69047e8b0fbf132830d96531b9b049d56bf 100644 --- a/core/lib/Drupal/Component/Discovery/composer.json +++ b/core/lib/Drupal/Component/Discovery/composer.json @@ -7,7 +7,7 @@ "homepage": "https://www.drupal.org/project/drupal", "license": "GPL-2.0-or-later", "require": { - "php": ">=8.1.0", + "php": ">=8.3.0", "drupal/core-file-cache": "11.x-dev", "drupal/core-serialization": "11.x-dev" }, diff --git a/core/lib/Drupal/Component/EventDispatcher/composer.json b/core/lib/Drupal/Component/EventDispatcher/composer.json index 79ed3a24cfdf798e0a06191ba783f07011598e98..b492f29621cf016c50051a4467768dbaaa66f752 100644 --- a/core/lib/Drupal/Component/EventDispatcher/composer.json +++ b/core/lib/Drupal/Component/EventDispatcher/composer.json @@ -7,7 +7,7 @@ "homepage": "https://www.drupal.org/project/drupal", "license": "GPL-2.0-or-later", "require": { - "php": ">=8.1.0", + "php": ">=8.3.0", "symfony/dependency-injection": "^6.4", "symfony/event-dispatcher": "^6.4", "symfony/event-dispatcher-contracts": "v3.4.0" diff --git a/core/lib/Drupal/Component/FileCache/composer.json b/core/lib/Drupal/Component/FileCache/composer.json index c262143bb5c85806920a7b91d74b8b4d63d94f9a..456e26532439f59118b76d0819512552172552cb 100644 --- a/core/lib/Drupal/Component/FileCache/composer.json +++ b/core/lib/Drupal/Component/FileCache/composer.json @@ -7,7 +7,7 @@ "homepage": "https://www.drupal.org/project/drupal", "license": "GPL-2.0-or-later", "require": { - "php": ">=8.1.0" + "php": ">=8.3.0" }, "autoload": { "psr-4": { diff --git a/core/lib/Drupal/Component/FileSecurity/composer.json b/core/lib/Drupal/Component/FileSecurity/composer.json index 880de76a6c58559473d3ae0b7d3d87c0505b2c7b..3408fa0aecc06c14c8c7047bae17fb0781f51dad 100644 --- a/core/lib/Drupal/Component/FileSecurity/composer.json +++ b/core/lib/Drupal/Component/FileSecurity/composer.json @@ -7,7 +7,7 @@ "homepage": "https://www.drupal.org/project/drupal", "license": "GPL-2.0-or-later", "require": { - "php": ">=8.1.0" + "php": ">=8.3.0" }, "autoload": { "psr-4": { diff --git a/core/lib/Drupal/Component/FileSystem/composer.json b/core/lib/Drupal/Component/FileSystem/composer.json index 975c5d554a3430306d176c47f82a374d2112364b..029cb3682a56bed15719462f6296f1ee43bd2580 100644 --- a/core/lib/Drupal/Component/FileSystem/composer.json +++ b/core/lib/Drupal/Component/FileSystem/composer.json @@ -7,7 +7,7 @@ "homepage": "https://www.drupal.org/project/drupal", "license": "GPL-2.0-or-later", "require": { - "php": ">=8.1.0" + "php": ">=8.3.0" }, "autoload": { "psr-4": { diff --git a/core/lib/Drupal/Component/FrontMatter/composer.json b/core/lib/Drupal/Component/FrontMatter/composer.json index 9baa12c9d92d3c36b822103d0b4858281b873d51..da56de5b7efadae92ca007b3468bd0d5f026310d 100644 --- a/core/lib/Drupal/Component/FrontMatter/composer.json +++ b/core/lib/Drupal/Component/FrontMatter/composer.json @@ -7,7 +7,7 @@ "homepage": "https://www.drupal.org/project/drupal", "license": "GPL-2.0-or-later", "require": { - "php": ">=8.1.0", + "php": ">=8.3.0", "drupal/core-serialization": "11.x-dev" }, "autoload": { diff --git a/core/lib/Drupal/Component/Gettext/composer.json b/core/lib/Drupal/Component/Gettext/composer.json index 0db3a4bc30b6db7ee1c4411bbd75614ab08f5f4d..94e3e6c137de730d40ee8ad94fd105a900487723 100644 --- a/core/lib/Drupal/Component/Gettext/composer.json +++ b/core/lib/Drupal/Component/Gettext/composer.json @@ -8,7 +8,7 @@ "source": "https://www.drupal.org/project/drupal/git-instructions" }, "require": { - "php": ">=8.1.0", + "php": ">=8.3.0", "drupal/core-render": "11.x-dev" }, "autoload": { diff --git a/core/lib/Drupal/Component/Graph/composer.json b/core/lib/Drupal/Component/Graph/composer.json index c6c4e2b02ce28f27c3e7148eb83a4ed053eeff96..245c41e197e96d6af34c8b75b7865534127130a6 100644 --- a/core/lib/Drupal/Component/Graph/composer.json +++ b/core/lib/Drupal/Component/Graph/composer.json @@ -7,7 +7,7 @@ "homepage": "https://www.drupal.org/project/drupal", "license": "GPL-2.0-or-later", "require": { - "php": ">=8.1.0" + "php": ">=8.3.0" }, "autoload": { "psr-4": { diff --git a/core/lib/Drupal/Component/HttpFoundation/composer.json b/core/lib/Drupal/Component/HttpFoundation/composer.json index 634267f9b6515c1d85648d8af40098ec5d975d78..5ec33a66051d48b6a71683008e47a7e5108fadd6 100644 --- a/core/lib/Drupal/Component/HttpFoundation/composer.json +++ b/core/lib/Drupal/Component/HttpFoundation/composer.json @@ -7,7 +7,7 @@ "homepage": "https://www.drupal.org/project/drupal", "license": "GPL-2.0-or-later", "require": { - "php": ">=8.1.0", + "php": ">=8.3.0", "symfony/http-foundation": "^6.4" }, "autoload": { diff --git a/core/lib/Drupal/Component/PhpStorage/composer.json b/core/lib/Drupal/Component/PhpStorage/composer.json index 0517f06b0e35c65a610a043656a3c89ec3130299..bf7c2d3b42e3243e5d8ecc990f5f006781549f79 100644 --- a/core/lib/Drupal/Component/PhpStorage/composer.json +++ b/core/lib/Drupal/Component/PhpStorage/composer.json @@ -7,7 +7,7 @@ "homepage": "https://www.drupal.org/project/drupal", "license": "GPL-2.0-or-later", "require": { - "php": ">=8.1.0", + "php": ">=8.3.0", "drupal/core-file-security": "11.x-dev" }, "autoload": { diff --git a/core/lib/Drupal/Component/Plugin/composer.json b/core/lib/Drupal/Component/Plugin/composer.json index bc618403b32a2d38712443f4b0fa1601c53d2e3a..53c93b6501b65cb24dd9ef96727c9060a2c7096a 100644 --- a/core/lib/Drupal/Component/Plugin/composer.json +++ b/core/lib/Drupal/Component/Plugin/composer.json @@ -9,7 +9,7 @@ "homepage": "https://www.drupal.org/project/drupal", "license": "GPL-2.0-or-later", "require": { - "php": ">=8.1.0", + "php": ">=8.3.0", "symfony/validator": "^6.4" }, "autoload": { diff --git a/core/lib/Drupal/Component/ProxyBuilder/composer.json b/core/lib/Drupal/Component/ProxyBuilder/composer.json index 68b9be598cd89bd1749f808431d5c0fe864832c8..1359626f2ccbcb8050300a02dfce85a596d8e4f2 100644 --- a/core/lib/Drupal/Component/ProxyBuilder/composer.json +++ b/core/lib/Drupal/Component/ProxyBuilder/composer.json @@ -8,7 +8,7 @@ "homepage": "https://www.drupal.org/project/drupal", "license": "GPL-2.0-or-later", "require": { - "php": ">=8.1.0" + "php": ">=8.3.0" }, "autoload": { "psr-4": { diff --git a/core/lib/Drupal/Component/Render/composer.json b/core/lib/Drupal/Component/Render/composer.json index 338eb5135b2b8798493ed4c551ef5d4a8963d00e..83a3bf936a3c0046f4deaec078476b0db00a1a6a 100644 --- a/core/lib/Drupal/Component/Render/composer.json +++ b/core/lib/Drupal/Component/Render/composer.json @@ -7,7 +7,7 @@ "homepage": "https://www.drupal.org/project/drupal", "license": "GPL-2.0-or-later", "require": { - "php": ">=8.1.0", + "php": ">=8.3.0", "drupal/core-utility": "11.x-dev" }, "autoload": { diff --git a/core/lib/Drupal/Component/Serialization/composer.json b/core/lib/Drupal/Component/Serialization/composer.json index 60e1c028bb9b5486d9d8af23301a6026595bb1a0..f000d6892b392960ddc8cf0ca2a52033d26149e2 100644 --- a/core/lib/Drupal/Component/Serialization/composer.json +++ b/core/lib/Drupal/Component/Serialization/composer.json @@ -7,7 +7,7 @@ "homepage": "https://www.drupal.org/project/drupal", "license": "GPL-2.0-or-later", "require": { - "php": ">=8.1.0", + "php": ">=8.3.0", "symfony/yaml": "^6.4" }, "autoload": { diff --git a/core/lib/Drupal/Component/Transliteration/composer.json b/core/lib/Drupal/Component/Transliteration/composer.json index 7e42ba488ab7d52cec39c760276d4c9c9fa0df7a..165fc69d99c4023fa9dcf46e50f01f177015ddda 100644 --- a/core/lib/Drupal/Component/Transliteration/composer.json +++ b/core/lib/Drupal/Component/Transliteration/composer.json @@ -18,6 +18,6 @@ ] }, "require": { - "php": ">=8.1.0" + "php": ">=8.3.0" } } diff --git a/core/lib/Drupal/Component/Utility/composer.json b/core/lib/Drupal/Component/Utility/composer.json index f20959e228f865c125e2115b4d1adcc86449b3bd..bde91afb9ea5d4413fb6fab6ae6c97dbf89cd58a 100644 --- a/core/lib/Drupal/Component/Utility/composer.json +++ b/core/lib/Drupal/Component/Utility/composer.json @@ -7,7 +7,7 @@ "homepage": "https://www.drupal.org/project/drupal", "license": "GPL-2.0-or-later", "require": { - "php": ">=8.1.0", + "php": ">=8.3.0", "masterminds/html5": "^2.7" }, "autoload": { diff --git a/core/lib/Drupal/Component/Uuid/composer.json b/core/lib/Drupal/Component/Uuid/composer.json index 0e021a23c446c0a03e56e1c063cb374f3db043ca..1b1d5ea2e25afa900abaaeba4569693ce2cfb6b2 100644 --- a/core/lib/Drupal/Component/Uuid/composer.json +++ b/core/lib/Drupal/Component/Uuid/composer.json @@ -8,7 +8,7 @@ "source": "https://www.drupal.org/project/drupal/git-instructions" }, "require": { - "php": ">=8.1.0" + "php": ">=8.3.0" }, "autoload": { "psr-4": { diff --git a/core/lib/Drupal/Component/Version/composer.json b/core/lib/Drupal/Component/Version/composer.json index d7785a3a49ab801037f04011c2b5c764e2fc253d..221f2eb1b02742b1a34e10dcaad2a99a143476bc 100644 --- a/core/lib/Drupal/Component/Version/composer.json +++ b/core/lib/Drupal/Component/Version/composer.json @@ -7,7 +7,7 @@ "homepage": "https://www.drupal.org/project/drupal", "license": "GPL-2.0-or-later", "require": { - "php": ">=8.1.0" + "php": ">=8.3.0" }, "autoload": { "psr-4": { diff --git a/core/lib/Drupal/Core/Utility/PhpRequirements.php b/core/lib/Drupal/Core/Utility/PhpRequirements.php index e80882b0bec0409d0842df30818a112250674159..3e5818dd4a16a751f09dc7e9af0811b38b41c84c 100644 --- a/core/lib/Drupal/Core/Utility/PhpRequirements.php +++ b/core/lib/Drupal/Core/Utility/PhpRequirements.php @@ -31,8 +31,6 @@ final class PhpRequirements { * by the PHP version. */ private static $phpEolDates = [ - '8.1' => '2024-11-25', - '8.2' => '2025-12-08', '8.3' => '2026-11-23', ]; diff --git a/core/modules/system/system.install b/core/modules/system/system.install index 26cc2577742486e23ed865c643d9adf1861143c3..e4d6cd07ba835d37ccb0bd98895c84e7eb19f445 100644 --- a/core/modules/system/system.install +++ b/core/modules/system/system.install @@ -327,19 +327,6 @@ function system_requirements($phase) { elseif ($phase === 'runtime' && version_compare($phpversion, \Drupal::RECOMMENDED_PHP) < 0) { $requirements['php']['description'] = t('It is recommended to upgrade to PHP version %recommended or higher for the best ongoing support. See <a href="http://php.net/supported-versions.php">PHP\'s version support documentation</a> and the <a href=":php_requirements">Drupal PHP requirements</a> page for more information.', ['%recommended' => \Drupal::RECOMMENDED_PHP, ':php_requirements' => 'https://www.drupal.org/docs/system-requirements/php-requirements']); $requirements['php']['severity'] = REQUIREMENT_INFO; - - // PHP 8.1.0 through 8.1.5 have a known OPcache bug that can cause fatal - // errors, so warn about that when running Drupal on those versions. - // @todo Remove this when \Drupal::MINIMUM_PHP is at least 8.1.6 in - // https://www.drupal.org/i/3305726. - if (version_compare($phpversion, '8.1.6') < 0) { - $requirements['php']['description'] = t('PHP %version has <a href=":bug_url">an OPcache bug that can cause fatal errors with class autoloading</a>. This can be fixed by upgrading to PHP 8.1.6 or later. See <a href="http://php.net/supported-versions.php">PHP\'s version support documentation</a> and the <a href=":php_requirements">Drupal PHP requirements</a> page for more information.', [ - '%version' => $phpversion, - ':bug_url' => 'https://github.com/php/php-src/issues/8164', - ':php_requirements' => 'https://www.drupal.org/docs/system-requirements/php-requirements', - ]); - $requirements['php']['severity'] = REQUIREMENT_WARNING; - } } // Test for PHP extensions. diff --git a/core/modules/system/tests/src/Functional/System/PhpRequirementTest.php b/core/modules/system/tests/src/Functional/System/PhpRequirementTest.php index 1cd07dd7e73a4a3f62198f36b54855751fa1478b..497d6d2a1a6e4b0401301b6294a8dd26f2a8d009 100644 --- a/core/modules/system/tests/src/Functional/System/PhpRequirementTest.php +++ b/core/modules/system/tests/src/Functional/System/PhpRequirementTest.php @@ -74,17 +74,7 @@ public function testStatusPage() { // There should be an informational message if the PHP version is below the // recommended version. if (version_compare($phpversion, \Drupal::RECOMMENDED_PHP) < 0) { - // If it's possible to run Drupal on PHP 8.1.0 to 8.1.5, warn about a - // bug in OPcache. - // @todo Remove this when \Drupal::MINIMUM_PHP is at least 8.1.6 in - // https://www.drupal.org/i/3305726. - if (version_compare($phpversion, '8.1.6') < 0) { - $this->assertSession()->pageTextContains("PHP $phpversion has an OPcache bug that can cause fatal errors with class autoloading. This can be fixed by upgrading to PHP 8.1.6 or later."); - $this->assertSession()->linkExists('an OPcache bug that can cause fatal errors with class autoloading'); - } - else { - $this->assertSession()->pageTextContains('It is recommended to upgrade to PHP version ' . \Drupal::RECOMMENDED_PHP . ' or higher'); - } + $this->assertSession()->pageTextContains('It is recommended to upgrade to PHP version ' . \Drupal::RECOMMENDED_PHP . ' or higher'); } // Otherwise, the message should not be there. else {