summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorElis Hirwing <elis@hirwing.se>2020-10-14 17:46:02 +0200
committerGitHub <noreply@github.com>2020-10-14 17:46:02 +0200
commit90a7b7672cc2264b23cde7dc5273a532f1fb487b (patch)
tree70904b2348f7e345af22d5014cf7f51643282339
parent89a166e0f994c87a5c868b1c22a2aa9ad5452d23 (diff)
parent7557bf0ca7fc500d5b26a674702fcfb2f782a20b (diff)
Merge pull request #100341 from etu/php-move-extension-derivations-to-separate-dirs
php: move extension derivations to separate dirs
-rw-r--r--.github/CODEOWNERS1
-rw-r--r--pkgs/development/php-packages/apcu/default.nix17
-rw-r--r--pkgs/development/php-packages/apcu_bc/default.nix18
-rw-r--r--pkgs/development/php-packages/ast/default.nix10
-rw-r--r--pkgs/development/php-packages/couchbase/default.nix48
-rw-r--r--pkgs/development/php-packages/event/default.nix36
-rw-r--r--pkgs/development/php-packages/igbinary/default.nix14
-rw-r--r--pkgs/development/php-packages/imagick/default.nix14
-rw-r--r--pkgs/development/php-packages/mailparse/default.nix15
-rw-r--r--pkgs/development/php-packages/maxminddb/default.nix24
-rw-r--r--pkgs/development/php-packages/memcached/default.nix30
-rw-r--r--pkgs/development/php-packages/mongodb/default.nix20
-rw-r--r--pkgs/development/php-packages/oci8/default.nix17
-rw-r--r--pkgs/development/php-packages/pcov/default.nix12
-rw-r--r--pkgs/development/php-packages/pdo_sqlsrv/default.nix14
-rw-r--r--pkgs/development/php-packages/php_excel/default.nix24
-rw-r--r--pkgs/development/php-packages/phpmd/default.nix4
-rw-r--r--pkgs/development/php-packages/pinba/default.nix32
-rw-r--r--pkgs/development/php-packages/protobuf/default.nix19
-rw-r--r--pkgs/development/php-packages/pthreads/default.nix28
-rw-r--r--pkgs/development/php-packages/rdkafka/default.nix21
-rw-r--r--pkgs/development/php-packages/redis/default.nix17
-rw-r--r--pkgs/development/php-packages/sqlsrv/default.nix16
-rw-r--r--pkgs/development/php-packages/xdebug/default.nix15
-rw-r--r--pkgs/development/php-packages/yaml/default.nix14
-rw-r--r--pkgs/top-level/php-packages.nix437
26 files changed, 505 insertions, 412 deletions
diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS
index 556dcd770ca6..17777b058728 100644
--- a/.github/CODEOWNERS
+++ b/.github/CODEOWNERS
@@ -192,6 +192,7 @@
/nixos/tests/php @NixOS/php
/pkgs/build-support/build-pecl.nix @NixOS/php
/pkgs/development/interpreters/php @NixOS/php
+/pkgs/development/php-packages @NixOS/php
/pkgs/top-level/php-packages.nix @NixOS/php
# Podman, CRI-O modules and related
diff --git a/pkgs/development/php-packages/apcu/default.nix b/pkgs/development/php-packages/apcu/default.nix
new file mode 100644
index 000000000000..fab4f534d439
--- /dev/null
+++ b/pkgs/development/php-packages/apcu/default.nix
@@ -0,0 +1,17 @@
+{ buildPecl, lib, pcre' }:
+
+buildPecl {
+ pname = "apcu";
+
+ version = "5.1.18";
+ sha256 = "0ayykd4hfvdzk7qnr5k6yq5scwf6rb2i05xscfv76q5dmkkynvfl";
+
+ buildInputs = [ pcre' ];
+ doCheck = true;
+ checkTarget = "test";
+ checkFlagsArray = [ "REPORT_EXIT_STATUS=1" "NO_INTERACTION=1" ];
+ makeFlags = [ "phpincludedir=$(dev)/include" ];
+ outputs = [ "out" "dev" ];
+
+ meta.maintainers = lib.teams.php.members;
+}
diff --git a/pkgs/development/php-packages/apcu_bc/default.nix b/pkgs/development/php-packages/apcu_bc/default.nix
new file mode 100644
index 000000000000..132a25a2df4c
--- /dev/null
+++ b/pkgs/development/php-packages/apcu_bc/default.nix
@@ -0,0 +1,18 @@
+{ buildPecl, lib, pcre', php }:
+
+buildPecl {
+ pname = "apcu_bc";
+
+ version = "1.0.5";
+ sha256 = "0ma00syhk2ps9k9p02jz7rii6x3i2p986il23703zz5npd6y9n20";
+
+ peclDeps = [ php.extensions.apcu ];
+
+ buildInputs = [ pcre' ];
+
+ postInstall = ''
+ mv $out/lib/php/extensions/apc.so $out/lib/php/extensions/apcu_bc.so
+ '';
+
+ meta.maintainers = lib.teams.php.members;
+}
diff --git a/pkgs/development/php-packages/ast/default.nix b/pkgs/development/php-packages/ast/default.nix
new file mode 100644
index 000000000000..9df099734aa7
--- /dev/null
+++ b/pkgs/development/php-packages/ast/default.nix
@@ -0,0 +1,10 @@
+{ buildPecl, lib }:
+
+buildPecl {
+ pname = "ast";
+
+ version = "1.0.5";
+ sha256 = "16c5isldm4csjbcvz1qk2mmrhgvh24sxsp6w6f5a37xpa3vciawp";
+
+ meta.maintainers = lib.teams.php.members;
+}
diff --git a/pkgs/development/php-packages/couchbase/default.nix b/pkgs/development/php-packages/couchbase/default.nix
new file mode 100644
index 000000000000..a46bbea817a8
--- /dev/null
+++ b/pkgs/development/php-packages/couchbase/default.nix
@@ -0,0 +1,48 @@
+{ buildPecl, lib, pkgs, php }:
+let
+ pname = "couchbase";
+ version = "2.6.1";
+in
+buildPecl {
+ inherit pname version;
+
+ src = pkgs.fetchFromGitHub {
+ owner = "couchbase";
+ repo = "php-couchbase";
+ rev = "v${version}";
+ sha256 = "0jdzgcvab1vpxai23brmmvizjjq2d2dik9aklz6bzspfb512qjd6";
+ };
+
+ configureFlags = [ "--with-couchbase" ];
+
+ buildInputs = with pkgs; [ libcouchbase zlib ];
+ internalDeps = [ php.extensions.json ];
+ peclDeps = [ php.extensions.igbinary ];
+
+ patches = [
+ (pkgs.writeText "php-couchbase.patch" ''
+ --- a/config.m4
+ +++ b/config.m4
+ @@ -9,7 +9,7 @@ if test "$PHP_COUCHBASE" != "no"; then
+ LIBCOUCHBASE_DIR=$PHP_COUCHBASE
+ else
+ AC_MSG_CHECKING(for libcouchbase in default path)
+ - for i in /usr/local /usr; do
+ + for i in ${pkgs.libcouchbase}; do
+ if test -r $i/include/libcouchbase/couchbase.h; then
+ LIBCOUCHBASE_DIR=$i
+ AC_MSG_RESULT(found in $i)
+ @@ -154,6 +154,8 @@ COUCHBASE_FILES=" \
+ igbinary_inc_path="$phpincludedir"
+ elif test -f "$phpincludedir/ext/igbinary/igbinary.h"; then
+ igbinary_inc_path="$phpincludedir"
+ + elif test -f "${php.extensions.igbinary.dev}/include/ext/igbinary/igbinary.h"; then
+ + igbinary_inc_path="${php.extensions.igbinary.dev}/include"
+ fi
+ if test "$igbinary_inc_path" = ""; then
+ AC_MSG_WARN([Cannot find igbinary.h])
+ '')
+ ];
+
+ meta.maintainers = lib.teams.php.members;
+}
diff --git a/pkgs/development/php-packages/event/default.nix b/pkgs/development/php-packages/event/default.nix
new file mode 100644
index 000000000000..bf90d680c499
--- /dev/null
+++ b/pkgs/development/php-packages/event/default.nix
@@ -0,0 +1,36 @@
+{ buildPecl, lib, pkgs, php }:
+let
+in
+buildPecl {
+ pname = "event";
+
+ version = "2.5.3";
+ sha256 = "12liry5ldvgwp1v1a6zgfq8w6iyyxmsdj4c71bp157nnf58cb8hb";
+
+ configureFlags = [
+ "--with-event-libevent-dir=${pkgs.libevent.dev}"
+ "--with-event-core"
+ "--with-event-extra"
+ "--with-event-pthreads"
+ ];
+
+ postPhpize = ''
+ substituteInPlace configure --replace \
+ 'as_fn_error $? "Couldn'\'''t find $phpincludedir/sockets/php_sockets.h. Please check if sockets extension installed" "$LINENO" 5' \
+ ':'
+ '';
+
+ nativeBuildInputs = [ pkgs.pkgconfig ];
+ buildInputs = with pkgs; [ openssl libevent ];
+ internalDeps = [ php.extensions.sockets ];
+
+ meta = with pkgs.lib; {
+ description = ''
+ This is an extension to efficiently schedule I/O, time and signal based
+ events using the best I/O notification mechanism available for specific platform.
+ '';
+ license = licenses.php301;
+ homepage = "https://bitbucket.org/osmanov/pecl-event/";
+ maintainers = teams.php.members;
+ };
+}
diff --git a/pkgs/development/php-packages/igbinary/default.nix b/pkgs/development/php-packages/igbinary/default.nix
new file mode 100644
index 000000000000..e9c6de2e5b06
--- /dev/null
+++ b/pkgs/development/php-packages/igbinary/default.nix
@@ -0,0 +1,14 @@
+{ buildPecl, lib }:
+
+buildPecl {
+ pname = "igbinary";
+
+ version = "3.0.1";
+ sha256 = "1w8jmf1qpggdvq0ndfi86n7i7cqgh1s8q6hys2lijvi37rzn0nar";
+
+ configureFlags = [ "--enable-igbinary" ];
+ makeFlags = [ "phpincludedir=$(dev)/include" ];
+ outputs = [ "out" "dev" ];
+
+ meta.maintainers = lib.teams.php.members;
+}
diff --git a/pkgs/development/php-packages/imagick/default.nix b/pkgs/development/php-packages/imagick/default.nix
new file mode 100644
index 000000000000..63524fb2d068
--- /dev/null
+++ b/pkgs/development/php-packages/imagick/default.nix
@@ -0,0 +1,14 @@
+{ buildPecl, lib, pkgs, pcre' }:
+
+buildPecl {
+ pname = "imagick";
+
+ version = "3.4.4";
+ sha256 = "0xvhaqny1v796ywx83w7jyjyd0nrxkxf34w9zi8qc8aw8qbammcd";
+
+ configureFlags = [ "--with-imagick=${pkgs.imagemagick.dev}" ];
+ nativeBuildInputs = [ pkgs.pkgconfig ];
+ buildInputs = [ pcre' ];
+
+ meta.maintainers = lib.teams.php.members;
+}
diff --git a/pkgs/development/php-packages/mailparse/default.nix b/pkgs/development/php-packages/mailparse/default.nix
new file mode 100644
index 000000000000..4ec6f77df45c
--- /dev/null
+++ b/pkgs/development/php-packages/mailparse/default.nix
@@ -0,0 +1,15 @@
+{ buildPecl, lib, php }:
+
+buildPecl {
+ pname = "mailparse";
+
+ version = "3.0.3";
+ sha256 = "00nk14jbdbln93mx3ag691avc11ff94hkadrcv5pn51c6ihsxbmz";
+
+ internalDeps = [ php.extensions.mbstring ];
+ postConfigure = ''
+ echo "#define HAVE_MBSTRING 1" >> config.h
+ '';
+
+ meta.maintainers = lib.teams.php.members;
+}
diff --git a/pkgs/development/php-packages/maxminddb/default.nix b/pkgs/development/php-packages/maxminddb/default.nix
new file mode 100644
index 000000000000..e3a9584db1c9
--- /dev/null
+++ b/pkgs/development/php-packages/maxminddb/default.nix
@@ -0,0 +1,24 @@
+{ buildPecl, lib, pkgs }:
+let
+ pname = "maxminddb";
+ version = "1.7.0";
+in
+buildPecl {
+ inherit pname version;
+
+ src = pkgs.fetchFromGitHub {
+ owner = "maxmind";
+ repo = "MaxMind-DB-Reader-php";
+ rev = "v${version}";
+ sha256 = "16msc9s15y43lxw89kj51aldlkd57dc8gms199i51jc984b68ljc";
+ };
+
+ buildInputs = [ pkgs.libmaxminddb ];
+ sourceRoot = "source/ext";
+
+ meta = with pkgs.lib; {
+ description = "C extension that is a drop-in replacement for MaxMind\\Db\\Reader";
+ license = with licenses; [ asl20 ];
+ maintainers = with maintainers; [ ajs124 das_j ] ++ teams.php.members;
+ };
+}
diff --git a/pkgs/development/php-packages/memcached/default.nix b/pkgs/development/php-packages/memcached/default.nix
new file mode 100644
index 000000000000..b2d9333f2949
--- /dev/null
+++ b/pkgs/development/php-packages/memcached/default.nix
@@ -0,0 +1,30 @@
+{ buildPecl, lib, fetchgit, php, pkgs }:
+let
+ pname = "memcached";
+ version = "3.1.5";
+in
+buildPecl {
+ inherit pname version;
+
+ src = fetchgit {
+ url = "https://github.com/php-memcached-dev/php-memcached";
+ rev = "v${version}";
+ sha256 = "01mbh2m3kfbdvih3c8g3g9h4vdd80r0i9g2z8b3lx3mi8mmcj380";
+ };
+
+ internalDeps = [
+ php.extensions.session
+ ] ++ lib.optionals (lib.versionOlder php.version "7.4") [
+ php.extensions.hash
+ ];
+
+ configureFlags = [
+ "--with-zlib-dir=${pkgs.zlib.dev}"
+ "--with-libmemcached-dir=${pkgs.libmemcached}"
+ ];
+
+ nativeBuildInputs = [ pkgs.pkgconfig ];
+ buildInputs = with pkgs; [ cyrus_sasl zlib ];
+
+ meta.maintainers = lib.teams.php.members;
+}
diff --git a/pkgs/development/php-packages/mongodb/default.nix b/pkgs/development/php-packages/mongodb/default.nix
new file mode 100644
index 000000000000..dd8fa9a6c2b0
--- /dev/null
+++ b/pkgs/development/php-packages/mongodb/default.nix
@@ -0,0 +1,20 @@
+{ buildPecl, lib, pkgs, pcre' }:
+
+buildPecl {
+ pname = "mongodb";
+
+ version = "1.6.1";
+ sha256 = "1j1w4n33347j9kwvxwsrix3gvjbiqcn1s5v59pp64s536cci8q0m";
+
+ nativeBuildInputs = [ pkgs.pkgconfig ];
+ buildInputs = with pkgs; [
+ cyrus_sasl
+ icu64
+ openssl
+ snappy
+ zlib
+ pcre'
+ ] ++ lib.optional (pkgs.stdenv.isDarwin) pkgs.darwin.apple_sdk.frameworks.Security;
+
+ meta.maintainers = lib.teams.php.members;
+}
diff --git a/pkgs/development/php-packages/oci8/default.nix b/pkgs/development/php-packages/oci8/default.nix
new file mode 100644
index 000000000000..ea699c2034e8
--- /dev/null
+++ b/pkgs/development/php-packages/oci8/default.nix
@@ -0,0 +1,17 @@
+{ buildPecl, lib, pkgs }:
+
+buildPecl {
+ pname = "oci8";
+
+ version = "2.2.0";
+ sha256 = "0jhivxj1nkkza4h23z33y7xhffii60d7dr51h1czjk10qywl7pyd";
+
+ buildInputs = [ pkgs.oracle-instantclient ];
+ configureFlags = [ "--with-oci8=shared,instantclient,${pkgs.oracle-instantclient.lib}/lib" ];
+
+ postPatch = ''
+ sed -i -e 's|OCISDKMANINC=`.*$|OCISDKMANINC="${pkgs.oracle-instantclient.dev}/include"|' config.m4
+ '';
+
+ meta.maintainers = lib.teams.php.members;
+}
diff --git a/pkgs/development/php-packages/pcov/default.nix b/pkgs/development/php-packages/pcov/default.nix
new file mode 100644
index 000000000000..84fbc4f7a469
--- /dev/null
+++ b/pkgs/development/php-packages/pcov/default.nix
@@ -0,0 +1,12 @@
+{ buildPecl, lib, pcre' }:
+
+buildPecl {
+ pname = "pcov";
+
+ version = "1.0.6";
+ sha256 = "1psfwscrc025z8mziq69pcx60k4fbkqa5g2ia8lplb94mmarj0v1";
+
+ buildInputs = [ pcre' ];
+
+ meta.maintainers = lib.teams.php.members;
+}
diff --git a/pkgs/development/php-packages/pdo_sqlsrv/default.nix b/pkgs/development/php-packages/pdo_sqlsrv/default.nix
new file mode 100644
index 000000000000..46da30248097
--- /dev/null
+++ b/pkgs/development/php-packages/pdo_sqlsrv/default.nix
@@ -0,0 +1,14 @@
+{ buildPecl, lib, pkgs, php }:
+
+buildPecl {
+ pname = "pdo_sqlsrv";
+
+ version = "5.8.1";
+ sha256 = "06ba4x34fgs092qq9w62y2afsm1nyasqiprirk4951ax9v5vcir0";
+
+ internalDeps = [ php.extensions.pdo ];
+
+ buildInputs = [ pkgs.unixODBC ] ++ pkgs.lib.optionals pkgs.stdenv.isDarwin [ pkgs.libiconv ];
+
+ meta.maintainers = lib.teams.php.members;
+}
diff --git a/pkgs/development/php-packages/php_excel/default.nix b/pkgs/development/php-packages/php_excel/default.nix
new file mode 100644
index 000000000000..ab6d193fcd4d
--- /dev/null
+++ b/pkgs/development/php-packages/php_excel/default.nix
@@ -0,0 +1,24 @@
+{ buildPecl, fetchurl, lib, pkgs }:
+let
+ pname = "php_excel";
+ phpVersion = "php7";
+ version = "1.0.2";
+in
+buildPecl {
+ inherit pname version;
+
+ src = fetchurl {
+ url = "https://github.com/iliaal/php_excel/releases/download/Excel-1.0.2-PHP7/excel-${version}-${phpVersion}.tgz";
+ sha256 = "0dpvih9gpiyh1ml22zi7hi6kslkilzby00z1p8x248idylldzs2n";
+ };
+
+ buildInputs = with pkgs; [ libxl ];
+
+ configureFlags = [
+ "--with-excel"
+ "--with-libxl-incdir=${pkgs.libxl}/include_c"
+ "--with-libxl-libdir=${pkgs.libxl}/lib"
+ ];
+
+ meta.maintainers = lib.teams.php.members;
+}
diff --git a/pkgs/development/php-packages/phpmd/default.nix b/pkgs/development/php-packages/phpmd/default.nix
index ffdb877d76ec..fd7390498ba3 100644
--- a/pkgs/development/php-packages/phpmd/default.nix
+++ b/pkgs/development/php-packages/phpmd/default.nix
@@ -1,7 +1,9 @@
-{ mkDerivation, fetchurl, pkgs, lib, php, isPhp74 }:
+{ mkDerivation, fetchurl, pkgs, lib, php }:
let
pname = "phpmd";
version = "2.8.2";
+
+ isPhp74 = lib.versionAtLeast php.version "7.4";
in
mkDerivation {
inherit pname version;
diff --git a/pkgs/development/php-packages/pinba/default.nix b/pkgs/development/php-packages/pinba/default.nix
new file mode 100644
index 000000000000..0880c2a46e21
--- /dev/null
+++ b/pkgs/development/php-packages/pinba/default.nix
@@ -0,0 +1,32 @@
+{ buildPecl, lib, fetchFromGitHub, php }:
+let
+ pname = "pinba";
+
+ isPhp73 = lib.versionAtLeast php.version "7.3";
+
+ version = if isPhp73 then "1.1.2-dev" else "1.1.1";
+
+ src = fetchFromGitHub ({
+ owner = "tony2001";
+ repo = "pinba_extension";
+ } // (if (isPhp73) then {
+ rev = "edbc313f1b4fb8407bf7d5acf63fbb0359c7fb2e";
+ sha256 = "02sljqm6griw8ccqavl23f7w1hp2zflcv24lpf00k6pyrn9cwx80";
+ } else {
+ rev = "RELEASE_1_1_1";
+ sha256 = "1kdp7vav0y315695vhm3xifgsh6h6y6pny70xw3iai461n58khj5";
+ }));
+in
+buildPecl {
+ inherit pname version src;
+
+ meta = with lib; {
+ description = "PHP extension for Pinba";
+ longDescription = ''
+ Pinba is a MySQL storage engine that acts as a realtime monitoring and
+ statistics server for PHP using MySQL as a read-only interface.
+ '';
+ homepage = "http://pinba.org/";
+ maintainers = teams.php.members;
+ };
+}
diff --git a/pkgs/development/php-packages/protobuf/default.nix b/pkgs/development/php-packages/protobuf/default.nix
new file mode 100644
index 000000000000..d577f8482831
--- /dev/null
+++ b/pkgs/development/php-packages/protobuf/default.nix
@@ -0,0 +1,19 @@
+{ buildPecl, lib, pcre' }:
+
+buildPecl {
+ pname = "protobuf";
+
+ version = "3.11.2";
+ sha256 = "0bhdykdyk58ywqj940zb7jyvrlgdr6hdb4s8kn79fz3p0i79l9hz";
+
+ buildInputs = [ pcre' ];
+
+ meta = with lib; {
+ description = ''
+ Google's language-neutral, platform-neutral, extensible mechanism for serializing structured data.
+ '';
+ license = licenses.bsd3;
+ homepage = "https://developers.google.com/protocol-buffers/";
+ maintainers = teams.php.members;
+ };
+}
diff --git a/pkgs/development/php-packages/pthreads/default.nix b/pkgs/development/php-packages/pthreads/default.nix
new file mode 100644
index 000000000000..31b32e82967d
--- /dev/null
+++ b/pkgs/development/php-packages/pthreads/default.nix
@@ -0,0 +1,28 @@
+{ buildPecl, lib, fetchFromGitHub, php, pcre' }:
+let
+ pname = "pthreads";
+
+ isPhp73 = lib.versionAtLeast php.version "7.3";
+ isPhp74 = lib.versionAtLeast php.version "7.4";
+
+ version = if isPhp73 then "3.2.0-dev" else "3.2.0";
+
+ src = fetchFromGitHub ({
+ owner = "krakjoe";
+ repo = "pthreads";
+ } // (if (isPhp73) then {
+ rev = "4d1c2483ceb459ea4284db4eb06646d5715e7154";
+ sha256 = "07kdxypy0bgggrfav2h1ccbv67lllbvpa3s3zsaqci0gq4fyi830";
+ } else {
+ rev = "v3.2.0";
+ sha256 = "17hypm75d4w7lvz96jb7s0s87018yzmmap0l125d5fd7abnhzfvv";
+ }));
+in
+buildPecl {
+ inherit pname version src;
+
+ buildInputs = [ pcre'.dev ];
+
+ meta.broken = isPhp74;
+ meta.maintainers = lib.teams.php.members;
+}
diff --git a/pkgs/development/php-packages/rdkafka/default.nix b/pkgs/development/php-packages/rdkafka/default.nix
new file mode 100644
index 000000000000..f96b18007693
--- /dev/null
+++ b/pkgs/development/php-packages/rdkafka/default.nix
@@ -0,0 +1,21 @@
+{ buildPecl, lib, pkgs, pcre' }:
+
+buildPecl {
+ pname = "rdkafka";
+
+ version = "4.0.3";
+ sha256 = "1g00p911raxcc7n2w9pzadxaggw5c564md6hjvqfs9ip550y5x16";
+
+ buildInputs = [ pkgs.rdkafka pcre' ];
+
+ postPhpize = ''
+ substituteInPlace configure \
+ --replace 'SEARCH_PATH="/usr/local /usr"' 'SEARCH_PATH=${pkgs.rdkafka}'
+ '';
+
+ meta = with lib; {
+ description = "Kafka client based on librdkafka";
+ homepage = "https://github.com/arnaud-lb/php-rdkafka";
+ maintainers = teams.php.members;
+ };
+}
diff --git a/pkgs/development/php-packages/redis/default.nix b/pkgs/development/php-packages/redis/default.nix
new file mode 100644
index 000000000000..6e322aecf2b8
--- /dev/null
+++ b/pkgs/development/php-packages/redis/default.nix
@@ -0,0 +1,17 @@
+{ buildPecl, lib, php }:
+
+buildPecl {
+ pname = "redis";
+
+ version = "5.1.1";
+ sha256 = "1041zv91fkda73w4c3pj6zdvwjgb3q7mxg6mwnq9gisl80mrs732";
+
+ internalDeps = with php.extensions; [
+ json
+ session
+ ] ++ lib.optionals (lib.versionOlder php.version "7.4") [
+ hash
+ ];
+
+ meta.maintainers = lib.teams.php.members;
+}
diff --git a/pkgs/development/php-packages/sqlsrv/default.nix b/pkgs/development/php-packages/sqlsrv/default.nix
new file mode 100644
index 000000000000..341152277cae
--- /dev/null
+++ b/pkgs/development/php-packages/sqlsrv/default.nix
@@ -0,0 +1,16 @@
+{ buildPecl, lib, pkgs }:
+
+buildPecl {
+ pname = "sqlsrv";
+
+ version = "5.8.1";
+ sha256 = "0c9a6ghch2537vi0274vx0mn6nb1xg2qv7nprnf3xdfqi5ww1i9r";
+
+ buildInputs = [
+ pkgs.unixODBC
+ ] ++ pkgs.lib.optionals pkgs.stdenv.isDarwin [
+ pkgs.libiconv
+ ];
+
+ meta.maintainers = lib.teams.php.members;
+}
diff --git a/pkgs/development/php-packages/xdebug/default.nix b/pkgs/development/php-packages/xdebug/default.nix
new file mode 100644
index 000000000000..731e0bc0baea
--- /dev/null
+++ b/pkgs/development/php-packages/xdebug/default.nix
@@ -0,0 +1,15 @@
+{ buildPecl, lib }:
+
+buildPecl {
+ pname = "xdebug";
+
+ version = "2.8.1";
+ sha256 = "080mwr7m72rf0jsig5074dgq2n86hhs7rdbfg6yvnm959sby72w3";
+
+ doCheck = true;
+ checkTarget = "test";
+
+ zendExtension = true;
+
+ meta.maintainers = lib.teams.php.members;
+}
diff --git a/pkgs/development/php-packages/yaml/default.nix b/pkgs/development/php-packages/yaml/default.nix
new file mode 100644
index 000000000000..8ce5c34757fc
--- /dev/null
+++ b/pkgs/development/php-packages/yaml/default.nix
@@ -0,0 +1,14 @@
+{ buildPecl, lib, pkgs }:
+
+buildPecl {
+ pname = "yaml";
+
+ version = "2.0.4";
+ sha256 = "1036zhc5yskdfymyk8jhwc34kvkvsn5kaf50336153v4dqwb11lp";
+
+ configureFlags = [ "--with-yaml=${pkgs.libyaml}" ];
+
+ nativeBuildInputs = [ pkgs.pkgconfig ];
+
+ meta.maintainers = lib.teams.php.members;
+}
diff --git a/pkgs/top-level/php-packages.nix b/pkgs/top-level/php-packages.nix
index be440a314774..d4518b60d24d 100644
--- a/pkgs/top-level/php-packages.nix
+++ b/pkgs/top-level/php-packages.nix
@@ -19,13 +19,10 @@ let
pname = "php-${pname}";
});
- isPhp73 = pkgs.lib.versionAtLeast php.version "7.3";
- isPhp74 = pkgs.lib.versionAtLeast php.version "7.4";
-
pcre' = if (lib.versionAtLeast php.version "7.3") then pcre2 else pcre;
callPackage = pkgs.newScope {
- inherit mkDerivation php isPhp73 isPhp74 buildPecl pcre';
+ inherit mkDerivation php buildPecl pcre';
};
in
{
@@ -62,264 +59,33 @@ in
# or php.withExtensions to extend the functionality of the PHP
# interpreter.
extensions = {
- apcu = buildPecl {
- version = "5.1.18";
- pname = "apcu";
-
- sha256 = "0ayykd4hfvdzk7qnr5k6yq5scwf6rb2i05xscfv76q5dmkkynvfl";
-
- buildInputs = [ pcre' ];
- doCheck = true;
- checkTarget = "test";
- checkFlagsArray = ["REPORT_EXIT_STATUS=1" "NO_INTERACTION=1"];
- makeFlags = [ "phpincludedir=$(dev)/include" ];
- outputs = [ "out" "dev" ];
-
- meta.maintainers = lib.teams.php.members;
- };
-
- apcu_bc = buildPecl {
- version = "1.0.5";
- pname = "apcu_bc";
-
- sha256 = "0ma00syhk2ps9k9p02jz7rii6x3i2p986il23703zz5npd6y9n20";
-
- peclDeps = [ php.extensions.apcu ];
+ apcu = callPackage ../development/php-packages/apcu { };
- buildInputs = [
- pcre'
- ];
-
- postInstall = ''
- mv $out/lib/php/extensions/apc.so $out/lib/php/extensions/apcu_bc.so
- '';
-
- meta.maintainers = lib.teams.php.members;
- };
-
- ast = buildPecl {
- version = "1.0.5";
- pname = "ast";
-
- sha256 = "16c5isldm4csjbcvz1qk2mmrhgvh24sxsp6w6f5a37xpa3vciawp";
+ apcu_bc = callPackage ../development/php-packages/apcu_bc { };
- meta.maintainers = lib.teams.php.members;
- };
+ ast = callPackage ../development/php-packages/ast { };
blackfire = pkgs.callPackage ../development/tools/misc/blackfire/php-probe.nix { inherit php; };
- couchbase = buildPecl rec {
- version = "2.6.1";
- pname = "couchbase";
+ couchbase = callPackage ../development/php-packages/couchbase { };
- src = pkgs.fetchFromGitHub {
- owner = "couchbase";
- repo = "php-couchbase";
- rev = "v${version}";
- sha256 = "0jdzgcvab1vpxai23brmmvizjjq2d2dik9aklz6bzspfb512qjd6";
- };
+ event = callPackage ../development/php-packages/event { };
- configureFlags = [ "--with-couchbase" ];
+ igbinary = callPackage ../development/php-packages/igbinary { };
- buildInputs = [
- pkgs.libcouchbase
- pkgs.zlib
- ];
- internalDeps = [ php.extensions.json ];
- peclDeps = [ php.extensions.igbinary ];
-
- patches = [
- (pkgs.writeText "php-couchbase.patch" ''
- --- a/config.m4
- +++ b/config.m4
- @@ -9,7 +9,7 @@ if test "$PHP_COUCHBASE" != "no"; then
- LIBCOUCHBASE_DIR=$PHP_COUCHBASE
- else
- AC_MSG_CHECKING(for libcouchbase in default path)
- - for i in /usr/local /usr; do
- + for i in ${pkgs.libcouchbase}; do
- if test -r $i/include/libcouchbase/couchbase.h; then
- LIBCOUCHBASE_DIR=$i
- AC_MSG_RESULT(found in $i)
- @@ -154,6 +154,8 @@ COUCHBASE_FILES=" \
- igbinary_inc_path="$phpincludedir"
- elif test -f "$phpincludedir/ext/igbinary/igbinary.h"; then
- igbinary_inc_path="$phpincludedir"
- + elif test -f "${php.extensions.igbinary.dev}/include/ext/igbinary/igbinary.h"; then
- + igbinary_inc_path="${php.extensions.igbinary.dev}/include"
- fi
- if test "$igbinary_inc_path" = ""; then
- AC_MSG_WARN([Cannot find igbinary.h])
- '')
- ];
-
- meta.maintainers = lib.teams.php.members;
- };
+ imagick = callPackage ../development/php-packages/imagick { };
- event = buildPecl {
- version = "2.5.3";
- pname = "event";
+ mailparse = callPackage ../development/php-packages/mailparse { };
- sha256 = "12liry5ldvgwp1v1a6zgfq8w6iyyxmsdj4c71bp157nnf58cb8hb";
+ maxminddb = callPackage ../development/php-packages/maxminddb { };
- configureFlags = [
- "--with-event-libevent-dir=${pkgs.libevent.dev}"
- "--with-event-core"
- "--with-event-extra"
- "--with-event-pthreads"
- ];
+ memcached = callPackage ../development/php-packages/memcached { };
- postPhpize = ''
- substituteInPlace configure --replace 'as_fn_error $? "Couldn'\'''t find $phpincludedir/sockets/php_sockets.h. Please check if sockets extension installed" "$LINENO" 5' \
- ':'
- '';
+ mongodb = callPackage ../development/php-packages/mongodb { };
- nativeBuildInputs = [ pkgs.pkgconfig ];
- buildInputs = with pkgs; [ openssl libevent ];
- internalDeps = [ php.extensions.sockets ];
+ oci8 = callPackage ../development/php-packages/oci8 { };
- meta = with pkgs.lib; {
- description = ''
- This is an extension to efficiently schedule I/O, time and signal based
- events using the best I/O notification mechanism available for specific platform.
- '';
- license = licenses.php301;
- homepage = "https://bitbucket.org/osmanov/pecl-event/";
- maintainers = teams.php.members;
- };
- };
-
- igbinary = buildPecl {
- version = "3.0.1";
- pname = "igbinary";
-
- sha256 = "1w8jmf1qpggdvq0ndfi86n7i7cqgh1s8q6hys2lijvi37rzn0nar";
-
- configureFlags = [ "--enable-igbinary" ];
- makeFlags = [ "phpincludedir=$(dev)/include" ];
- outputs = [ "out" "dev" ];
-
- meta.maintainers = lib.teams.php.members;
- };
-
- imagick = buildPecl {
- version = "3.4.4";
- pname = "imagick";
-
- sha256 = "0xvhaqny1v796ywx83w7jyjyd0nrxkxf34w9zi8qc8aw8qbammcd";
-
- configureFlags = [ "--with-imagick=${pkgs.imagemagick.dev}" ];
- nativeBuildInputs = [ pkgs.pkgconfig ];
- buildInputs = [ pcre' ];
-
- meta.maintainers = lib.teams.php.members;
- };
-
- mailparse = buildPecl {
- version = "3.0.3";
- pname = "mailparse";
- sha256 = "00nk14jbdbln93mx3ag691avc11ff94hkadrcv5pn51c6ihsxbmz";