'mbstring', 'xml_parser_create' => 'xml', 'ctype_digit' => 'ctype', 'json_decode' => 'json', 'iconv' => 'iconv', 'mime_content_type' => 'fileinfo', 'intl_is_failure' => 'intl', ); /** * @var string The format used for errors. One of "text" or "html" */ var $format = 'text'; /** * @var string */ var $scriptPath = '/'; /** * Set the format used for errors. * * @param string $format One of "text" or "html" */ function setFormat( $format ) { $this->format = $format; } /** * Set the script path used for images in HTML-formatted errors. * * @param string $scriptPath */ function setScriptPath( $scriptPath ) { $this->scriptPath = $scriptPath; } /** * Displays an error, if the installed PHP version does not meet the minimum requirement. */ function checkRequiredPHPVersion() { $minimumVersion = '7.2.22'; /** * This is a list of known-bad ranges of PHP versions. Syntax is like SemVer – either: * * - '1.2.3' to prohibit a single version of PHP, or * - '1.2.3 – 1.2.5' to block a range, inclusive. * * Whitespace will be ignored. * * The key is not shown to users; use it to prompt future developers as to why this was * chosen, ideally one or more Phabricator task references. * * Remember to drop irrelevant ranges when bumping $minimumVersion. */ $knownBad = array( 'CVE-2019-11048' => '7.3.0 - 7.3.18', ); $passes = version_compare( PHP_VERSION, $minimumVersion, '>=' ); $versionString = "PHP $minimumVersion or higher"; // Left as a programmatic check to make it easier to update. if ( count( $knownBad ) ) { $versionString .= ' (and not ' . implode( ', ', array_values( $knownBad ) ) . ')'; foreach ( $knownBad as $task => $range ) { // As we don't have composer at this point, we have to do our own version range checking. if ( strpos( $range, '-' ) ) { $passes = $passes && !( version_compare( PHP_VERSION, trim( strstr( $range, '-', true ) ), '>=' ) && version_compare( PHP_VERSION, trim( substr( strstr( $range, '-', false ), 1 ) ), '<' ) ); } else { $passes = $passes && version_compare( PHP_VERSION, trim( $range ), '<>' ); } } } if ( !$passes ) { $cliText = "Error: You are using an unsupported PHP version (PHP " . PHP_VERSION . ").\n" . "MediaWiki $this->mwVersion needs $versionString.\n\nCheck if you might have a newer " . "PHP executable with a different name.\n\n"; $web = array(); $web['intro'] = "MediaWiki $this->mwVersion requires $versionString; you are using PHP " . PHP_VERSION . "."; $web['longTitle'] = "Supported PHP versions"; // phpcs:disable Generic.Files.LineLength $web['longHtml'] = << Please consider upgrading your copy of PHP. PHP versions less than v7.3.0 are no longer supported by the PHP Group and will not receive security or bugfix updates.
If for some reason you are unable to upgrade your PHP version, you will need to download an older version of MediaWiki from our website. See our compatibility page for details of which versions are compatible with prior versions of PHP.
HTML; // phpcs:enable Generic.Files.LineLength $this->triggerError( $web, $cliText ); } } /** * Displays an error, if the vendor/autoload.php file could not be found. */ function checkVendorExistence() { if ( !file_exists( dirname( __FILE__ ) . '/../vendor/autoload.php' ) ) { $cliText = "Error: You are missing some external dependencies. \n" . "MediaWiki also has some external dependencies that need to be installed\n" . "via composer or from a separate git repo. Please see\n" . "https://www.mediawiki.org/wiki/Download_from_Git#Fetch_external_libraries\n" . "for help on installing the required components."; $web = array(); $web['intro'] = "Installing some external dependencies (e.g. via composer) is required."; $web['longTitle'] = 'External dependencies'; // phpcs:disable Generic.Files.LineLength $web['longHtml'] = << MediaWiki also has some external dependencies that need to be installed via composer or from a separate git repo. Please see mediawiki.org for help on installing the required components. HTML; // phpcs:enable Generic.Files.LineLength $this->triggerError( $web, $cliText ); } } /** * Displays an error, if a PHP extension does not exist. */ function checkExtensionExistence() { $missingExtensions = array(); foreach ( $this->functionsExtensionsMapping as $function => $extension ) { if ( !function_exists( $function ) ) { $missingExtensions[] = $extension; } } if ( $missingExtensions ) { $missingExtText = ''; $missingExtHtml = ''; $baseUrl = 'https://www.php.net'; foreach ( $missingExtensions as $ext ) { $missingExtText .= " * $ext <$baseUrl/$ext>\n"; $missingExtHtml .= "{$introHtml}