Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Increase PHP version requirement to 8.2 #1506

Closed
wants to merge 5 commits into from
Closed

Conversation

pjcdawkins
Copy link
Collaborator

@pjcdawkins pjcdawkins commented Nov 24, 2024

This would need a major version increase.

Backwards compatibility is very important to this project. But this is now a good time for a PHP version requirement increase.

Rationale:

  • The newer installation method via the static binary (Go wrapper) has been available for more than a year. This uses its own embedded PHP, currently 8.2 (though it could easily be updated to later versions).
  • The legacy installer will continue to work on lower PHP versions, because it filters out incompatible CLI versions.
  • PHP 8.1 reached EOL a year ago.
  • PHP 7.4 reached EOL three years ago.
  • Major PHP frameworks require PHP 8.2, including Symfony, Laravel, and Adobe Commerce. Drupal 10 requires 8.1 and Drupal 11 requires 8.3.
  • Metrics on CLI use vary, but in general they show widespread PHP 8.2 and 8.3 adoption (and some PHP 8.4).
  • Some CLI dependencies report critical security issues. The issues do not affect this project directly, but others could occur in future. They could only be resolved by upgrading to versions that themselves have PHP >8 requirements, for example Guzzle >5.
  • Maintenance and testing by now would be significantly easier without needing to support older PHP versions. For example, public CI images are typically only available with newer versions.

This PR simply updates the PHP requirement. See the (much larger) pull requests #1507 for ugprading Guzzle and #1514 for upgrading Symfony.

@pjcdawkins pjcdawkins force-pushed the upgrade-php-8 branch 2 times, most recently from 0868be4 to 0d16efd Compare November 24, 2024 09:41
@pjcdawkins pjcdawkins force-pushed the upgrade-php-8 branch 3 times, most recently from 60e488e to de6cf13 Compare December 3, 2024 23:25
@pjcdawkins
Copy link
Collaborator Author

pjcdawkins commented Dec 6, 2024

@akalipetis as far as I can see the main blocker here is version numbers, we should probably increase the major version to reflect the backwards compatibility break, but version 5.x has kind of been 'claimed' by the Go CLI. I think the options are:

  1. We keep the legacy CLI on 4.x and just increment the minor version (i.e. v4.22.0 requires PHP 5.6 then v4.23.0 requires PHP 8.2). I think this should only practically upset those who are installing it with some very custom method, using neither the Phar system nor Composer (since those both verify the PHP version requirement and restrict upgrade accordingly). However, this feels uncivil, given the significance of the change (PHP 5 to 8, Symfony 3 to 7, 10K lines of code, etc).
  2. We keep the version numbers going in an independent, semver way, in both platformsh/cli and platformsh/legacy-cli - which means they'll look similar but confusingly different (e.g. wrapper 5.1.0 embedding legacy 5.0.0).
  3. We rewrite the legacy CLI's version number to something completely different, though still quasi-semver, like 100.0.0.

@pjcdawkins pjcdawkins marked this pull request as ready for review December 6, 2024 16:53
@pjcdawkins pjcdawkins force-pushed the upgrade-php-8 branch 3 times, most recently from 67cd944 to 6bfa2b6 Compare December 16, 2024 11:45
@pjcdawkins pjcdawkins force-pushed the upgrade-php-8 branch 2 times, most recently from 96d61da to a1704bf Compare December 16, 2024 16:10
@pjcdawkins
Copy link
Collaborator Author

This is now part of branch 5.x
https://github.com/platformsh/legacy-cli/tree/5.x

@pjcdawkins pjcdawkins closed this Dec 27, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant