From 3b59fe2c48c2b9eacce5157de014d8b1e4a35690 Mon Sep 17 00:00:00 2001 From: Paul-Henri Froidmont Date: Fri, 3 Mar 2023 16:41:06 +0100 Subject: [PATCH] php: support old php versions --- flake.lock | 17 +++++++++ flake.nix | 3 ++ .../php/builders/granular-php/default.nix | 35 +++++++++++-------- .../php/builders/simple-php/default.nix | 35 +++++++++++-------- 4 files changed, 60 insertions(+), 30 deletions(-) diff --git a/flake.lock b/flake.lock index 04b613b8f9..7fce855751 100644 --- a/flake.lock +++ b/flake.lock @@ -222,6 +222,22 @@ "type": "indirect" } }, + "phps": { + "flake": false, + "locked": { + "lastModified": 1677386056, + "narHash": "sha256-7zjqCeKW7YWjqR6EsUOqd2JzyCioYGVbbqmTgHTytBs=", + "owner": "fossar", + "repo": "nix-phps", + "rev": "98c16af0f9c329de8d62ef4817a5356c7685fffb", + "type": "github" + }, + "original": { + "owner": "fossar", + "repo": "nix-phps", + "type": "github" + } + }, "poetry2nix": { "flake": false, "locked": { @@ -292,6 +308,7 @@ "mach-nix": "mach-nix", "nix-pypi-fetcher": "nix-pypi-fetcher", "nixpkgs": "nixpkgs", + "phps": "phps", "poetry2nix": "poetry2nix", "pre-commit-hooks": "pre-commit-hooks", "pruned-racket-catalog": "pruned-racket-catalog" diff --git a/flake.nix b/flake.nix index f22fab920f..3b3b72e707 100644 --- a/flake.nix +++ b/flake.nix @@ -73,6 +73,9 @@ url = "github:nix-community/pruned-racket-catalog/catalog"; flake = false; }; + + # required for old PHP versions + phps.url = "github:fossar/nix-phps"; }; outputs = { diff --git a/src/subsystems/php/builders/granular-php/default.nix b/src/subsystems/php/builders/granular-php/default.nix index f37619bd56..5735f58d34 100644 --- a/src/subsystems/php/builders/granular-php/default.nix +++ b/src/subsystems/php/builders/granular-php/default.nix @@ -2,6 +2,7 @@ lib, pkgs, externals, + inputs, ... }: { type = "pure"; @@ -36,26 +37,30 @@ inherit (pkgs.callPackage ../../semver.nix {}) satisfies; - # php with required extensions - php = - if satisfies pkgs.php81.version subsystemAttrs.phpSemver + phpPackages = l.attrValues inputs.phps.packages.x86_64-linux; + phpPackage = let + matchingVersions = l.filter (phpAttrs: satisfies phpAttrs.version subsystemAttrs.phpSemver) phpPackages; + in + if matchingVersions == [] then - pkgs.php81.withExtensions ( - { - all, - enabled, - }: - l.unique (enabled - ++ (l.attrValues (l.filterAttrs (e: _: l.elem e subsystemAttrs.phpExtensions) all))) - ) - else l.abort '' Error: incompatible php versions. Package "${defaultPackageName}" defines required php version: "php": "${subsystemAttrs.phpSemver}" - Using php version "${pkgs.php81.version}" from attribute "pkgs.php81". - ''; - composer = php.packages.composer; + No matching php version was found in known versions: ${toString (l.map (attrs: attrs.version) phpPackages)}. + '' + else l.head matchingVersions; + + # php with required extensions + php = phpPackage.withExtensions ( + { + all, + enabled, + }: + l.unique (enabled + ++ (l.attrValues (l.filterAttrs (e: _: l.elem e subsystemAttrs.phpExtensions) all))) + ); + composer = phpPackage.packages.composer; # packages to export packages = diff --git a/src/subsystems/php/builders/simple-php/default.nix b/src/subsystems/php/builders/simple-php/default.nix index 64923fdfd4..295af930d3 100644 --- a/src/subsystems/php/builders/simple-php/default.nix +++ b/src/subsystems/php/builders/simple-php/default.nix @@ -2,6 +2,7 @@ lib, pkgs, externals, + inputs, ... }: { type = "pure"; @@ -36,26 +37,30 @@ inherit (pkgs.callPackage ../../semver.nix {}) satisfies; - # php with required extensions - php = - if satisfies pkgs.php81.version subsystemAttrs.phpSemver + phpPackages = l.attrValues inputs.phps.packages.x86_64-linux; + phpPackage = let + matchingVersions = l.filter (phpAttrs: satisfies phpAttrs.version subsystemAttrs.phpSemver) phpPackages; + in + if matchingVersions == [] then - pkgs.php81.withExtensions ( - { - all, - enabled, - }: - l.unique (enabled - ++ (l.attrValues (l.filterAttrs (e: _: l.elem e subsystemAttrs.phpExtensions) all))) - ) - else l.abort '' Error: incompatible php versions. Package "${defaultPackageName}" defines required php version: "php": "${subsystemAttrs.phpSemver}" - Using php version "${pkgs.php81.version}" from attribute "pkgs.php81". - ''; - composer = php.packages.composer; + No matching php version was found in known versions: ${toString (l.map (attrs: attrs.version) phpPackages)}. + '' + else l.head matchingVersions; + + # php with required extensions + php = phpPackage.withExtensions ( + { + all, + enabled, + }: + l.unique (enabled + ++ (l.attrValues (l.filterAttrs (e: _: l.elem e subsystemAttrs.phpExtensions) all))) + ); + composer = phpPackage.packages.composer; # packages to export packages =