From d15b114d16b446eea7113a982021c7b03c387b50 Mon Sep 17 00:00:00 2001 From: Remi Collet Date: Wed, 30 Aug 2017 11:21:43 +0200 Subject: PHP 7.2.0RC1 --- 10-opcache.ini | 5 +- 20-oci8.ini | 2 +- bug71914.patch | 192 --- failed.txt | 13 +- php-5.6.3-oci8conf.patch | 39 - php-7.0.0-fixheader.patch | 23 - php-7.0.0-includedir.patch | 11 - php-7.0.2-libdb.patch | 92 -- php-7.1.0-libdb.patch | 92 ++ php-7.1.0-systzdata-v14.patch | 677 --------- php-7.2.0-fixheader.patch | 15 + php-7.2.0-includedir.patch | 11 + php-7.2.0-oci8conf.patch | 35 + php-7.2.0-systzdata-v15.patch | 653 +++++++++ php-fpm.conf | 14 +- php-timelib.patch | 30 + php.conf | 2 +- php.conf2 | 2 +- php.ini | 45 +- php71.spec | 3085 ---------------------------------------- php72.spec | 3162 +++++++++++++++++++++++++++++++++++++++++ 21 files changed, 4027 insertions(+), 4173 deletions(-) delete mode 100644 bug71914.patch delete mode 100644 php-5.6.3-oci8conf.patch delete mode 100644 php-7.0.0-fixheader.patch delete mode 100644 php-7.0.0-includedir.patch delete mode 100644 php-7.0.2-libdb.patch create mode 100644 php-7.1.0-libdb.patch delete mode 100644 php-7.1.0-systzdata-v14.patch create mode 100644 php-7.2.0-fixheader.patch create mode 100644 php-7.2.0-includedir.patch create mode 100644 php-7.2.0-oci8conf.patch create mode 100644 php-7.2.0-systzdata-v15.patch create mode 100644 php-timelib.patch delete mode 100644 php71.spec create mode 100644 php72.spec diff --git a/10-opcache.ini b/10-opcache.ini index cd4c8fa..1bf3d2a 100644 --- a/10-opcache.ini +++ b/10-opcache.ini @@ -1,5 +1,5 @@ ; Enable Zend OPcache extension module -zend_extension=opcache.so +zend_extension=opcache ; Determines if Zend OPCache is enabled opcache.enable=1 @@ -14,7 +14,7 @@ opcache.memory_consumption=128 opcache.interned_strings_buffer=8 ; The maximum number of keys (scripts) in the OPcache hash table. -; Only numbers between 200 and 100000 are allowed. +; Only numbers between 200 and 1000000 are allowed. opcache.max_accelerated_files=4000 ; The maximum percentage of "wasted" memory until a restart is scheduled. @@ -43,6 +43,7 @@ opcache.max_accelerated_files=4000 ;opcache.save_comments=1 ; If enabled, a fast shutdown sequence is used for the accelerated code +; Depending on the used Memory Manager this may cause some incompatibilities. ;opcache.fast_shutdown=0 ; Allow file existence override (file_exists, etc.) performance feature. diff --git a/20-oci8.ini b/20-oci8.ini index f1fe49a..46e0668 100644 --- a/20-oci8.ini +++ b/20-oci8.ini @@ -1,5 +1,5 @@ ; Enable oci8 extension module -extension=oci8.so +extension=oci8 ; Connection: Enables privileged connections using external ; credentials (OCI_SYSOPER, OCI_SYSDBA) diff --git a/bug71914.patch b/bug71914.patch deleted file mode 100644 index f52389e..0000000 --- a/bug71914.patch +++ /dev/null @@ -1,192 +0,0 @@ -From 2e6d70787c93413daecbea529bf0f74fa901d1db Mon Sep 17 00:00:00 2001 -From: Xinchen Hui -Date: Tue, 29 Mar 2016 17:14:36 +0800 -Subject: [PATCH] Fixed bug #71914 (Reference is lost in "switch") - ---- - NEWS | 1 + - Zend/tests/bug71914.phpt | 25 +++++++++++++++++++++++++ - Zend/zend_vm_def.h | 2 +- - Zend/zend_vm_execute.h | 18 +++++++++--------- - 4 files changed, 36 insertions(+), 10 deletions(-) - create mode 100644 Zend/tests/bug71914.phpt - -diff --git a/Zend/tests/bug71914.phpt b/Zend/tests/bug71914.phpt -new file mode 100644 -index 0000000..8f825f8 ---- /dev/null -+++ b/Zend/tests/bug71914.phpt -@@ -0,0 +1,25 @@ -+--TEST-- -+Bug #71914 (Reference is lost in "switch") -+--FILE-- -+ "xxxx"); -+test($array, $array["str"]); -+?> -+--EXPECT-- -+bool(true) -diff --git a/Zend/zend_vm_def.h b/Zend/zend_vm_def.h -index 2c721c3..8e658f5 100644 ---- a/Zend/zend_vm_def.h -+++ b/Zend/zend_vm_def.h -@@ -4903,7 +4903,7 @@ ZEND_VM_HANDLER(48, ZEND_CASE, CONST|TMPVAR|CV, CONST|TMPVAR|CV) - SAVE_OPLINE(); - if (OP1_TYPE == IS_CV && UNEXPECTED(Z_TYPE_P(op1) == IS_UNDEF)) { - op1 = GET_OP1_UNDEF_CV(op1, BP_VAR_R); -- } else if ((OP1_TYPE & (IS_VAR|IS_CV)) && UNEXPECTED(Z_ISREF_P(op1))) { -+ } else if ((OP1_TYPE & IS_VAR) && UNEXPECTED(Z_ISREF_P(op1))) { - /* Don't keep lock on reference, lock the value instead */ - if (UNEXPECTED(Z_REFCOUNT_P(op1) == 1)) { - ZVAL_UNREF(op1); -diff --git a/Zend/zend_vm_execute.h b/Zend/zend_vm_execute.h -index c719aa2..bdc1bd7 100644 ---- a/Zend/zend_vm_execute.h -+++ b/Zend/zend_vm_execute.h -@@ -5858,7 +5858,7 @@ static ZEND_OPCODE_HANDLER_RET ZEND_FASTCALL ZEND_CASE_SPEC_CONST_CONST_HANDLER( - SAVE_OPLINE(); - if (IS_CONST == IS_CV && UNEXPECTED(Z_TYPE_P(op1) == IS_UNDEF)) { - op1 = GET_OP1_UNDEF_CV(op1, BP_VAR_R); -- } else if ((IS_CONST & (IS_VAR|IS_CV)) && UNEXPECTED(Z_ISREF_P(op1))) { -+ } else if ((IS_CONST & IS_VAR) && UNEXPECTED(Z_ISREF_P(op1))) { - /* Don't keep lock on reference, lock the value instead */ - if (UNEXPECTED(Z_REFCOUNT_P(op1) == 1)) { - ZVAL_UNREF(op1); -@@ -9654,7 +9654,7 @@ static ZEND_OPCODE_HANDLER_RET ZEND_FASTCALL ZEND_CASE_SPEC_CONST_CV_HANDLER(ZEN - SAVE_OPLINE(); - if (IS_CONST == IS_CV && UNEXPECTED(Z_TYPE_P(op1) == IS_UNDEF)) { - op1 = GET_OP1_UNDEF_CV(op1, BP_VAR_R); -- } else if ((IS_CONST & (IS_VAR|IS_CV)) && UNEXPECTED(Z_ISREF_P(op1))) { -+ } else if ((IS_CONST & IS_VAR) && UNEXPECTED(Z_ISREF_P(op1))) { - /* Don't keep lock on reference, lock the value instead */ - if (UNEXPECTED(Z_REFCOUNT_P(op1) == 1)) { - ZVAL_UNREF(op1); -@@ -11428,7 +11428,7 @@ static ZEND_OPCODE_HANDLER_RET ZEND_FASTCALL ZEND_CASE_SPEC_CONST_TMPVAR_HANDLER - SAVE_OPLINE(); - if (IS_CONST == IS_CV && UNEXPECTED(Z_TYPE_P(op1) == IS_UNDEF)) { - op1 = GET_OP1_UNDEF_CV(op1, BP_VAR_R); -- } else if ((IS_CONST & (IS_VAR|IS_CV)) && UNEXPECTED(Z_ISREF_P(op1))) { -+ } else if ((IS_CONST & IS_VAR) && UNEXPECTED(Z_ISREF_P(op1))) { - /* Don't keep lock on reference, lock the value instead */ - if (UNEXPECTED(Z_REFCOUNT_P(op1) == 1)) { - ZVAL_UNREF(op1); -@@ -32184,7 +32184,7 @@ static ZEND_OPCODE_HANDLER_RET ZEND_FASTCALL ZEND_CASE_SPEC_CV_CONST_HANDLER(ZEN - SAVE_OPLINE(); - if (IS_CV == IS_CV && UNEXPECTED(Z_TYPE_P(op1) == IS_UNDEF)) { - op1 = GET_OP1_UNDEF_CV(op1, BP_VAR_R); -- } else if ((IS_CV & (IS_VAR|IS_CV)) && UNEXPECTED(Z_ISREF_P(op1))) { -+ } else if ((IS_CV & IS_VAR) && UNEXPECTED(Z_ISREF_P(op1))) { - /* Don't keep lock on reference, lock the value instead */ - if (UNEXPECTED(Z_REFCOUNT_P(op1) == 1)) { - ZVAL_UNREF(op1); -@@ -37280,7 +37280,7 @@ static ZEND_OPCODE_HANDLER_RET ZEND_FASTCALL ZEND_CASE_SPEC_CV_CV_HANDLER(ZEND_O - SAVE_OPLINE(); - if (IS_CV == IS_CV && UNEXPECTED(Z_TYPE_P(op1) == IS_UNDEF)) { - op1 = GET_OP1_UNDEF_CV(op1, BP_VAR_R); -- } else if ((IS_CV & (IS_VAR|IS_CV)) && UNEXPECTED(Z_ISREF_P(op1))) { -+ } else if ((IS_CV & IS_VAR) && UNEXPECTED(Z_ISREF_P(op1))) { - /* Don't keep lock on reference, lock the value instead */ - if (UNEXPECTED(Z_REFCOUNT_P(op1) == 1)) { - ZVAL_UNREF(op1); -@@ -39873,7 +39873,7 @@ static ZEND_OPCODE_HANDLER_RET ZEND_FASTCALL ZEND_CASE_SPEC_CV_TMPVAR_HANDLER(ZE - SAVE_OPLINE(); - if (IS_CV == IS_CV && UNEXPECTED(Z_TYPE_P(op1) == IS_UNDEF)) { - op1 = GET_OP1_UNDEF_CV(op1, BP_VAR_R); -- } else if ((IS_CV & (IS_VAR|IS_CV)) && UNEXPECTED(Z_ISREF_P(op1))) { -+ } else if ((IS_CV & IS_VAR) && UNEXPECTED(Z_ISREF_P(op1))) { - /* Don't keep lock on reference, lock the value instead */ - if (UNEXPECTED(Z_REFCOUNT_P(op1) == 1)) { - ZVAL_UNREF(op1); -@@ -42108,7 +42108,7 @@ static ZEND_OPCODE_HANDLER_RET ZEND_FASTCALL ZEND_CASE_SPEC_TMPVAR_CONST_HANDLER - SAVE_OPLINE(); - if ((IS_TMP_VAR|IS_VAR) == IS_CV && UNEXPECTED(Z_TYPE_P(op1) == IS_UNDEF)) { - op1 = GET_OP1_UNDEF_CV(op1, BP_VAR_R); -- } else if (((IS_TMP_VAR|IS_VAR) & (IS_VAR|IS_CV)) && UNEXPECTED(Z_ISREF_P(op1))) { -+ } else if (((IS_TMP_VAR|IS_VAR) & IS_VAR) && UNEXPECTED(Z_ISREF_P(op1))) { - /* Don't keep lock on reference, lock the value instead */ - if (UNEXPECTED(Z_REFCOUNT_P(op1) == 1)) { - ZVAL_UNREF(op1); -@@ -44256,7 +44256,7 @@ static ZEND_OPCODE_HANDLER_RET ZEND_FASTCALL ZEND_CASE_SPEC_TMPVAR_CV_HANDLER(ZE - SAVE_OPLINE(); - if ((IS_TMP_VAR|IS_VAR) == IS_CV && UNEXPECTED(Z_TYPE_P(op1) == IS_UNDEF)) { - op1 = GET_OP1_UNDEF_CV(op1, BP_VAR_R); -- } else if (((IS_TMP_VAR|IS_VAR) & (IS_VAR|IS_CV)) && UNEXPECTED(Z_ISREF_P(op1))) { -+ } else if (((IS_TMP_VAR|IS_VAR) & IS_VAR) && UNEXPECTED(Z_ISREF_P(op1))) { - /* Don't keep lock on reference, lock the value instead */ - if (UNEXPECTED(Z_REFCOUNT_P(op1) == 1)) { - ZVAL_UNREF(op1); -@@ -45403,7 +45403,7 @@ static ZEND_OPCODE_HANDLER_RET ZEND_FASTCALL ZEND_CASE_SPEC_TMPVAR_TMPVAR_HANDLE - SAVE_OPLINE(); - if ((IS_TMP_VAR|IS_VAR) == IS_CV && UNEXPECTED(Z_TYPE_P(op1) == IS_UNDEF)) { - op1 = GET_OP1_UNDEF_CV(op1, BP_VAR_R); -- } else if (((IS_TMP_VAR|IS_VAR) & (IS_VAR|IS_CV)) && UNEXPECTED(Z_ISREF_P(op1))) { -+ } else if (((IS_TMP_VAR|IS_VAR) & IS_VAR) && UNEXPECTED(Z_ISREF_P(op1))) { - /* Don't keep lock on reference, lock the value instead */ - if (UNEXPECTED(Z_REFCOUNT_P(op1) == 1)) { - ZVAL_UNREF(op1); --- -2.1.4 - -From 256593abcf0452d2a95cc1869baeeaea0d72d2a7 Mon Sep 17 00:00:00 2001 -From: Xinchen Hui -Date: Tue, 29 Mar 2016 17:52:58 +0800 -Subject: [PATCH] Update tests - ---- - Zend/tests/bug71914.phpt | 15 +++++++++++++++ - 1 file changed, 15 insertions(+) - -diff --git a/Zend/tests/bug71914.phpt b/Zend/tests/bug71914.phpt -index 8f825f8..a43eb56 100644 ---- a/Zend/tests/bug71914.phpt -+++ b/Zend/tests/bug71914.phpt -@@ -11,15 +11,30 @@ function bug(&$value) { - } - } - -+function returnArray() { -+ $array = array(); -+ $array["str"] = "xxxx"; -+ return $array; -+} -+ -+class Foo { -+ public $array = array("str" => "xxxx"); -+} - - function test($arr, &$dummy) { - bug($arr["str"]); - var_dump($arr["str"]); - } - -+$foo = new Foo(); -+$arr = returnArray(); - - $array = array("str" => "xxxx"); - test($array, $array["str"]); -+test($arr, $arr["str"]); -+test($foo->array, $foo->array["str"]); - ?> - --EXPECT-- - bool(true) -+bool(true) -+bool(true) --- -2.1.4 - diff --git a/failed.txt b/failed.txt index fcc62e8..7d5bf61 100644 --- a/failed.txt +++ b/failed.txt @@ -1,14 +1,10 @@ -===== 7.1.9RC1 (2017-08-17) +===== 7.2.0RC1 (2017-08-31) $ grep -r 'Tests failed' /var/lib/mock/*/build.log /var/lib/mock/el6i/build.log:Tests failed : 0 /var/lib/mock/el6x/build.log:Tests failed : 0 /var/lib/mock/el7x/build.log:Tests failed : 0 -/var/lib/mock/fc23i/build.log:Tests failed : 0 -/var/lib/mock/fc23x/build.log:Tests failed : 0 -/var/lib/mock/fc24i/build.log:Tests failed : 0 -/var/lib/mock/fc24x/build.log:Tests failed : 0 /var/lib/mock/fc25i/build.log:Tests failed : 0 /var/lib/mock/fc25x/build.log:Tests failed : 0 /var/lib/mock/fc26i/build.log:Tests failed : 1 @@ -16,13 +12,6 @@ $ grep -r 'Tests failed' /var/lib/mock/*/build.log /var/lib/mock/fc27x/build.log:Tests failed : 1 -fc26i - 1 Bug #64438 proc_open hangs with stdin/out with 4097+ bytes [ext/standard/tests/streams/proc_open_bug64438.phpt] -fc26x - 5 proc_nice() basic behaviour [ext/standard/tests/general_functions/proc_nice_basic.phpt] - 5 Check cli_process_title support on Unix [sapi/cli/tests/cli_process_title_unix.phpt] -fc27x - 5 substr_compare() [ext/standard/tests/strings/substr_compare.phpt] 1 proc_open give erratic test results :( diff --git a/php-5.6.3-oci8conf.patch b/php-5.6.3-oci8conf.patch deleted file mode 100644 index f2d8f99..0000000 --- a/php-5.6.3-oci8conf.patch +++ /dev/null @@ -1,39 +0,0 @@ -diff -up php5.3-201104170830/ext/ldap/php_ldap.h.remi-oci8 php5.3-201104170830/ext/ldap/php_ldap.h ---- php5.3-201104170830/ext/ldap/php_ldap.h.remi-oci8 2011-01-01 04:37:23.000000000 +0100 -+++ php5.3-201104170830/ext/ldap/php_ldap.h 2011-04-17 11:55:25.630871609 +0200 -@@ -27,7 +27,7 @@ - #include - #endif - --#include -+#include "/usr/include/ldap.h" - - extern zend_module_entry ldap_module_entry; - #define ldap_module_ptr &ldap_module_entry -diff -up php5.3-201104170830/ext/oci8/config.m4.remi-oci8 php5.3-201104170830/ext/oci8/config.m4 ---- php5.3-201104170830/ext/oci8/config.m4.remi-oci8 2011-03-30 00:35:22.000000000 +0200 -+++ php5.3-201104170830/ext/oci8/config.m4 2011-04-17 11:55:25.628871315 +0200 -@@ -376,6 +376,7 @@ if test "$PHP_OCI8" != "no"; then - - dnl Header directory for Instant Client SDK RPM install - OCISDKRPMINC=`echo "$PHP_OCI8_INSTANT_CLIENT" | $PHP_OCI8_SED -e 's!^/usr/lib/oracle/\(.*\)/client\('${PHP_OCI8_IC_LIBDIR_SUFFIX}'\)*/lib[/]*$!/usr/include/oracle/\1/client\2!'` -+ OCISDKRPMINC=`echo "$PHP_OCI8_INSTANT_CLIENT" | $PHP_OCI8_SED -e 's!^/usr/\(lib64\|lib\)/oracle/\(.*\)/\(client64\|client\)/lib[/]*$!/usr/include/oracle/\2/\3!'` - - dnl Header directory for Instant Client SDK zip file install - OCISDKZIPINC=$PHP_OCI8_INSTANT_CLIENT/sdk/include -diff -up php5.3-201104170830/ext/pdo_oci/config.m4.remi-oci8 php5.3-201104170830/ext/pdo_oci/config.m4 ---- php5.3-201104170830/ext/pdo_oci/config.m4.remi-oci8 2011-04-02 04:35:24.000000000 +0200 -+++ php5.3-201104170830/ext/pdo_oci/config.m4 2011-04-17 12:02:42.837194120 +0200 -@@ -104,8 +104,10 @@ You need to tell me where to find your O - else - AC_MSG_ERROR([I'm too dumb to figure out where the include dir is in your Instant Client install]) - fi -- if test -f "$PDO_OCI_IC_PREFIX/lib/oracle/$PDO_OCI_IC_VERS/$PDO_OCI_CLIENT_DIR/lib/libclntsh.$SHLIB_SUFFIX_NAME" ; then -- PDO_OCI_LIB_DIR="$PDO_OCI_IC_PREFIX/lib/oracle/$PDO_OCI_IC_VERS/$PDO_OCI_CLIENT_DIR/lib" -+ if test -f "$PDO_OCI_IC_PREFIX/lib64/oracle/$PDO_OCI_IC_VERS/$PDO_OCI_CLIENT_DIR/lib/libclntsh.$SHLIB_SUFFIX_NAME" ; then -+ PDO_OCI_LIB_DIR="$PDO_OCI_IC_PREFIX/lib64/oracle/$PDO_OCI_IC_VERS/$PDO_OCI_CLIENT_DIR/lib" -+ elif test -f "$PDO_OCI_IC_PREFIX/lib/oracle/$PDO_OCI_IC_VERS/$PDO_OCI_CLIENT_DIR/lib/libclntsh.$SHLIB_SUFFIX_NAME" ; then -+ PDO_OCI_LIB_DIR="$PDO_OCI_IC_PREFIX/lib/oracle/$PDO_OCI_IC_VERS/$PDO_OCI_CLIENT_DIR/lib" - elif test -f "$PDO_OCI_IC_PREFIX/$PDO_OCI_CLIENT_DIR/lib/libclntsh.$SHLIB_SUFFIX_NAME" ; then - PDO_OCI_LIB_DIR="$PDO_OCI_IC_PREFIX/$PDO_OCI_CLIENT_DIR/lib" - elif test -f "$PDO_OCI_IC_PREFIX/libclntsh.$SHLIB_SUFFIX_NAME" ; then diff --git a/php-7.0.0-fixheader.patch b/php-7.0.0-fixheader.patch deleted file mode 100644 index 771a19e..0000000 --- a/php-7.0.0-fixheader.patch +++ /dev/null @@ -1,23 +0,0 @@ - -Make generated php_config.h constant across rebuilds. - ---- php-7.0.0/configure.in.fixheader -+++ php-7.0.0/configure.in -@@ -1278,7 +1278,7 @@ fi - EXTRA_LDFLAGS="$EXTRA_LDFLAGS $PHP_LDFLAGS" - EXTRA_LDFLAGS_PROGRAM="$EXTRA_LDFLAGS_PROGRAM $PHP_LDFLAGS" - --PHP_BUILD_DATE=`date '+%Y-%m-%d'` -+PHP_BUILD_DATE=`date '+%Y-%m-%d' -r $srcdir/NEWS` - AC_DEFINE_UNQUOTED(PHP_BUILD_DATE,"$PHP_BUILD_DATE",[PHP build date]) - - case $host_alias in -@@ -1289,7 +1289,7 @@ case $host_alias in - AC_DEFINE_UNQUOTED(PHP_UNAME,"$PHP_UNAME",[hardcode for each of the cross compiler host]) - ;; - *) -- PHP_UNAME=`uname -a | xargs` -+ PHP_UNAME=`uname | xargs` - AC_DEFINE_UNQUOTED(PHP_UNAME,"$PHP_UNAME",[uname -a output]) - PHP_OS=`uname | xargs` - AC_DEFINE_UNQUOTED(PHP_OS,"$PHP_OS",[uname output]) diff --git a/php-7.0.0-includedir.patch b/php-7.0.0-includedir.patch deleted file mode 100644 index 2822c3f..0000000 --- a/php-7.0.0-includedir.patch +++ /dev/null @@ -1,11 +0,0 @@ ---- php-7.0.0/configure.in.includedir -+++ php-7.0.0/configure.in -@@ -1245,7 +1245,7 @@ - EXPANDED_DATADIR=$datadir - EXPANDED_PHP_CONFIG_FILE_PATH=`eval echo "$PHP_CONFIG_FILE_PATH"` - EXPANDED_PHP_CONFIG_FILE_SCAN_DIR=`eval echo "$PHP_CONFIG_FILE_SCAN_DIR"` --INCLUDE_PATH=.:$EXPANDED_PEAR_INSTALLDIR -+INCLUDE_PATH=.:$EXPANDED_PEAR_INSTALLDIR:${EXPANDED_DATADIR}/php - - exec_prefix=$old_exec_prefix - libdir=$old_libdir diff --git a/php-7.0.2-libdb.patch b/php-7.0.2-libdb.patch deleted file mode 100644 index f9bff95..0000000 --- a/php-7.0.2-libdb.patch +++ /dev/null @@ -1,92 +0,0 @@ -diff -up php-7.0.2RC1/ext/dba/config.m4.libdb php-7.0.2RC1/ext/dba/config.m4 ---- php-7.0.2RC1/ext/dba/config.m4.libdb 2015-12-27 07:54:48.669923462 +0100 -+++ php-7.0.2RC1/ext/dba/config.m4 2015-12-27 07:55:03.607947034 +0100 -@@ -312,61 +312,13 @@ if test "$PHP_DB4" != "no"; then - dbdp4="/usr/local/BerkeleyDB.4." - dbdp5="/usr/local/BerkeleyDB.5." - for i in $PHP_DB4 ${dbdp5}1 ${dbdp5}0 ${dbdp4}8 ${dbdp4}7 ${dbdp4}6 ${dbdp4}5 ${dbdp4}4 ${dbdp4}3 ${dbdp4}2 ${dbdp4}1 ${dbdp}0 /usr/local /usr; do -- if test -f "$i/db5/db.h"; then -- THIS_PREFIX=$i -- THIS_INCLUDE=$i/db5/db.h -- break -- elif test -f "$i/db4/db.h"; then -- THIS_PREFIX=$i -- THIS_INCLUDE=$i/db4/db.h -- break -- elif test -f "$i/include/db5.3/db.h"; then -- THIS_PREFIX=$i -- THIS_INCLUDE=$i/include/db5.3/db.h -- break -- elif test -f "$i/include/db5.1/db.h"; then -- THIS_PREFIX=$i -- THIS_INCLUDE=$i/include/db5.1/db.h -- break -- elif test -f "$i/include/db5.0/db.h"; then -- THIS_PREFIX=$i -- THIS_INCLUDE=$i/include/db5.0/db.h -- break -- elif test -f "$i/include/db4.8/db.h"; then -- THIS_PREFIX=$i -- THIS_INCLUDE=$i/include/db4.8/db.h -- break -- elif test -f "$i/include/db4.7/db.h"; then -- THIS_PREFIX=$i -- THIS_INCLUDE=$i/include/db4.7/db.h -- break -- elif test -f "$i/include/db4.6/db.h"; then -- THIS_PREFIX=$i -- THIS_INCLUDE=$i/include/db4.6/db.h -- break -- elif test -f "$i/include/db4.5/db.h"; then -- THIS_PREFIX=$i -- THIS_INCLUDE=$i/include/db4.5/db.h -- break -- elif test -f "$i/include/db4/db.h"; then -- THIS_PREFIX=$i -- THIS_INCLUDE=$i/include/db4/db.h -- break -- elif test -f "$i/include/db/db4.h"; then -- THIS_PREFIX=$i -- THIS_INCLUDE=$i/include/db/db4.h -- break -- elif test -f "$i/include/db4.h"; then -- THIS_PREFIX=$i -- THIS_INCLUDE=$i/include/db4.h -- break -- elif test -f "$i/include/db.h"; then -+ if test -f "$i/include/db.h"; then - THIS_PREFIX=$i - THIS_INCLUDE=$i/include/db.h - break - fi - done -- PHP_DBA_DB_CHECK(4, db-5.3 db-5.1 db-5.0 db-4.8 db-4.7 db-4.6 db-4.5 db-4.4 db-4.3 db-4.2 db-4.1 db-4.0 db-4 db4 db, [(void)db_create((DB**)0, (DB_ENV*)0, 0)]) -+ PHP_DBA_DB_CHECK(4, db, [(void)db_create((DB**)0, (DB_ENV*)0, 0)]) - fi - PHP_DBA_STD_RESULT(db4,Berkeley DB4) - -diff -up php-7.0.2RC1/ext/dba/dba.c.libdb php-7.0.2RC1/ext/dba/dba.c ---- php-7.0.2RC1/ext/dba/dba.c.libdb 2015-12-22 16:19:29.000000000 +0100 -+++ php-7.0.2RC1/ext/dba/dba.c 2015-12-27 07:52:30.381638216 +0100 -@@ -52,6 +52,10 @@ - #include "php_qdbm.h" - #include "php_tcadb.h" - -+#ifdef DB4_INCLUDE_FILE -+#include DB4_INCLUDE_FILE -+#endif -+ - /* {{{ arginfo */ - ZEND_BEGIN_ARG_INFO_EX(arginfo_dba_popen, 0, 0, 2) - ZEND_ARG_INFO(0, path) -@@ -552,6 +556,10 @@ PHP_MINFO_FUNCTION(dba) - - php_info_print_table_start(); - php_info_print_table_row(2, "DBA support", "enabled"); -+#ifdef DB_VERSION_STRING -+ php_info_print_table_row(2, "libdb header version", DB_VERSION_STRING); -+ php_info_print_table_row(2, "libdb library version", db_version(NULL, NULL, NULL)); -+#endif - if (handlers.s) { - smart_str_0(&handlers); - php_info_print_table_row(2, "Supported handlers", ZSTR_VAL(handlers.s)); diff --git a/php-7.1.0-libdb.patch b/php-7.1.0-libdb.patch new file mode 100644 index 0000000..ca36d1a --- /dev/null +++ b/php-7.1.0-libdb.patch @@ -0,0 +1,92 @@ +diff -up php-7.2.0alpha0/ext/dba/config.m4.libdb php-7.2.0alpha0/ext/dba/config.m4 +--- php-7.2.0alpha0/ext/dba/config.m4.libdb 2017-05-29 08:56:06.000000000 +0200 ++++ php-7.2.0alpha0/ext/dba/config.m4 2017-05-29 09:13:52.014823282 +0200 +@@ -346,61 +346,13 @@ if test "$PHP_DB4" != "no"; then + dbdp4="/usr/local/BerkeleyDB.4." + dbdp5="/usr/local/BerkeleyDB.5." + for i in $PHP_DB4 ${dbdp5}1 ${dbdp5}0 ${dbdp4}8 ${dbdp4}7 ${dbdp4}6 ${dbdp4}5 ${dbdp4}4 ${dbdp4}3 ${dbdp4}2 ${dbdp4}1 ${dbdp}0 /usr/local /usr; do +- if test -f "$i/db5/db.h"; then +- THIS_PREFIX=$i +- THIS_INCLUDE=$i/db5/db.h +- break +- elif test -f "$i/db4/db.h"; then +- THIS_PREFIX=$i +- THIS_INCLUDE=$i/db4/db.h +- break +- elif test -f "$i/include/db5.3/db.h"; then +- THIS_PREFIX=$i +- THIS_INCLUDE=$i/include/db5.3/db.h +- break +- elif test -f "$i/include/db5.1/db.h"; then +- THIS_PREFIX=$i +- THIS_INCLUDE=$i/include/db5.1/db.h +- break +- elif test -f "$i/include/db5.0/db.h"; then +- THIS_PREFIX=$i +- THIS_INCLUDE=$i/include/db5.0/db.h +- break +- elif test -f "$i/include/db4.8/db.h"; then +- THIS_PREFIX=$i +- THIS_INCLUDE=$i/include/db4.8/db.h +- break +- elif test -f "$i/include/db4.7/db.h"; then +- THIS_PREFIX=$i +- THIS_INCLUDE=$i/include/db4.7/db.h +- break +- elif test -f "$i/include/db4.6/db.h"; then +- THIS_PREFIX=$i +- THIS_INCLUDE=$i/include/db4.6/db.h +- break +- elif test -f "$i/include/db4.5/db.h"; then +- THIS_PREFIX=$i +- THIS_INCLUDE=$i/include/db4.5/db.h +- break +- elif test -f "$i/include/db4/db.h"; then +- THIS_PREFIX=$i +- THIS_INCLUDE=$i/include/db4/db.h +- break +- elif test -f "$i/include/db/db4.h"; then +- THIS_PREFIX=$i +- THIS_INCLUDE=$i/include/db/db4.h +- break +- elif test -f "$i/include/db4.h"; then +- THIS_PREFIX=$i +- THIS_INCLUDE=$i/include/db4.h +- break +- elif test -f "$i/include/db.h"; then ++ if test -f "$i/include/db.h"; then + THIS_PREFIX=$i + THIS_INCLUDE=$i/include/db.h + break + fi + done +- PHP_DBA_DB_CHECK(4, db-5.3 db-5.1 db-5.0 db-4.8 db-4.7 db-4.6 db-4.5 db-4.4 db-4.3 db-4.2 db-4.1 db-4.0 db-4 db4 db, [(void)db_create((DB**)0, (DB_ENV*)0, 0)]) ++ PHP_DBA_DB_CHECK(4, db, [(void)db_create((DB**)0, (DB_ENV*)0, 0)]) + fi + PHP_DBA_STD_RESULT(db4,Berkeley DB4) + +diff -up php-7.2.0alpha0/ext/dba/dba.c.libdb php-7.2.0alpha0/ext/dba/dba.c +--- php-7.2.0alpha0/ext/dba/dba.c.libdb 2017-05-29 09:16:15.736628202 +0200 ++++ php-7.2.0alpha0/ext/dba/dba.c 2017-05-29 09:16:20.494654746 +0200 +@@ -53,6 +53,10 @@ + #include "php_tcadb.h" + #include "php_lmdb.h" + ++#ifdef DB4_INCLUDE_FILE ++#include DB4_INCLUDE_FILE ++#endif ++ + /* {{{ arginfo */ + ZEND_BEGIN_ARG_INFO_EX(arginfo_dba_popen, 0, 0, 2) + ZEND_ARG_INFO(0, path) +@@ -558,6 +562,10 @@ PHP_MINFO_FUNCTION(dba) + + php_info_print_table_start(); + php_info_print_table_row(2, "DBA support", "enabled"); ++#ifdef DB_VERSION_STRING ++ php_info_print_table_row(2, "libdb header version", DB_VERSION_STRING); ++ php_info_print_table_row(2, "libdb library version", db_version(NULL, NULL, NULL)); ++#endif + if (handlers.s) { + smart_str_0(&handlers); + php_info_print_table_row(2, "Supported handlers", ZSTR_VAL(handlers.s)); diff --git a/php-7.1.0-systzdata-v14.patch b/php-7.1.0-systzdata-v14.patch deleted file mode 100644 index bd73a4b..0000000 --- a/php-7.1.0-systzdata-v14.patch +++ /dev/null @@ -1,677 +0,0 @@ -# License: MIT -# http://opensource.org/licenses/MIT - -Add support for use of the system timezone database, rather -than embedding a copy. Discussed upstream but was not desired. - -History: -r14: improve check for valid tz file -r13: adapt for upstream changes to use PHP allocator -r12: adapt for upstream changes for new zic -r11: use canonical names to avoid more case sensitivity issues - round lat/long from zone.tab towards zero per builtin db -r10: make timezone case insensitive -r9: fix another compile error without --with-system-tzdata configured (Michael Heimpold) -r8: fix compile error without --with-system-tzdata configured -r7: improve check for valid timezone id to exclude directories -r6: fix fd leak in r5, fix country code/BC flag use in - timezone_identifiers_list() using system db, - fix use of PECL timezonedb to override system db, -r5: reverts addition of "System/Localtime" fake tzname. - updated for 5.3.0, parses zone.tab to pick up mapping between - timezone name, country code and long/lat coords -r4: added "System/Localtime" tzname which uses /etc/localtime -r3: fix a crash if /usr/share/zoneinfo doesn't exist (Raphael Geissert) -r2: add filesystem trawl to set up name alias index -r1: initial revision - -diff -up php-7.1.0RC4/ext/date/lib/parse_tz.c.systzdata php-7.1.0RC4/ext/date/lib/parse_tz.c ---- php-7.1.0RC4/ext/date/lib/parse_tz.c.systzdata 2016-10-17 13:35:11.000000000 +0200 -+++ php-7.1.0RC4/ext/date/lib/parse_tz.c 2016-10-17 13:40:47.806358674 +0200 -@@ -24,6 +24,16 @@ - - #include "timelib.h" - -+#ifdef HAVE_SYSTEM_TZDATA -+#include -+#include -+#include -+#include -+#include -+ -+#include "php_scandir.h" -+#endif -+ - #include - - #ifdef HAVE_LOCALE_H -@@ -36,8 +46,12 @@ - #include - #endif - -+#ifndef HAVE_SYSTEM_TZDATA - #define TIMELIB_SUPPORTS_V2DATA - #include "timezonedb.h" -+#endif -+ -+#include - - #if (defined(__APPLE__) || defined(__APPLE_CC__)) && (defined(__BIG_ENDIAN__) || defined(__LITTLE_ENDIAN__)) - # if defined(__LITTLE_ENDIAN__) -@@ -59,6 +73,11 @@ static int read_preamble(const unsigned - { - uint32_t version; - -+ if (memcmp(*tzf, "TZif", 4) == 0) { -+ *tzf += 20; -+ return 0; -+ } -+ - /* read ID */ - version = (*tzf)[3] - '0'; - *tzf += 4; -@@ -302,7 +321,429 @@ void timelib_dump_tzinfo(timelib_tzinfo - } - } - --static int seek_to_tz_position(const unsigned char **tzf, char *timezone, const timelib_tzdb *tzdb) -+#ifdef HAVE_SYSTEM_TZDATA -+ -+#ifdef HAVE_SYSTEM_TZDATA_PREFIX -+#define ZONEINFO_PREFIX HAVE_SYSTEM_TZDATA_PREFIX -+#else -+#define ZONEINFO_PREFIX "/usr/share/zoneinfo" -+#endif -+ -+/* System timezone database pointer. */ -+static const timelib_tzdb *timezonedb_system; -+ -+/* Hash table entry for the cache of the zone.tab mapping table. */ -+struct location_info { -+ char code[2]; -+ double latitude, longitude; -+ char name[64]; -+ char *comment; -+ struct location_info *next; -+}; -+ -+/* Cache of zone.tab. */ -+static struct location_info **system_location_table; -+ -+/* Size of the zone.tab hash table; a random-ish prime big enough to -+ * prevent too many collisions. */ -+#define LOCINFO_HASH_SIZE (1021) -+ -+/* Compute a case insensitive hash of str */ -+static uint32_t tz_hash(const char *str) -+{ -+ const unsigned char *p = (const unsigned char *)str; -+ uint32_t hash = 5381; -+ int c; -+ -+ while ((c = tolower(*p++)) != '\0') { -+ hash = (hash << 5) ^ hash ^ c; -+ } -+ -+ return hash % LOCINFO_HASH_SIZE; -+} -+ -+/* Parse an ISO-6709 date as used in zone.tab. Returns end of the -+ * parsed string on success, or NULL on parse error. On success, -+ * writes the parsed number to *result. */ -+static char *parse_iso6709(char *p, double *result) -+{ -+ double v, sign; -+ char *pend; -+ size_t len; -+ -+ if (*p == '+') -+ sign = 1.0; -+ else if (*p == '-') -+ sign = -1.0; -+ else -+ return NULL; -+ -+ p++; -+ for (pend = p; *pend >= '0' && *pend <= '9'; pend++) -+ ;; -+ -+ /* Annoying encoding used by zone.tab has no decimal point, so use -+ * the length to determine the format: -+ * -+ * 4 = DDMM -+ * 5 = DDDMM -+ * 6 = DDMMSS -+ * 7 = DDDMMSS -+ */ -+ len = pend - p; -+ if (len < 4 || len > 7) { -+ return NULL; -+ } -+ -+ /* p => [D]DD */ -+ v = (p[0] - '0') * 10.0 + (p[1] - '0'); -+ p += 2; -+ if (len == 5 || len == 7) -+ v = v * 10.0 + (*p++ - '0'); -+ /* p => MM[SS] */ -+ v += (10.0 * (p[0] - '0') -+ + p[1] - '0') / 60.0; -+ p += 2; -+ /* p => [SS] */ -+ if (len > 5) { -+ v += (10.0 * (p[0] - '0') -+ + p[1] - '0') / 3600.0; -+ p += 2; -+ } -+ -+ /* Round to five decimal place, not because it's a good idea, -+ * but, because the builtin data uses rounded data, so, match -+ * that. */ -+ *result = trunc(v * sign * 100000.0) / 100000.0; -+ -+ return p; -+} -+ -+/* This function parses the zone.tab file to build up the mapping of -+ * timezone to country code and geographic location, and returns a -+ * hash table. The hash table is indexed by the function: -+ * -+ * tz_hash(timezone-name) -+ */ -+static struct location_info **create_location_table(void) -+{ -+ struct location_info **li, *i; -+ char zone_tab[PATH_MAX]; -+ char line[512]; -+ FILE *fp; -+ -+ strncpy(zone_tab, ZONEINFO_PREFIX "/zone.tab", sizeof zone_tab); -+ -+ fp = fopen(zone_tab, "r"); -+ if (!fp) { -+ return NULL; -+ } -+ -+ li = calloc(LOCINFO_HASH_SIZE, sizeof *li); -+ -+ while (fgets(line, sizeof line, fp)) { -+ char *p = line, *code, *name, *comment; -+ uint32_t hash; -+ double latitude, longitude; -+ -+ while (isspace(*p)) -+ p++; -+ -+ if (*p == '#' || *p == '\0' || *p == '\n') -+ continue; -+ -+ if (!isalpha(p[0]) || !isalpha(p[1]) || p[2] != '\t') -+ continue; -+ -+ /* code => AA */ -+ code = p; -+ p[2] = 0; -+ p += 3; -+ -+ /* coords => [+-][D]DDMM[SS][+-][D]DDMM[SS] */ -+ p = parse_iso6709(p, &latitude); -+ if (!p) { -+ continue; -+ } -+ p = parse_iso6709(p, &longitude); -+ if (!p) { -+ continue; -+ } -+ -+ if (!p || *p != '\t') { -+ continue; -+ } -+ -+ /* name = string */ -+ name = ++p; -+ while (*p != '\t' && *p && *p != '\n') -+ p++; -+ -+ *p++ = '\0'; -+ -+ /* comment = string */ -+ comment = p; -+ while (*p != '\t' && *p && *p != '\n') -+ p++; -+ -+ if (*p == '\n' || *p == '\t') -+ *p = '\0'; -+ -+ hash = tz_hash(name); -+ i = malloc(sizeof *i); -+ memcpy(i->code, code, 2); -+ strncpy(i->name, name, sizeof i->name); -+ i->comment = strdup(comment); -+ i->longitude = longitude; -+ i->latitude = latitude; -+ i->next = li[hash]; -+ li[hash] = i; -+ /* printf("%s [%u, %f, %f]\n", name, hash, latitude, longitude); */ -+ } -+ -+ fclose(fp); -+ -+ return li; -+} -+ -+/* Return location info from hash table, using given timezone name. -+ * Returns NULL if the name could not be found. */ -+const struct location_info *find_zone_info(struct location_info **li, -+ const char *name) -+{ -+ uint32_t hash = tz_hash(name); -+ const struct location_info *l; -+ -+ if (!li) { -+ return NULL; -+ } -+ -+ for (l = li[hash]; l; l = l->next) { -+ if (strcasecmp(l->name, name) == 0) -+ return l; -+ } -+ -+ return NULL; -+} -+ -+/* Filter out some non-tzdata files and the posix/right databases, if -+ * present. */ -+static int index_filter(const struct dirent *ent) -+{ -+ return strcmp(ent->d_name, ".") != 0 -+ && strcmp(ent->d_name, "..") != 0 -+ && strcmp(ent->d_name, "posix") != 0 -+ && strcmp(ent->d_name, "posixrules") != 0 -+ && strcmp(ent->d_name, "right") != 0 -+ && strstr(ent->d_name, ".list") == NULL -+ && strstr(ent->d_name, ".tab") == NULL; -+} -+ -+static int sysdbcmp(const void *first, const void *second) -+{ -+ const timelib_tzdb_index_entry *alpha = first, *beta = second; -+ -+ return strcasecmp(alpha->id, beta->id); -+} -+ -+ -+/* Create the zone identifier index by trawling the filesystem. */ -+static void create_zone_index(timelib_tzdb *db) -+{ -+ size_t dirstack_size, dirstack_top; -+ size_t index_size, index_next; -+ timelib_tzdb_index_entry *db_index; -+ char **dirstack; -+ -+ /* LIFO stack to hold directory entries to scan; each slot is a -+ * directory name relative to the zoneinfo prefix. */ -+ dirstack_size = 32; -+ dirstack = malloc(dirstack_size * sizeof *dirstack); -+ dirstack_top = 1; -+ dirstack[0] = strdup(""); -+ -+ /* Index array. */ -+ index_size = 64; -+ db_index = malloc(index_size * sizeof *db_index); -+ index_next = 0; -+ -+ do { -+ struct dirent **ents; -+ char name[PATH_MAX], *top; -+ int count; -+ -+ /* Pop the top stack entry, and iterate through its contents. */ -+ top = dirstack[--dirstack_top]; -+ snprintf(name, sizeof name, ZONEINFO_PREFIX "/%s", top); -+ -+ count = php_scandir(name, &ents, index_filter, php_alphasort); -+ -+ while (count > 0) { -+ struct stat st; -+ const char *leaf = ents[count - 1]->d_name; -+ -+ snprintf(name, sizeof name, ZONEINFO_PREFIX "/%s/%s", -+ top, leaf); -+ -+ if (strlen(name) && stat(name, &st) == 0) { -+ /* Name, relative to the zoneinfo prefix. */ -+ const char *root = top; -+ -+ if (root[0] == '/') root++; -+ -+ snprintf(name, sizeof name, "%s%s%s", root, -+ *root ? "/": "", leaf); -+ -+ if (S_ISDIR(st.st_mode)) { -+ if (dirstack_top == dirstack_size) { -+ dirstack_size *= 2; -+ dirstack = realloc(dirstack, -+ dirstack_size * sizeof *dirstack); -+ } -+ dirstack[dirstack_top++] = strdup(name); -+ } -+ else { -+ if (index_next == index_size) { -+ index_size *= 2; -+ db_index = realloc(db_index, -+ index_size * sizeof *db_index); -+ } -+ -+ db_index[index_next++].id = strdup(name); -+ } -+ } -+ -+ free(ents[--count]); -+ } -+ -+ if (count != -1) free(ents); -+ free(top); -+ } while (dirstack_top); -+ -+ qsort(db_index, index_next, sizeof *db_index, sysdbcmp); -+ -+ db->index = db_index; -+ db->index_size = index_next; -+ -+ free(dirstack); -+} -+ -+#define FAKE_HEADER "1234\0??\1??" -+#define FAKE_UTC_POS (7 - 4) -+ -+/* Create a fake data segment for database 'sysdb'. */ -+static void fake_data_segment(timelib_tzdb *sysdb, -+ struct location_info **info) -+{ -+ size_t n; -+ char *data, *p; -+ -+ data = malloc(3 * sysdb->index_size + 7); -+ -+ p = mempcpy(data, FAKE_HEADER, sizeof(FAKE_HEADER) - 1); -+ -+ for (n = 0; n < sysdb->index_size; n++) { -+ const struct location_info *li; -+ timelib_tzdb_index_entry *ent; -+ -+ ent = (timelib_tzdb_index_entry *)&sysdb->index[n]; -+ -+ /* Lookup the timezone name in the hash table. */ -+ if (strcmp(ent->id, "UTC") == 0) { -+ ent->pos = FAKE_UTC_POS; -+ continue; -+ } -+ -+ li = find_zone_info(info, ent->id); -+ if (li) { -+ /* If found, append the BC byte and the -+ * country code; set the position for this -+ * section of timezone data. */ -+ ent->pos = (p - data) - 4; -+ *p++ = '\1'; -+ *p++ = li->code[0]; -+ *p++ = li->code[1]; -+ } -+ else { -+ /* If not found, the timezone data can -+ * point at the header. */ -+ ent->pos = 0; -+ } -+ } -+ -+ sysdb->data = (unsigned char *)data; -+} -+ -+/* Returns true if the passed-in stat structure describes a -+ * probably-valid timezone file. */ -+static int is_valid_tzfile(const struct stat *st, int fd) -+{ -+ if (fd) { -+ char buf[20]; -+ if (read(fd, buf, 20)!=20) { -+ return 0; -+ } -+ lseek(fd, SEEK_SET, 0); -+ if (memcmp(buf, "TZif", 4)) { -+ return 0; -+ } -+ } -+ return S_ISREG(st->st_mode) && st->st_size > 20; -+} -+ -+/* To allow timezone names to be used case-insensitively, find the -+ * canonical name for this timezone, if possible. */ -+static const char *canonical_tzname(const char *timezone) -+{ -+ if (timezonedb_system) { -+ timelib_tzdb_index_entry *ent, lookup; -+ -+ lookup.id = (char *)timezone; -+ -+ ent = bsearch(&lookup, timezonedb_system->index, -+ timezonedb_system->index_size, sizeof lookup, -+ sysdbcmp); -+ if (ent) { -+ return ent->id; -+ } -+ } -+ -+ return timezone; -+} -+ -+/* Return the mmap()ed tzfile if found, else NULL. On success, the -+ * length of the mapped data is placed in *length. */ -+static char *map_tzfile(const char *timezone, size_t *length) -+{ -+ char fname[PATH_MAX]; -+ struct stat st; -+ char *p; -+ int fd; -+ -+ if (timezone[0] == '\0' || strstr(timezone, "..") != NULL) { -+ return NULL; -+ } -+ -+ snprintf(fname, sizeof fname, ZONEINFO_PREFIX "/%s", canonical_tzname(timezone)); -+ -+ fd = open(fname, O_RDONLY); -+ if (fd == -1) { -+ return NULL; -+ } else if (fstat(fd, &st) != 0 || !is_valid_tzfile(&st, fd)) { -+ close(fd); -+ return NULL; -+ } -+ -+ *length = st.st_size; -+ p = mmap(NULL, st.st_size, PROT_READ, MAP_SHARED, fd, 0); -+ close(fd); -+ -+ return p != MAP_FAILED ? p : NULL; -+} -+ -+#endif -+ -+static int inmem_seek_to_tz_position(const unsigned char **tzf, char *timezone, const timelib_tzdb *tzdb) - { - int left = 0, right = tzdb->index_size - 1; - #ifdef HAVE_SETLOCALE -@@ -341,21 +782,88 @@ static int seek_to_tz_position(const uns - return 0; - } - -+static int seek_to_tz_position(const unsigned char **tzf, char *timezone, -+ char **map, size_t *maplen, -+ const timelib_tzdb *tzdb) -+{ -+#ifdef HAVE_SYSTEM_TZDATA -+ if (tzdb == timezonedb_system) { -+ char *orig; -+ -+ orig = map_tzfile(timezone, maplen); -+ if (orig == NULL) { -+ return 0; -+ } -+ -+ (*tzf) = (unsigned char *)orig; -+ *map = orig; -+ return 1; -+ } -+ else -+#endif -+ { -+ return inmem_seek_to_tz_position(tzf, timezone, tzdb); -+ } -+} -+ - const timelib_tzdb *timelib_builtin_db(void) - { -+#ifdef HAVE_SYSTEM_TZDATA -+ if (timezonedb_system == NULL) { -+ timelib_tzdb *tmp = malloc(sizeof *tmp); -+ -+ tmp->version = "0.system"; -+ tmp->data = NULL; -+ create_zone_index(tmp); -+ system_location_table = create_location_table(); -+ fake_data_segment(tmp, system_location_table); -+ timezonedb_system = tmp; -+ } -+ -+ return timezonedb_system; -+#else - return &timezonedb_builtin; -+#endif - } - - const timelib_tzdb_index_entry *timelib_timezone_builtin_identifiers_list(int *count) - { -+#ifdef HAVE_SYSTEM_TZDATA -+ *count = timezonedb_system->index_size; -+ return timezonedb_system->index; -+#else - *count = sizeof(timezonedb_idx_builtin) / sizeof(*timezonedb_idx_builtin); - return timezonedb_idx_builtin; -+#endif - } - - int timelib_timezone_id_is_valid(char *timezone, const timelib_tzdb *tzdb) - { - const unsigned char *tzf; -- return (seek_to_tz_position(&tzf, timezone, tzdb)); -+ -+#ifdef HAVE_SYSTEM_TZDATA -+ if (tzdb == timezonedb_system) { -+ char fname[PATH_MAX]; -+ struct stat st; -+ -+ if (timezone[0] == '\0' || strstr(timezone, "..") != NULL) { -+ return 0; -+ } -+ -+ if (system_location_table) { -+ if (find_zone_info(system_location_table, timezone) != NULL) { -+ /* found in cache */ -+ return 1; -+ } -+ } -+ -+ snprintf(fname, sizeof fname, ZONEINFO_PREFIX "/%s", canonical_tzname(timezone)); -+ -+ return stat(fname, &st) == 0 && is_valid_tzfile(&st, 0); -+ } -+#endif -+ -+ return (inmem_seek_to_tz_position(&tzf, timezone, tzdb)); - } - - static void skip_64bit_preamble(const unsigned char **tzf, timelib_tzinfo *tz) -@@ -380,24 +888,54 @@ static void read_64bit_header(const unsi - timelib_tzinfo *timelib_parse_tzfile(char *timezone, const timelib_tzdb *tzdb) - { - const unsigned char *tzf; -+ char *memmap = NULL; -+ size_t maplen; - timelib_tzinfo *tmp; - int version; - -- if (seek_to_tz_position(&tzf, timezone, tzdb)) { -+ if (seek_to_tz_position(&tzf, timezone, &memmap, &maplen, tzdb)) { - tmp = timelib_tzinfo_ctor(timezone); - - version = read_preamble(&tzf, tmp); - read_header(&tzf, tmp); - read_transistions(&tzf, tmp); - read_types(&tzf, tmp); -- if (version == 2) { -- skip_64bit_preamble(&tzf, tmp); -- read_64bit_header(&tzf, tmp); -- skip_64bit_transistions(&tzf, tmp); -- skip_64bit_types(&tzf, tmp); -- skip_posix_string(&tzf, tmp); -- } -- read_location(&tzf, tmp); -+ -+#ifdef HAVE_SYSTEM_TZDATA -+ if (memmap) { -+ const struct location_info *li; -+ -+ /* TZif-style - grok the location info from the system database, -+ * if possible. */ -+ -+ if ((li = find_zone_info(system_location_table, timezone)) != NULL) { -+ tmp->location.comments = timelib_strdup(li->comment); -+ strncpy(tmp->location.country_code, li->code, 2); -+ tmp->location.longitude = li->longitude; -+ tmp->location.latitude = li->latitude; -+ tmp->bc = 1; -+ } -+ else { -+ strcpy(tmp->location.country_code, "??"); -+ tmp->bc = 0; -+ tmp->location.comments = timelib_strdup(""); -+ } -+ -+ /* Now done with the mmap segment - discard it. */ -+ munmap(memmap, maplen); -+ } else -+#endif -+ { -+ /* PHP-style - use the embedded info. */ -+ if (version == 2) { -+ skip_64bit_preamble(&tzf, tmp); -+ read_64bit_header(&tzf, tmp); -+ skip_64bit_transistions(&tzf, tmp); -+ skip_64bit_types(&tzf, tmp); -+ skip_posix_string(&tzf, tmp); -+ } -+ read_location(&tzf, tmp); -+ } - } else { - tmp = NULL; - } -diff -up php-7.1.0RC4/ext/date/lib/timelib.m4.systzdata php-7.1.0RC4/ext/date/lib/timelib.m4 ---- php-7.1.0RC4/ext/date/lib/timelib.m4.systzdata 2016-10-17 13:40:47.807358679 +0200 -+++ php-7.1.0RC4/ext/date/lib/timelib.m4 2016-10-17 13:42:06.304743330 +0200 -@@ -78,3 +78,16 @@ stdlib.h - - dnl Check for strtoll, atoll - AC_CHECK_FUNCS(strtoll atoll strftime gettimeofday) -+ -+PHP_ARG_WITH(system-tzdata, for use of system timezone data, -+[ --with-system-tzdata[=DIR] to specify use of system timezone data], -+no, no) -+ -+if test "$PHP_SYSTEM_TZDATA" != "no"; then -+ AC_DEFINE(HAVE_SYSTEM_TZDATA, 1, [Define if system timezone data is used]) -+ -+ if test "$PHP_SYSTEM_TZDATA" != "yes"; then -+ AC_DEFINE_UNQUOTED(HAVE_SYSTEM_TZDATA_PREFIX, "$PHP_SYSTEM_TZDATA", -+ [Define for location of system timezone data]) -+ fi -+fi diff --git a/php-7.2.0-fixheader.patch b/php-7.2.0-fixheader.patch new file mode 100644 index 0000000..bc822fd --- /dev/null +++ b/php-7.2.0-fixheader.patch @@ -0,0 +1,15 @@ +--- php-7.2.0/configure.ac.fixheader 2017-04-12 09:42:21.510812285 +0200 ++++ php-7.2.0/configure.ac 2017-04-12 09:43:45.055224385 +0200 +@@ -1263,10 +1263,10 @@ + EXTRA_LDFLAGS="$EXTRA_LDFLAGS $PHP_LDFLAGS" + EXTRA_LDFLAGS_PROGRAM="$EXTRA_LDFLAGS_PROGRAM $PHP_LDFLAGS" + +-PHP_BUILD_DATE=`date '+%Y-%m-%d'` ++PHP_BUILD_DATE=`date '+%Y-%m-%d' -r $srcdir/NEWS` + AC_DEFINE_UNQUOTED(PHP_BUILD_DATE,"$PHP_BUILD_DATE",[PHP build date]) + +-PHP_UNAME=`uname -a | xargs` ++PHP_UNAME=`uname | xargs` + AC_DEFINE_UNQUOTED(PHP_UNAME,"$PHP_UNAME",[uname -a output]) + PHP_OS=`uname | xargs` + AC_DEFINE_UNQUOTED(PHP_OS,"$PHP_OS",[uname output]) diff --git a/php-7.2.0-includedir.patch b/php-7.2.0-includedir.patch new file mode 100644 index 0000000..6d9a871 --- /dev/null +++ b/php-7.2.0-includedir.patch @@ -0,0 +1,11 @@ +--- php-7.2.0/configure.ac.includedir ++++ php-7.2.0/configure.ac +@@ -1230,7 +1230,7 @@ + EXPANDED_DATADIR=$datadir + EXPANDED_PHP_CONFIG_FILE_PATH=`eval echo "$PHP_CONFIG_FILE_PATH"` + EXPANDED_PHP_CONFIG_FILE_SCAN_DIR=`eval echo "$PHP_CONFIG_FILE_SCAN_DIR"` +-INCLUDE_PATH=.:$EXPANDED_PEAR_INSTALLDIR ++INCLUDE_PATH=.:$EXPANDED_PEAR_INSTALLDIR:${EXPANDED_DATADIR}/php + + exec_prefix=$old_exec_prefix + libdir=$old_libdir diff --git a/php-7.2.0-oci8conf.patch b/php-7.2.0-oci8conf.patch new file mode 100644 index 0000000..0ad16a1 --- /dev/null +++ b/php-7.2.0-oci8conf.patch @@ -0,0 +1,35 @@ +diff -up ./ext/ldap/php_ldap.h.remi-oci8 ./ext/ldap/php_ldap.h +--- ./ext/ldap/php_ldap.h.remi-oci8 2017-06-20 15:45:35.000000000 +0200 ++++ ./ext/ldap/php_ldap.h 2017-06-20 16:55:01.640203868 +0200 +@@ -27,7 +27,7 @@ + #include + #endif + +-#include ++#include "/usr/include/ldap.h" + + extern zend_module_entry ldap_module_entry; + #define ldap_module_ptr &ldap_module_entry +diff -up ./ext/oci8/config.m4.remi-oci8 ./ext/oci8/config.m4 +--- ./ext/oci8/config.m4.remi-oci8 2017-06-20 15:45:39.000000000 +0200 ++++ ./ext/oci8/config.m4 2017-06-20 16:55:01.640203868 +0200 +@@ -372,6 +372,7 @@ if test "$PHP_OCI8" != "no"; then + + dnl Header directory for Instant Client SDK RPM install + OCISDKRPMINC=`echo "$PHP_OCI8_INSTANT_CLIENT" | $PHP_OCI8_SED -e 's!^/usr/lib/oracle/\(.*\)/client\('${PHP_OCI8_IC_LIBDIR_SUFFIX}'\)*/lib[/]*$!/usr/include/oracle/\1/client\2!'` ++ OCISDKRPMINC=`echo "$PHP_OCI8_INSTANT_CLIENT" | $PHP_OCI8_SED -e 's!^/usr/\(lib64\|lib\)/oracle/\(.*\)/\(client64\|client\)/lib[/]*$!/usr/include/oracle/\2/\3!'` + + dnl Header directory for Instant Client SDK zip file install + OCISDKZIPINC=$PHP_OCI8_INSTANT_CLIENT/sdk/include +diff -up ./ext/pdo_oci/config.m4.remi-oci8 ./ext/pdo_oci/config.m4 +--- ./ext/pdo_oci/config.m4.remi-oci8 2017-06-20 16:55:01.640203868 +0200 ++++ ./ext/pdo_oci/config.m4 2017-06-20 17:16:03.053538358 +0200 +@@ -93,7 +93,7 @@ if test "$PHP_PDO_OCI" != "no"; then + + AC_MSG_CHECKING([for oci.h]) + dnl Header directory for Instant Client SDK RPM install +- OCISDKRPMINC=`echo "$PDO_OCI_LIB_DIR" | $PHP_PDO_OCI_SED -e 's!^\(.*\)/lib/oracle/\(.*\)/\('${PDO_OCI_CLIENT_DIR}'\)/lib[/]*$!\1/include/oracle/\2/\3!'` ++ OCISDKRPMINC=`echo "$PDO_OCI_LIB_DIR" | $PHP_PDO_OCI_SED -e 's!^\(.*\)/\(lib64\|lib\)/oracle/\(.*\)/\('${PDO_OCI_CLIENT_DIR}'\)/lib[/]*$!\1/include/oracle/\3/\4!'` + + dnl Header directory for manual installation + OCISDKMANINC=`echo "$PDO_OCI_LIB_DIR" | $PHP_PDO_OCI_SED -e 's!^\(.*\)/lib[/]*$!\1/include!'` diff --git a/php-7.2.0-systzdata-v15.patch b/php-7.2.0-systzdata-v15.patch new file mode 100644 index 0000000..97fd734 --- /dev/null +++ b/php-7.2.0-systzdata-v15.patch @@ -0,0 +1,653 @@ +# License: MIT +# http://opensource.org/licenses/MIT + +Add support for use of the system timezone database, rather +than embedding a copy. Discussed upstream but was not desired. + +History: +r15: adapt for timelib 2017.05beta7 (in 7.2.0RC1) +r14: improve check for valid tz file +r13: adapt for upstream changes to use PHP allocator +r12: adapt for upstream changes for new zic +r11: use canonical names to avoid more case sensitivity issues + round lat/long from zone.tab towards zero per builtin db +r10: make timezone case insensitive +r9: fix another compile error without --with-system-tzdata configured (Michael Heimpold) +r8: fix compile error without --with-system-tzdata configured +r7: improve check for valid timezone id to exclude directories +r6: fix fd leak in r5, fix country code/BC flag use in + timezone_identifiers_list() using system db, + fix use of PECL timezonedb to override system db, +r5: reverts addition of "System/Localtime" fake tzname. + updated for 5.3.0, parses zone.tab to pick up mapping between + timezone name, country code and long/lat coords +r4: added "System/Localtime" tzname which uses /etc/localtime +r3: fix a crash if /usr/share/zoneinfo doesn't exist (Raphael Geissert) +r2: add filesystem trawl to set up name alias index +r1: initial revision + +diff -up ./ext/date/lib/parse_tz.c.systzdata ./ext/date/lib/parse_tz.c +--- ./ext/date/lib/parse_tz.c.systzdata 2017-08-22 09:40:38.000000000 +0200 ++++ ./ext/date/lib/parse_tz.c 2017-08-22 12:16:00.370298079 +0200 +@@ -25,8 +25,21 @@ + #include "timelib.h" + #include "timelib_private.h" + ++#ifdef HAVE_SYSTEM_TZDATA ++#include ++#include ++#include ++#include ++#include ++ ++#include "php_scandir.h" ++ ++#else + #define TIMELIB_SUPPORTS_V2DATA + #include "timezonedb.h" ++#endif ++ ++#include + + #if (defined(__APPLE__) || defined(__APPLE_CC__)) && (defined(__BIG_ENDIAN__) || defined(__LITTLE_ENDIAN__)) + # if defined(__LITTLE_ENDIAN__) +@@ -67,6 +80,11 @@ static int read_php_preamble(const unsig + { + uint32_t version; + ++ if (memcmp(*tzf, "TZif", 4) == 0) { ++ *tzf += 20; ++ return 0; ++ } ++ + /* read ID */ + version = (*tzf)[3] - '0'; + *tzf += 4; +@@ -374,7 +392,429 @@ void timelib_dump_tzinfo(timelib_tzinfo + } + } + +-static int seek_to_tz_position(const unsigned char **tzf, char *timezone, const timelib_tzdb *tzdb) ++#ifdef HAVE_SYSTEM_TZDATA ++ ++#ifdef HAVE_SYSTEM_TZDATA_PREFIX ++#define ZONEINFO_PREFIX HAVE_SYSTEM_TZDATA_PREFIX ++#else ++#define ZONEINFO_PREFIX "/usr/share/zoneinfo" ++#endif ++ ++/* System timezone database pointer. */ ++static const timelib_tzdb *timezonedb_system; ++ ++/* Hash table entry for the cache of the zone.tab mapping table. */ ++struct location_info { ++ char code[2]; ++ double latitude, longitude; ++ char name[64]; ++ char *comment; ++ struct location_info *next; ++}; ++ ++/* Cache of zone.tab. */ ++static struct location_info **system_location_table; ++ ++/* Size of the zone.tab hash table; a random-ish prime big enough to ++ * prevent too many collisions. */ ++#define LOCINFO_HASH_SIZE (1021) ++ ++/* Compute a case insensitive hash of str */ ++static uint32_t tz_hash(const char *str) ++{ ++ const unsigned char *p = (const unsigned char *)str; ++ uint32_t hash = 5381; ++ int c; ++ ++ while ((c = tolower(*p++)) != '\0') { ++ hash = (hash << 5) ^ hash ^ c; ++ } ++ ++ return hash % LOCINFO_HASH_SIZE; ++} ++ ++/* Parse an ISO-6709 date as used in zone.tab. Returns end of the ++ * parsed string on success, or NULL on parse error. On success, ++ * writes the parsed number to *result. */ ++static char *parse_iso6709(char *p, double *result) ++{ ++ double v, sign; ++ char *pend; ++ size_t len; ++ ++ if (*p == '+') ++ sign = 1.0; ++ else if (*p == '-') ++ sign = -1.0; ++ else ++ return NULL; ++ ++ p++; ++ for (pend = p; *pend >= '0' && *pend <= '9'; pend++) ++ ;; ++ ++ /* Annoying encoding used by zone.tab has no decimal point, so use ++ * the length to determine the format: ++ * ++ * 4 = DDMM ++ * 5 = DDDMM ++ * 6 = DDMMSS ++ * 7 = DDDMMSS ++ */ ++ len = pend - p; ++ if (len < 4 || len > 7) { ++ return NULL; ++ } ++ ++ /* p => [D]DD */ ++ v = (p[0] - '0') * 10.0 + (p[1] - '0'); ++ p += 2; ++ if (len == 5 || len == 7) ++ v = v * 10.0 + (*p++ - '0'); ++ /* p => MM[SS] */ ++ v += (10.0 * (p[0] - '0') ++ + p[1] - '0') / 60.0; ++ p += 2; ++ /* p => [SS] */ ++ if (len > 5) { ++ v += (10.0 * (p[0] - '0') ++ + p[1] - '0') / 3600.0; ++ p += 2; ++ } ++ ++ /* Round to five decimal place, not because it's a good idea, ++ * but, because the builtin data uses rounded data, so, match ++ * that. */ ++ *result = trunc(v * sign * 100000.0) / 100000.0; ++ ++ return p; ++} ++ ++/* This function parses the zone.tab file to build up the mapping of ++ * timezone to country code and geographic location, and returns a ++ * hash table. The hash table is indexed by the function: ++ * ++ * tz_hash(timezone-name) ++ */ ++static struct location_info **create_location_table(void) ++{ ++ struct location_info **li, *i; ++ char zone_tab[PATH_MAX]; ++ char line[512]; ++ FILE *fp; ++ ++ strncpy(zone_tab, ZONEINFO_PREFIX "/zone.tab", sizeof zone_tab); ++ ++ fp = fopen(zone_tab, "r"); ++ if (!fp) { ++ return NULL; ++ } ++ ++ li = calloc(LOCINFO_HASH_SIZE, sizeof *li); ++ ++ while (fgets(line, sizeof line, fp)) { ++ char *p = line, *code, *name, *comment; ++ uint32_t hash; ++ double latitude, longitude; ++ ++ while (isspace(*p)) ++ p++; ++ ++ if (*p == '#' || *p == '\0' || *p == '\n') ++ continue; ++ ++ if (!isalpha(p[0]) || !isalpha(p[1]) || p[2] != '\t') ++ continue; ++ ++ /* code => AA */ ++ code = p; ++ p[2] = 0; ++ p += 3; ++ ++ /* coords => [+-][D]DDMM[SS][+-][D]DDMM[SS] */ ++ p = parse_iso6709(p, &latitude); ++ if (!p) { ++ continue; ++ } ++ p = parse_iso6709(p, &longitude); ++ if (!p) { ++ continue; ++ } ++ ++ if (!p || *p != '\t') { ++ continue; ++ } ++ ++ /* name = string */ ++ name = ++p; ++ while (*p != '\t' && *p && *p != '\n') ++ p++; ++ ++ *p++ = '\0'; ++ ++ /* comment = string */ ++ comment = p; ++ while (*p != '\t' && *p && *p != '\n') ++ p++; ++ ++ if (*p == '\n' || *p == '\t') ++ *p = '\0'; ++ ++ hash = tz_hash(name); ++ i = malloc(sizeof *i); ++ memcpy(i->code, code, 2); ++ strncpy(i->name, name, sizeof i->name); ++ i->comment = strdup(comment); ++ i->longitude = longitude; ++ i->latitude = latitude; ++ i->next = li[hash]; ++ li[hash] = i; ++ /* printf("%s [%u, %f, %f]\n", name, hash, latitude, longitude); */ ++ } ++ ++ fclose(fp); ++ ++ return li; ++} ++ ++/* Return location info from hash table, using given timezone name. ++ * Returns NULL if the name could not be found. */ ++const struct location_info *find_zone_info(struct location_info **li, ++ const char *name) ++{ ++ uint32_t hash = tz_hash(name); ++ const struct location_info *l; ++ ++ if (!li) { ++ return NULL; ++ } ++ ++ for (l = li[hash]; l; l = l->next) { ++ if (strcasecmp(l->name, name) == 0) ++ return l; ++ } ++ ++ return NULL; ++} ++ ++/* Filter out some non-tzdata files and the posix/right databases, if ++ * present. */ ++static int index_filter(const struct dirent *ent) ++{ ++ return strcmp(ent->d_name, ".") != 0 ++ && strcmp(ent->d_name, "..") != 0 ++ && strcmp(ent->d_name, "posix") != 0 ++ && strcmp(ent->d_name, "posixrules") != 0 ++ && strcmp(ent->d_name, "right") != 0 ++ && strstr(ent->d_name, ".list") == NULL ++ && strstr(ent->d_name, ".tab") == NULL; ++} ++ ++static int sysdbcmp(const void *first, const void *second) ++{ ++ const timelib_tzdb_index_entry *alpha = first, *beta = second; ++ ++ return strcasecmp(alpha->id, beta->id); ++} ++ ++ ++/* Create the zone identifier index by trawling the filesystem. */ ++static void create_zone_index(timelib_tzdb *db) ++{ ++ size_t dirstack_size, dirstack_top; ++ size_t index_size, index_next; ++ timelib_tzdb_index_entry *db_index; ++ char **dirstack; ++ ++ /* LIFO stack to hold directory entries to scan; each slot is a ++ * directory name relative to the zoneinfo prefix. */ ++ dirstack_size = 32; ++ dirstack = malloc(dirstack_size * sizeof *dirstack); ++ dirstack_top = 1; ++ dirstack[0] = strdup(""); ++ ++ /* Index array. */ ++ index_size = 64; ++ db_index = malloc(index_size * sizeof *db_index); ++ index_next = 0; ++ ++ do { ++ struct dirent **ents; ++ char name[PATH_MAX], *top; ++ int count; ++ ++ /* Pop the top stack entry, and iterate through its contents. */ ++ top = dirstack[--dirstack_top]; ++ snprintf(name, sizeof name, ZONEINFO_PREFIX "/%s", top); ++ ++ count = php_scandir(name, &ents, index_filter, php_alphasort); ++ ++ while (count > 0) { ++ struct stat st; ++ const char *leaf = ents[count - 1]->d_name; ++ ++ snprintf(name, sizeof name, ZONEINFO_PREFIX "/%s/%s", ++ top, leaf); ++ ++ if (strlen(name) && stat(name, &st) == 0) { ++ /* Name, relative to the zoneinfo prefix. */ ++ const char *root = top; ++ ++ if (root[0] == '/') root++; ++ ++ snprintf(name, sizeof name, "%s%s%s", root, ++ *root ? "/": "", leaf); ++ ++ if (S_ISDIR(st.st_mode)) { ++ if (dirstack_top == dirstack_size) { ++ dirstack_size *= 2; ++ dirstack = realloc(dirstack, ++ dirstack_size * sizeof *dirstack); ++ } ++ dirstack[dirstack_top++] = strdup(name); ++ } ++ else { ++ if (index_next == index_size) { ++ index_size *= 2; ++ db_index = realloc(db_index, ++ index_size * sizeof *db_index); ++ } ++ ++ db_index[index_next++].id = strdup(name); ++ } ++ } ++ ++ free(ents[--count]); ++ } ++ ++ if (count != -1) free(ents); ++ free(top); ++ } while (dirstack_top); ++ ++ qsort(db_index, index_next, sizeof *db_index, sysdbcmp); ++ ++ db->index = db_index; ++ db->index_size = index_next; ++ ++ free(dirstack); ++} ++ ++#define FAKE_HEADER "1234\0??\1??" ++#define FAKE_UTC_POS (7 - 4) ++ ++/* Create a fake data segment for database 'sysdb'. */ ++static void fake_data_segment(timelib_tzdb *sysdb, ++ struct location_info **info) ++{ ++ size_t n; ++ char *data, *p; ++ ++ data = malloc(3 * sysdb->index_size + 7); ++ ++ p = mempcpy(data, FAKE_HEADER, sizeof(FAKE_HEADER) - 1); ++ ++ for (n = 0; n < sysdb->index_size; n++) { ++ const struct location_info *li; ++ timelib_tzdb_index_entry *ent; ++ ++ ent = (timelib_tzdb_index_entry *)&sysdb->index[n]; ++ ++ /* Lookup the timezone name in the hash table. */ ++ if (strcmp(ent->id, "UTC") == 0) { ++ ent->pos = FAKE_UTC_POS; ++ continue; ++ } ++ ++ li = find_zone_info(info, ent->id); ++ if (li) { ++ /* If found, append the BC byte and the ++ * country code; set the position for this ++ * section of timezone data. */ ++ ent->pos = (p - data) - 4; ++ *p++ = '\1'; ++ *p++ = li->code[0]; ++ *p++ = li->code[1]; ++ } ++ else { ++ /* If not found, the timezone data can ++ * point at the header. */ ++ ent->pos = 0; ++ } ++ } ++ ++ sysdb->data = (unsigned char *)data; ++} ++ ++/* Returns true if the passed-in stat structure describes a ++ * probably-valid timezone file. */ ++static int is_valid_tzfile(const struct stat *st, int fd) ++{ ++ if (fd) { ++ char buf[20]; ++ if (read(fd, buf, 20)!=20) { ++ return 0; ++ } ++ lseek(fd, SEEK_SET, 0); ++ if (memcmp(buf, "TZif", 4)) { ++ return 0; ++ } ++ } ++ return S_ISREG(st->st_mode) && st->st_size > 20; ++} ++ ++/* To allow timezone names to be used case-insensitively, find the ++ * canonical name for this timezone, if possible. */ ++static const char *canonical_tzname(const char *timezone) ++{ ++ if (timezonedb_system) { ++ timelib_tzdb_index_entry *ent, lookup; ++ ++ lookup.id = (char *)timezone; ++ ++ ent = bsearch(&lookup, timezonedb_system->index, ++ timezonedb_system->index_size, sizeof lookup, ++ sysdbcmp); ++ if (ent) { ++ return ent->id; ++ } ++ } ++ ++ return timezone; ++} ++ ++/* Return the mmap()ed tzfile if found, else NULL. On success, the ++ * length of the mapped data is placed in *length. */ ++static char *map_tzfile(const char *timezone, size_t *length) ++{ ++ char fname[PATH_MAX]; ++ struct stat st; ++ char *p; ++ int fd; ++ ++ if (timezone[0] == '\0' || strstr(timezone, "..") != NULL) { ++ return NULL; ++ } ++ ++ snprintf(fname, sizeof fname, ZONEINFO_PREFIX "/%s", canonical_tzname(timezone)); ++ ++ fd = open(fname, O_RDONLY); ++ if (fd == -1) { ++ return NULL; ++ } else if (fstat(fd, &st) != 0 || !is_valid_tzfile(&st, fd)) { ++ close(fd); ++ return NULL; ++ } ++ ++ *length = st.st_size; ++ p = mmap(NULL, st.st_size, PROT_READ, MAP_SHARED, fd, 0); ++ close(fd); ++ ++ return p != MAP_FAILED ? p : NULL; ++} ++ ++#endif ++ ++static int inmem_seek_to_tz_position(const unsigned char **tzf, char *timezone, const timelib_tzdb *tzdb) + { + int left = 0, right = tzdb->index_size - 1; + #ifdef HAVE_SETLOCALE +@@ -419,9 +859,48 @@ static int seek_to_tz_position(const uns + return 0; + } + ++static int seek_to_tz_position(const unsigned char **tzf, char *timezone, ++ char **map, size_t *maplen, ++ const timelib_tzdb *tzdb) ++{ ++#ifdef HAVE_SYSTEM_TZDATA ++ if (tzdb == timezonedb_system) { ++ char *orig; ++ ++ orig = map_tzfile(timezone, maplen); ++ if (orig == NULL) { ++ return 0; ++ } ++ ++ (*tzf) = (unsigned char *)orig; ++ *map = orig; ++ return 1; ++ } ++ else ++#endif ++ { ++ return inmem_seek_to_tz_position(tzf, timezone, tzdb); ++ } ++} ++ + const timelib_tzdb *timelib_builtin_db(void) + { ++#ifdef HAVE_SYSTEM_TZDATA ++ if (timezonedb_system == NULL) { ++ timelib_tzdb *tmp = malloc(sizeof *tmp); ++ ++ tmp->version = "0.system"; ++ tmp->data = NULL; ++ create_zone_index(tmp); ++ system_location_table = create_location_table(); ++ fake_data_segment(tmp, system_location_table); ++ timezonedb_system = tmp; ++ } ++ ++ return timezonedb_system; ++#else + return &timezonedb_builtin; ++#endif + } + + const timelib_tzdb_index_entry *timelib_timezone_identifiers_list(timelib_tzdb *tzdb, int *count) +@@ -433,7 +912,30 @@ const timelib_tzdb_index_entry *timelib_ + int timelib_timezone_id_is_valid(char *timezone, const timelib_tzdb *tzdb) + { + const unsigned char *tzf; +- return (seek_to_tz_position(&tzf, timezone, tzdb)); ++ ++#ifdef HAVE_SYSTEM_TZDATA ++ if (tzdb == timezonedb_system) { ++ char fname[PATH_MAX]; ++ struct stat st; ++ ++ if (timezone[0] == '\0' || strstr(timezone, "..") != NULL) { ++ return 0; ++ } ++ ++ if (system_location_table) { ++ if (find_zone_info(system_location_table, timezone) != NULL) { ++ /* found in cache */ ++ return 1; ++ } ++ } ++ ++ snprintf(fname, sizeof fname, ZONEINFO_PREFIX "/%s", canonical_tzname(timezone)); ++ ++ return stat(fname, &st) == 0 && is_valid_tzfile(&st, 0); ++ } ++#endif ++ ++ return (inmem_seek_to_tz_position(&tzf, timezone, tzdb)); + } + + static int skip_64bit_preamble(const unsigned char **tzf, timelib_tzinfo *tz) +@@ -475,12 +977,14 @@ static timelib_tzinfo* timelib_tzinfo_ct + timelib_tzinfo *timelib_parse_tzfile(char *timezone, const timelib_tzdb *tzdb, int *error_code) + { + const unsigned char *tzf; ++ char *memmap = NULL; ++ size_t maplen; + timelib_tzinfo *tmp; + int version; + int transitions_result, types_result; + unsigned int type; /* TIMELIB_TZINFO_PHP or TIMELIB_TZINFO_ZONEINFO */ + +- if (seek_to_tz_position(&tzf, timezone, tzdb)) { ++ if (seek_to_tz_position(&tzf, timezone, &memmap, &maplen, tzdb)) { + tmp = timelib_tzinfo_ctor(timezone); + + version = read_preamble(&tzf, tmp, &type); +@@ -503,6 +1007,29 @@ timelib_tzinfo *timelib_parse_tzfile(cha + timelib_tzinfo_dtor(tmp); + return NULL; + } ++ ++#ifdef HAVE_SYSTEM_TZDATA ++ if (memmap) { ++ const struct location_info *li; ++ ++ /* TZif-style - grok the location info from the system database, ++ * if possible. */ ++ ++ if ((li = find_zone_info(system_location_table, timezone)) != NULL) { ++ tmp->location.comments = timelib_strdup(li->comment); ++ strncpy(tmp->location.country_code, li->code, 2); ++ tmp->location.longitude = li->longitude; ++ tmp->location.latitude = li->latitude; ++ tmp->bc = 1; ++ } ++ else { ++ set_default_location_and_comments(&tzf, tmp); ++ } ++ ++ /* Now done with the mmap segment - discard it. */ ++ munmap(memmap, maplen); ++ } else { ++#endif + if (version == 2 || version == 3) { + if (!skip_64bit_preamble(&tzf, tmp)) { + /* 64 bit preamble is not in place */ +@@ -520,6 +1047,9 @@ timelib_tzinfo *timelib_parse_tzfile(cha + } else { + set_default_location_and_comments(&tzf, tmp); + } ++#ifdef HAVE_SYSTEM_TZDATA ++ } ++#endif + } else { + *error_code = TIMELIB_ERROR_NO_SUCH_TIMEZONE; + tmp = NULL; +diff -up ./ext/date/lib/timelib.m4.systzdata ./ext/date/lib/timelib.m4 +--- ./ext/date/lib/timelib.m4.systzdata 2017-08-22 09:40:38.000000000 +0200 ++++ ./ext/date/lib/timelib.m4 2017-08-22 11:32:29.357799927 +0200 +@@ -81,3 +81,16 @@ io.h + + dnl Check for strtoll, atoll + AC_CHECK_FUNCS(strtoll atoll strftime gettimeofday) ++ ++PHP_ARG_WITH(system-tzdata, for use of system timezone data, ++[ --with-system-tzdata[=DIR] to specify use of system timezone data], ++no, no) ++ ++if test "$PHP_SYSTEM_TZDATA" != "no"; then ++ AC_DEFINE(HAVE_SYSTEM_TZDATA, 1, [Define if system timezone data is used]) ++ ++ if test "$PHP_SYSTEM_TZDATA" != "yes"; then ++ AC_DEFINE_UNQUOTED(HAVE_SYSTEM_TZDATA_PREFIX, "$PHP_SYSTEM_TZDATA", ++ [Define for location of system timezone data]) ++ fi ++fi diff --git a/php-fpm.conf b/php-fpm.conf index 55dc684..29ec0d9 100644 --- a/php-fpm.conf +++ b/php-fpm.conf @@ -49,7 +49,7 @@ error_log = /var/log/php-fpm/error.log ; Default Value: 0 ;emergency_restart_threshold = 0 -; Interval of time used by emergency_restart_interval to determine when +; Interval of time used by emergency_restart_interval to determine when ; a graceful restart will be initiated. This can be useful to work around ; accidental corruptions in an accelerator's shared memory. ; Available Units: s(econds), m(inutes), h(ours), or d(ays) @@ -63,7 +63,7 @@ error_log = /var/log/php-fpm/error.log ; Default Value: 0 ;process_control_timeout = 0 -; The maximum number of processes FPM will fork. This has been design to control +; The maximum number of processes FPM will fork. This has been designed to control ; the global number of processes when using dynamic PM within a lot of pools. ; Use it with caution. ; Note: A value of 0 indicates no limit @@ -71,10 +71,10 @@ error_log = /var/log/php-fpm/error.log ;process.max = 128 ; Specify the nice(2) priority to apply to the master process (only if set) -; The value can vary from -19 (highest priority) to 20 (lower priority) +; The value can vary from -19 (highest priority) to 20 (lowest priority) ; Note: - It will only work if the FPM master process is launched as root ; - The pool process will inherit the master process priority -; unless it specified otherwise +; unless specified otherwise ; Default Value: no set ;process.priority = -19 @@ -98,8 +98,8 @@ daemonize = yes ; Default Value: not set (auto detection) ;events.mechanism = epoll -; When FPM is build with systemd integration, specify the interval, -; in second, between health report notification to systemd. +; When FPM is built with systemd integration, specify the interval, +; in seconds, between health report notification to systemd. ; Set to 0 to disable. ; Available Units: s(econds), m(inutes), h(ours) ; Default Unit: seconds @@ -107,7 +107,7 @@ daemonize = yes ;systemd_interval = 10 ;;;;;;;;;;;;;;;;;;;; -; Pool Definitions ; +; Pool Definitions ; ;;;;;;;;;;;;;;;;;;;; ; Multiple pools of child processes may be started with different listening diff --git a/php-timelib.patch b/php-timelib.patch new file mode 100644 index 0000000..dd8d8cf --- /dev/null +++ b/php-timelib.patch @@ -0,0 +1,30 @@ +diff --git a/timelib_private.h b/timelib_private.h +index cd402e0..efc7c80 100644 +--- a/ext/date/lib/timelib_private.h ++++ b/ext/date/lib/timelib_private.h +@@ -115,7 +115,7 @@ + m = NULL; \ + } + +-typedef struct ttinfo ++struct ttinfo + { + int32_t offset; + int isdst; +@@ -123,13 +123,13 @@ typedef struct ttinfo + + unsigned int isstdcnt; + unsigned int isgmtcnt; +-} ttinfo; ++}; + +-typedef struct tlinfo ++struct tlinfo + { + int32_t trans; + int32_t offset; +-} tlinfo; ++}; + + + #ifndef LONG_MAX diff --git a/php.conf b/php.conf index 38f54ae..d192ccf 100644 --- a/php.conf +++ b/php.conf @@ -28,7 +28,7 @@ DirectoryIndex index.php # # Cause the PHP interpreter to handle files with a .php extension. # - + SetHandler application/x-httpd-php diff --git a/php.conf2 b/php.conf2 index fc6de6f..aeed80f 100644 --- a/php.conf2 +++ b/php.conf2 @@ -5,7 +5,7 @@ # Enable http authorization headers SetEnvIfNoCase ^Authorization$ "(.+)" HTTP_AUTHORIZATION=$1 - + SetHandler "proxy:fcgi://127.0.0.1:9000" diff --git a/php.ini b/php.ini index fc457f2..ecc660c 100644 --- a/php.ini +++ b/php.ini @@ -294,7 +294,7 @@ implicit_flush = Off ; callback-function. unserialize_callback_func = -; When floats & doubles are serialized store serialize_precision significant +; When floats & doubles are serialized, store serialize_precision significant ; digits after the floating point. The default value ensures that when floats ; are decoded with unserialize, the data will remain the same. ; The value is also used for json_encode when encoding double values. @@ -338,7 +338,7 @@ disable_classes = ; be increased on systems where PHP opens many files to reflect the quantity of ; the file operations performed. ; http://php.net/realpath-cache-size -;realpath_cache_size = 16k +;realpath_cache_size = 4096k ; Duration of time, in seconds for which to cache realpath information for a given ; file or directory. For systems with rarely changing files, consider increasing this @@ -525,11 +525,12 @@ report_memleaks = On ; Store the last error/warning message in $php_errormsg (boolean). Setting this value ; to On can assist in debugging and is appropriate for development servers. It should ; however be disabled on production servers. +; This directive is DEPRECATED. ; Default Value: Off -; Development Value: On +; Development Value: Off ; Production Value: Off ; http://php.net/track-errors -track_errors = Off +;track_errors = Off ; Turn off normal error reporting and emit XML-RPC error XML ; http://php.net/xmlrpc-errors @@ -866,22 +867,21 @@ default_socket_timeout = 60 ; If you wish to have an extension loaded automatically, use the following ; syntax: ; -; extension=modulename.extension -; -; For example, on Windows: -; -; extension=msql.dll +; extension=modulename ; -; ... or under UNIX: +; For example: ; -; extension=msql.so +; extension=mysqli ; -; ... or with a path: +; When the extension library to load is not located in the default extension +; directory, You may specify an absolute path to the library file: ; -; extension=/path/to/extension/msql.so +; extension=/path/to/extension/mysqli.so ; -; If you only provide the name of the extension, PHP will look for it in its -; default extension directory. +; Note : The syntax used in previous PHP versions ('extension=.so' and +; 'extension='php_.dll') is supported for legacy reasons and may be +; deprecated in a future PHP major version. So, when it is possible, please +; move to the new ('extension=) syntax. ;;;; ; Note: packaged extension modules are now loaded via the .ini files @@ -1010,10 +1010,6 @@ mail.add_x_header = On ; Log mail to syslog; ;mail.log = syslog -[SQL] -; http://php.net/sql.safe-mode -sql.safe_mode = Off - [ODBC] ; http://php.net/odbc.default-db ;odbc.default_db = Not yet implemented @@ -1646,17 +1642,6 @@ soap.wsdl_cache_limit = 5 ; Sets the maximum number of open links or -1 for unlimited. ldap.max_links = -1 -[mcrypt] -; For more information about mcrypt settings see http://php.net/mcrypt-module-open - -; Directory where to load mcrypt algorithms -; Default: Compiled in into libmcrypt (usually /usr/local/lib/libmcrypt) -;mcrypt.algorithms_dir= - -; Directory where to load mcrypt modes -; Default: Compiled in into libmcrypt (usually /usr/local/lib/libmcrypt) -;mcrypt.modes_dir= - [dba] ;dba.default_handler= diff --git a/php71.spec b/php71.spec deleted file mode 100644 index 4921043..0000000 --- a/php71.spec +++ /dev/null @@ -1,3085 +0,0 @@ -# remirepo spec file for php 7.1 -# with backport stuff, adapted from -# -# Fedora spec file for php -# -# License: MIT -# http://opensource.org/licenses/MIT -# -# Please preserve changelog entries -# -# API/ABI check -%global apiver 20160303 -%global zendver 20160303 -%global pdover 20150127 -# Extension version -%global fileinfover 1.0.5 -%global oci8ver 2.1.7 -%global zipver 1.13.0 -%global jsonver 1.5.0 - -# Adds -z now to the linker flags -%global _hardened_build 1 - -# version used for php embedded library soname -%global embed_version 7.1 - -%global mysql_sock %(mysql_config --socket 2>/dev/null || echo /var/lib/mysql/mysql.sock) - -%ifarch ppc ppc64 -%global oraclever 10.2.0.2 -%else -%global oraclever 12.2 -%endif - -# Build for LiteSpeed Web Server (LSAPI) -%global with_lsws 1 - -# Regression tests take a long time, you can skip 'em with this -#global runselftest 0 -%{!?runselftest: %global runselftest 1} - -# Use the arch-specific mysql_config binary to avoid mismatch with the -# arch detection heuristic used by bindir/mysql_config. -%global mysql_config %{_libdir}/mysql/mysql_config - -# Optional components; pass "--with mssql" etc to rpmbuild. -%global with_oci8 %{?_with_oci8:1}%{!?_with_oci8:0} - -%if 0%{?fedora} >= 22 || 0%{?rhel} >= 8 -%global with_libpcre 1 -%else -%global with_libpcre 0 -%endif - -%global with_sqlite3 1 - -# Build ZTS extension or only NTS -%global with_zts 1 - -# Debuild build -%global with_debug %{?_with_debug:1}%{!?_with_debug:0} - -%if 0%{?__isa_bits:1} -%global isasuffix -%{__isa_bits} -%else -%global isasuffix %nil -%endif - -# /usr/sbin/apsx with httpd < 2.4 and defined as /usr/bin/apxs with httpd >= 2.4 -%{!?_httpd_apxs: %{expand: %%global _httpd_apxs %%{_sbindir}/apxs}} -%{!?_httpd_mmn: %{expand: %%global _httpd_mmn %%(cat %{_includedir}/httpd/.mmn 2>/dev/null || echo 0-0)}} -%{!?_httpd_confdir: %{expand: %%global _httpd_confdir %%{_sysconfdir}/httpd/conf.d}} -# /etc/httpd/conf.d with httpd < 2.4 and defined as /etc/httpd/conf.modules.d with httpd >= 2.4 -%{!?_httpd_modconfdir: %{expand: %%global _httpd_modconfdir %%{_sysconfdir}/httpd/conf.d}} -%{!?_httpd_moddir: %{expand: %%global _httpd_moddir %%{_libdir}/httpd/modules}} -%{!?_httpd_contentdir: %{expand: %%global _httpd_contentdir /var/www}} - -%global macrosdir %(d=%{_rpmconfigdir}/macros.d; [ -d $d ] || d=%{_sysconfdir}/rpm; echo $d) - -# systemd to manage the service, with notify mode, with additional service config -%if 0%{?fedora} >= 19 || 0%{?rhel} >= 7 -%global with_systemd 1 -%else -%global with_systemd 0 -%endif -# httpd 2.4.10 with httpd-filesystem and sethandler support -%if 0%{?fedora} >= 21 -%global with_httpd2410 1 -%else -%global with_httpd2410 0 -%endif -# nginx 1.6 with nginx-filesystem -%if 0%{?fedora} >= 21 -%global with_nginx 1 -%else -%global with_nginx 0 -%endif - -%global with_dtrace 1 -%global with_libgd 1 -%global with_libzip 1 -%global with_zip 0 - -%if 0%{?fedora} < 18 && 0%{?rhel} < 7 -%global db_devel db4-devel -%else -%global db_devel libdb-devel -%endif - -%global upver 7.1.9 -%global rcver RC1 - -Summary: PHP scripting language for creating dynamic web sites -Name: php -Version: %{upver}%{?rcver:~%{rcver}} -Release: 2%{?dist} -# All files licensed under PHP version 3.01, except -# Zend is licensed under Zend -# TSRM is licensed under BSD -# main/snprintf.c, main/spprintf.c and main/rfc1867.c are ASL 1.0 -# ext/date/lib is MIT -License: PHP and Zend and BSD and MIT and ASL 1.0 -Group: Development/Languages -URL: http://www.php.net/ - -Source0: http://www.php.net/distributions/php-%{upver}%{?rcver}.tar.xz -Source1: php.conf -Source2: php.ini -Source3: macros.php -Source4: php-fpm.conf -Source5: php-fpm-www.conf -Source6: php-fpm.service -Source7: php-fpm.logrotate -Source8: php-fpm.sysconfig -Source9: php.modconf -Source10: php.ztsmodconf -Source12: php.conf2 -Source13: nginx-fpm.conf -Source14: nginx-php.conf -# Configuration files for some extensions -Source50: 10-opcache.ini -Source51: opcache-default.blacklist -Source52: 20-oci8.ini -Source99: php-fpm.init - -# Build fixes -Patch1: php-7.1.7-httpd.patch -Patch5: php-7.0.0-includedir.patch -Patch6: php-5.6.3-embed.patch -Patch7: php-5.3.0-recode.patch -Patch8: php-7.0.2-libdb.patch -Patch9: php-7.0.7-curl.patch - -# Functional changes -Patch40: php-7.1.3-dlopen.patch -Patch42: php-7.1.0-systzdata-v14.patch -# See http://bugs.php.net/53436 -Patch43: php-5.4.0-phpize.patch -# Use -lldap_r for OpenLDAP -Patch45: php-5.6.3-ldap_r.patch -# Make php_config.h constant across builds -Patch46: php-7.0.0-fixheader.patch -# drop "Configure command" from phpinfo output -Patch47: php-5.6.3-phpinfo.patch - -# RC Patch -Patch91: php-5.6.3-oci8conf.patch - -# Upstream fixes (100+) - -# Security fixes (200+) - -# Fixes for tests (300+) -# Factory is droped from system tzdata -Patch300: php-7.0.10-datetests.patch -# Revert changes for pcre < 8.34 -Patch301: php-7.0.0-oldpcre.patch - -# WIP - -BuildRequires: bzip2-devel, curl-devel >= 7.9 -BuildRequires: httpd-devel >= 2.0.46-1, pam-devel -%if %{with_httpd2410} -# to ensure we are using httpd with filesystem feature (see #1081453) -BuildRequires: httpd-filesystem -%endif -%if %{with_nginx} -# to ensure we are using nginx with filesystem feature (see #1142298) -BuildRequires: nginx-filesystem -%endif -BuildRequires: %{?dtsprefix}libstdc++-devel, openssl-devel -%if %{with_sqlite3} -# For Sqlite3 extension -BuildRequires: sqlite-devel >= 3.6.0 -%else -BuildRequires: sqlite-devel >= 3.0.0 -%endif -BuildRequires: zlib-devel, smtpdaemon, libedit-devel -%if %{with_libpcre} -BuildRequires: pcre-devel >= 8.20 -%endif -BuildRequires: bzip2, perl, libtool >= 1.4.3, %{?dtsprefix}gcc-c++ -BuildRequires: libtool-ltdl-devel -%if %{with_dtrace} -BuildRequires: %{?dtsprefix}systemtap-sdt-devel -%endif -#BuildRequires: bison - -%if 0%{?rhel} -Obsoletes: php53, php53u, php54w, php55u, php55w, php56u, php56w, mod_php70u, php70w, mod_php71u, mod_php71w -%endif -# Avoid obsoleting php54 from RHSCL -Obsoletes: php54 > 5.4 -%if %{with_zts} -Obsoletes: php-zts < 5.3.7 -Provides: php-zts = %{version}-%{release} -Provides: php-zts%{?_isa} = %{version}-%{release} -%endif - -Requires: httpd-mmn = %{_httpd_mmn} -Provides: mod_php = %{version}-%{release} -Requires: php-common%{?_isa} = %{version}-%{release} -# For backwards-compatibility, require php-cli for the time being: -Requires: php-cli%{?_isa} = %{version}-%{release} -# To ensure correct /var/lib/php/session ownership: -%if %{with_httpd2410} -Requires(pre): httpd-filesystem -%else -Requires(pre): httpd -%endif -# php engine for Apache httpd webserver -Provides: php(httpd) - -%if 0%{?fedora} < 20 && 0%{?rhel} < 7 -# Don't provides extensions, which are not shared library, as .so -%{?filter_provides_in: %filter_provides_in %{_libdir}/php/modules/.*\.so$} -%{?filter_provides_in: %filter_provides_in %{_libdir}/php-zts/modules/.*\.so$} -%{?filter_provides_in: %filter_provides_in %{_httpd_moddir}/.*\.so$} -%{?filter_setup} -%endif - - -%description -PHP is an HTML-embedded scripting language. PHP attempts to make it -easy for developers to write dynamically generated web pages. PHP also -offers built-in database integration for several commercial and -non-commercial database management systems, so writing a -database-enabled webpage with PHP is fairly simple. The most common -use of PHP coding is probably as a replacement for CGI scripts. - -The php package contains the module (often referred to as mod_php) -which adds support for the PHP language to Apache HTTP Server. - -%package cli -Group: Development/Languages -Summary: Command-line interface for PHP -Requires: php-common%{?_isa} = %{version}-%{release} -Provides: php-cgi = %{version}-%{release}, php-cgi%{?_isa} = %{version}-%{release} -Provides: php-pcntl, php-pcntl%{?_isa} -Provides: php-readline, php-readline%{?_isa} -%if 0%{?rhel} -Obsoletes: php53-cli, php53u-cli, php54-cli, php54w-cli, php55u-cli, php55w-cli, php56u-cli, php56w-cli, php70u-cli, php70w-cli, php71u-cli, php71w-cli -%endif - -%description cli -The php-cli package contains the command-line interface -executing PHP scripts, /usr/bin/php, and the CGI interface. - - -%package dbg -Group: Development/Languages -Summary: The interactive PHP debugger -Requires: php-common%{?_isa} = %{version}-%{release} -%if 0%{?rhel} -Obsoletes: php56u-dbg, php56w-dbg, php70u-dbg, php70w-phpdbg, php70u-dbg, php71w-phpdbg -%endif -%description dbg -The php-dbg package contains the interactive PHP debugger. - - -%package fpm -Group: Development/Languages -Summary: PHP FastCGI Process Manager -BuildRequires: libacl-devel -Requires: php-common%{?_isa} = %{version}-%{release} -Requires(pre): /usr/sbin/useradd -%if %{with_systemd} -BuildRequires: systemd-devel -BuildRequires: systemd-units -Requires: systemd-units -Requires(post): systemd-units -Requires(preun): systemd-units -Requires(postun): systemd-units -# This is actually needed for the %%triggerun script but Requires(triggerun) -# is not valid. We can use %%post because this particular %%triggerun script -# should fire just after this package is installed. -Requires(post): systemd-sysv -%else -# This is for /sbin/service -Requires(preun): initscripts -Requires(postun): initscripts -%endif -%if %{with_httpd2410} -# To ensure correct /var/lib/php/session ownership: -Requires(pre): httpd-filesystem -# For php.conf in /etc/httpd/conf.d -# and version 2.4.10 for proxy support in SetHandler -Requires: httpd-filesystem >= 2.4.10 -# php engine for Apache httpd webserver -Provides: php(httpd) -%endif -%if %{with_nginx} -# for /etc/nginx ownership -Requires: nginx-filesystem -%endif -%if 0%{?rhel} -Obsoletes: php53-fpm, php53u-fpm, php54-fpm, php54w-fpm, php55u-fpm, php55w-fpm, php56u-fpm, php56w-fpm, php70u-fpm, php70w-fpm, php71u-fpm, php71w-fpm -%endif - -%description fpm -PHP-FPM (FastCGI Process Manager) is an alternative PHP FastCGI -implementation with some additional features useful for sites of -any size, especially busier sites. - -%if %{with_lsws} -%package litespeed -Summary: LiteSpeed Web Server PHP support -Group: Development/Languages -Requires: php-common%{?_isa} = %{version}-%{release} -%if 0%{?rhel} -Obsoletes: php53-litespeed, php53u-litespeed, php54-litespeed, php54w-litespeed, php55u-litespeed, php55w-litespeed, php56u-litespeed, php56w-litespeed, php70u-litespeed, php70w-litespeed, php70w-litespeed, php71w-litespeed -%endif - -%description litespeed -The php-litespeed package provides the %{_bindir}/lsphp command -used by the LiteSpeed Web Server (LSAPI enabled PHP). -%endif - -%package common -Group: Development/Languages -Summary: Common files for PHP -# All files licensed under PHP version 3.01, except -# fileinfo is licensed under PHP version 3.0 -# regex, libmagic are licensed under BSD -License: PHP and BSD -# ABI/API check - Arch specific -Provides: php(api) = %{apiver}%{isasuffix} -Provides: php(zend-abi) = %{zendver}%{isasuffix} -Provides: php(language) = %{version}, php(language)%{?_isa} = %{version} -# Provides for all builtin/shared modules: -Provides: php-bz2, php-bz2%{?_isa} -Provides: php-calendar, php-calendar%{?_isa} -Provides: php-core = %{version}, php-core%{?_isa} = %{version} -Provides: php-ctype, php-ctype%{?_isa} -Provides: php-curl, php-curl%{?_isa} -Provides: php-date, php-date%{?_isa} -Provides: php-exif, php-exif%{?_isa} -Provides: php-fileinfo, php-fileinfo%{?_isa} -Provides: php-filter, php-filter%{?_isa} -Provides: php-ftp, php-ftp%{?_isa} -Provides: php-gettext, php-gettext%{?_isa} -Provides: php-hash, php-hash%{?_isa} -Provides: php-mhash = %{version}, php-mhash%{?_isa} = %{version} -Provides: php-iconv, php-iconv%{?_isa} -Provides: php-libxml, php-libxml%{?_isa} -Provides: php-openssl, php-openssl%{?_isa} -Provides: php-phar, php-phar%{?_isa} -Provides: php-pcre, php-pcre%{?_isa} -Provides: php-reflection, php-reflection%{?_isa} -Provides: php-session, php-session%{?_isa} -Provides: php-sockets, php-sockets%{?_isa} -Provides: php-spl, php-spl%{?_isa} -Provides: php-standard = %{version}, php-standard%{?_isa} = %{version} -Provides: php-tokenizer, php-tokenizer%{?_isa} -Provides: php-zlib, php-zlib%{?_isa} -# For user experience, those extensions were part of php-common -Requires: php-json%{?_isa} = %{version}-%{release} -#Requires: php-zip%%{?_isa} - -Obsoletes: php-pecl-phar < 1.2.4 -Obsoletes: php-pecl-Fileinfo < 1.0.5 -Provides: php-pecl-Fileinfo = %{fileinfover}, php-pecl-Fileinfo%{?_isa} = %{fileinfover} -Provides: php-pecl(Fileinfo) = %{fileinfover}, php-pecl(Fileinfo)%{?_isa} = %{fileinfover} -Obsoletes: php-mhash < 5.3.0 -%if 0%{?rhel} -Obsoletes: php53-mhash, php53u-mhash -Obsoletes: php53-common, php53u-common, php54-common, php54w-common, php55u-common, php55w-common, php56u-common, php56w-common, php70u-common, php70w-common, php71u-common, php71w-common -%endif - -%description common -The php-common package contains files used by both the php -package and the php-cli package. - -%package devel -Group: Development/Libraries -Summary: Files needed for building PHP extensions -Requires: php-cli%{?_isa} = %{version}-%{release}, autoconf, automake -%if %{with_libpcre} -Requires: pcre-devel%{?_isa} -%endif -Obsoletes: php-pecl-pdo-devel -Obsoletes: php-pecl-json-devel < %{jsonver} -Obsoletes: php-pecl-jsonc-devel < %{jsonver} -%if %{with_zts} -Provides: php-zts-devel = %{version}-%{release} -Provides: php-zts-devel%{?_isa} = %{version}-%{release} -%endif -%if 0%{?rhel} -Obsoletes: php53-devel, php53u-devel, php54-devel, php54w-devel, php55u-devel, php55w-devel, php56u-devel, php56w-devel, php70u-devel, php70w-devel, php71u-devel, php71w-devel -%endif - -%description devel -The php-devel package contains the files needed for building PHP -extensions. If you need to compile your own PHP extensions, you will -need to install this package. - -%package opcache -Summary: The Zend OPcache -Group: Development/Languages -License: PHP -Requires: php-common%{?_isa} = %{version}-%{release} -Obsoletes: php-pecl-zendopcache -Provides: php-pecl-zendopcache = %{version} -Provides: php-pecl-zendopcache%{?_isa} = %{version} -Provides: php-pecl(opcache) = %{version} -Provides: php-pecl(opcache)%{?_isa} = %{version} -%if 0%{?rhel} -Obsoletes: php55u-opcache, php55w-opcache, php56u-opcache, php56w-opcache, php70u-opcache, php70w-opcache, php71u-opcache, php71w-opcache -%endif - -%description opcache -The Zend OPcache provides faster PHP execution through opcode caching and -optimization. It improves PHP performance by storing precompiled script -bytecode in the shared memory. This eliminates the stages of reading code from -the disk and compiling it on future access. In addition, it applies a few -bytecode optimization patterns that make code execution faster. - -%package imap -Summary: A module for PHP applications that use IMAP -Group: Development/Languages -# All files licensed under PHP version 3.01 -License: PHP -Requires: php-common%{?_isa} = %{version}-%{release} -Obsoletes: mod_php3-imap, stronghold-php-imap -BuildRequires: krb5-devel, openssl-devel, libc-client-devel -%if 0%{?rhel} -Obsoletes: php53-imap, php53u-imap, php54-imap, php54w-imap, php55u-imap, php55w-imap, php56u-imap, php56w-imap, php70u-imap, php70w-imap, php71u-imap, php71w-imap -%endif - -%description imap -The php-imap module will add IMAP (Internet Message Access Protocol) -support to PHP. IMAP is a protocol for retrieving and uploading e-mail -messages on mail servers. PHP is an HTML-embedded scripting language. - -%package ldap -Summary: A module for PHP applications that use LDAP -Group: Development/Languages -# All files licensed under PHP version 3.01 -License: PHP -Requires: php-common%{?_isa} = %{version}-%{release} -BuildRequires: cyrus-sasl-devel, openldap-devel, openssl-devel -%if 0%{?rhel} -Obsoletes: php53-ldap, php53u-ldap, php54-ldap, php54w-ldap, php55u-ldap, php55w-ldap, php56u-ldap, php56w-ldap, php70u-ldap, php70w-ldap, php71u-ldap, php71w-ldap -%endif - -%description ldap -The php-ldap adds Lightweight Directory Access Protocol (LDAP) -support to PHP. LDAP is a set of protocols for accessing directory -services over the Internet. PHP is an HTML-embedded scripting -language. - -%package pdo -Summary: A database access abstraction module for PHP applications -Group: Development/Languages -# All files licensed under PHP version 3.01 -License: PHP -Requires: php-common%{?_isa} = %{version}-%{release} -# ABI/API check - Arch specific -Provides: php-pdo-abi = %{pdover}%{isasuffix} -Provides: php(pdo-abi) = %{pdover}%{isasuffix} -%if %{with_sqlite3} -Provides: php-sqlite3, php-sqlite3%{?_isa} -%endif -Provides: php-pdo_sqlite, php-pdo_sqlite%{?_isa} -%if 0%{?rhel} -Obsoletes: php53-pdo, php53u-pdo, php54-pdo, php54w-pdo, php55u-pdo, php55w-pdo, php56u-pdo, php56w-pdo, php70u-pdo, php70w-pdo, php71u-pdo, php71w-pdo -%endif - -%description pdo -The php-pdo package contains a dynamic shared object that will add -a database access abstraction layer to PHP. This module provides -a common interface for accessing MySQL, PostgreSQL or other -databases. - -%package mysqlnd -Summary: A module for PHP applications that use MySQL databases -Group: Development/Languages -# All files licensed under PHP version 3.01 -License: PHP -Requires: php-pdo%{?_isa} = %{version}-%{release} -Provides: php_database -Provides: php-mysqli = %{version}-%{release} -Provides: php-mysqli%{?_isa} = %{version}-%{release} -Provides: php-pdo_mysql, php-pdo_mysql%{?_isa} -Obsoletes: php-mysql < %{version}-%{release} -%if 0%{?rhel} -Obsoletes: php53-mysqlnd, php53u-mysqlnd, php54-mysqlnd, php54w-mysqlnd, php55u-mysqlnd, php55w-mysqlnd, php56u-mysqlnd, php56w-mysqlnd, php70u-mysqlnd, php70w-mysqlnd, php71u-mysqlnd, php71w-mysqlnd -Obsoletes: php53-mysql, php53u-mysql, php54-mysql, php54w-mysql, php55u-mysql, php55w-mysql, php56u-mysql, php56w-mysql, php70u-mysql, php70w-mysql, php71u-mysql, php71w-mysql -%endif - -%description mysqlnd -The php-mysqlnd package contains a dynamic shared object that will add -MySQL database support to PHP. MySQL is an object-relational database -management system. PHP is an HTML-embeddable scripting language. If -you need MySQL support for PHP applications, you will need to install -this package and the php package. - -This package use the MySQL Native Driver - -%package pgsql -Summary: A PostgreSQL database module for PHP -Group: Development/Languages -# All files licensed under PHP version 3.01 -License: PHP -Requires: php-pdo%{?_isa} = %{version}-%{release} -Provides: php_database -Provides: php-pdo_pgsql, php-pdo_pgsql%{?_isa} -BuildRequires: krb5-devel, openssl-devel, postgresql-devel -%if 0%{?rhel} -Obsoletes: php53-pgsql, php53u-pgsql, php54-pgsql, php54w-pgsql, php55u-pgsql, php55w-pgsql, php56u-pgsql, php56w-pgsql, php70u-pgsql, php70w-pgsql, php71u-pgsql, php71w-pgsql -%endif - -%description pgsql -The php-pgsql package add PostgreSQL database support to PHP. -PostgreSQL is an object-relational database management -system that supports almost all SQL constructs. PHP is an -HTML-embedded scripting language. If you need back-end support for -PostgreSQL, you should install this package in addition to the main -php package. - -%package process -Summary: Modules for PHP script using system process interfaces -Group: Development/Languages -# All files licensed under PHP version 3.01 -License: PHP -Requires: php-common%{?_isa} = %{version}-%{release} -Provides: php-posix, php-posix%{?_isa} -Provides: php-shmop, php-shmop%{?_isa} -Provides: php-sysvsem, php-sysvsem%{?_isa} -Provides: php-sysvshm, php-sysvshm%{?_isa} -Provides: php-sysvmsg, php-sysvmsg%{?_isa} -%if 0%{?rhel} -Obsoletes: php53-process, php53u-process, php54-process, php54w-process, php55u-process, php55w-process, php56u-process, php56w-process, php70u-process, php70w-process, php71u-process, php71w-process -%endif - -%description process -The php-process package contains dynamic shared objects which add -support to PHP using system interfaces for inter-process -communication. - -%package odbc -Summary: A module for PHP applications that use ODBC databases -Group: Development/Languages -# All files licensed under PHP version 3.01, except -# pdo_odbc is licensed under PHP version 3.0 -License: PHP -Requires: php-pdo%{?_isa} = %{version}-%{release} -Provides: php_database -Provides: php-pdo_odbc, php-pdo_odbc%{?_isa} -BuildRequires: unixODBC-devel -%if 0%{?rhel} -Obsoletes: php53-odbc, php53u-odbc, php54-odbc, php54w-odbc, php55u-odbc, php55w-odbc, php56u-odbc, php56w-odbc, php70u-odbc, php70w-odbc, php71u-odbc, php71w-odbc -%endif - -%description odbc -The php-odbc package contains a dynamic shared object that will add -database support through ODBC to PHP. ODBC is an open specification -which provides a consistent API for developers to use for accessing -data sources (which are often, but not always, databases). PHP is an -HTML-embeddable scripting language. If you need ODBC support for PHP -applications, you will need to install this package and the php -package. - -%package soap -Summary: A module for PHP applications that use the SOAP protocol -Group: Development/Languages -# All files licensed under PHP version 3.01 -License: PHP -Requires: php-common%{?_isa} = %{version}-%{release} -BuildRequires: libxml2-devel -%if 0%{?rhel} -Obsoletes: php53-soap, php53u-soap, php54-soap, php54w-soap, php55u-soap, php55w-soap, php56u-soap, php56w-soap, php70u-soap, php70w-soap, php71u-soap, php71w-soap -%endif - -%description soap -The php-soap package contains a dynamic shared object that will add -support to PHP for using the SOAP web services protocol. - -%package interbase -Summary: A module for PHP applications that use Interbase/Firebird databases -Group: Development/Languages -# All files licensed under PHP version 3.01 -License: PHP -BuildRequires: firebird-devel -Requires: php-pdo%{?_isa} = %{version}-%{release} -Provides: php_database -Provides: php-firebird, php-firebird%{?_isa} -Provides: php-pdo_firebird, php-pdo_firebird%{?_isa} -%if 0%{?rhel} -Obsoletes: php53-interbase, php53u-interbase, php54-interbase, php54w-interbase, php55u-interbase, php55w-interbase, php56u-interbase, php56w-interbase, php70u-interbase, php70w-interbase, php71u-interbase, php71w-interbase -%endif - -%description interbase -The php-interbase package contains a dynamic shared object that will add -database support through Interbase/Firebird to PHP. - -InterBase is the name of the closed-source variant of this RDBMS that was -developed by Borland/Inprise. - -Firebird is a commercially independent project of C and C++ programmers, -technical advisors and supporters developing and enhancing a multi-platform -relational database management system based on the source code released by -Inprise Corp (now known as Borland Software Corp) under the InterBase Public -License. - -%if %{with_oci8} -%package oci8 -Summary: A module for PHP applications that use OCI8 databases -Group: Development/Languages -# All files licensed under PHP version 3.01 -License: PHP -BuildRequires: oracle-instantclient-devel >= %{oraclever} -Requires: php-pdo%{?_isa} = %{version}-%{release} -Provides: php_database -Provides: php-pdo_oci, php-pdo_oci%{?_isa} -Obsoletes: php-pecl-oci8 < %{oci8ver} -Conflicts: php-pecl-oci8 >= %{oci8ver} -Provides: php-pecl(oci8) = %{oci8ver}, php-pecl(oci8)%{?_isa} = %{oci8ver} -# Should requires libclntsh.so.12.1, but it's not provided by Oracle RPM. -AutoReq: 0 -%if 0%{?rhel} -Obsoletes: php53-oci8, php53u-oci8, php54-oci8, php54w-oci8, php55u-oci8, php55w-oci8, php56u-oci8, php56w-oci8, php70u-oci8, php70w-oci8, php71u-oci8, php71w-oci8 -%endif - -%description oci8 -The php-oci8 packages provides the OCI8 extension version %{oci8ver} -and the PDO driver to access Oracle Database. - -The extension is linked with Oracle client libraries %{oraclever} -(Oracle Instant Client). For details, see Oracle's note -"Oracle Client / Server Interoperability Support" (ID 207303.1). - -You must install libclntsh.so.%{oraclever} to use this package, provided -in the database installation, or in the free Oracle Instant Client -available from Oracle. - -Notice: -- php-oci8 provides oci8 and pdo_oci extensions from php sources. -- php-pecl-oci8 only provides oci8 extension. - -Documentation is at http://php.net/oci8 and http://php.net/pdo_oci -%endif - -%package snmp -Summary: A module for PHP applications that query SNMP-managed devices -Group: Development/Languages -# All files licensed under PHP version 3.01 -License: PHP -Requires: php-common%{?_isa} = %{version}-%{release}, net-snmp -BuildRequires: net-snmp-devel -%if 0%{?rhel} -Obsoletes: php53-snmp, php53u-snmp, php54-snmp, php54w-snmp, php55u-snmp, php55w-snmp, php56u-snmp, php56w-snmp, php70u-snmp, php70w-snmp, php71u-snmp, php71w-snmp -%endif - -%description snmp -The php-snmp package contains a dynamic shared object that will add -support for querying SNMP devices to PHP. PHP is an HTML-embeddable -scripting language. If you need SNMP support for PHP applications, you -will need to install this package and the php package. - -%package xml -Summary: A module for PHP applications which use XML -Group: Development/Languages -# All files licensed under PHP version 3.01 -License: PHP -Requires: php-common%{?_isa} = %{version}-%{release} -Provides: php-dom, php-dom%{?_isa} -Provides: php-domxml, php-domxml%{?_isa} -Provides: php-simplexml, php-simplexml%{?_isa} -Provides: php-wddx, php-wddx%{?_isa} -Provides: php-xmlreader, php-xmlreader%{?_isa} -Provides: php-xmlwriter, php-xmlwriter%{?_isa} -Provides: php-xsl, php-xsl%{?_isa} -BuildRequires: libxslt-devel >= 1.0.18-1, libxml2-devel >= 2.4.14-1 -%if 0%{?rhel} -Obsoletes: php53-xml, php53u-xml, php54-xml, php54w-xml, php55u-xml, php55w-xml, php56u-xml, php56w-xml, php70u-xml, php70w-xml, php71u-xml, php71w-xml -%endif - -%description xml -The php-xml package contains dynamic shared objects which add support -to PHP for manipulating XML documents using the DOM tree, -and performing XSL transformations on XML documents. - -%package xmlrpc -Summary: A module for PHP applications which use the XML-RPC protocol -Group: Development/Languages -# All files licensed under PHP version 3.01, except -# libXMLRPC is licensed under BSD -License: PHP and BSD -Requires: php-xml%{?_isa} = %{version}-%{release} -%if 0%{?rhel} -Obsoletes: php53-xmlrpc, php53u-xmlrpc, php54-xmlrpc, php54w-xmlrpc, php55u-xmlrpc, php55w-xmlrpc, php56u-xmlrpc, php56w-xmlrpc, php70u-xmlrpc, php70w-xmlrpc, php71u-xmlrpc, php71w-xmlrpc -%endif - -%description xmlrpc -The php-xmlrpc package contains a dynamic shared object that will add -support for the XML-RPC protocol to PHP. - -%package mbstring -Summary: A module for PHP applications which need multi-byte string handling -Group: Development/Languages -# All files licensed under PHP version 3.01, except -# libmbfl is licensed under LGPLv2 -# onigurama is licensed under BSD -# ucgendat is licensed under OpenLDAP -License: PHP and LGPLv2 and BSD and OpenLDAP -Requires: php-common%{?_isa} = %{version}-%{release} -%if 0%{?rhel} -Obsoletes: php53-mbstring, php53u-mbstring, php54-mbstring, php54w-mbstring, php55u-mbstring, php55w-mbstring, php56u-mbstring, php56w-mbstring, php70u-mbstring, php70w-mbstring, php71u-mbstring, php71w-mbstring -%endif - -%description mbstring -The php-mbstring package contains a dynamic shared object that will add -support for multi-byte string handling to PHP. - -%package gd -Summary: A module for PHP applications for using the gd graphics library -Group: Development/Languages -# All files licensed under PHP version 3.01 -%if %{with_libgd} -License: PHP -%else -# bundled libgd is licensed under BSD -License: PHP and BSD -%endif -Requires: php-common%{?_isa} = %{version}-%{release} -%if %{with_libgd} -BuildRequires: gd-devel >= 2.1.1 -%if 0%{?fedora} <= 19 && 0%{?rhel} <= 7 -Requires: gd-last%{?_isa} >= 2.1.1 -%else -Requires: gd%{?_isa} >= 2.1.1 -%endif -%else -# Required to build the bundled GD library -BuildRequires: libjpeg-devel -BuildRequires: libpng-devel -BuildRequires: freetype-devel -BuildRequires: libXpm-devel -BuildRequires: libwebp-devel -%endif -%if 0%{?rhel} -Obsoletes: php53-gd, php53u-gd, php54-gd, php54w-gd, php55u-gd, php55w-gd, php56u-gd, php56w-gd, php70u-gd, php70w-gd, php71u-gd, php71w-gd -%endif - -%description gd -The php-gd package contains a dynamic shared object that will add -support for using the gd graphics library to PHP. - -%package bcmath -Summary: A module for PHP applications for using the bcmath library -Group: Development/Languages -# All files licensed under PHP version 3.01, except -# libbcmath is licensed under LGPLv2+ -License: PHP and LGPLv2+ -Requires: php-common%{?_isa} = %{version}-%{release} -%if 0%{?rhel} -Obsoletes: php53-bcmath, php53u-bcmath, php54-bcmath, php54w-bcmath, php55u-bcmath, php55w-bcmath, php56u-bcmath, php56w-bcmath, php70u-bcmath, php70w-bcmath, php71u-bcmath, php71w-bcmath -%endif - -%description bcmath -The php-bcmath package contains a dynamic shared object that will add -support for using the bcmath library to PHP. - -%package gmp -Summary: A module for PHP applications for using the GNU MP library -Group: Development/Languages -# All files licensed under PHP version 3.01 -License: PHP -BuildRequires: gmp-devel -Requires: php-common%{?_isa} = %{version}-%{release} -%if 0%{?rhel} -Obsoletes: php53-gmp, php53u-gmp, php54-gmp, php54w-gmp, php55u-gmp, php55w-gmp, php56u-gmp, php56w-gmp, php70u-gmp, php70w-gmp, php71u-gmp, php71w-gmp -%endif - -%description gmp -These functions allow you to work with arbitrary-length integers -using the GNU MP library. - -%package dba -Summary: A database abstraction layer module for PHP applications -Group: Development/Languages -# All files licensed under PHP version 3.01 -License: PHP -BuildRequires: %{db_devel}, gdbm-devel, tokyocabinet-devel -Requires: php-common%{?_isa} = %{version}-%{release} -%if 0%{?rhel} -Obsoletes: php53-dba, php53u-dba, php54-dba, php54w-dba, php55u-dba, php55w-dba, php56u-dba, php56w-dba, php70u-dba, php70w-dba, php71u-dba, php71w-dba -%endif - -%description dba -The php-dba package contains a dynamic shared object that will add -support for using the DBA database abstraction layer to PHP. - -%package mcrypt -Summary: Standard PHP module provides mcrypt library support -Group: Development/Languages -# All files licensed under PHP version 3.01 -License: PHP -Requires: php-common%{?_isa} = %{version}-%{release} -BuildRequires: libmcrypt-devel -%if 0%{?rhel} -Obsoletes: php53-mcrypt, php53u-mcrypt, php54-mcrypt, php54w-mcrypt, php55u-mcrypt, php55w-mcrypt, php56u-mcrypt, php56w-mcrypt, php70u-mcrypt, php70w-mcrypt, php71u-mcrypt, php71w-mcrypt -%endif - -%description mcrypt -The php-mcrypt package contains a dynamic shared object that will add -support for using the mcrypt library to PHP. - -%package tidy -Summary: Standard PHP module provides tidy library support -Group: Development/Languages -# All files licensed under PHP version 3.01 -License: PHP -Requires: php-common%{?_isa} = %{version}-%{release} -BuildRequires: libtidy-devel -%if 0%{?rhel} -Obsoletes: php53-tidy, php53u-tidy, php54-tidy, php54w-tidy, php55u-tidy, php55w-tidy, php56u-tidy, php56w-tidy, php70u-tidy, php70w-tidy, php71u-tidy, php71w-tidy -%endif - -%description tidy -The php-tidy package contains a dynamic shared object that will add -support for using the tidy library to PHP. - -%package pdo-dblib -Summary: PDO driver Microsoft SQL Server and Sybase databases -# All files licensed under PHP version 3.01 -License: PHP -Requires: php-pdo%{?_isa} = %{version}-%{release} -BuildRequires: freetds-devel >= 0.91 -Provides: php-pdo_dblib, php-pdo_dblib%{?_isa} -Obsoletes: php-mssql < %{version}-%{release} -%if 0%{?rhel} -Obsoletes: php53-mssql, php53u-mssql, php54-mssql, php54w-mssql, php55u-mssql, php55w-mssql, php56u-mssql, php56w-mssql, php70u-pdo-dblib, php70w-pdo_dblib, php71u-pdo-dblib, php71w-pdo_dblib -%endif - -%description pdo-dblib -The php-pdo-dblib package contains a dynamic shared object -that implements the PHP Data Objects (PDO) interface to enable access from -PHP to Microsoft SQL Server and Sybase databases through the FreeTDS libary. - -%package embedded -Summary: PHP library for embedding in applications -Group: System Environment/Libraries -Requires: php-common%{?_isa} = %{version}-%{release} -# doing a real -devel package for just the .so symlink is a bit overkill -Provides: php-embedded-devel = %{version}-%{release} -Provides: php-embedded-devel%{?_isa} = %{version}-%{release} -%if 0%{?rhel} -Obsoletes: php53-embedded, php53u-embedded, php54-embedded, php54w-embedded, php55u-embedded, php55w-embedded, php56u-embedded, php56w-embedded, php70u-embedded, php70w-embedded, php71u-embedded, php71w-embedded -%endif - -%description embedded -The php-embedded package contains a library which can be embedded -into applications to provide PHP scripting language support. - -%package pspell -Summary: A module for PHP applications for using pspell interfaces -Group: System Environment/Libraries -# All files licensed under PHP version 3.01 -License: PHP -Requires: php-common%{?_isa} = %{version}-%{release} -BuildRequires: aspell-devel >= 0.50.0 -%if 0%{?rhel} -Obsoletes: php53-pspell, php53u-pspell, php54-pspell, php54w-pspell, php55u-pspell, php55w-pspell, php56u-pspell, php56w-pspell, php70u-pspell, php70w-pspell, php71u-pspell, php71w-pspell -%endif - -%description pspell -The php-pspell package contains a dynamic shared object that will add -support for using the pspell library to PHP. - -%package recode -Summary: A module for PHP applications for using the recode library -Group: System Environment/Libraries -# All files licensed under PHP version 3.01 -License: PHP -Requires: php-common%{?_isa} = %{version}-%{release} -BuildRequires: recode-devel -%if 0%{?rhel} -Obsoletes: php53-recode, php53u-recode, php54-recode, php54w-recode, php55u-recode, php55w-recode, php56u-recode, php56w-recode, php70u-recode, php70w-recode, php71u-recode, php71w-recode -%endif - -%description recode -The php-recode package contains a dynamic shared object that will add -support for using the recode library to PHP. - -%package intl -Summary: Internationalization extension for PHP applications -Group: System Environment/Libraries -# All files licensed under PHP version 3.01 -License: PHP -Requires: php-common%{?_isa} = %{version}-%{release} -# Upstream requires 4.0, we require 50 to ensure use of libicu-last -BuildRequires: libicu-devel >= 50 -%if 0%{?rhel} -Obsoletes: php53-intl, php53u-intl, php54-intl, php54w-intl, php55u-intl, php55w-intl, php56u-intl, php56w-intl, php70u-intl, php70w-intl, php71u-intl, php71w-intl -%endif - -%description intl -The php-intl package contains a dynamic shared object that will add -support for using the ICU library to PHP. - -%package enchant -Summary: Enchant spelling extension for PHP applications -Group: System Environment/Libraries -# All files licensed under PHP version 3.0 -License: PHP -Requires: php-common%{?_isa} = %{version}-%{release} -BuildRequires: enchant-devel >= 1.2.4 -%if 0%{?rhel} -Obsoletes: php53-enchant, php53u-enchant, php54-enchant, php54w-enchant, php55u-enchant, php55w-enchant, php56u-enchant, php56w-enchant, php70u-enchant, php70w-enchant, php71u-enchant, php71w-enchant -%endif - -%description enchant -The php-enchant package contains a dynamic shared object that will add -support for using the enchant library to PHP. - -%if %{with_zip} -%package zip -Summary: ZIP archive management extension for PHP -# All files licensed under PHP version 3.0.1 -License: PHP -Group: System Environment/Libraries -Requires: php-common%{?_isa} = %{version}-%{release} -Obsoletes: php-pecl-zip < %{zipver} -Provides: php-pecl(zip) = %{zipver} -Provides: php-pecl(zip)%{?_isa} = %{zipver} -Provides: php-pecl-zip = %{zipver} -Provides: php-pecl-zip%{?_isa} = %{zipver} -%if 0%{?rhel} -Obsoletes: php53-zip, php53u-zip, php54-zip, php54w-zip, php55u-zip, php55w-zip, php56u-zip, php56w-zip, php70u-zip, php70w-zip, php71u-zip, php71w-zip -%endif -%if %{with_libzip} -# 0.11.1 required, but 1.0.1 is bundled -BuildRequires: pkgconfig(libzip) >= 1.0.1 -%endif - -%description zip -The php-zip package provides an extension that will add -support for ZIP archive management to PHP. -%endif - -%package json -Summary: JavaScript Object Notation extension for PHP -# All files licensed under PHP version 3.0.1 -License: PHP -Group: System Environment/Libraries -Requires: php-common%{?_isa} = %{version}-%{release} -Obsoletes: php-pecl-json < %{jsonver} -Obsoletes: php-pecl-jsonc < %{jsonver} -Provides: php-pecl(json) = %{jsonver} -Provides: php-pecl(json)%{?_isa} = %{jsonver} -Provides: php-pecl-json = %{jsonver} -Provides: php-pecl-json%{?_isa} = %{jsonver} -%if 0%{?rhel} -Obsoletes: php53-json, php53u-json, php54-json, php54w-json, php55u-json, php55w-json, php56u-json, php56w-json, php70u-json, php70w-json, php71u-json, php71w-json -%endif - -%description json -The php-json package provides an extension that will add -support for JavaScript Object Notation (JSON) to PHP. - - -%prep -: CIBLE = %{name}-%{version}-%{release} oci8=%{with_oci8} libzip=%{with_libzip} - -%setup -q -n php-%{upver}%{?rcver} - -%patch1 -p1 -b .mpmcheck -%patch5 -p1 -b .includedir -%patch6 -p1 -b .embed -%patch7 -p1 -b .recode -%patch8 -p1 -b .libdb -%if 0%{?rhel} -%patch9 -p1 -b .curltls -%endif - -%patch40 -p1 -b .dlopen -%if 0%{?fedora} >= 25 || 0%{?rhel} >= 6 -%patch42 -p1 -b .systzdata -%endif -%patch43 -p1 -b .headers -%if 0%{?fedora} >= 18 || 0%{?rhel} >= 7 -%patch45 -p1 -b .ldap_r -%endif -%patch46 -p1 -b .fixheader -%patch47 -p1 -b .phpinfo - -%patch91 -p1 -b .remi-oci8 - -# upstream patches - -# security patches - -# Fixes for tests -%if 0%{?fedora} >= 25 || 0%{?rhel} >= 6 -%patch300 -p1 -b .datetests -%endif -%if %{with_libpcre} -if ! pkg-config libpcre --atleast-version 8.34 ; then -# Only apply when system libpcre < 8.34 -%patch301 -p1 -b .pcre834 -fi -%endif - -# WIP patch - -# Prevent %%doc confusion over LICENSE files -cp Zend/LICENSE Zend/ZEND_LICENSE -cp TSRM/LICENSE TSRM_LICENSE -%if ! %{with_libgd} -cp ext/gd/libgd/README libgd_README -cp ext/gd/libgd/COPYING libgd_COPYING -%endif -cp sapi/fpm/LICENSE fpm_LICENSE -cp ext/mbstring/libmbfl/LICENSE libmbfl_LICENSE -cp ext/mbstring/oniguruma/COPYING oniguruma_COPYING -cp ext/mbstring/ucgendat/OPENLDAP_LICENSE ucgendat_LICENSE -cp ext/fileinfo/libmagic/LICENSE libmagic_LICENSE -cp ext/phar/LICENSE phar_LICENSE -cp ext/bcmath/libbcmath/COPYING.LIB libbcmath_COPYING -cp ext/date/lib/LICENSE.rst timelib_LICENSE - -# Multiple builds for multiple SAPIs -mkdir build-cgi build-apache build-embedded \ -%if %{with_zts} - build-zts build-ztscli \ -%endif - build-fpm - -# ----- Manage known as failed test ------- -# affected by systzdata patch -rm ext/date/tests/timezone_location_get.phpt -rm ext/date/tests/timezone_version_get.phpt -rm ext/date/tests/timezone_version_get_basic1.phpt -# Should be skipped but fails sometime -rm ext/standard/tests/file/file_get_contents_error001.phpt -# fails sometime -rm ext/sockets/tests/mcast_ipv?_recv.phpt -# cause stack exhausion -rm Zend/tests/bug54268.phpt -rm Zend/tests/bug68412.phpt -# avoid issue when 2 builds run simultaneously -%ifarch x86_64 -sed -e 's/64321/64322/' -i ext/openssl/tests/*.phpt -%endif - -# Safety check for API version change. -pver=$(sed -n '/#define PHP_VERSION /{s/.* "//;s/".*$//;p}' main/php_version.h) -if test "x${pver}" != "x%{upver}%{?rcver}"; then - : Error: Upstream PHP version is now ${pver}, expecting %{upver}%{?rcver}. - : Update the version/rcver macros and rebuild. - exit 1 -fi - -vapi=$(sed -n '/#define PHP_API_VERSION/{s/.* //;p}' main/php.h) -if test "x${vapi}" != "x%{apiver}"; then - : Error: Upstream API version is now ${vapi}, expecting %{apiver}. - : Update the apiver macro and rebuild. - exit 1 -fi - -vzend=$(sed -n '/#define ZEND_MODULE_API_NO/{s/^[^0-9]*//;p;}' Zend/zend_modules.h) -if test "x${vzend}" != "x%{zendver}"; then - : Error: Upstream Zend ABI version is now ${vzend}, expecting %{zendver}. - : Update the zendver macro and rebuild. - exit 1 -fi - -# Safety check for PDO ABI version change -vpdo=$(sed -n '/#define PDO_DRIVER_API/{s/.*[ ]//;p}' ext/pdo/php_pdo_driver.h) -if test "x${vpdo}" != "x%{pdover}"; then - : Error: Upstream PDO ABI version is now ${vpdo}, expecting %{pdover}. - : Update the pdover macro and rebuild. - exit 1 -fi - -# Check for some extension version -ver=$(sed -n '/#define PHP_OCI8_VERSION /{s/.* "//;s/".*$//;p}' ext/oci8/php_oci8.h) -if test "$ver" != "%{oci8ver}"; then - : Error: Upstream OCI8 version is now ${ver}, expecting %{oci8ver}. - : Update the oci8ver macro and rebuild. - exit 1 -fi - -%if %{with_zip} -ver=$(sed -n '/#define PHP_ZIP_VERSION /{s/.* "//;s/".*$//;p}' ext/zip/php_zip.h) -if test "$ver" != "%{zipver}"; then - : Error: Upstream ZIP version is now ${ver}, expecting %{zipver}. - : Update the %{zipver} macro and rebuild. - exit 1 -fi -%endif - -ver=$(sed -n '/#define PHP_JSON_VERSION /{s/.* "//;s/".*$//;p}' ext/json/php_json.h) -if test "$ver" != "%{jsonver}"; then - : Error: Upstream JSON version is now ${ver}, expecting %{jsonver}. - : Update the %{jsonver} macro and rebuild. - exit 1 -fi - -# https://bugs.php.net/63362 - Not needed but installed headers. -# Drop some Windows specific headers to avoid installation, -# before build to ensure they are really not needed. -rm -f TSRM/tsrm_win32.h \ - TSRM/tsrm_config.w32.h \ - Zend/zend_config.w32.h \ - ext/mysqlnd/config-win.h \ - ext/standard/winver.h \ - main/win32_internal_function_disabled.h \ - main/win95nt.h - -# Fix some bogus permissions -find . -name \*.[ch] -exec chmod 644 {} \; -chmod 644 README.* - -# php-fpm configuration files for tmpfiles.d -echo "d /run/php-fpm 755 root root" >php-fpm.tmpfiles - -# Some extensions have their own configuration file -cp %{SOURCE50} 10-opcache.ini -%if 0%{?rhel} != 6 -cat << EOF >>10-opcache.ini - -; Enables or disables copying of PHP code (text segment) into HUGE PAGES. -; This should improve performance, but requires appropriate OS configuration. -opcache.huge_code_pages=0 -EOF -%ifarch x86_64 -sed -e '/opcache.huge_code_pages/s/0/1/' -i 10-opcache.ini -%endif -%endif -cp %{SOURCE52} 20-oci8.ini - -# Regenerated bison files -# to force, rm Zend/zend_{language,ini}_parser.[ch] -if [ ! -f Zend/zend_language_parser.c ]; then - ./genfiles -fi - - -%build -%{?dtsenable} - -# aclocal workaround - to be improved -cat $(aclocal --print-ac-dir)/{libtool,ltoptions,ltsugar,ltversion,lt~obsolete}.m4 >>aclocal.m4 - -# Force use of system libtool: -libtoolize --force --copy -cat $(aclocal --print-ac-dir)/{libtool,ltoptions,ltsugar,ltversion,lt~obsolete}.m4 >build/libtool.m4 - -# Regenerate configure scripts (patches change config.m4's) -touch configure.in -./buildconf --force -%if %{with_debug} -LDFLAGS="-fsanitize=address" -export LDFLAGS -CFLAGS="$RPM_OPT_FLAGS -fno-strict-aliasing -Wno-pointer-sign -fsanitize=address -ggdb" -%else -CFLAGS="$RPM_OPT_FLAGS -fno-strict-aliasing -Wno-pointer-sign" -%endif -export CFLAGS - -# Install extension modules in %{_libdir}/php/modules. -EXTENSION_DIR=%{_libdir}/php/modules; export EXTENSION_DIR - -# Set PEAR_INSTALLDIR to ensure that the hard-coded include_path -# includes the PEAR directory even though pear is packaged -# separately. -PEAR_INSTALLDIR=%{_datadir}/pear; export PEAR_INSTALLDIR - -# Shell function to configure and build a PHP tree. -build() { -# Old/recent bison version seems to produce a broken parser; -# upstream uses GNU Bison 2.3. Workaround: -# Only provided in official tarball (not in snapshot) -if [ -f ../Zend/zend_language_parser.c ]; then -mkdir Zend && cp ../Zend/zend_{language,ini}_{parser,scanner}.[ch] Zend -fi - -# Always static: -# date, filter, libxml, reflection, spl: not supported -# hash: for PHAR_SIG_SHA256 and PHAR_SIG_SHA512 -# session: dep on hash, used by soap and wddx -# pcre: used by filter, zip -# pcntl, readline: only used by CLI sapi -# openssl: for PHAR_SIG_OPENSSL -# zlib: used by image - -ln -sf ../configure -%configure \ - --cache-file=../config.cache \ - --with-libdir=%{_lib} \ - --with-config-file-path=%{_sysconfdir} \ - --with-config-file-scan-dir=%{_sysconfdir}/php.d \ - --disable-debug \ - --with-pic \ - --disable-rpath \ - --without-pear \ - --with-exec-dir=%{_bindir} \ - --with-freetype-dir=%{_prefix} \ - --with-png-dir=%{_prefix} \ - --with-xpm-dir=%{_prefix} \ - --enable-gd-native-ttf \ - --without-gdbm \ - --with-jpeg-dir=%{_prefix} \ - --with-openssl \ - --with-system-ciphers \ -%if %{with_libpcre} - --with-pcre-regex=%{_prefix} \ -%endif - --with-zlib \ - --with-layout=GNU \ - --with-kerberos \ - --with-libxml-dir=%{_prefix} \ -%if 0%{?fedora} >= 25 || 0%{?rhel} >= 6 - --with-system-tzdata \ -%endif - --with-mhash \ -%if %{with_dtrace} - --enable-dtrace \ -%endif -%if %{with_debug} - --enable-debug \ -%endif - $* -if test $? != 0; then - tail -500 config.log - : configure failed - exit 1 -fi - -make %{?_smp_mflags} -} - -# Build /usr/bin/php-cgi with the CGI SAPI, and most shared extensions -pushd build-cgi - -build --libdir=%{_libdir}/php \ - --enable-pcntl \ - --enable-opcache \ - --enable-opcache-file \ -%if 0%{?rhel} == 6 - --disable-huge-code-pages \ -%endif - --enable-phpdbg \ - --with-imap=shared --with-imap-ssl \ - --enable-mbstring=shared \ - --enable-mbregex \ -%if %{with_libgd} - --with-gd=shared,%{_prefix} \ -%else - --with-gd=shared \ - --with-webp-dir=%{_prefix} \ -%endif - --with-gmp=shared \ - --enable-calendar=shared \ - --enable-bcmath=shared \ - --with-bz2=shared \ - --enable-ctype=shared \ - --enable-dba=shared --with-db4=%{_prefix} \ - --with-gdbm=%{_prefix} \ - --with-tcadb=%{_prefix} \ - --enable-exif=shared \ - --enable-ftp=shared \ - --with-gettext=shared \ - --with-iconv=shared \ - --enable-sockets=shared \ - --enable-tokenizer=shared \ - --with-xmlrpc=shared \ - --with-ldap=shared --with-ldap-sasl \ - --enable-mysqlnd=shared \ - --with-mysqli=shared,mysqlnd \ - --with-mysql-sock=%{mysql_sock} \ -%if %{with_oci8} -%ifarch x86_64 - --with-oci8=shared,instantclient,%{_libdir}/oracle/%{oraclever}/client64/lib,%{oraclever} \ -%else - --with-oci8=shared,instantclient,%{_libdir}/oracle/%{oraclever}/client/lib,%{oraclever} \ -%endif - --with-pdo-oci=shared,instantclient,/usr,%{oraclever} \ -%endif - --with-interbase=shared \ - --with-pdo-firebird=shared \ - --enable-dom=shared \ - --with-pgsql=shared \ - --enable-simplexml=shared \ - --enable-xml=shared \ - --enable-wddx=shared \ - --with-snmp=shared,%{_prefix} \ - --enable-soap=shared \ - --with-xsl=shared,%{_prefix} \ - --enable-xmlreader=shared --enable-xmlwriter=shared \ - --with-curl=shared,%{_prefix} \ - --enable-pdo=shared \ - --with-pdo-odbc=shared,unixODBC,%{_prefix} \ - --with-pdo-mysql=shared,mysqlnd \ - --with-pdo-pgsql=shared,%{_prefix} \ - --with-pdo-sqlite=shared,%{_prefix} \ - --with-pdo-dblib=shared,%{_prefix} \ -%if %{with_sqlite3} - --with-sqlite3=shared,%{_prefix} \ -%else - --without-sqlite3 \ -%endif - --enable-json=shared \ -%if %{with_zip} - --enable-zip=shared \ -%if %{with_libzip} - --with-libzip \ -%endif -%endif - --without-readline \ - --with-libedit \ - --with-pspell=shared \ - --enable-phar=shared \ - --with-mcrypt=shared,%{_prefix} \ - --with-tidy=shared,%{_prefix} \ - --enable-sysvmsg=shared --enable-sysvshm=shared --enable-sysvsem=shared \ - --enable-shmop=shared \ - --enable-posix=shared \ - --with-unixODBC=shared,%{_prefix} \ - --enable-fileinfo=shared \ - --enable-intl=shared \ - --with-icu-dir=%{_prefix} \ - --with-enchant=shared,%{_prefix} \ - --with-recode=shared,%{_prefix} -popd - -without_shared="--without-gd \ - --disable-dom --disable-dba --without-unixODBC \ - --disable-opcache \ - --disable-json \ - --disable-xmlreader --disable-xmlwriter \ - --without-sqlite3 --disable-phar --disable-fileinfo \ - --without-pspell --disable-wddx \ - --without-curl --disable-posix --disable-xml \ - --disable-simplexml --disable-exif --without-gettext \ - --without-iconv --disable-ftp --without-bz2 --disable-ctype \ - --disable-shmop --disable-sockets --disable-tokenizer \ - --disable-sysvmsg --disable-sysvshm --disable-sysvsem" - -# Build Apache module, and the CLI SAPI, /usr/bin/php -pushd build-apache -build --with-apxs2=%{_httpd_apxs} \ - --libdir=%{_libdir}/php \ -%if %{with_lsws} - --with-litespeed \ -%endif - --without-mysqli \ - --disable-pdo \ - ${without_shared} -popd - -# Build php-fpm -pushd build-fpm -build --enable-fpm \ -%if %{with_systemd} - --with-fpm-systemd \ -%endif - --with-fpm-acl \ - --libdir=%{_libdir}/php \ - --without-mysqli \ - --disable-pdo \ - ${without_shared} -popd - -# Build for inclusion as embedded script language into applications, -# /usr/lib[64]/libphp7.so -pushd build-embedded -build --enable-embed \ - --without-mysqli --disable-pdo \ - ${without_shared} -popd - -%if %{with_zts} -# Build a special thread-safe (mainly for modules) -pushd build-ztscli - -EXTENSION_DIR=%{_libdir}/php-zts/modules -build --includedir=%{_includedir}/php-zts \ - --libdir=%{_libdir}/php-zts \ - --enable-maintainer-zts \ - --program-prefix=zts- \ - --disable-cgi \ - --with-config-file-scan-dir=%{_sysconfdir}/php-zts.d \ - --enable-pcntl \ - --enable-opcache \ - --enable-opcache-file \ -%if 0%{?rhel} == 6 - --disable-huge-code-pages \ -%endif - --with-imap=shared --with-imap-ssl \ - --enable-mbstring=shared \ - --enable-mbregex \ -%if %{with_libgd} - --with-gd=shared,%{_prefix} \ -%else - --with-gd=shared \ - --with-webp-dir=%{_prefix} \ -%endif - --with-gmp=shared \ - --enable-calendar=shared \ - --enable-bcmath=shared \ - --with-bz2=shared \ - --enable-ctype=shared \ - --enable-dba=shared --with-db4=%{_prefix} \ - --with-gdbm=%{_prefix} \ - --with-tcadb=%{_prefix} \ - --with-gettext=shared \ - --with-iconv=shared \ - --enable-sockets=shared \ - --enable-tokenizer=shared \ - --enable-exif=shared \ - --enable-ftp=shared \ - --with-xmlrpc=shared \ - --with-ldap=shared --with-ldap-sasl \ - --enable-mysqlnd=shared \ - --with-mysqli=shared,mysqlnd \ - --with-mysql-sock=%{mysql_sock} \ - --enable-mysqlnd-threading \ -%if %{with_oci8} -%ifarch x86_64 - --with-oci8=shared,instantclient,%{_libdir}/oracle/%{oraclever}/client64/lib,%{oraclever} \ -%else - --with-oci8=shared,instantclient,%{_libdir}/oracle/%{oraclever}/client/lib,%{oraclever} \ -%endif - --with-pdo-oci=shared,instantclient,/usr,%{oraclever} \ -%endif - --with-interbase=shared \ - --with-pdo-firebird=shared \ - --enable-dom=shared \ - --with-pgsql=shared \ - --enable-simplexml=shared \ - --enable-xml=shared \ - --enable-wddx=shared \ - --with-snmp=shared,%{_prefix} \ - --enable-soap=shared \ - --with-xsl=shared,%{_prefix} \ - --enable-xmlreader=shared --enable-xmlwriter=shared \ - --with-curl=shared,%{_prefix} \ - --enable-pdo=shared \ - --with-pdo-odbc=shared,unixODBC,%{_prefix} \ - --with-pdo-mysql=shared,mysqlnd \ - --with-pdo-pgsql=shared,%{_prefix} \ - --with-pdo-sqlite=shared,%{_prefix} \ - --with-pdo-dblib=shared,%{_prefix} \ -%if %{with_sqlite3} - --with-sqlite3=shared,%{_prefix} \ -%else - --without-sqlite3 \ -%endif - --enable-json=shared \ -%if %{with_zip} - --enable-zip=shared \ -%if %{with_libzip} - --with-libzip \ -%endif -%endif - --without-readline \ - --with-libedit \ - --with-pspell=shared \ - --enable-phar=shared \ - --with-mcrypt=shared,%{_prefix} \ - --with-tidy=shared,%{_prefix} \ - --enable-sysvmsg=shared --enable-sysvshm=shared --enable-sysvsem=shared \ - --enable-shmop=shared \ - --enable-posix=shared \ - --with-unixODBC=shared,%{_prefix} \ - --enable-fileinfo=shared \ - --enable-intl=shared \ - --with-icu-dir=%{_prefix} \ - --with-enchant=shared,%{_prefix} \ - --with-recode=shared,%{_prefix} -popd - -# Build a special thread-safe Apache SAPI -pushd build-zts -build --with-apxs2=%{_httpd_apxs} \ - --includedir=%{_includedir}/php-zts \ - --libdir=%{_libdir}/php-zts \ - --enable-maintainer-zts \ - --with-config-file-scan-dir=%{_sysconfdir}/php-zts.d \ - --without-mysql \ - --disable-pdo \ - ${without_shared} -popd - -### NOTE!!! EXTENSION_DIR was changed for the -zts build, so it must remain -### the last SAPI to be built. -%endif - - -%check -%if %runselftest -cd build-apache - -# Run tests, using the CLI SAPI -export NO_INTERACTION=1 REPORT_EXIT_STATUS=1 MALLOC_CHECK_=2 -export SKIP_ONLINE_TESTS=1 -unset TZ LANG LC_ALL -if ! make test; then - set +x - for f in $(find .. -name \*.diff -type f -print); do - if ! grep -q XFAIL "${f/.diff/.phpt}" - then - echo "TEST FAILURE: $f --" - head -n 100 "$f" - echo -e "\n-- $f result ends." - fi - done - set -x - #exit 1 -fi -unset NO_INTERACTION REPORT_EXIT_STATUS MALLOC_CHECK_ -%endif - - -%install -%{?dtsenable} - -%if %{with_zts} -# Install the extensions for the ZTS version -make -C build-ztscli install \ - INSTALL_ROOT=$RPM_BUILD_ROOT -%endif - -# Install the version for embedded script language in applications + php_embed.h -make -C build-embedded install-sapi install-headers \ - INSTALL_ROOT=$RPM_BUILD_ROOT - -# Install the php-fpm binary -make -C build-fpm install-fpm \ - INSTALL_ROOT=$RPM_BUILD_ROOT - -# Install everything from the CGI SAPI build -make -C build-cgi install \ - INSTALL_ROOT=$RPM_BUILD_ROOT - -# Install the default configuration file and icons -install -m 755 -d $RPM_BUILD_ROOT%{_sysconfdir}/ -install -m 644 %{SOURCE2} $RPM_BUILD_ROOT%{_sysconfdir}/php.ini -install -m 755 -d $RPM_BUILD_ROOT%{_httpd_contentdir}/icons -install -m 644 php.gif $RPM_BUILD_ROOT%{_httpd_contentdir}/icons/php.gif - -# For third-party packaging: -install -m 755 -d $RPM_BUILD_ROOT%{_datadir}/php - -# install the DSO -install -m 755 -d $RPM_BUILD_ROOT%{_httpd_moddir} -install -m 755 build-apache/libs/libphp7.so $RPM_BUILD_ROOT%{_httpd_moddir}/libphp7.so - -%if %{with_zts} -# install the ZTS DSO -install -m 755 build-zts/libs/libphp7.so $RPM_BUILD_ROOT%{_httpd_moddir}/libphp7-zts.so -%endif - -# Apache config fragment -%if "%{_httpd_modconfdir}" == "%{_httpd_confdir}" -# Single config file with httpd < 2.4 (fedora <= 17) -install -D -m 644 %{SOURCE9} $RPM_BUILD_ROOT%{_httpd_confdir}/php.conf -%if %{with_zts} -cat %{SOURCE10} >>$RPM_BUILD_ROOT%{_httpd_confdir}/php.conf -%endif -cat %{SOURCE1} >>$RPM_BUILD_ROOT%{_httpd_confdir}/php.conf -%else -# Dual config file with httpd >= 2.4 (fedora >= 18) -install -D -m 644 %{SOURCE9} $RPM_BUILD_ROOT%{_httpd_modconfdir}/15-php.conf -%if %{with_zts} -cat %{SOURCE10} >>$RPM_BUILD_ROOT%{_httpd_modconfdir}/15-php.conf -%endif -install -D -m 644 %{SOURCE1} $RPM_BUILD_ROOT%{_httpd_confdir}/php.conf -%endif -%if %{with_httpd2410} -cat %{SOURCE12} >>$RPM_BUILD_ROOT%{_httpd_confdir}/php.conf -%endif - -install -m 755 -d $RPM_BUILD_ROOT%{_sysconfdir}/php.d -%if %{with_zts} -install -m 755 -d $RPM_BUILD_ROOT%{_sysconfdir}/php-zts.d -%endif -install -m 755 -d $RPM_BUILD_ROOT%{_localstatedir}/lib/php -install -m 700 -d $RPM_BUILD_ROOT%{_localstatedir}/lib/php/session -install -m 700 -d $RPM_BUILD_ROOT%{_localstatedir}/lib/php/wsdlcache -install -m 700 -d $RPM_BUILD_ROOT%{_localstatedir}/lib/php/opcache -%if 0%{?fedora} >= 24 -install -m 755 -d $RPM_BUILD_ROOT%{_localstatedir}/lib/php/peclxml -install -m 755 -d $RPM_BUILD_ROOT%{_docdir}/pecl -install -m 755 -d $RPM_BUILD_ROOT%{_datadir}/tests/pecl -%endif - -%if %{with_lsws} -install -m 755 build-apache/sapi/litespeed/php $RPM_BUILD_ROOT%{_bindir}/lsphp -%endif - -# PHP-FPM stuff -# Log -install -m 755 -d $RPM_BUILD_ROOT%{_localstatedir}/log/php-fpm -# Config -install -m 755 -d $RPM_BUILD_ROOT%{_sysconfdir}/php-fpm.d -install -m 644 %{SOURCE4} $RPM_BUILD_ROOT%{_sysconfdir}/php-fpm.conf -install -m 644 %{SOURCE5} $RPM_BUILD_ROOT%{_sysconfdir}/php-fpm.d/www.conf -mv $RPM_BUILD_ROOT%{_sysconfdir}/php-fpm.conf.default . -mv $RPM_BUILD_ROOT%{_sysconfdir}/php-fpm.d/www.conf.default . -# LogRotate -install -m 755 -d $RPM_BUILD_ROOT%{_sysconfdir}/logrotate.d -install -m 644 %{SOURCE7} $RPM_BUILD_ROOT%{_sysconfdir}/logrotate.d/php-fpm - -# Environment file -%if 0%{?fedora} < 26 -install -m 755 -d $RPM_BUILD_ROOT%{_sysconfdir}/sysconfig -install -m 644 %{SOURCE8} $RPM_BUILD_ROOT%{_sysconfdir}/sysconfig/php-fpm -%endif - -%if %{with_systemd} -install -m 755 -d $RPM_BUILD_ROOT/run/php-fpm -# tmpfiles.d -install -m 755 -d $RPM_BUILD_ROOT%{_prefix}/lib/tmpfiles.d -install -m 644 php-fpm.tmpfiles $RPM_BUILD_ROOT%{_prefix}/lib/tmpfiles.d/php-fpm.conf -# install systemd unit files and scripts for handling server startup -sed -e 's/^pid/;pid/' \ - -i $RPM_BUILD_ROOT%{_sysconfdir}/php-fpm.conf -# this folder requires systemd >= 204 -install -m 755 -d $RPM_BUILD_ROOT%{_sysconfdir}/systemd/system/php-fpm.service.d -install -m 755 -d $RPM_BUILD_ROOT%{_unitdir} -install -m 644 %{SOURCE6} $RPM_BUILD_ROOT%{_unitdir}/ -%else -sed -ne '1,2p' -i $RPM_BUILD_ROOT%{_sysconfdir}/sysconfig/php-fpm -install -m 755 -d $RPM_BUILD_ROOT%{_localstatedir}/run/php-fpm -sed -i -e 's:/run:/var/run:' $RPM_BUILD_ROOT%{_sysconfdir}/php-fpm.conf -sed -i -e 's:/run:/var/run:' $RPM_BUILD_ROOT%{_sysconfdir}/logrotate.d/php-fpm -# Service -install -m 755 -d $RPM_BUILD_ROOT%{_initrddir} -install -m 755 %{SOURCE99} $RPM_BUILD_ROOT%{_initrddir}/php-fpm -%endif - -%if 0%{?fedora} >= 26 -sed -e '/EnvironmentFile/d' -i $RPM_BUILD_ROOT%{_unitdir}/php-fpm.service -%endif - -%if %{with_nginx} -# Nginx configuration -install -D -m 644 %{SOURCE13} $RPM_BUILD_ROOT%{_sysconfdir}/nginx/conf.d/php-fpm.conf -install -D -m 644 %{SOURCE14} $RPM_BUILD_ROOT%{_sysconfdir}/nginx/default.d/php.conf - -# Switch to UDS -# FPM -sed -e 's@127.0.0.1:9000@/run/php-fpm/www.sock@' \ - -e 's@^;listen.acl_users@listen.acl_users@' \ - -i $RPM_BUILD_ROOT%{_sysconfdir}/php-fpm.d/www.conf -# Nginx -sed -e 's@127.0.0.1:9000@unix:/run/php-fpm/www.sock@' \ - -i $RPM_BUILD_ROOT%{_sysconfdir}/nginx/conf.d/php-fpm.conf -# Apache -sed -e 's@proxy:fcgi://127.0.0.1:9000@proxy:unix:/run/php-fpm/www.sock|fcgi://localhost@' \ - -i $RPM_BUILD_ROOT%{_httpd_confdir}/php.conf -%endif - -# Generate files lists and stub .ini files for each subpackage -for mod in pgsql odbc ldap snmp xmlrpc imap json \ - mysqlnd mysqli pdo_mysql \ - mbstring gd dom xsl soap bcmath dba xmlreader xmlwriter \ - simplexml bz2 calendar ctype exif ftp gettext gmp iconv \ - sockets tokenizer opcache \ - pdo pdo_pgsql pdo_odbc pdo_sqlite \ -%if %{with_zip} - zip \ -%endif -%if %{with_oci8} - oci8 pdo_oci \ -%endif - interbase pdo_firebird \ -%if %{with_sqlite3} - sqlite3 \ -%endif - enchant phar fileinfo intl \ - mcrypt tidy pdo_dblib pspell curl wddx \ - posix shmop sysvshm sysvsem sysvmsg recode xml \ - ; do - case $mod in - opcache) - # Zend extensions - ini=10-${mod}.ini;; - pdo_*|mysqli|wddx|xmlreader|xmlrpc) - # Extensions with dependencies on 20-* - ini=30-${mod}.ini;; - *) - # Extensions with no dependency - ini=20-${mod}.ini;; - esac - # some extensions have their own config file - if [ -f ${ini} ]; then - cp -p ${ini} $RPM_BUILD_ROOT%{_sysconfdir}/php.d/${ini} - cp -p ${ini} $RPM_BUILD_ROOT%{_sysconfdir}/php-zts.d/${ini} - else - cat > $RPM_BUILD_ROOT%{_sysconfdir}/php.d/${ini} < $RPM_BUILD_ROOT%{_sysconfdir}/php-zts.d/${ini} < files.${mod} <> files.xml - -# mysqlnd -cat files.mysqli \ - files.pdo_mysql \ - >> files.mysqlnd - -# Split out the PDO modules -cat files.pdo_pgsql >> files.pgsql -cat files.pdo_odbc >> files.odbc -%if %{with_oci8} -cat files.pdo_oci >> files.oci8 -%endif -cat files.pdo_firebird >> files.interbase - -# sysv* and posix in packaged in php-process -cat files.shmop files.sysv* files.posix > files.process - -# Package sqlite3 and pdo_sqlite with pdo; isolating the sqlite dependency -# isn't useful at this time since rpm itself requires sqlite. -cat files.pdo_sqlite >> files.pdo -%if %{with_sqlite3} -cat files.sqlite3 >> files.pdo -%endif - -# Package curl, phar and fileinfo in -common. -cat files.curl files.phar files.fileinfo \ - files.exif files.gettext files.iconv files.calendar \ - files.ftp files.bz2 files.ctype files.sockets \ - files.tokenizer > files.common - -# The default Zend OPcache blacklist file -install -m 644 %{SOURCE51} $RPM_BUILD_ROOT%{_sysconfdir}/php.d/opcache-default.blacklist -install -m 644 %{SOURCE51} $RPM_BUILD_ROOT%{_sysconfdir}/php-zts.d/opcache-default.blacklist -sed -e '/blacklist_filename/s/php.d/php-zts.d/' \ - -i $RPM_BUILD_ROOT%{_sysconfdir}/php-zts.d/10-opcache.ini - -# Install the macros file: -sed -e "s/@PHP_APIVER@/%{apiver}%{isasuffix}/" \ - -e "s/@PHP_ZENDVER@/%{zendver}%{isasuffix}/" \ - -e "s/@PHP_PDOVER@/%{pdover}%{isasuffix}/" \ - -e "s/@PHP_VERSION@/%{upver}/" \ -%if ! %{with_zts} - -e "/zts/d" \ -%endif - < %{SOURCE3} > macros.php -%if 0%{?fedora} >= 24 -echo '%pecl_xmldir %{_localstatedir}/lib/php/peclxml' >>macros.php -%endif -install -m 644 -D macros.php \ - $RPM_BUILD_ROOT%{macrosdir}/macros.php - -# Remove unpackaged files -rm -rf $RPM_BUILD_ROOT%{_libdir}/php/modules/*.a \ - $RPM_BUILD_ROOT%{_libdir}/php-zts/modules/*.a \ - $RPM_BUILD_ROOT%{_bindir}/{phptar} \ - $RPM_BUILD_ROOT%{_datadir}/pear \ - $RPM_BUILD_ROOT%{_libdir}/libphp7.la - -# Remove irrelevant docs -rm -f README.{Zeus,QNX,CVS-RULES} - - -%pre common -%if %{?fedora}%{!?fedora:99} < 25 -echo -e "WARNING : Fedora %{fedora} is now EOL :" -echo -e "You should consider upgrading to a supported release.\n" -%endif - - -%if ! %{with_httpd2410} -%pre fpm -# Add the "apache" user as we don't require httpd -getent group apache >/dev/null || \ - groupadd -g 48 -r apache -getent passwd apache >/dev/null || \ - useradd -r -u 48 -g apache -s /sbin/nologin \ - -d %{_httpd_contentdir} -c "Apache" apache -exit 0 -%endif - -%post fpm -%if %{with_systemd} -%systemd_post php-fpm.service -%else -if [ $1 = 1 ]; then - # Initial installation - /sbin/chkconfig --add php-fpm -fi -%endif - -%preun fpm -%if %{with_systemd} -%systemd_preun php-fpm.service -%else -if [ $1 = 0 ]; then - # Package removal, not upgrade - /sbin/service php-fpm stop >/dev/null 2>&1 - /sbin/chkconfig --del php-fpm -fi -%endif - -%postun fpm -%if %{with_systemd} -%systemd_postun_with_restart php-fpm.service -%else -if [ $1 -ge 1 ]; then - /sbin/service php-fpm condrestart >/dev/null 2>&1 || : -fi -%endif - -# Handle upgrading from SysV initscript to native systemd unit. -# We can tell if a SysV version of php-fpm was previously installed by -# checking to see if the initscript is present. -%triggerun fpm -- php-fpm -%if 0%{?fedora} >= 15 -if [ -f /etc/rc.d/init.d/php-fpm ]; then - # Save the current service runlevel info - # User must manually run systemd-sysv-convert --apply php-fpm - # to migrate them to systemd targets - /usr/bin/systemd-sysv-convert --save php-fpm >/dev/null 2>&1 || : - - # Run these because the SysV package being removed won't do them - /sbin/chkconfig --del php-fpm >/dev/null 2>&1 || : - /bin/systemctl try-restart php-fpm.service >/dev/null 2>&1 || : -fi -%endif - -%post embedded -p /sbin/ldconfig -%postun embedded -p /sbin/ldconfig - - -%{!?_licensedir:%global license %%doc} - -%files -%{_httpd_moddir}/libphp7.so -%if %{with_zts} -%{_httpd_moddir}/libphp7-zts.so -%endif -%attr(0770,root,apache) %dir %{_localstatedir}/lib/php/session -%attr(0770,root,apache) %dir %{_localstatedir}/lib/php/wsdlcache -%attr(0770,root,apache) %dir %{_localstatedir}/lib/php/opcache -%config(noreplace) %{_httpd_confdir}/php.conf -%if "%{_httpd_modconfdir}" != "%{_httpd_confdir}" -%config(noreplace) %{_httpd_modconfdir}/15-php.conf -%endif -%{_httpd_contentdir}/icons/php.gif - -%files common -f files.common -%doc CODING_STANDARDS CREDITS EXTENSIONS NEWS README* -%license LICENSE TSRM_LICENSE -%license libmagic_LICENSE -%license phar_LICENSE -%license timelib_LICENSE -%doc php.ini-* -%config(noreplace) %{_sysconfdir}/php.ini -%dir %{_sysconfdir}/php.d -%dir %{_libdir}/php -%dir %{_libdir}/php/modules -%if %{with_zts} -%dir %{_sysconfdir}/php-zts.d -%dir %{_libdir}/php-zts -%dir %{_libdir}/php-zts/modules -%endif -%dir %{_localstatedir}/lib/php -%if 0%{?fedora} >= 24 -%dir %{_localstatedir}/lib/php/peclxml -%dir %{_docdir}/pecl -%dir %{_datadir}/tests -%dir %{_datadir}/tests/pecl -%endif -%dir %{_datadir}/php - -%files cli -%{_bindir}/php -%{_bindir}/zts-php -%{_bindir}/php-cgi -%{_bindir}/phar.phar -%{_bindir}/phar -# provides phpize here (not in -devel) for pecl command -%{_bindir}/phpize -%{_mandir}/man1/php.1* -%{_mandir}/man1/zts-php.1* -%{_mandir}/man1/php-cgi.1* -%{_mandir}/man1/phar.1* -%{_mandir}/man1/phar.phar.1* -%{_mandir}/man1/phpize.1* -%{_mandir}/man1/zts-phpize.1* -%doc sapi/cgi/README* sapi/cli/README - -%files dbg -%{_bindir}/phpdbg -%{_mandir}/man1/phpdbg.1* -%if %{with_zts} -%{_bindir}/zts-phpdbg -%{_mandir}/man1/zts-phpdbg.1* -%endif -%doc sapi/phpdbg/{README.md,CREDITS} - -%files fpm -%doc php-fpm.conf.default www.conf.default -%license fpm_LICENSE -%attr(0770,root,apache) %dir %{_localstatedir}/lib/php/session -%attr(0770,root,apache) %dir %{_localstatedir}/lib/php/wsdlcache -%attr(0770,root,apache) %dir %{_localstatedir}/lib/php/opcache -%if %{with_httpd2410} -%config(noreplace) %{_httpd_confdir}/php.conf -%endif -%config(noreplace) %{_sysconfdir}/php-fpm.conf -%config(noreplace) %{_sysconfdir}/php-fpm.d/www.conf -%config(noreplace) %{_sysconfdir}/logrotate.d/php-fpm -%if 0%{?fedora} < 26 -%config(noreplace) %{_sysconfdir}/sysconfig/php-fpm -%endif -%if %{with_nginx} -%config(noreplace) %{_sysconfdir}/nginx/conf.d/php-fpm.conf -%config(noreplace) %{_sysconfdir}/nginx/default.d/php.conf -%endif -%if %{with_systemd} -%{_prefix}/lib/tmpfiles.d/php-fpm.conf -%{_unitdir}/php-fpm.service -%dir %{_sysconfdir}/systemd/system/php-fpm.service.d -%dir /run/php-fpm -%else -%{_initrddir}/php-fpm -%dir %{_localstatedir}/run/php-fpm -%endif -%{_sbindir}/php-fpm -%dir %{_sysconfdir}/php-fpm.d -# log owned by apache for log -%attr(770,apache,root) %dir %{_localstatedir}/log/php-fpm -%{_mandir}/man8/php-fpm.8* -%dir %{_datadir}/fpm -%{_datadir}/fpm/status.html - -%if %{with_lsws} -%files litespeed -%{_bindir}/lsphp -%endif - -%files devel -%{_bindir}/php-config -%{_includedir}/php -%{_libdir}/php/build -%if %{with_zts} -%{_bindir}/zts-php-config -%{_includedir}/php-zts -%{_bindir}/zts-phpize -%{_libdir}/php-zts/build -%endif -%{_mandir}/man1/php-config.1* -%{_mandir}/man1/zts-php-config.1* -%{macrosdir}/macros.php - -%files embedded -%{_libdir}/libphp7.so -%{_libdir}/libphp7-%{embed_version}.so - -%files pgsql -f files.pgsql -%files odbc -f files.odbc -%files imap -f files.imap -%files ldap -f files.ldap -%files snmp -f files.snmp -%files xml -f files.xml -%files xmlrpc -f files.xmlrpc -%files mbstring -f files.mbstring -%license libmbfl_LICENSE -%license oniguruma_COPYING -%license ucgendat_LICENSE -%files gd -f files.gd -%if ! %{with_libgd} -%license libgd_README -%license libgd_COPYING -%endif -%files soap -f files.soap -%files bcmath -f files.bcmath -%license libbcmath_COPYING -%files gmp -f files.gmp -%files dba -f files.dba -%files pdo -f files.pdo -%files mcrypt -f files.mcrypt -%files tidy -f files.tidy -%files pdo-dblib -f files.pdo_dblib -%files pspell -f files.pspell -%files intl -f files.intl -%files process -f files.process -%files recode -f files.recode -%files interbase -f files.interbase -%files enchant -f files.enchant -%files mysqlnd -f files.mysqlnd -%files opcache -f files.opcache -%config(noreplace) %{_sysconfdir}/php.d/opcache-default.blacklist -%config(noreplace) %{_sysconfdir}/php-zts.d/opcache-default.blacklist -%if %{with_oci8} -%files oci8 -f files.oci8 -%endif -%if %{with_zip} -%files zip -f files.zip -%endif -%files json -f files.json - - -%changelog -* Tue Aug 22 2017 Remi Collet - 7.1.9~RC1-2 -- disable httpd MPM check -- php-fpm: drop unneeded "pid" from default configuration - -* Wed Aug 16 2017 Remi Collet - 7.1.9~RC1-1 -- Update to 7.1.9RC1 -- oci8 version is now 2.1.7 - -* Wed Aug 2 2017 Remi Collet - 7.1.8-2 -- add patch for EL-6, fix undefined symbol: sqlite3_errstr - -* Wed Aug 2 2017 Remi Collet - 7.1.8-1 -- Update to 7.1.8 - http://www.php.net/releases/7_1_8.php - -* Tue Jul 18 2017 Remi Collet - 7.1.8~RC1-1 -- Update to 7.1.8RC1 -- oci8 version is now 2.1.6 - -* Thu Jul 6 2017 Remi Collet - 7.1.7-1 -- Update to 7.1.7 - http://www.php.net/releases/7_1_7.php - -* Wed Jun 21 2017 Remi Collet - 7.1.7~RC1-1 -- Update to 7.1.7RC1 -- oci8 version is now 2.1.5 -- use oracle instant client version 12.2 - -* Wed Jun 7 2017 Remi Collet - 7.1.6-1 -- Update to 7.1.6 - http://www.php.net/releases/7_1_6.php -- add upstream security patches for oniguruma - -* Wed May 24 2017 Remi Collet - 7.1.6~RC1-1 -- Update to 7.1.6RC1 - -* Tue May 9 2017 Remi Collet - 7.1.5-1 -- Update to 7.1.5 - http://www.php.net/releases/7_1_5.php - -* Thu Apr 27 2017 Remi Collet - 7.1.5~RC1-2 -- new sources from new tag - -* Tue Apr 25 2017 Remi Collet - 7.1.5~RC1-1 -- Update to 7.1.5RC1 -- oci8 version is now 2.1.4 - -* Tue Apr 11 2017 Remi Collet - 7.1.4-1 -- Update to 7.1.4 - http://www.php.net/releases/7_1_4.php - -* Tue Mar 28 2017 Remi Collet - 7.1.4-0.1.RC1 -- Update to 7.1.4RC1 - -* Tue Mar 14 2017 Remi Collet - 7.1.3-1 -- Update to 7.1.3 - http://www.php.net/releases/7_1_3.php - -* Fri Mar 10 2017 Remi Collet - 7.1.3-0.2.RC1 -- fix interbase build on F26 - -* Tue Feb 28 2017 Remi Collet - 7.1.3-0.1.RC1 -- Update to 7.1.3RC1 - -* Wed Feb 15 2017 Remi Collet - 7.1.2-1 -- Update to 7.1.2 - http://www.php.net/releases/7_1_2.php - -* Thu Feb 2 2017 Remi Collet - 7.1.2-0.2.RC1 -- Update to 7.1.2RC1 (new sources) - -* Wed Feb 1 2017 Remi Collet 7.1.2-0.1.RC1 -- Update to 7.1.2RC1 - -* Wed Jan 18 2017 Remi Collet 7.1.1-3 -- EL-7: add patch for https://bugs.php.net/73956 -- switch back to gcc 6.2 - -* Wed Jan 18 2017 Remi Collet 7.1.1-2 -- EL-7: rebuild using gcc 4.8 instead of 6.2 - because of https://bugzilla.redhat.com/1414348 - -* Wed Jan 18 2017 Remi Collet 7.1.1-1 -- Update to 7.1.1 - http://www.php.net/releases/7_1_1.php - -* Thu Jan 5 2017 Remi Collet 7.1.1-0.1.RC1 -- Update to 7.1.1RC1 - -* Mon Dec 26 2016 Remi Collet 7.1.0-2 -- test optimized build using GCC 6.2 - -* Thu Dec 1 2016 Remi Collet 7.1.0-1 -- Update to 7.1.0 - http://www.php.net/releases/7_1_0.php -- use bundled pcre library 8.38 on EL-7 -- disable pcre.jit everywhere as it raise AVC #1398474 -- sync provided configuration with upstream production defaults - -* Wed Nov 9 2016 Remi Collet 7.1.0-0.8.RC6 -- Update to 7.1.0RC6 - -* Wed Oct 26 2016 Remi Collet 7.1.0-0.7.RC5 -- Update to 7.1.0RC5 - -* Mon Oct 17 2016 Remi Collet 7.1.0-0.6.RC4 -- Update to 7.1.0RC4 -- update tzdata patch to v14, improve check for valid tz file -- oci8 version is now 2.1.3 - -* Thu Sep 29 2016 Remi Collet 7.1.0-0.5.RC3 -- Update to 7.1.0RC3 - -* Wed Sep 14 2016 Remi Collet 7.1.0-0.4.RC2 -- Update to 7.1.0RC2 -- API version is now 20160303 - -* Thu Sep 1 2016 Remi Collet 7.1.0-0.3.RC1 -- Update to 7.1.0RC1 -- oci8 version is now 2.1.2 -- json version is now 1.5.0 - -* Wed Aug 3 2016 Remi Collet 7.1.0-0.2.beta2 -- Update to 7.1.0beta2 - -* Sat Jul 23 2016 Remi Collet 7.1.0-0.1.beta1 -- Update to 7.1.0beta1 - -* Wed Jul 20 2016 Remi Collet 7.0.9-1 -- Update to 7.0.9 - http://www.php.net/releases/7_0_9.php -- wddx: add upstream patch for https://bugs.php.net/72564 - -* Wed Jul 6 2016 Remi Collet 7.0.9-0.1.RC1 -- Update to 7.0.9RC1 - -* Thu Jun 30 2016 Remi Collet 7.0.8-1.1 -- own tests/doc directories for pecl packages (f24) - -* Wed Jun 22 2016 Remi Collet 7.0.8-1 -- Update to 7.0.8 - http://www.php.net/releases/7_0_8.php - -* Wed Jun 8 2016 Remi Collet 7.0.8-0.1.RC1 -- Update to 7.0.8RC1 -- opcache version is now php version - -* Wed May 25 2016 Remi Collet 7.0.7-1 -- Update to 7.0.7 - http://www.php.net/releases/7_0_7.php - -* Thu May 12 2016 Remi Collet 7.0.7-0.1.RC1 -- Update to 7.0.7RC1 -- oci8 version is now 2.1.1 - -* Thu Apr 28 2016 Remi Collet 7.0.6-3 -- Update to 7.0.6 - http://www.php.net/releases/7_0_6.php -- rebuild for new sources - -* Wed Apr 27 2016 Remi Collet 7.0.6-1 -- Update to 7.0.6 - http://www.php.net/releases/7_0_6.php - -* Tue Apr 12 2016 Remi Collet 7.0.6-0.1.RC1 -- Update to 7.0.6RC1 - -* Fri Apr 8 2016 Remi Collet 7.0.5-2 -- Fixed bug #71914 (Reference is lost in "switch") - -* Wed Mar 30 2016 Remi Collet 7.0.5-1 -- Update to 7.0.5 - http://www.php.net/releases/7_0_5.php - -* Wed Mar 16 2016 Remi Collet 7.0.5-0.1.RC1 -- Update to 7.0.5RC1 - -* Fri Mar 4 2016 Remi Collet 7.0.4-2 -- adapt for F24: define %%pecl_xmldir and own it - -* Wed Mar 2 2016 Remi Collet 7.0.4-1 -- Update to 7.0.4 - http://www.php.net/releases/7_0_4.php -- pcre: disables JIT compilation of patterns with system pcre < 8.38 - -* Thu Feb 18 2016 Remi Collet 7.0.4-0.1.RC1 -- Update to 7.0.4RC1 - -* Wed Feb 3 2016 Remi Collet 7.0.3-1 -- Update to 7.0.3 - http://www.php.net/releases/7_0_3.php - -* Fri Jan 29 2016 Remi Collet 7.0.3-0.2.RC1 -- FPM: test build for https://bugs.php.net/62172 - -* Wed Jan 20 2016 Remi Collet 7.0.3-0.1.RC1 -- Update to 7.0.3RC1 - -* Wed Jan 6 2016 Remi Collet 7.0.2-1 -- Update to 7.0.2 - http://www.php.net/releases/7_0_2.php - -* Sun Dec 27 2015 Remi Collet 7.0.2-0.1.RC1 -- Update to 7.0.2RC1 -- opcache: build with --disable-huge-code-pages on EL-6 - -* Wed Dec 16 2015 Remi Collet 7.0.1-1 -- Update to 7.0.1 - http://www.php.net/releases/7_0_1.php -- curl: add CURL_SSLVERSION_TLSv1_x constant (EL) - -* Wed Dec 9 2015 Remi Collet 7.0.1-0.1.RC1 -- Update to 7.0.1RC1 -- drop --disable-huge-code-pages build option on EL-6, - but keep it disabled in default configuration -- php-devel obsoletes php-pecl-jsonc-devel - -* Sat Dec 5 2015 Remi Collet 7.0.0-3 -- EL-6 rebuild - -* Thu Dec 3 2015 Remi Collet 7.0.0-2 -- build with --disable-huge-code-pages on EL-6 - -* Tue Dec 1 2015 Remi Collet 7.0.0-1 -- Update to 7.0.0 - http://www.php.net/releases/7_0_0.php - -* Mon Nov 30 2015 Remi Collet 7.0.0-0.16.RC8 -- set opcache.huge_code_pages=0 on EL-6 - see https://bugs.php.net/70973 and https://bugs.php.net/70977 - -* Wed Nov 25 2015 Remi Collet 7.0.0-0.12.RC8 -- Update to 7.0.0RC8 -- set opcache.huge_code_pages=1 on x86_64 - -* Thu Nov 12 2015 Remi Collet 7.0.0-0.11.RC7 -- Update to 7.0.0RC7 (retagged) - -* Wed Nov 11 2015 Remi Collet 7.0.0-0.10.RC7 -- Update to 7.0.0RC7 - -* Wed Oct 28 2015 Remi Collet 7.0.0-0.9.RC6 -- Update to 7.0.0RC6 - -* Wed Oct 14 2015 Remi Collet 7.0.0-0.8.RC5 -- rebuild as retagged - -* Tue Oct 13 2015 Remi Collet 7.0.0-0.7.RC5 -- Update to 7.0.0RC5 -- update php-fpm.d/www.conf comments -- API and Zend API are now set to 20151012 - -* Wed Sep 30 2015 Remi Collet 7.0.0-0.6.RC4 -- Update to 7.0.0RC4 -- php-fpm: set http authorization headers - -* Wed Sep 16 2015 Remi Collet 7.0.0-0.5.RC3 -- Update to 7.0.0RC3 -- disable zip extension (provided in php-pecl-zip) - -* Fri Sep 4 2015 Remi Collet 7.0.0-0.4.RC2 -- Update to 7.0.0RC2 -- enable oci8 and pdo_oci extensions -- sync php.ini with upstream php.ini-production - -* Sat Aug 22 2015 Remi Collet 7.0.0-0.3.RC1 -- Update to 7.0.0RC1 - -* Wed Aug 5 2015 Remi Collet 7.0.0-0.2.beta3 -- update to 7.0.0beta3 - -* Thu Jul 23 2015 Remi Collet 7.0.0-0.1.beta2 -- update to 7.0.0beta2 -- merge changes from php70-php spec file - -* Sun Jul 12 2015 Remi Collet 5.6.11-1 -- Update to 5.6.11 - http://www.php.net/releases/5_6_11.php - -* Thu Jun 11 2015 Remi Collet 5.6.10-1.1 -- don't provide php-sqlite3 on EL-5 -- the phar link is now correctly created -- avoid issue when 2 builds run simultaneously - -* Thu Jun 11 2015 Remi Collet 5.6.10-1 -- Update to 5.6.10 - http://www.php.net/releases/5_6_10.php -- opcache is now 7.0.6-dev - -* Fri May 15 2015 Remi Collet 5.6.9-1 -- Update to 5.6.9 - http://www.php.net/releases/5_6_9.php - -* Thu Apr 16 2015 Remi Collet 5.6.8-1 -- Update to 5.6.8 - http://www.php.net/releases/5_6_8.php - -* Fri Apr 10 2015 Remi Collet 5.6.7-2 -- add upstream patch to drop SSLv3 tests - -* Thu Mar 19 2015 Remi Collet 5.6.7-1 -- Update to 5.6.7 - http://www.php.net/releases/5_6_7.php - -* Fri Feb 20 2015 Remi Collet 5.6.6-1.1 -- rebuild for new tokyocabinet in EL-5 - -* Thu Feb 19 2015 Remi Collet 5.6.6-1 -- Update to 5.6.6 - http://www.php.net/releases/5_6_6.php - -* Wed Jan 21 2015 Remi Collet 5.6.5-1 -- Update to 5.6.5 - http://www.php.net/releases/5_6_5.php - -* Fri Jan 9 2015 Remi Collet 5.6.5-0.1.RC1 -- update to 5.6.5RC1 -- FPM: enable ACL for Unix Domain Socket - -* Wed Dec 17 2014 Remi Collet 5.6.4-2 -- Update to 5.6.4 - http://www.php.net/releases/5_6_4.php -- add sybase_ct extension (in mssql sub-package) -- xmlrpc requires xml - -* Wed Dec 10 2014 Remi Collet 5.6.4-1 -- Update to 5.6.4 - http://www.php.net/releases/5_6_4.php - -* Thu Nov 27 2014 Remi Collet 5.6.4-0.1.RC1 -- php 5.6.4RC1 - -* Sun Nov 16 2014 Remi Collet 5.6.3-3 -- FPM: add upstream patch for https://bugs.php.net/68421 - access.format=R doesn't log ipv6 address -- FPM: add upstream patch for https://bugs.php.net/68420 - listen=9000 listens to ipv6 localhost instead of all addresses -- FPM: add upstream patch for https://bugs.php.net/68423 - will no longer load all pools - -* Thu Nov 13 2014 Remi Collet 5.6.3-1 -- Update to PHP 5.6.3 - http://php.net/releases/5_6_3.php -- GMP: add upstream patch for https://bugs.php.net/68419 - Fix build with libgmp < 4.2 - -* Thu Oct 30 2014 Remi Collet 5.6.3-0.4.RC1 -- php 5.6.3RC1 (refreshed, phpdbg changes reverted) - -* Thu Oct 30 2014 Remi Collet 5.6.3-0.3.RC1 -- new version of systzdata patch, fix case sensitivity -- ignore Factory in date tests - -* Wed Oct 29 2014 Remi Collet 5.6.3-0.2.RC1 -- php 5.6.3RC1 (refreshed) -- enable phpdbg_webhelper new extension (in php-dbg) - -* Tue Oct 28 2014 Remi Collet 5.6.3-0.1.RC1 -- php 5.6.3RC1 -- disable opcache.fast_shutdown in default config -- disable phpdbg_webhelper new extension for now - -* Thu Oct 16 2014 Remi Collet 5.6.1-1 -- Update to PHP 5.6.2 - http://php.net/releases/5_6_2.php - -* Fri Oct 3 2014 Remi Collet 5.6.1-1 -- Update to PHP 5.6.1 - http://php.net/releases/5_6_1.php - -* Fri Sep 26 2014 Remi Collet 5.6.1-0 -- test build for upcoming 5.6.1 -- use default system cipher list by Fedora policy - http://fedoraproject.org/wiki/Changes/CryptoPolicy - -* Wed Sep 24 2014 Remi Collet 5.6.1-0.2.RC1 -- provides nginx configuration (see #1142298) - -* Fri Sep 12 2014 Remi Collet 5.6.1-0.1.RC1 -- php 5.6.1RC1 - -* Wed Sep 3 2014 Remi Collet 5.6.0-1.2 -- ensure gd-last 2.1.0-3, with libvpx support, is used - -* Fri Aug 29 2014 Remi Collet 5.6.0-1.1 -- enable libvpx on EL 6 (with libvpx 1.3.0) - -* Thu Aug 28 2014 Remi Collet 5.6.0-1 -- PHP 5.6.0 is GA -- fix ZTS man pages, upstream patch for 67878 - -* Wed Aug 20 2014 Remi Collet 5.6.0-0.22.RC4 -- backport rawhide stuff for F21+ and httpd-filesystem - with support for SetHandler to proxy_fcgi - -* Thu Aug 14 2014 Remi Collet 5.6.0-0.21.RC4 -- php 5.6.0RC4 - -* Wed Jul 30 2014 Remi Collet 5.6.0-0.20.RC3 -- php 5.6.0RC3 -- fix license handling -- fix zts-php-config --php-binary output #1124605 -- cleanup with_libmysql -- add php-litespeed subpackage (/usr/bin/lsphp) - -* Fri Jul 25 2014 Remi Collet 5.6.0-0.18.RC2 -- dont display timezone version in phpinfo (tzdata patch v11) - -* Sat Jul 19 2014 Remi Collet 5.6.0-0.17.RC2 -- test build for #67635 - -* Mon Jul 7 2014 Remi Collet 5.6.0-0.16.RC2 -- php 5.6.0RC2 - -* Mon Jun 23 2014 Remi Collet 5.6.0-0.15.RC1 -- add workaround for unserialize/mock issue from 5.4/5.5 - -* Mon Jun 23 2014 Remi Collet 5.6.0-0.14.RC1 -- fix phpdbg with libedit https://bugs.php.net/67499 - -* Thu Jun 19 2014 Remi Collet 5.6.0-0.13.RC1 -- php 5.6.0RC1 - -* Mon Jun 16 2014 Remi Collet 5.6.0-0.12.beta4 -- test build for serialize - -* Tue Jun 10 2014 Remi Collet 5.6.0-0.11.beta4 -- test build for bug 67410, 67411, 67412, 67413 -- fix 67392, dtrace breaks argument unpack - -* Thu Jun 5 2014 Remi Collet 5.6.0-0.10.beta4 -- fix regression introduce in fix for #67118 - -* Wed Jun 4 2014 Remi Collet 5.6.0-0.9.beta4 -- php 5.6.0beta4 - -* Wed May 14 2014 Remi Collet 5.6.0-0.8.beta3 -- php 5.6.0beta3 - -* Tue May 6 2014 Remi Collet 5.6.0-0.8.201405061030 -- new snapshot php5.6-201405061030 - -* Sat May 3 2014 Remi Collet 5.6.0-0.7.beta2 -- php 5.6.0beta2 - -* Thu Apr 10 2014 Remi Collet 5.6.0-0.6.beta1 -- php 5.6.0beta1 - -* Wed Apr 9 2014 Remi Collet 5.6.0-0.5.201404090430 -- new snapshot php5.6-201404090430 -- add numerical prefix to extension configuration files -- prevent .user.ini files from being viewed by Web clients -- load php directives only when mod_php is active - -* Wed Mar 26 2014 Remi Collet 5.6.0-0.4.201403261230 -- new snapshot php5.6-201403261230 -- oci8 version 2.0.9 -- opcache version 7.0.4-dev - -* Mon Mar 17 2014 Remi Collet 5.6.0-0.4.201403170630 -- new snapshot php5.6-201403170630 - -* Wed Mar 12 2014 Remi Collet 5.6.0-0.3.201403120830 -- new snapshot php5.6-201403120830 -- rebuild against gd-last without libvpx on EL < 7 -- oci8 version 2.0.8 - -* Fri Feb 28 2014 Remi Collet 5.6.0-0.2.alpha3 -- php 5.6.0alpha3 -- add php-dbg subpackage -- update php.ini from upstream production template -- move /usr/bin/zts-php to php-cli subpackage - -* Wed Feb 26 2014 Remi Collet 5.5.10-0.4.RC1 -- php-fpm should own /var/lib/php/session and wsdlcache - -* Tue Feb 25 2014 Remi Collet 5.5.10-0.3.RC1 -- test build for https://bugs.php.net/66762 - -* Fri Feb 21 2014 Remi Collet 5.5.10-0.2.RC1 -- another test build of 5.5.10RC1 -- fix memleak in fileinfo ext -- revert test changes for pcre 8.34 - -* Thu Feb 20 2014 Remi Collet 5.5.10-0.1.RC1 -- test build of 5.5.10RC1 - -* Tue Feb 18 2014 Remi Collet 5.5.9-2 -- upstream patch for https://bugs.php.net/66731 - -* Tue Feb 11 2014 Remi Collet 5.5.9-1 -- Update to 5.5.9 - http://www.php.net/ChangeLog-5.php#5.5.9 -- Install macros to /usr/lib/rpm/macros.d where available. -- Add configtest option to php-fpm ini script (EL) - -* Thu Jan 23 2014 Remi Collet 5.5.9-0.1.RC1 -- test build of 5.5.9RC1 - -* Thu Jan 23 2014 Joe Orton - 5.5.8-2 -- fix _httpd_mmn expansion in absence of httpd-devel - -* Mon Jan 20 2014 Remi Collet 5.5.8-2 -- test build for https://bugs.php.net/66412 - -* Wed Jan 8 2014 Remi Collet 5.5.8-1 -- update to 5.5.8 -- drop conflicts with other opcode caches as both can - be used only for user data cache - -* Wed Jan 8 2014 Remi Collet 5.5.8-0.2.RC1 -- another test build of 5.5.8RC1 - -* Sat Dec 28 2013 Remi Collet 5.5.8-0.1.RC1 -- test build of 5.5.8RC1 - -* Fri Dec 20 2013 Remi Collet 5.5.7-1.1 -- test build for https://bugs.php.net/66331 - -* Wed Dec 11 2013 Remi Collet 5.5.7-1 -- update to 5.5.7, fix for CVE-2013-6420 -- fix zend_register_functions breaks reflection, php bug 66218 -- fix Heap buffer over-read in DateInterval, php bug 66060 -- fix fix overflow handling bug in non-x86 - -* Tue Dec 10 2013 Remi Collet 5.5.7-0.4.RC1 -- test build - -* Wed Dec 04 2013 Remi Collet 5.5.7-0.3.RC1 -- test build - -* Mon Dec 02 2013 Remi Collet 5.5.7-0.2.RC1 -- test build for https://bugs.php.net/66218 - zend_register_functions breaks reflection - -* Thu Nov 28 2013 Remi Collet 5.5.7-0.1.RC1 -- test build of 5.5.7RC1 - -* Wed Nov 13 2013 Remi Collet 5.5.6-1 -- update to 5.5.6 - -* Tue Nov 12 2013 Remi Collet 5.5.6-0.7 -- update to 5.5.6, test build - -* Fri Nov 8 2013 Remi Collet 5.5.6-0.6.RC1 -- add --with debug option for debug build - -* Wed Nov 6 2013 Remi Collet 5.5.6-0.5.RC1 -- test buid with opcache changes reverted - -* Mon Nov 4 2013 Remi Collet 5.5.6-0.4.RC1 -- test build opcache with phar build shared - https://github.com/zendtech/ZendOptimizerPlus/issues/147 - -* Mon Nov 4 2013 Remi Collet 5.5.6-0.3.RC1 -- build phar shared, opcache loaded with RTLD_LAZY - -* Sat Nov 2 2013 Remi Collet 5.5.6-0.2.RC1 -- build phar static for opcache dep. - -* Sat Nov 2 2013 Remi Collet 5.5.6-0.1.RC1 -- test build of 5.5.6RC1 - -* Sun Oct 27 2013 Remi Collet 5.5.5-2 -- rebuild using libicu-last 50.1.2 - -* Tue Oct 15 2013 Remi Collet - 5.5.5-1 -- update to 5.5.5 - -* Mon Sep 23 2013 Remi Collet - 5.5.4-2 -- test build - -* Thu Sep 19 2013 Remi Collet - 5.5.4-1 -- update to 5.5.4 -- improve security, use specific soap.wsdl_cache_dir - use /var/lib/php/wsdlcache for mod_php and php-fpm -- sync short_tag comments in php.ini with upstream - -* Fri Aug 30 2013 Remi Collet - 5.5.4.0.1-201308300430 -- test build with -fsanitize=address -- test build for https://bugs.php.net/65564 - -* Wed Aug 21 2013 Remi Collet - 5.5.3-1 -- update to 5.5.3 -- build without zip extension, requires php-pecl-zip -- fix typo and add missing entries in php.ini - -* Tue Aug 20 2013 Remi Collet - 5.5.3-0 -- update to 5.5.3 -- test build without zip extension -- fix typo and add missing entries in php.ini - -* Mon Aug 19 2013 Remi Collet - 5.5.2-1 -- update to 5.5.2 - -* Thu Aug 8 2013 Remi Collet - 5.5.2-0.2.RC1 -- improve system libzip patch - -* Thu Aug 1 2013 Remi Collet - 5.5.2-0.1.RC1 -- 5.5.2RC1 - -* Fri Jul 26 2013 Remi Collet - 5.5.1-2 -- test build with oracle instantclient 12.1 - -* Mon Jul 22 2013 Remi Collet - 5.5.1-1 -- update to 5.5.1 -- add Provides: php(pdo-abi), for consistency with php(api) - and php(zend-abi) -- improved description for mod_php -- fix opcache ZTS configuration (blacklists in /etc/php-zts.d) -- add missing man pages (phar, php-cgi) -- fix php-enchant summary and description - -* Fri Jul 12 2013 Remi Collet - 5.5.0-2 -- add security fix for CVE-2013-4113 -- add missing ASL 1.0 license -- 32k stack size seems ok for tests on both 32/64bits build - -* Mon Jun 24 2013 Remi Collet 5.5.1-0.1.201306240630 -- test build (bundled libgd) - -* Thu Jun 20 2013 Remi Collet 5.5.0-1 -- update to 5.5.0 final - -* Fri Jun 14 2013 Remi Collet 5.5.0-0.11.RC3 -- also drop JSON from sources -- clean conditional for JSON (as removed from the sources) -- clean conditional for FPM (always build) - -* Fri Jun 14 2013 Remi Collet 5.5.0-0.36.RC3.1 -- EL-5 rebuild with gd-last - -* Thu Jun 13 2013 Remi Collet 5.5.0-0.36.RC3 -- drop JSON extension -- build with system GD when 2.1.0 is available - -* Thu Jun 6 2013 Remi Collet 5.5.0-0.35.RC3 -- update to 5.5.0RC3 - -* Mon May 27 2013 Remi Collet 5.5.0-0.34.201305271230. --test build with systemd gd - -* Thu May 23 2013 Remi Collet 5.5.0-0.33.RC2 -- update to 5.5.0RC2 -- add missing options in php-fpm.conf -- improved systemd configuration, documentation about - /etc/sysconfig/php-fpm being deprecated - -* Wed May 22 2013 Remi Collet 5.5.0-0.32.201305220430 -- test build for https://bugs.php.net/64895 - -* Sat May 18 2013 Remi Collet 5.5.0-0.32.201305181030 -- test build with systemd integration (type=notify) - -* Wed May 8 2013 Remi Collet 5.5.0-0.31.RC1 -- update to 5.5.0RC1 - -* Sat Apr 27 2013 Remi Collet 5.5.0-0.30.201305041230 -- test build for libgd - -* Sat Apr 27 2013 Remi Collet 5.5.0-0.29.201304291030 -- new snapshot -- review some sub-packages description -- add option to disable json extension - -* Thu Apr 25 2013 Remi Collet 5.5.0-0.28.beta4 -- update to 5.5.0beta4, rebuild with new sources - -* Thu Apr 25 2013 Remi Collet 5.5.0-0.27.beta4 -- update to 5.5.0beta4 - -* Mon Apr 22 2013 Remi Collet 5.5.0-0.27-201304221230 -- new snapshot -- try build with system gd 2.1.0 - -* Thu Apr 18 2013 Remi Collet 5.5.0-0.26-201304181030 -- new snapshot -- zend_extension doesn't requires full path -- refresh system libzip patch -- drop opcache patch merged upstream - -* Thu Apr 11 2013 Remi Collet 5.5.0-0.25.beta3 -- allow wildcard in opcache.blacklist_filename and provide - default /etc/php.d/opcache-default.blacklist - -* Wed Apr 10 2013 Remi Collet 5.5.0-0.24.beta3 -- update to 5.5.0beta3 - -* Thu Apr 4 2013 Remi Collet 5.5.0-0.23-201304040630 -- new snapshot -- clean old deprecated options - -* Thu Mar 28 2013 Remi Collet 5.5.0-0.22.beta2 -- update to 5.5.0beta2 -- Zend Optimizer+ renamed to Zend OPcache -- sync provided configuration with upstream - -* Mon Mar 25 2013 Remi Collet 5.5.0-0.21-201303251230 -- new snapshot -- generated parser using system bison, test for https://bugs.php.net/64503 - -* Wed Mar 20 2013 Remi Collet 5.5.0-0.20-201303201430 -- new snapshot (beta1) - -* Mon Mar 18 2013 Remi Collet 5.5.0-0.19-201303180830 -- new snapshot -- temporary disable dtrace -- new extension opcache in php-opccache sub-package - -* Thu Mar 14 2013 Remi Collet 5.5.0-0.18-201303141230 -- new snapshot -- hardened build (links with -z now option) -- remove %%config from /etc/rpm/macros.php - -* Fri Mar 8 2013 Remi Collet 5.5.0-0.17-201303081230 -- new snapshot (post alpha 6) -- make php-mysql package optional (and disabled) -- make ZTS build optional (still enabled) - -* Thu Feb 28 2013 Remi Collet 5.5.0-0.16-201302281430 -- new snapshot - -* Thu Feb 21 2013 Remi Collet 5.5.0-0.16-201302211230 -- new snapshot (post alpha 5) - -* Wed Feb 13 2013 Remi Collet 5.5.0-0.16-201302131030 -- enable tokyocabinet and gdbm dba handlers - -* Tue Feb 12 2013 Remi Collet 5.5.0-0.15-201302121230 -- new snapshot - -* Mon Feb 4 2013 Remi Collet 5.5.0-0.14-201302040630 -- new snapshot - -* Fri Feb 1 2013 Remi Collet 5.5.0-0.14-201302010630 -- new snapshot - -* Mon Jan 28 2013 Remi Collet 5.5.0-0.13-201301281030 -- new snapshot -- don't display XFAIL tests in report - -* Wed Jan 23 2013 Remi Collet 5.5.0-0.12-201301230630 -- new snapshot, alpha4 - -* Thu Jan 17 2013 Remi Collet 5.5.0-0.11-201301170830 -- new snapshot -- fix php.conf to allow MultiViews managed by php scripts - -* Thu Jan 10 2013 Remi Collet 5.5.0-0.10-201301100830 -- new snapshot, alpha3 - -* Wed Jan 2 2013 Remi Collet 5.5.0-0.10-201301021430 -- new snapshot - -* Mon Dec 24 2012 Remi Collet 5.5.0-0.9.201212241030 -- new snapshot (post alpha2) -- use xz compressed tarball - -* Tue Dec 18 2012 Remi Collet 5.5.0-0.9.201212181230 -- new snapshot - -* Wed Dec 12 2012 Remi Collet 5.5.0-0.8.201212121430 -- new snapshot - -* Tue Dec 11 2012 Remi Collet 5.5.0-0.8.201212110630 -- patch for unpack - -* Tue Dec 11 2012 Remi Collet 5.5.0-0.7.201212110630 -- prevent php_config.h changes across (otherwise identical) rebuilds -- drop "Configure Command" from phpinfo output - -* Tue Dec 11 2012 Remi Collet 5.5.0-0.6.201212110630 -- new snapshot -- move gmp in new sub-package - -* Mon Dec 10 2012 Remi Collet 5.5.0-0.6.201212100830 -- build sockets, tokenizer extensions shared - -* Mon Dec 10 2012 Remi Collet 5.5.0-0.5.201212100830 -- new snapshot -- enable dtrace - -* Tue Dec 4 2012 Remi Collet 5.5.0-0.4.201211301534 -- build simplexml and xml extensions shared (in php-xml) -- build bz2, calendar, ctype, exif, ftp, gettext and iconv - extensions shared (in php-common) -- build gmp extension shared (in php-bcmath) -- build shmop extension shared (in php-process) - -* Mon Dec 3 2012 Remi Collet 5.5.0-0.3.201211301534 -- drop some old compatibility provides (php-api, php-zend-abi, php-pecl-*) -- obsoletes php55-* - -* Fri Nov 30 2012 Remi Collet 5.5.0-0.2.201211301534 -- update to have zend_execute_ex for xDebug - -* Fri Nov 30 2012 Remi Collet 5.5.0-0.1.201211300857 -- Initial work on 5.5.0-dev - -* Fri Nov 23 2012 Remi Collet 5.4.9-2 -- add patch for https://bugs.php.net/63588 - duplicated implementation of php_next_utf8_char - -* Thu Nov 22 2012 Remi Collet 5.4.9-1 -- update to 5.4.9 - -* Thu Nov 15 2012 Remi Collet 5.4.9-0.5.RC1 -- switch back to upstream generated scanner/parser - -* Thu Nov 15 2012 Remi Collet 5.4.9-0.4.RC1 -- use _httpd_contentdir macro and fix php.gif path - -* Wed Nov 14 2012 Remi Collet 5.4.9-0.3.RC1 -- improve system libzip patch to use pkg-config - -* Wed Nov 14 2012 Remi Collet 5.4.9-0.2.RC1 -- use _httpd_moddir macro - -* Wed Nov 14 2012 Remi Collet 5.4.9-0.1.RC1 -- update to 5.4.9RC1 -- improves php.conf (use FilesMatch + SetHandler) -- improves filter (httpd module) -- apply ldap_r patch on fedora >= 18 only - -* Fri Nov 9 2012 Remi Collet 5.4.9-0.2.RC1 -- sync with rawhide - -* Fri Nov 9 2012 Remi Collet 5.4.8-6 -- clarify Licenses -- missing provides xmlreader and xmlwriter -- modernize spec - -* Thu Nov 8 2012 Remi Collet 5.4.9-0.1.RC1 -- update to 5.4.9RC1 -- change php embedded library soname version to 5.4 - -* Tue Nov 6 2012 Remi Collet 5.4.8-5 -- fix _httpd_mmn macro definition - -* Mon Nov 5 2012 Remi Collet 5.4.8-4 -- fix mysql_sock macro definition - -* Thu Oct 25 2012 Remi Collet 5.4.8-3 -- fix installed headers - -* Tue Oct 23 2012 Joe Orton - 5.4.8-2 -- use libldap_r for ldap extension - -* Thu Oct 18 2012 Remi Collet 5.4.8-1 -- update to 5.4.8 -- define both session.save_handler and session.save_path -- fix possible segfault in libxml (#828526) -- php-fpm: create apache user if needed -- use SKIP_ONLINE_TEST during make test -- php-devel requires pcre-devel and php-cli (instead of php) - -* Fri Oct 5 2012 Remi Collet 5.4.8-0.3.RC1 -- provides php-phar - -* Thu Oct 4 2012 Remi Collet 5.4.8-0.2.RC1 -- update systzdata patch to v10, timezone are case insensitive - -* Thu Oct 4 2012 Remi Collet 5.4.8-0.1.RC1 -- update to 5.4.8RC1 - -* Mon Oct 1 2012 Remi Collet 5.4.7-10 -- fix typo in systemd macro - -* Mon Oct 1 2012 Remi Collet 5.4.7-9 -- php-fpm: enable PrivateTmp -- php-fpm: new systemd macros (#850268) -- php-fpm: add upstream patch for startup issue (#846858) - -* Fri Sep 28 2012 Remi Collet 5.4.7-8 -- systemd integration, https://bugs.php.net/63085 -- no odbc call during timeout, https://bugs.php.net/63171 -- check sqlite3_column_table_name, https://bugs.php.net/63149 - -* Mon Sep 24 2012 Remi Collet 5.4.7-7 -- most failed tests explained (i386, x86_64) - -* Wed Sep 19 2012 Remi Collet 5.4.7-6 -- fix for http://bugs.php.net/63126 (#783967) - -* Wed Sep 19 2012 Remi Collet 5.4.7-6 -- add --daemonize / --nodaemonize options to php-fpm - upstream RFE: https://bugs.php.net/63085 - -* Wed Sep 19 2012 Remi Collet 5.4.7-5 -- sync with rawhide -- patch to report libdb version https://bugs.php.net/63117 - -* Wed Sep 19 2012 Remi Collet 5.4.7-5 -- patch to ensure we use latest libdb (not libdb4) - -* Wed Sep 19 2012 Remi Collet 5.4.7-4 -- really fix rhel tests (use libzip and libdb) - -* Tue Sep 18 2012 Remi Collet 5.4.7-3 -- fix test to enable zip extension on RHEL-7 - -* Mon Sep 17 2012 Remi Collet 5.4.7-2 -- remove session.save_path from php.ini - move it to apache and php-fpm configuration files - -* Fri Sep 14 2012 Remi Collet 5.4.7-1 -- update to 5.4.7 - http://www.php.net/releases/5_4_7.php -- php-fpm: don't daemonize - -* Thu Sep 13 2012 Remi Collet 5.4.7-1 -- update to 5.4.7 - -* Mon Sep 3 2012 Remi Collet 5.4.7-0.2.RC1 -- obsoletes php53* and php54* - -* Fri Aug 31 2012 Remi Collet 5.4.7-0.1.RC1 -- update to 5.4.7RC1 - -* Mon Aug 20 2012 Remi Collet 5.4.6-2 -- enable php-fpm on secondary arch (#849490) - -* Thu Aug 16 2012 Remi Collet 5.4.6-1 -- update to 5.4.6 - -* Thu Aug 02 2012 Remi Collet 5.4.6-0.1.RC1 -- update to 5.4.6RC1 - -* Fri Jul 20 2012 Remi Collet 5.4.5-1 -- update to 5.4.5 - -* Sat Jul 07 2012 Remi Collet 5.4.5-0.2.RC1 -- update patch for system libzip - -* Wed Jul 04 2012 Remi Collet 5.4.5-0.1.RC1 -- update to 5.4.5RC1 with bundled libzip. - -* Mon Jul 02 2012 Remi Collet 5.4.4-4 -- use system pcre only on fedora >= 14 (version 8.10) -- drop BR for libevent (#835671) -- provide php(language) to allow version check -- define %%{php_version} - -* Thu Jun 21 2012 Remi Collet 5.4.4-2 -- clean spec, sync with rawhide -- add missing provides (core, ereg, filter, standard) - -* Wed Jun 13 2012 Remi Collet 5.4.4-1 -- update to 5.4.4 finale -- fedora >= 15: use /usr/lib/tmpfiles.d instead of /etc/tmpfiles.d -- fedora >= 15: use /run/php-fpm instead of /var/run/php-fpm - -* Thu May 31 2012 Remi Collet 5.4.4-0.2.RC2 -- update to 5.4.4RC2 - -* Thu May 17 2012 Remi Collet 5.4.4-0.1.RC1 -- update to 5.4.4RC1 - -* Wed May 09 2012 Remi Collet 5.4.3-1 -- update to 5.4.3 (CVE-2012-2311, CVE-2012-2329) - -* Thu May 03 2012 Remi Collet 5.4.2-1 -- update to 5.4.2 (CVE-2012-1823) - -* Fri Apr 27 2012 Remi Collet 5.4.1-1 -- update to 5.4.1 -- use libdb in fedora >= 18 instead of db4 - -* Fri Apr 13 2012 Remi Collet 5.4.1-0.3.RC2 -- update to 5.4.1RC2 - -* Sat Mar 31 2012 Remi Collet 5.4.1-0.2.RC1 -- rebuild - -* Sat Mar 31 2012 Remi Collet 5.4.1-0.1.RC1 -- update to 5.4.1RC1, split php conf when httpd 2.4 - -* Tue Mar 27 2012 Remi Collet 5.4.0-1.1 -- sync with rawhide (httpd 2.4 stuff) - -* Mon Mar 26 2012 Joe Orton - 5.4.0-2 -- rebuild against httpd 2.4 -- use _httpd_mmn, _httpd_apxs macros -- fix --without-system-tzdata build for Debian et al - -* Fri Mar 02 2012 Remi Collet 5.4.0-1 -- update to PHP 5.4.0 finale - -* Sat Feb 18 2012 Remi Collet 5.4.0-0.16.RC8 -- update to 5.4.0RC8 - -* Sat Feb 04 2012 Remi Collet 5.4.0-0.15.RC7 -- update to 5.4.0RC7 - -* Fri Jan 27 2012 Remi Collet 5.4.0-0.14.RC6 -- build against system libzip (fedora >= 17), patch from spot - -* Thu Jan 26 2012 Remi Collet 5.4.0-0.13.RC6 -- add /etc/sysconfig/php-fpm environment file (#784770) - -* Wed Jan 25 2012 Remi Collet 5.4.0-0.12.RC6 -- keep all ZTS binaries in /usr/bin (with zts prefix) - -* Thu Jan 19 2012 Remi Collet 5.4.0-0.11.RC6 -- update to 5.4.0RC6 - -* Wed Jan 18 2012 Remi Collet 5.4.0-0.10.RC5 -- add some fedora patches back (dlopen, easter, phpize) - -* Mon Jan 16 2012 Remi Collet 5.4.0-0.9.RC5 -- improves mysql.sock default path - -* Fri Jan 13 2012 Remi Collet 5.4.0-0.8.RC5 -- update to 5.4.0RC5 -- patch for https://bugs.php.net/60748 (mysql.sock hardcoded) -- move session.path from php.ini to httpd/conf.d/php.conf -- provides both ZTS mysql extensions (libmysql/mysqlnd) -- build php cli ZTS binary, in -devel, mainly for test - -* Wed Jan 04 2012 Remi Collet 5.4.0-0.7.201201041830 -- new snapshot (5.4.0RC5-dev) with fix for https://bugs.php.net/60627 - -* Fri Dec 30 2011 Remi Collet 5.4.0-0.6.201112300630 -- new snapshot (5.4.0RC5-dev) - -* Mon Dec 26 2011 Remi Collet 5.4.0-0.6.201112261030 -- new snapshot (5.4.0RC5-dev) - -* Sat Dec 17 2011 Remi Collet 5.4.0-0.5.201112170630 -- new snapshot (5.4.0RC4-dev) - -* Mon Dec 12 2011 Remi Collet 5.4.0-0.4.201112121330 -- new snapshot (5.4.0RC4-dev) -- switch to systemd - -* Fri Dec 09 2011 Remi Collet 5.4.0-0.3.201112091730 -- new snapshot (5.4.0RC4-dev) -- removed patch merged upstream for https://bugs.php.net/60392 -- clean ini (from upstream production default) - -* Sun Nov 13 2011 Remi Collet 5.4.0-0.3.201111260730 -- new snapshot (5.4.0RC3-dev) -- patch for https://bugs.php.net/60392 (old libicu on EL-5) - -* Sun Nov 13 2011 Remi Collet 5.4.0-0.3.201111130730 -- new snapshot (5.4.0RC2-dev) -- sync with latest changes in 5.3 spec - -* Thu Sep 08 2011 Remi Collet 5.4.0-0.2.201109081430 -- new snapshot -- build mysql/mysqli against both libmysql and mysqlnd (new mysqlnd sub-package) - -* Sat Sep 03 2011 Remi Collet 5.4.0-0.1.201109031230 -- first work on php 5.4 -- remove -sqlite subpackage -- move php/modules-zts to php-zts/modules - diff --git a/php72.spec b/php72.spec new file mode 100644 index 0000000..f388e42 --- /dev/null +++ b/php72.spec @@ -0,0 +1,3162 @@ +# remirepo spec file for php 7.2 +# with backport stuff, adapted from +# +# Fedora spec file for php +# +# License: MIT +# http://opensource.org/licenses/MIT +# +# Please preserve changelog entries +# +# API/ABI check +%global apiver 20170718 +%global zendver 20170718 +%global pdover 20170320 +# Extension version +%global fileinfover 1.0.5 +%global oci8ver 2.1.7 +%global zipver 1.13.0 +%global jsonver 1.6.0 + +# Adds -z now to the linker flags +%global _hardened_build 1 + +# version used for php embedded library soname +%global embed_version 7.2 + +%global mysql_sock %(mysql_config --socket 2>/dev/null || echo /var/lib/mysql/mysql.sock) + +%ifarch ppc ppc64 +%global oraclever 10.2.0.2 +%else +%global oraclever 12.2 +%endif + +# Build for LiteSpeed Web Server (LSAPI) +%global with_lsws 1 + +# Regression tests take a long time, you can skip 'em with this +#global runselftest 0 +%{!?runselftest: %global runselftest 1} + +# Use the arch-specific mysql_config binary to avoid mismatch with the +# arch detection heuristic used by bindir/mysql_config. +%global mysql_config %{_libdir}/mysql/mysql_config + +# Optional components; pass "--with mssql" etc to rpmbuild. +%global with_oci8 %{?_with_oci8:1}%{!?_with_oci8:0} + +%if 0%{?fedora} >= 22 || 0%{?rhel} >= 8 +%global with_libpcre 1 +%else +%global with_libpcre 0 +%endif +%if 0%{?fedora} >= 26 +%global with_onig 1 +%else +%global with_onig 0 +%endif + +%global with_sqlite3 1 + +# Build ZTS extension or only NTS +%global with_zts 1 + +# Debuild build +%global with_debug %{?_with_debug:1}%{!?_with_debug:0} + +%if 0%{?__isa_bits:1} +%global isasuffix -%{__isa_bits} +%else +%global isasuffix %nil +%endif + +# /usr/sbin/apsx with httpd < 2.4 and defined as /usr/bin/apxs with httpd >= 2.4 +%{!?_httpd_apxs: %{expand: %%global _httpd_apxs %%{_sbindir}/apxs}} +%{!?_httpd_mmn: %{expand: %%global _httpd_mmn %%(cat %{_includedir}/httpd/.mmn 2>/dev/null || echo 0-0)}} +%{!?_httpd_confdir: %{expand: %%global _httpd_confdir %%{_sysconfdir}/httpd/conf.d}} +# /etc/httpd/conf.d with httpd < 2.4 and defined as /etc/httpd/conf.modules.d with httpd >= 2.4 +%{!?_httpd_modconfdir: %{expand: %%global _httpd_modconfdir %%{_sysconfdir}/httpd/conf.d}} +%{!?_httpd_moddir: %{expand: %%global _httpd_moddir %%{_libdir}/httpd/modules}} +%{!?_httpd_contentdir: %{expand: %%global _httpd_contentdir /var/www}} + +%global macrosdir %(d=%{_rpmconfigdir}/macros.d; [ -d $d ] || d=%{_sysconfdir}/rpm; echo $d) + +# systemd to manage the service, with notify mode, with additional service config +%if 0%{?fedora} >= 19 || 0%{?rhel} >= 7 +%global with_systemd 1 +%else +%global with_systemd 0 +%endif +# httpd 2.4.10 with httpd-filesystem and sethandler support +%if 0%{?fedora} >= 21 +%global with_httpd2410 1 +%else +%global with_httpd2410 0 +%endif +# nginx 1.6 with nginx-filesystem +%if 0%{?fedora} >= 21 +%global with_nginx 1 +%else +%global with_nginx 0 +%endif + +%global with_dtrace 1 +%global with_libgd 1 +%global with_libzip 1 +%global with_zip 0 + +%if 0%{?fedora} < 18 && 0%{?rhel} < 7 +%global db_devel db4-devel +%else +%global db_devel libdb-devel +%endif + +%global upver 7.2.0 +%global rcver RC1 + +Summary: PHP scripting language for creating dynamic web sites +Name: php +Version: %{upver}%{?rcver:~%{rcver}} +Release: 1%{?dist} +# All files licensed under PHP version 3.01, except +# Zend is licensed under Zend +# TSRM is licensed under BSD +# main/snprintf.c, main/spprintf.c and main/rfc1867.c are ASL 1.0 +# ext/date/lib is MIT +License: PHP and Zend and BSD and MIT and ASL 1.0 +Group: Development/Languages +URL: http://www.php.net/ + +Source0: http://www.php.net/distributions/php-%{upver}%{?rcver}.tar.xz +Source1: php.conf +Source2: php.ini +Source3: macros.php +Source4: php-fpm.conf +Source5: php-fpm-www.conf +Source6: php-fpm.service +Source7: php-fpm.logrotate +Source8: php-fpm.sysconfig +Source9: php.modconf +Source10: php.ztsmodconf +Source12: php.conf2 +Source13: nginx-fpm.conf +Source14: nginx-php.conf +# Configuration files for some extensions +Source50: 10-opcache.ini +Source51: opcache-default.blacklist +Source52: 20-oci8.ini +Source99: php-fpm.init + +# Build fixes +Patch1: php-7.1.7-httpd.patch +Patch5: php-7.2.0-includedir.patch +Patch6: php-5.6.3-embed.patch +Patch7: php-5.3.0-recode.patch +Patch8: php-7.1.0-libdb.patch +Patch9: php-7.0.7-curl.patch +# From https://github.com/derickr/timelib/pull/21 +Patch10: php-timelib.patch + +# Functional changes +Patch40: php-7.1.3-dlopen.patch +Patch42: php-7.2.0-systzdata-v15.patch +# See http://bugs.php.net/53436 +Patch43: php-5.4.0-phpize.patch +# Use -lldap_r for OpenLDAP +Patch45: php-5.6.3-ldap_r.patch +# Make php_config.h constant across builds +Patch46: php-7.2.0-fixheader.patch +# drop "Configure command" from phpinfo output +Patch47: php-5.6.3-phpinfo.patch + +# RC Patch +Patch91: php-7.2.0-oci8conf.patch + +# Upstream fixes (100+) + +# Security fixes (200+) + +# Fixes for tests (300+) +# Factory is droped from system tzdata +Patch300: php-7.0.10-datetests.patch +# Revert changes for pcre < 8.34 +Patch301: php-7.0.0-oldpcre.patch + +# WIP + +BuildRequires: bzip2-devel, curl-devel >= 7.9 +BuildRequires: httpd-devel >= 2.0.46-1, pam-devel +%if %{with_httpd2410} +# to ensure we are using httpd with filesystem feature (see #1081453) +BuildRequires: httpd-filesystem +%endif +%if %{with_nginx} +# to ensure we are using nginx with filesystem feature (see #1142298) +BuildRequires: nginx-filesystem +%endif +BuildRequires: %{?dtsprefix}libstdc++-devel, openssl-devel +%if %{with_sqlite3} +# For Sqlite3 extension +BuildRequires: sqlite-devel >= 3.6.0 +%else +BuildRequires: sqlite-devel >= 3.0.0 +%endif +BuildRequires: zlib-devel, smtpdaemon, libedit-devel +%if %{with_libpcre} +BuildRequires: pcre-devel >= 8.20 +%endif +BuildRequires: bzip2, perl, libtool >= 1.4.3, %{?dtsprefix}gcc-c++ +BuildRequires: libtool-ltdl-devel +%if %{with_dtrace} +BuildRequires: %{?dtsprefix}systemtap-sdt-devel +%endif +#BuildRequires: bison + +%if 0%{?rhel} +Obsoletes: php53, php53u, php54w, php55u, php55w, php56u, php56w, mod_php70u, php70w, mod_php71u, mod_php71w, mod_php72u, mod_php72w +%endif +# Avoid obsoleting php54 from RHSCL +Obsoletes: php54 > 5.4 +%if %{with_zts} +Obsoletes: php-zts < 5.3.7 +Provides: php-zts = %{version}-%{release} +Provides: php-zts%{?_isa} = %{version}-%{release} +%endif + +Requires: httpd-mmn = %{_httpd_mmn} +Provides: mod_php = %{version}-%{release} +Requires: php-common%{?_isa} = %{version}-%{release} +# For backwards-compatibility, require php-cli for the time being: +Requires: php-cli%{?_isa} = %{version}-%{release} +# To ensure correct /var/lib/php/session ownership: +%if %{with_httpd2410} +Requires(pre): httpd-filesystem +%else +Requires(pre): httpd +%endif +# php engine for Apache httpd webserver +Provides: php(httpd) + +%if 0%{?fedora} < 20 && 0%{?rhel} < 7 +# Don't provides extensions, which are not shared library, as .so +%{?filter_provides_in: %filter_provides_in %{_libdir}/php/modules/.*\.so$} +%{?filter_provides_in: %filter_provides_in %{_libdir}/php-zts/modules/.*\.so$} +%{?filter_provides_in: %filter_provides_in %{_httpd_moddir}/.*\.so$} +%{?filter_setup} +%endif + + +%description +PHP is an HTML-embedded scripting language. PHP attempts to make it +easy for developers to write dynamically generated web pages. PHP also +offers built-in database integration for several commercial and +non-commercial database management systems, so writing a +database-enabled webpage with PHP is fairly simple. The most common +use of PHP coding is probably as a replacement for CGI scripts. + +The php package contains the module (often referred to as mod_php) +which adds support for the PHP language to Apache HTTP Server. + +%package cli +Group: Development/Languages +Summary: Command-line interface for PHP +Requires: php-common%{?_isa} = %{version}-%{release} +Provides: php-cgi = %{version}-%{release}, php-cgi%{?_isa} = %{version}-%{release} +Provides: php-pcntl, php-pcntl%{?_isa} +Provides: php-readline, php-readline%{?_isa} +%if 0%{?rhel} +Obsoletes: php53-cli, php53u-cli, php54-cli, php54w-cli, php55u-cli, php55w-cli, php56u-cli, php56w-cli +Obsoletes: php70u-cli, php70w-cli, php71u-cli, php71w-cli, php72u-cli, php72w-cli +%endif + +%description cli +The php-cli package contains the command-line interface +executing PHP scripts, /usr/bin/php, and the CGI interface. + + +%package dbg +Group: Development/Languages +Summary: The interactive PHP debugger +Requires: php-common%{?_isa} = %{version}-%{release} +%if 0%{?rhel} +Obsoletes: php56u-dbg, php56w-dbg, php70u-dbg, php70w-phpdbg, php71u-dbg, php71w-phpdbg, php72u-dbg, php72w-phpdbg +%endif +%description dbg +The php-dbg package contains the interactive PHP debugger. + + +%package fpm +Group: Development/Languages +Summary: PHP FastCGI Process Manager +BuildRequires: libacl-devel +Requires: php-common%{?_isa} = %{version}-%{release} +Requires(pre): /usr/sbin/useradd +%if %{with_systemd} +BuildRequires: systemd-devel +BuildRequires: systemd-units +Requires: systemd-units +Requires(post): systemd-units +Requires(preun): systemd-units +Requires(postun): systemd-units +# This is actually needed for the %%triggerun script but Requires(triggerun) +# is not valid. We can use %%post because this particular %%triggerun script +# should fire just after this package is installed. +Requires(post): systemd-sysv +%else +# This is for /sbin/service +Requires(preun): initscripts +Requires(postun): initscripts +%endif +%if %{with_httpd2410} +# To ensure correct /var/lib/php/session ownership: +Requires(pre): httpd-filesystem +# For php.conf in /etc/httpd/conf.d +# and version 2.4.10 for proxy support in SetHandler +Requires: httpd-filesystem >= 2.4.10 +# php engine for Apache httpd webserver +Provides: php(httpd) +%endif +%if %{with_nginx} +# for /etc/nginx ownership +Requires: nginx-filesystem +%endif +%if 0%{?rhel} +Obsoletes: php53-fpm, php53u-fpm, php54-fpm, php54w-fpm, php55u-fpm, php55w-fpm, php56u-fpm, php56w-fpm +Obsoletes: php70u-fpm, php70w-fpm, php71u-fpm, php71w-fpm, php72u-fpm, php72w-fpm +%endif + +%description fpm +PHP-FPM (FastCGI Process Manager) is an alternative PHP FastCGI +implementation with some additional features useful for sites of +any size, especially busier sites. + +%if %{with_lsws} +%package litespeed +Summary: LiteSpeed Web Server PHP support +Group: Development/Languages +Requires: php-common%{?_isa} = %{version}-%{release} +%if 0%{?rhel} +Obsoletes: php53-litespeed, php53u-litespeed, php54-litespeed, php54w-litespeed, php55u-litespeed, php55w-litespeed, php56u-litespeed, php56w-litespeed +Obsoletes: php70u-litespeed, php70w-litespeed, php71u-litespeed, php71w-litespeed, php72u-litespeed, php72w-litespeed +%endif + +%description litespeed +The php-litespeed package provides the %{_bindir}/lsphp command +used by the LiteSpeed Web Server (LSAPI enabled PHP). +%endif + +%package common +Group: Development/Languages +Summary: Common files for PHP +# All files licensed under PHP version 3.01, except +# fileinfo is licensed under PHP version 3.0 +# regex, libmagic are licensed under BSD +License: PHP and BSD +# ABI/API check - Arch specific +Provides: php(api) = %{apiver}%{isasuffix} +Provides: php(zend-abi) = %{zendver}%{isasuffix} +Provides: php(language) = %{version}, php(language)%{?_isa} = %{version} +# Provides for all builtin/shared modules: +Provides: php-bz2, php-bz2%{?_isa} +Provides: php-calendar, php-calendar%{?_isa} +Provides: php-core = %{version}, php-core%{?_isa} = %{version} +Provides: php-ctype, php-ctype%{?_isa} +Provides: php-curl, php-curl%{?_isa} +Provides: php-date, php-date%{?_isa} +Provides: bundled(timelib) +Provides: php-exif, php-exif%{?_isa} +Provides: php-fileinfo, php-fileinfo%{?_isa} +Provides: bundled(libmagic) = 5.29 +Provides: php-filter, php-filter%{?_isa} +Provides: php-ftp, php-ftp%{?_isa} +Provides: php-gettext, php-gettext%{?_isa} +Provides: php-hash, php-hash%{?_isa} +Provides: php-mhash = %{version}, php-mhash%{?_isa} = %{version} +Provides: php-iconv, php-iconv%{?_isa} +Provides: php-libxml, php-libxml%{?_isa} +Provides: php-openssl, php-openssl%{?_isa} +Provides: php-phar, php-phar%{?_isa} +Provides: php-pcre, php-pcre%{?_isa} +Provides: php-reflection, php-reflection%{?_isa} +Provides: php-session, php-session%{?_isa} +Provides: php-sockets, php-sockets%{?_isa} +Provides: php-spl, php-spl%{?_isa} +Provides: php-standard = %{version}, php-standard%{?_isa} = %{version} +Provides: php-tokenizer, php-tokenizer%{?_isa} +Provides: php-zlib, php-zlib%{?_isa} +# For user experience, those extensions were part of php-common +Requires: php-json%{?_isa} = %{version}-%{release} +#Requires: php-zip%%{?_isa} + +Obsoletes: php-pecl-phar < 1.2.4 +Obsoletes: php-pecl-Fileinfo < 1.0.5 +Provides: php-pecl-Fileinfo = %{fileinfover}, php-pecl-Fileinfo%{?_isa} = %{fileinfover} +Provides: php-pecl(Fileinfo) = %{fileinfover}, php-pecl(Fileinfo)%{?_isa} = %{fileinfover} +Obsoletes: php-mhash < 5.3.0 +%if 0%{?rhel} +Obsoletes: php53-mhash, php53u-mhash +Obsoletes: php53-common, php53u-common, php54-common, php54w-common, php55u-common, php55w-common, php56u-common, php56w-common +Obsoletes: php70u-common, php70w-common, php71u-common, php71w-common, php72u-common, php72w-common +%endif + +%description common +The php-common package contains files used by both the php +package and the php-cli package. + +%package devel +Group: Development/Libraries +Summary: Files needed for building PHP extensions +Requires: php-cli%{?_isa} = %{version}-%{release}, autoconf, automake +%if %{with_libpcre} +Requires: pcre-devel%{?_isa} +%endif +Obsoletes: php-pecl-pdo-devel +Obsoletes: php-pecl-json-devel < %{jsonver} +Obsoletes: php-pecl-jsonc-devel < %{jsonver} +%if %{with_zts} +Provides: php-zts-devel = %{version}-%{release} +Provides: php-zts-devel%{?_isa} = %{version}-%{release} +%endif +%if 0%{?rhel} +Obsoletes: php53-devel, php53u-devel, php54-devel, php54w-devel, php55u-devel, php55w-devel, php56u-devel, php56w-devel +Obsoletes: php70u-devel, php70w-devel, php71u-devel, php71w-devel, php72u-devel, php72w-devel +%endif + +%description devel +The php-devel package contains the files needed for building PHP +extensions. If you need to compile your own PHP extensions, you will +need to install this package. + +%package opcache +Summary: The Zend OPcache +Group: Development/Languages +License: PHP +Requires: php-common%{?_isa} = %{version}-%{release} +Obsoletes: php-pecl-zendopcache +Provides: php-pecl-zendopcache = %{version} +Provides: php-pecl-zendopcache%{?_isa} = %{version} +Provides: php-pecl(opcache) = %{version} +Provides: php-pecl(opcache)%{?_isa} = %{version} +%if 0%{?rhel} +Obsoletes: php55u-opcache, php55w-opcache, php56u-opcache, php56w-opcache +Obsoletes: php70u-opcache, php70w-opcache, php71u-opcache, php71w-opcache, php72u-opcache, php72w-opcache +%endif + +%description opcache +The Zend OPcache provides faster PHP execution through opcode caching and +optimization. It improves PHP performance by storing precompiled script +bytecode in the shared memory. This eliminates the stages of reading code from +the disk and compiling it on future access. In addition, it applies a few +bytecode optimization patterns that make code execution faster. + +%package imap +Summary: A module for PHP applications that use IMAP +Group: Development/Languages +# All files licensed under PHP version 3.01 +License: PHP +Requires: php-common%{?_isa} = %{version}-%{release} +Obsoletes: mod_php3-imap, stronghold-php-imap +BuildRequires: krb5-devel, openssl-devel, libc-client-devel +%if 0%{?rhel} +Obsoletes: php53-imap, php53u-imap, php54-imap, php54w-imap, php55u-imap, php55w-imap, php56u-imap, php56w-imap +Obsoletes: php70u-imap, php70w-imap, php71u-imap, php71w-imap, php72u-imap, php72w-imap +%endif + +%description imap +The php-imap module will add IMAP (Internet Message Access Protocol) +support to PHP. IMAP is a protocol for retrieving and uploading e-mail +messages on mail servers. PHP is an HTML-embedded scripting language. + +%package ldap +Summary: A module for PHP applications that use LDAP +Group: Development/Languages +# All files licensed under PHP version 3.01 +License: PHP +Requires: php-common%{?_isa} = %{version}-%{release} +BuildRequires: cyrus-sasl-devel, openldap-devel, openssl-devel +%if 0%{?rhel} +Obsoletes: php53-ldap, php53u-ldap, php54-ldap, php54w-ldap, php55u-ldap, php55w-ldap, php56u-ldap, php56w-ldap +Obsoletes: php70u-ldap, php70w-ldap, php71u-ldap, php71w-ldap, php72u-ldap, php72w-ldap +%endif + +%description ldap +The php-ldap adds Lightweight Directory Access Protocol (LDAP) +support to PHP. LDAP is a set of protocols for accessing directory +services over the Internet. PHP is an HTML-embedded scripting +language. + +%package pdo +Summary: A database access abstraction module for PHP applications +Group: Development/Languages +# All files licensed under PHP version 3.01 +License: PHP +Requires: php-common%{?_isa} = %{version}-%{release} +# ABI/API check - Arch specific +Provides: php-pdo-abi = %{pdover}%{isasuffix} +Provides: php(pdo-abi) = %{pdover}%{isasuffix} +%if %{with_sqlite3} +Provides: php-sqlite3, php-sqlite3%{?_isa} +%endif +Provides: php-pdo_sqlite, php-pdo_sqlite%{?_isa} +%if 0%{?rhel} +Obsoletes: php53-pdo, php53u-pdo, php54-pdo, php54w-pdo, php55u-pdo, php55w-pdo, php56u-pdo, php56w-pdo +Obsoletes: php70u-pdo, php70w-pdo, php71u-pdo, php71w-pdo, php72u-pdo, php72w-pdo +%endif + +%description pdo +The php-pdo package contains a dynamic shared object that will add +a database access abstraction layer to PHP. This module provides +a common interface for accessing MySQL, PostgreSQL or other +databases. + +%package mysqlnd +Summary: A module for PHP applications that use MySQL databases +Group: Development/Languages +# All files licensed under PHP version 3.01 +License: PHP +Requires: php-pdo%{?_isa} = %{version}-%{release} +Provides: php_database +Provides: php-mysqli = %{version}-%{release} +Provides: php-mysqli%{?_isa} = %{version}-%{release} +Provides: php-pdo_mysql, php-pdo_mysql%{?_isa} +Obsoletes: php-mysql < %{version}-%{release} +%if 0%{?rhel} +Obsoletes: php53-mysqlnd, php53u-mysqlnd, php54-mysqlnd, php54w-mysqlnd, php55u-mysqlnd, php55w-mysqlnd, php56u-mysqlnd, php56w-mysqlnd +Obsoletes: php70u-mysqlnd, php70w-mysqlnd, php71u-mysqlnd, php71w-mysqlnd, php72u-mysqlnd, php72w-mysqlnd +Obsoletes: php53-mysql, php53u-mysql, php54-mysql, php54w-mysql, php55u-mysql, php55w-mysql, php56u-mysql, php56w-mysql +Obsoletes: php70u-mysql, php70w-mysql, php71u-mysql, php71w-mysql, php72u-mysql, php72w-mysql +%endif + +%description mysqlnd +The php-mysqlnd package contains a dynamic shared object that will add +MySQL database support to PHP. MySQL is an object-relational database +management system. PHP is an HTML-embeddable scripting language. If +you need MySQL support for PHP applications, you will need to install +this package and the php package. + +This package use the MySQL Native Driver + +%package pgsql +Summary: A PostgreSQL database module for PHP +Group: Development/Languages +# All files licensed under PHP version 3.01 +License: PHP +Requires: php-pdo%{?_isa} = %{version}-%{release} +Provides: php_database +Provides: php-pdo_pgsql, php-pdo_pgsql%{?_isa} +BuildRequires: krb5-devel, openssl-devel, postgresql-devel +%if 0%{?rhel} +Obsoletes: php53-pgsql, php53u-pgsql, php54-pgsql, php54w-pgsql, php55u-pgsql, php55w-pgsql, php56u-pgsql, php56w-pgsql +Obsoletes: php70u-pgsql, php70w-pgsql, php71u-pgsql, php71w-pgsql, php72u-pgsql, php72w-pgsql +%endif + +%description pgsql +The php-pgsql package add PostgreSQL database support to PHP. +PostgreSQL is an object-relational database management +system that supports almost all SQL constructs. PHP is an +HTML-embedded scripting language. If you need back-end support for +PostgreSQL, you should install this package in addition to the main +php package. + +%package process +Summary: Modules for PHP script using system process interfaces +Group: Development/Languages +# All files licensed under PHP version 3.01 +License: PHP +Requires: php-common%{?_isa} = %{version}-%{release} +Provides: php-posix, php-posix%{?_isa} +Provides: php-shmop, php-shmop%{?_isa} +Provides: php-sysvsem, php-sysvsem%{?_isa} +Provides: php-sysvshm, php-sysvshm%{?_isa} +Provides: php-sysvmsg, php-sysvmsg%{?_isa} +%if 0%{?rhel} +Obsoletes: php53-process, php53u-process, php54-process, php54w-process, php55u-process, php55w-process, php56u-process, php56w-process +Obsoletes: php70u-process, php70w-process, php71u-process, php71w-process, php72u-process, php72w-process +%endif + +%description process +The php-process package contains dynamic shared objects which add +support to PHP using system interfaces for inter-process +communication. + +%package odbc +Summary: A module for PHP applications that use ODBC databases +Group: Development/Languages +# All files licensed under PHP version 3.01, except +# pdo_odbc is licensed under PHP version 3.0 +License: PHP +Requires: php-pdo%{?_isa} = %{version}-%{release} +Provides: php_database +Provides: php-pdo_odbc, php-pdo_odbc%{?_isa} +BuildRequires: unixODBC-devel +%if 0%{?rhel} +Obsoletes: php53-odbc, php53u-odbc, php54-odbc, php54w-odbc, php55u-odbc, php55w-odbc, php56u-odbc, php56w-odbc +Obsoletes: php70u-odbc, php70w-odbc, php71u-odbc, php71w-odbc, php72u-odbc, php72w-odbc +%endif + +%description odbc +The php-odbc package contains a dynamic shared object that will add +database support through ODBC to PHP. ODBC is an open specification +which provides a consistent API for developers to use for accessing +data sources (which are often, but not always, databases). PHP is an +HTML-embeddable scripting language. If you need ODBC support for PHP +applications, you will need to install this package and the php +package. + +%package soap +Summary: A module for PHP applications that use the SOAP protocol +Group: Development/Languages +# All files licensed under PHP version 3.01 +License: PHP +Requires: php-common%{?_isa} = %{version}-%{release} +BuildRequires: libxml2-devel +%if 0%{?rhel} +Obsoletes: php53-soap, php53u-soap, php54-soap, php54w-soap, php55u-soap, php55w-soap, php56u-soap, php56w-soap +Obsoletes: php70u-soap, php70w-soap, php71u-soap, php71w-soap, php72u-soap, php72w-soap +%endif + +%description soap +The php-soap package contains a dynamic shared object that will add +support to PHP for using the SOAP web services protocol. + +%package interbase +Summary: A module for PHP applications that use Interbase/Firebird databases +Group: Development/Languages +# All files licensed under PHP version 3.01 +License: PHP +BuildRequires: firebird-devel +Requires: php-pdo%{?_isa} = %{version}-%{release} +Provides: php_database +Provides: php-firebird, php-firebird%{?_isa} +Provides: php-pdo_firebird, php-pdo_firebird%{?_isa} +%if 0%{?rhel} +Obsoletes: php53-interbase, php53u-interbase, php54-interbase, php54w-interbase, php55u-interbase, php55w-interbase, php56u-interbase, php56w-interbase +Obsoletes: php70u-interbase, php70w-interbase, php71u-interbase, php71w-interbase, php72u-interbase, php72w-interbase +%endif + +%description interbase +The php-interbase package contains a dynamic shared object that will add +database support through Interbase/Firebird to PHP. + +InterBase is the name of the closed-source variant of this RDBMS that was +developed by Borland/Inprise. + +Firebird is a commercially independent project of C and C++ programmers, +technical advisors and supporters developing and enhancing a multi-platform +relational database management system based on the source code released by +Inprise Corp (now known as Borland Software Corp) under the InterBase Public +License. + +%if %{with_oci8} +%package oci8 +Summary: A module for PHP applications that use OCI8 databases +Group: Development/Languages +# All files licensed under PHP version 3.01 +License: PHP +BuildRequires: oracle-instantclient-devel >= %{oraclever} +Requires: php-pdo%{?_isa} = %{version}-%{release} +Provides: php_database +Provides: php-pdo_oci, php-pdo_oci%{?_isa} +Obsoletes: php-pecl-oci8 < %{oci8ver} +Conflicts: php-pecl-oci8 >= %{oci8ver} +Provides: php-pecl(oci8) = %{oci8ver}, php-pecl(oci8)%{?_isa} = %{oci8ver} +# Should requires libclntsh.so.12.1, but it's not provided by Oracle RPM. +AutoReq: 0 +%if 0%{?rhel} +Obsoletes: php53-oci8, php53u-oci8, php54-oci8, php54w-oci8, php55u-oci8, php55w-oci8, php56u-oci8, php56w-oci8 +Obsoletes: php70u-oci8, php70w-oci8, php71u-oci8, php71w-oci8, php72u-oci8, php72w-oci8 +%endif + +%description oci8 +The php-oci8 packages provides the OCI8 extension version %{oci8ver} +and the PDO driver to access Oracle Database. + +The extension is linked with Oracle client libraries %{oraclever} +(Oracle Instant Client). For details, see Oracle's note +"Oracle Client / Server Interoperability Support" (ID 207303.1). + +You must install libclntsh.so.%{oraclever} to use this package, provided +in the database installation, or in the free Oracle Instant Client +available from Oracle. + +Notice: +- php-oci8 provides oci8 and pdo_oci extensions from php sources. +- php-pecl-oci8 only provides oci8 extension. + +Documentation is at http://php.net/oci8 and http://php.net/pdo_oci +%endif + +%package snmp +Summary: A module for PHP applications that query SNMP-managed devices +Group: Development/Languages +# All files licensed under PHP version 3.01 +License: PHP +Requires: php-common%{?_isa} = %{version}-%{release}, net-snmp +BuildRequires: net-snmp-devel +%if 0%{?rhel} +Obsoletes: php53-snmp, php53u-snmp, php54-snmp, php54w-snmp, php55u-snmp, php55w-snmp, php56u-snmp, php56w-snmp +Obsoletes: php70u-snmp, php70w-snmp, php71u-snmp, php71w-snmp, php72u-snmp, php72w-snmp +%endif + +%description snmp +The php-snmp package contains a dynamic shared object that will add +support for querying SNMP devices to PHP. PHP is an HTML-embeddable +scripting language. If you need SNMP support for PHP applications, you +will need to install this package and the php package. + +%package xml +Summary: A module for PHP applications which use XML +Group: Development/Languages +# All files licensed under PHP version 3.01 +License: PHP +Requires: php-common%{?_isa} = %{version}-%{release} +Provides: php-dom, php-dom%{?_isa} +Provides: php-domxml, php-domxml%{?_isa} +Provides: php-simplexml, php-simplexml%{?_isa} +Provides: php-wddx, php-wddx%{?_isa} +Provides: php-xmlreader, php-xmlreader%{?_isa} +Provides: php-xmlwriter, php-xmlwriter%{?_isa} +Provides: php-xsl, php-xsl%{?_isa} +BuildRequires: libxslt-devel >= 1.0.18-1, libxml2-devel >= 2.4.14-1 +%if 0%{?rhel} +Obsoletes: php53-xml, php53u-xml, php54-xml, php54w-xml, php55u-xml, php55w-xml, php56u-xml, php56w-xml +Obsoletes: php70u-xml, php70w-xml, php71u-xml, php71w-xml, php72u-xml, php72w-xml +%endif + +%description xml +The php-xml package contains dynamic shared objects which add support +to PHP for manipulating XML documents using the DOM tree, +and performing XSL transformations on XML documents. + +%package xmlrpc +Summary: A module for PHP applications which use the XML-RPC protocol +Group: Development/Languages +# All files licensed under PHP version 3.01, except +# libXMLRPC is licensed under BSD +License: PHP and BSD +Requires: php-xml%{?_isa} = %{version}-%{release} +%if 0%{?rhel} +Obsoletes: php53-xmlrpc, php53u-xmlrpc, php54-xmlrpc, php54w-xmlrpc, php55u-xmlrpc, php55w-xmlrpc, php56u-xmlrpc, php56w-xmlrpc +Obsoletes: php70u-xmlrpc, php70w-xmlrpc, php71u-xmlrpc, php71w-xmlrpc, php72u-xmlrpc, php72w-xmlrpc +%endif + +%description xmlrpc +The php-xmlrpc package contains a dynamic shared object that will add +support for the XML-RPC protocol to PHP. + +%package mbstring +Summary: A module for PHP applications which need multi-byte string handling +Group: Development/Languages +# All files licensed under PHP version 3.01, except +# libmbfl is licensed under LGPLv2 +# onigurama is licensed under BSD +# ucgendat is licensed under OpenLDAP +License: PHP and LGPLv2 and BSD and OpenLDAP +%if %{with_onig} +BuildRequires: oniguruma-devel +%else +Provides: bundled(oniguruma) = 6.3.0 +%endif +Provides: bundled(libmbfl) = 1.3.2 +Requires: php-common%{?_isa} = %{version}-%{release} +%if 0%{?rhel} +Obsoletes: php53-mbstring, php53u-mbstring, php54-mbstring, php54w-mbstring, php55u-mbstring, php55w-mbstring, php56u-mbstring, php56w-mbstring +Obsoletes: php70u-mbstring, php70w-mbstring, php71u-mbstring, php71w-mbstring, php72u-mbstring, php72w-mbstring +%endif + +%description mbstring +The php-mbstring package contains a dynamic shared object that will add +support for multi-byte string handling to PHP. + +%package gd +Summary: A module for PHP applications for using the gd graphics library +Group: Development/Languages +# All files licensed under PHP version 3.01 +%if %{with_libgd} +License: PHP +%else +# bundled libgd is licensed under BSD +License: PHP and BSD +%endif +Requires: php-common%{?_isa} = %{version}-%{release} +%if %{with_libgd} +BuildRequires: gd-devel >= 2.1.1 +%if 0%{?fedora} <= 19 && 0%{?rhel} <= 7 +Requires: gd-last%{?_isa} >= 2.1.1 +%else +Requires: gd%{?_isa} >= 2.1.1 +%endif +%else +# Required to build the bundled GD library +BuildRequires: libjpeg-devel +BuildRequires: libpng-devel +BuildRequires: freetype-devel +BuildRequires: libXpm-devel +BuildRequires: libwebp-devel +Provides: bundled(gd) = 2.0.35 +%endif +%if 0%{?rhel} +Obsoletes: php53-gd, php53u-gd, php54-gd, php54w-gd, php55u-gd, php55w-gd, php56u-gd, php56w-gd +Obsoletes: php70u-gd, php70w-gd, php71u-gd, php71w-gd, php72u-gd, php72w-gd +%endif + +%description gd +The php-gd package contains a dynamic shared object that will add +support for using the gd graphics library to PHP. + +%package bcmath +Summary: A module for PHP applications for using the bcmath library +Group: Development/Languages +# All files licensed under PHP version 3.01, except +# libbcmath is licensed under LGPLv2+ +License: PHP and LGPLv2+ +Requires: php-common%{?_isa} = %{version}-%{release} +%if 0%{?rhel} +Obsoletes: php53-bcmath, php53u-bcmath, php54-bcmath, php54w-bcmath, php55u-bcmath, php55w-bcmath, php56u-bcmath, php56w-bcmath +Obsoletes: php70u-bcmath, php70w-bcmath, php71u-bcmath, php71w-bcmath, php72u-bcmath, php72w-bcmath +%endif +Provides: bundled(libbcmath) + +%description bcmath +The php-bcmath package contains a dynamic shared object that will add +support for using the bcmath library to PHP. + +%package gmp +Summary: A module for PHP applications for using the GNU MP library +Group: Development/Languages +# All files licensed under PHP version 3.01 +License: PHP +BuildRequires: gmp-devel +Requires: php-common%{?_isa} = %{version}-%{release} +%if 0%{?rhel} +Obsoletes: php53-gmp, php53u-gmp, php54-gmp, php54w-gmp, php55u-gmp, php55w-gmp, php56u-gmp, php56w-gmp +Obsoletes: php70u-gmp, php70w-gmp, php71u-gmp, php71w-gmp, php72u-gmp, php72w-gmp +%endif + +%description gmp +These functions allow you to work with arbitrary-length integers +using the GNU MP library. + +%package dba +Summary: A database abstraction layer module for PHP applications +Group: Development/Languages +# All files licensed under PHP version 3.01 +License: PHP +BuildRequires: %{db_devel} +BuildRequires: tokyocabinet-devel +BuildRequires: lmdb-devel +Requires: php-common%{?_isa} = %{version}-%{release} +%if 0%{?rhel} +Obsoletes: php53-dba, php53u-dba, php54-dba, php54w-dba, php55u-dba, php55w-dba, php56u-dba, php56w-dba +Obsoletes: php70u-dba, php70w-dba, php71u-dba, php71w-dba, php72u-dba, php72w-dba +%endif + +%description dba +The php-dba package contains a dynamic shared object that will add +support for using the DBA database abstraction layer to PHP. + +%package tidy +Summary: Standard PHP module provides tidy library support +Group: Development/Languages +# All files licensed under PHP version 3.01 +License: PHP +Requires: php-common%{?_isa} = %{version}-%{release} +BuildRequires: libtidy-devel +%if 0%{?rhel} +Obsoletes: php53-tidy, php53u-tidy, php54-tidy, php54w-tidy, php55u-tidy, php55w-tidy, php56u-tidy, php56w-tidy +Obsoletes: php70u-tidy, php70w-tidy, php71u-tidy, php71w-tidy, php72u-tidy, php72w-tidy +%endif + +%description tidy +The php-tidy package contains a dynamic shared object that will add +support for using the tidy library to PHP. + +%package pdo-dblib +Summary: PDO driver Microsoft SQL Server and Sybase databases +# All files licensed under PHP version 3.01 +License: PHP +Requires: php-pdo%{?_isa} = %{version}-%{release} +BuildRequires: freetds-devel >= 0.91 +Provides: php-pdo_dblib, php-pdo_dblib%{?_isa} +Obsoletes: php-mssql < %{version}-%{release} +%if 0%{?rhel} +Obsoletes: php53-mssql, php53u-mssql, php54-mssql, php54w-mssql, php55u-mssql, php55w-mssql, php56u-mssql, php56w-mssql +Obsoletes: php70u-pdo-dblib, php70w-pdo_dblib, php71u-pdo-dblib, php71w-pdo_dblib, php72u-pdo-dblib, php72w-pdo_dblib +%endif + +%description pdo-dblib +The php-pdo-dblib package contains a dynamic shared object +that implements the PHP Data Objects (PDO) interface to enable access from +PHP to Microsoft SQL Server and Sybase databases through the FreeTDS libary. + +%package embedded +Summary: PHP library for embedding in applications +Group: System Environment/Libraries +Requires: php-common%{?_isa} = %{version}-%{release} +# doing a real -devel package for just the .so symlink is a bit overkill +Provides: php-embedded-devel = %{version}-%{release} +Provides: php-embedded-devel%{?_isa} = %{version}-%{release} +%if 0%{?rhel} +Obsoletes: php53-embedded, php53u-embedded, php54-embedded, php54w-embedded, php55u-embedded, php55w-embedded, php56u-embedded, php56w-embedded +Obsoletes: php70u-embedded, php70w-embedded, php71u-embedded, php71w-embedded, php72u-embedded, php72w-embedded +%endif + +%description embedded +The php-embedded package contains a library which can be embedded +into applications to provide PHP scripting language support. + +%package pspell +Summary: A module for PHP applications for using pspell interfaces +Group: System Environment/Libraries +# All files licensed under PHP version 3.01 +License: PHP +Requires: php-common%{?_isa} = %{version}-%{release} +BuildRequires: aspell-devel >= 0.50.0 +%if 0%{?rhel} +Obsoletes: php53-pspell, php53u-pspell, php54-pspell, php54w-pspell, php55u-pspell, php55w-pspell, php56u-pspell, php56w-pspell +Obsoletes: php70u-pspell, php70w-pspell, php71u-pspell, php71w-pspell, php72u-pspell, php72w-pspell +%endif + +%description pspell +The php-pspell package contains a dynamic shared object that will add +support for using the pspell library to PHP. + +%package recode +Summary: A module for PHP applications for using the recode library +Group: System Environment/Libraries +# All files licensed under PHP version 3.01 +License: PHP +Requires: php-common%{?_isa} = %{version}-%{release} +BuildRequires: recode-devel +%if 0%{?rhel} +Obsoletes: php53-recode, php53u-recode, php54-recode, php54w-recode, php55u-recode, php55w-recode, php56u-recode, php56w-recode +Obsoletes: php70u-recode, php70w-recode, php71u-recode, php71w-recode, php72u-recode, php72w-recode +%endif + +%description recode +The php-recode package contains a dynamic shared object that will add +support for using the recode library to PHP. + +%package intl +Summary: Internationalization extension for PHP applications +Group: System Environment/Libraries +# All files licensed under PHP version 3.01 +License: PHP +Requires: php-common%{?_isa} = %{version}-%{release} +# Upstream requires 4.0, we require 50 to ensure use of libicu-last +BuildRequires: libicu-devel >= 50 +%if 0%{?rhel} +Obsoletes: php53-intl, php53u-intl, php54-intl, php54w-intl, php55u-intl, php55w-intl, php56u-intl, php56w-intl +Obsoletes: php70u-intl, php70w-intl, php71u-intl, php71w-intl, php72u-intl, php72w-intl +%endif + +%description intl +The php-intl package contains a dynamic shared object that will add +support for using the ICU library to PHP. + +%package enchant +Summary: Enchant spelling extension for PHP applications +Group: System Environment/Libraries +# All files licensed under PHP version 3.0 +License: PHP +Requires: php-common%{?_isa} = %{version}-%{release} +BuildRequires: enchant-devel >= 1.2.4 +%if 0%{?rhel} +Obsoletes: php53-enchant, php53u-enchant, php54-enchant, php54w-enchant, php55u-enchant, php55w-enchant, php56u-enchant, php56w-enchant +Obsoletes: php70u-enchant, php70w-enchant, php71u-enchant, php71w-enchant, php72u-enchant, php72w-enchant +%endif + +%description enchant +The php-enchant package contains a dynamic shared object that will add +support for using the enchant library to PHP. + +%if %{with_zip} +%package zip +Summary: ZIP archive management extension for PHP +# All files licensed under PHP version 3.0.1 +License: PHP +Group: System Environment/Libraries +Requires: php-common%{?_isa} = %{version}-%{release} +Obsoletes: php-pecl-zip < %{zipver} +Provides: php-pecl(zip) = %{zipver} +Provides: php-pecl(zip)%{?_isa} = %{zipver} +Provides: php-pecl-zip = %{zipver} +Provides: php-pecl-zip%{?_isa} = %{zipver} +%if 0%{?rhel} +Obsoletes: php53-zip, php53u-zip, php54-zip, php54w-zip, php55u-zip, php55w-zip, php56u-zip, php56w-zip +Obsoletes: php70u-zip, php70w-zip, php71u-zip, php71w-zip, php72u-zip, php72w-zip +%endif +%if %{with_libzip} +# 0.11.1 required, but 1.0.1 is bundled +BuildRequires: pkgconfig(libzip) >= 1.0.1 +%endif + +%description zip +The php-zip package provides an extension that will add +support for ZIP archive management to PHP. +%endif + +%package json +Summary: JavaScript Object Notation extension for PHP +# All files licensed under PHP version 3.0.1 +License: PHP +Group: System Environment/Libraries +Requires: php-common%{?_isa} = %{version}-%{release} +Obsoletes: php-pecl-json < %{jsonver} +Obsoletes: php-pecl-jsonc < %{jsonver} +Provides: php-pecl(json) = %{jsonver} +Provides: php-pecl(json)%{?_isa} = %{jsonver} +Provides: php-pecl-json = %{jsonver} +Provides: php-pecl-json%{?_isa} = %{jsonver} +%if 0%{?rhel} +Obsoletes: php53-json, php53u-json, php54-json, php54w-json, php55u-json, php55w-json, php56u-json, php56w-json +Obsoletes: php70u-json, php70w-json, php71u-json, php71w-json, php72u-json, php72w-json +%endif + +%description json +The php-json package provides an extension that will add +support for JavaScript Object Notation (JSON) to PHP. + + +%package sodium +Summary: Wrapper for the Sodium cryptographic library +# All files licensed under PHP version 3.0.1 +License: PHP +Group: System Environment/Libraries +# Ensure libsodium-last is used +BuildRequires: pkgconfig(libsodium) >= 1.0.13 + +Requires: php-common%{?_isa} = %{version}-%{release} +# not provided as API is different +Obsoletes: php-pecl-libsodium < 7 +Obsoletes: php-pecl-libsodium2 < 7 +Provides: php-pecl(libsodium) = %{version} +Provides: php-pecl(libsodium)%{?_isa} = %{version} +%if 0%{?rhel} +Obsoletes: php72u-sodium, php72w-sodium +%endif + +%description sodium +The php-sodium package provides a simple, +low-level PHP extension for the libsodium cryptographic library. + + +%prep +: CIBLE = %{name}-%{version}-%{release} oci8=%{with_oci8} libzip=%{with_libzip} + +%setup -q -n php-%{upver}%{?rcver} + +%patch1 -p1 -b .mpmcheck +%patch5 -p1 -b .includedir +%patch6 -p1 -b .embed +%patch7 -p1 -b .recode +%patch8 -p1 -b .libdb +%if 0%{?rhel} +%patch9 -p1 -b .curltls +%endif +%patch10 -p1 -b .timelib + +%patch40 -p1 -b .dlopen +%if 0%{?fedora} >= 25 || 0%{?rhel} >= 6 +%patch42 -p1 -b .systzdata +%endif +%patch43 -p1 -b .headers +%if 0%{?fedora} >= 18 || 0%{?rhel} >= 7 +%patch45 -p1 -b .ldap_r +%endif +%patch46 -p1 -b .fixheader +%patch47 -p1 -b .phpinfo + +%patch91 -p1 -b .remi-oci8 + +# upstream patches + +# security patches + +# Fixes for tests +%if 0%{?fedora} >= 25 || 0%{?rhel} >= 6 +%patch300 -p1 -b .datetests +%endif +%if %{with_libpcre} +if ! pkg-config libpcre --atleast-version 8.34 ; then +# Only apply when system libpcre < 8.34 +%patch301 -p1 -b .pcre834 +fi +%endif + +# WIP patch + +# Prevent %%doc confusion over LICENSE files +cp Zend/LICENSE Zend/ZEND_LICENSE +cp TSRM/LICENSE TSRM_LICENSE +%if ! %{with_libgd} +cp ext/gd/libgd/README libgd_README +cp ext/gd/libgd/COPYING libgd_COPYING +%endif +cp sapi/fpm/LICENSE fpm_LICENSE +cp ext/mbstring/libmbfl/LICENSE libmbfl_LICENSE +cp ext/mbstring/oniguruma/COPYING oniguruma_COPYING +cp ext/mbstring/ucgendat/OPENLDAP_LICENSE ucgendat_LICENSE +cp ext/fileinfo/libmagic/LICENSE libmagic_LICENSE +cp ext/phar/LICENSE phar_LICENSE +cp ext/bcmath/libbcmath/COPYING.LIB libbcmath_COPYING +cp ext/date/lib/LICENSE.rst timelib_LICENSE + +# Multiple builds for multiple SAPIs +mkdir build-cgi build-apache build-embedded \ +%if %{with_zts} + build-zts build-ztscli \ +%endif + build-fpm + +# ----- Manage known as failed test ------- +# affected by systzdata patch +rm ext/date/tests/timezone_location_get.phpt +rm ext/date/tests/timezone_version_get.phpt +rm ext/date/tests/timezone_version_get_basic1.phpt +# Should be skipped but fails sometime +rm ext/standard/tests/file/file_get_contents_error001.phpt +# fails sometime +rm ext/sockets/tests/mcast_ipv?_recv.phpt +# cause stack exhausion +rm Zend/tests/bug54268.phpt +rm Zend/tests/bug68412.phpt +# avoid issue when 2 builds run simultaneously +%ifarch x86_64 +sed -e 's/64321/64322/' -i ext/openssl/tests/*.phpt +%endif + +# Safety check for API version change. +pver=$(sed -n '/#define PHP_VERSION /{s/.* "//;s/".*$//;p}' main/php_version.h) +if test "x${pver}" != "x%{upver}%{?rcver}"; then + : Error: Upstream PHP version is now ${pver}, expecting %{upver}%{?rcver}. + : Update the version/rcver macros and rebuild. + exit 1 +fi + +vapi=$(sed -n '/#define PHP_API_VERSION/{s/.* //;p}' main/php.h) +if test "x${vapi}" != "x%{apiver}"; then + : Error: Upstream API version is now ${vapi}, expecting %{apiver}. + : Update the apiver macro and rebuild. + exit 1 +fi + +vzend=$(sed -n '/#define ZEND_MODULE_API_NO/{s/^[^0-9]*//;p;}' Zend/zend_modules.h) +if test "x${vzend}" != "x%{zendver}"; then + : Error: Upstream Zend ABI version is now ${vzend}, expecting %{zendver}. + : Update the zendver macro and rebuild. + exit 1 +fi + +# Safety check for PDO ABI version change +vpdo=$(sed -n '/#define PDO_DRIVER_API/{s/.*[ ]//;p}' ext/pdo/php_pdo_driver.h) +if test "x${vpdo}" != "x%{pdover}"; then + : Error: Upstream PDO ABI version is now ${vpdo}, expecting %{pdover}. + : Update the pdover macro and rebuild. + exit 1 +fi + +# Check for some extension version +ver=$(sed -n '/#define PHP_OCI8_VERSION /{s/.* "//;s/".*$//;p}' ext/oci8/php_oci8.h) +if test "$ver" != "%{oci8ver}"; then + : Error: Upstream OCI8 version is now ${ver}, expecting %{oci8ver}. + : Update the oci8ver macro and rebuild. + exit 1 +fi + +%if %{with_zip} +ver=$(sed -n '/#define PHP_ZIP_VERSION /{s/.* "//;s/".*$//;p}' ext/zip/php_zip.h) +if test "$ver" != "%{zipver}"; then + : Error: Upstream ZIP version is now ${ver}, expecting %{zipver}. + : Update the %{zipver} macro and rebuild. + exit 1 +fi +%endif + +ver=$(sed -n '/#define PHP_JSON_VERSION /{s/.* "//;s/".*$//;p}' ext/json/php_json.h) +if test "$ver" != "%{jsonver}"; then + : Error: Upstream JSON version is now ${ver}, expecting %{jsonver}. + : Update the %{jsonver} macro and rebuild. + exit 1 +fi + +# https://bugs.php.net/63362 - Not needed but installed headers. +# Drop some Windows specific headers to avoid installation, +# before build to ensure they are really not needed. +rm -f TSRM/tsrm_win32.h \ + TSRM/tsrm_config.w32.h \ + Zend/zend_config.w32.h \ + ext/mysqlnd/config-win.h \ + ext/standard/winver.h \ + main/win32_internal_function_disabled.h \ + main/win95nt.h + +# Fix some bogus permissions +find . -name \*.[ch] -exec chmod 644 {} \; +chmod 644 README.* + +# php-fpm configuration files for tmpfiles.d +echo "d /run/php-fpm 755 root root" >php-fpm.tmpfiles + +# Some extensions have their own configuration file +cp %{SOURCE50} 10-opcache.ini +%if 0%{?rhel} != 6 +cat << EOF >>10-opcache.ini + +; Enables or disables copying of PHP code (text segment) into HUGE PAGES. +; This should improve performance, but requires appropriate OS configuration. +opcache.huge_code_pages=0 +EOF +%ifarch x86_64 +sed -e '/opcache.huge_code_pages/s/0/1/' -i 10-opcache.ini +%endif +%endif +cp %{SOURCE52} 20-oci8.ini + +# Regenerated bison files +# to force, rm Zend/zend_{language,ini}_parser.[ch] +if [ ! -f Zend/zend_language_parser.c ]; then + ./genfiles +fi + + +%build +%{?dtsenable} + +# aclocal workaround - to be improved +cat $(aclocal --print-ac-dir)/{libtool,ltoptions,ltsugar,ltversion,lt~obsolete}.m4 >>aclocal.m4 + +# Force use of system libtool: +libtoolize --force --copy +cat $(aclocal --print-ac-dir)/{libtool,ltoptions,ltsugar,ltversion,lt~obsolete}.m4 >build/libtool.m4 + +# Regenerate configure scripts (patches change config.m4's) +touch configure.ac +./buildconf --force +%if %{with_debug} +LDFLAGS="-fsanitize=address" +export LDFLAGS +CFLAGS="$RPM_OPT_FLAGS -fno-strict-aliasing -Wno-pointer-sign -fsanitize=address -ggdb" +%else +CFLAGS="$RPM_OPT_FLAGS -fno-strict-aliasing -Wno-pointer-sign" +%endif +export CFLAGS + +# Install extension modules in %{_libdir}/php/modules. +EXTENSION_DIR=%{_libdir}/php/modules; export EXTENSION_DIR + +# Set PEAR_INSTALLDIR to ensure that the hard-coded include_path +# includes the PEAR directory even though pear is packaged +# separately. +PEAR_INSTALLDIR=%{_datadir}/pear; export PEAR_INSTALLDIR + +# Shell function to configure and build a PHP tree. +build() { +# Old/recent bison version seems to produce a broken parser; +# upstream uses GNU Bison 2.3. Workaround: +# Only provided in official tarball (not in snapshot) +if [ -f ../Zend/zend_language_parser.c ]; then +mkdir Zend && cp ../Zend/zend_{language,ini}_{parser,scanner}.[ch] Zend +fi + +# Always static: +# date, filter, libxml, reflection, spl: not supported +# hash: for PHAR_SIG_SHA256 and PHAR_SIG_SHA512 +# session: dep on hash, used by soap and wddx +# pcre: used by filter, zip +# pcntl, readline: only used by CLI sapi +# openssl: for PHAR_SIG_OPENSSL +# zlib: used by image + +ln -sf ../configure +%configure \ + --cache-file=../config.cache \ + --with-libdir=%{_lib} \ + --with-config-file-path=%{_sysconfdir} \ + --with-config-file-scan-dir=%{_sysconfdir}/php.d \ + --disable-debug \ + --with-pic \ + --disable-rpath \ + --without-pear \ + --with-exec-dir=%{_bindir} \ + --with-freetype-dir=%{_prefix} \ + --with-png-dir=%{_prefix} \ + --with-xpm-dir=%{_prefix} \ + --without-gdbm \ + --with-jpeg-dir=%{_prefix} \ + --with-openssl \ + --with-system-ciphers \ +%if %{with_libpcre} + --with-pcre-regex=%{_prefix} \ +%endif + --with-zlib \ + --with-layout=GNU \ + --with-kerberos \ + --with-libxml-dir=%{_prefix} \ +%if 0%{?fedora} >= 25 || 0%{?rhel} >= 6 + --with-system-tzdata \ +%endif + --with-mhash \ +%if %{with_dtrace} + --enable-dtrace \ +%endif +%if %{with_debug} + --enable-debug \ +%endif + $* +if test $? != 0; then + tail -500 config.log + : configure failed + exit 1 +fi + +make %{?_smp_mflags} +} + +# Build /usr/bin/php-cgi with the CGI SAPI, and most shared extensions +pushd build-cgi + +build --libdir=%{_libdir}/php \ + --enable-pcntl \ + --enable-opcache \ + --enable-opcache-file \ +%if 0%{?rhel} == 6 + --disable-huge-code-pages \ +%endif + --enable-phpdbg \ + --with-imap=shared --with-imap-ssl \ + --enable-mbstring=shared \ +%if %{with_onig} + --with-onig=%{_prefix} \ +%endif + --enable-mbregex \ +%if %{with_libgd} + --with-gd=shared,%{_prefix} \ +%else + --with-gd=shared \ + --with-webp-dir=%{_prefix} \ +%endif + --with-gmp=shared \ + --enable-calendar=shared \ + --enable-bcmath=shared \ + --with-bz2=shared \ + --enable-ctype=shared \ + --enable-dba=shared --with-db4=%{_prefix} \ + --with-gdbm=%{_prefix} \ + --with-tcadb=%{_prefix} \ + --with-lmdb=%{_prefix} \ + --enable-exif=shared \ + --enable-ftp=shared \ + --with-gettext=shared \ + --with-iconv=shared \ + --enable-sockets=shared \ + --enable-tokenizer=shared \ + --with-xmlrpc=shared \ + --with-ldap=shared --with-ldap-sasl \ + --enable-mysqlnd=shared \ + --with-mysqli=shared,mysqlnd \ + --with-mysql-sock=%{mysql_sock} \ +%if %{with_oci8} +%ifarch x86_64 + --with-oci8=shared,instantclient,%{_libdir}/oracle/%{oraclever}/client64/lib,%{oraclever} \ + --with-pdo-oci=shared,instantclient,%{_libdir}/oracle/%{oraclever}/client64/lib,%{oraclever} \ +%else + --with-oci8=shared,instantclient,%{_libdir}/oracle/%{oraclever}/client/lib,%{oraclever} \ + --with-pdo-oci=shared,instantclient,%{_libdir}/oracle/%{oraclever}/client/lib,%{oraclever} \ +%endif +%endif + --with-interbase=shared \ + --with-pdo-firebird=shared \ + --enable-dom=shared \ + --with-pgsql=shared \ + --enable-simplexml=shared \ + --enable-xml=shared \ + --enable-wddx=shared \ + --with-snmp=shared,%{_prefix} \ + --enable-soap=shared \ + --with-xsl=shared,%{_prefix} \ + --enable-xmlreader=shared --enable-xmlwriter=shared \ + --with-curl=shared,%{_prefix} \ + --enable-pdo=shared \ + --with-pdo-odbc=shared,unixODBC,%{_prefix} \ + --with-pdo-mysql=shared,mysqlnd \ + --with-pdo-pgsql=shared,%{_prefix} \ + --with-pdo-sqlite=shared,%{_prefix} \ + --with-pdo-dblib=shared,%{_prefix} \ +%if %{with_sqlite3} + --with-sqlite3=shared,%{_prefix} \ +%else + --without-sqlite3 \ +%endif + --enable-json=shared \ +%if %{with_zip} + --enable-zip=shared \ +%if %{with_libzip} + --with-libzip \ +%endif +%endif + --without-readline \ + --with-libedit \ + --with-pspell=shared \ + --enable-phar=shared \ + --with-tidy=shared,%{_prefix} \ + --enable-sysvmsg=shared --enable-sysvshm=shared --enable-sysvsem=shared \ + --enable-shmop=shared \ + --enable-posix=shared \ + --with-unixODBC=shared,%{_prefix} \ + --enable-fileinfo=shared \ + --with-sodium=shared \ + --enable-intl=shared \ + --with-icu-dir=%{_prefix} \ + --with-enchant=shared,%{_prefix} \ + --with-recode=shared,%{_prefix} +popd + +without_shared="--without-gd \ + --disable-dom --disable-dba --without-unixODBC \ + --disable-opcache \ + --disable-json \ + --disable-xmlreader --disable-xmlwriter \ + --without-sodium \ + --without-sqlite3 --disable-phar --disable-fileinfo \ + --without-pspell --disable-wddx \ + --without-curl --disable-posix --disable-xml \ + --disable-simplexml --disable-exif --without-gettext \ + --without-iconv --disable-ftp --without-bz2 --disable-ctype \ + --disable-shmop --disable-sockets --disable-tokenizer \ + --disable-sysvmsg --disable-sysvshm --disable-sysvsem" + +# Build Apache module, and the CLI SAPI, /usr/bin/php +pushd build-apache +build --with-apxs2=%{_httpd_apxs} \ + --libdir=%{_libdir}/php \ +%if %{with_lsws} + --with-litespeed \ +%endif + --without-mysqli \ + --disable-pdo \ + ${without_shared} +popd + +# Build php-fpm +pushd build-fpm +build --enable-fpm \ +%if %{with_systemd} + --with-fpm-systemd \ +%endif + --with-fpm-acl \ + --libdir=%{_libdir}/php \ + --without-mysqli \ + --disable-pdo \ + ${without_shared} +popd + +# Build for inclusion as embedded script language into applications, +# /usr/lib[64]/libphp7.so +pushd build-embedded +build --enable-embed \ + --without-mysqli --disable-pdo \ + ${without_shared} +popd + +%if %{with_zts} +# Build a special thread-safe (mainly for modules) +pushd build-ztscli + +EXTENSION_DIR=%{_libdir}/php-zts/modules +build --includedir=%{_includedir}/php-zts \ + --libdir=%{_libdir}/php-zts \ + --enable-maintainer-zts \ + --program-prefix=zts- \ + --disable-cgi \ + --with-config-file-scan-dir=%{_sysconfdir}/php-zts.d \ + --enable-pcntl \ + --enable-opcache \ + --enable-opcache-file \ +%if 0%{?rhel} == 6 + --disable-huge-code-pages \ +%endif + --with-imap=shared --with-imap-ssl \ + --enable-mbstring=shared \ +%if %{with_onig} + --with-onig=%{_prefix} \ +%endif + --enable-mbregex \ +%if %{with_libgd} + --with-gd=shared,%{_prefix} \ +%else + --with-gd=shared \ + --with-webp-dir=%{_prefix} \ +%endif + --with-gmp=shared \ + --enable-calendar=shared \ + --enable-bcmath=shared \ + --with-bz2=shared \ + --enable-ctype=shared \ + --enable-dba=shared --with-db4=%{_prefix} \ + --with-gdbm=%{_prefix} \ + --with-tcadb=%{_prefix} \ + --with-lmdb=%{_prefix} \ + --with-gettext=shared \ + --with-iconv=shared \ + --enable-sockets=shared \ + --enable-tokenizer=shared \ + --enable-exif=shared \ + --enable-ftp=shared \ + --with-xmlrpc=shared \ + --with-ldap=shared --with-ldap-sasl \ + --enable-mysqlnd=shared \ + --with-mysqli=shared,mysqlnd \ + --with-mysql-sock=%{mysql_sock} \ + --enable-mysqlnd-threading \ +%if %{with_oci8} +%ifarch x86_64 + --with-oci8=shared,instantclient,%{_libdir}/oracle/%{oraclever}/client64/lib,%{oraclever} \ + --with-pdo-oci=shared,instantclient,%{_libdir}/oracle/%{oraclever}/client64/lib,%{oraclever} \ +%else + --with-oci8=shared,instantclient,%{_libdir}/oracle/%{oraclever}/client/lib,%{oraclever} \ + --with-pdo-oci=shared,instantclient,%{_libdir}/oracle/%{oraclever}/client/lib,%{oraclever} \ +%endif +%endif + --with-interbase=shared \ + --with-pdo-firebird=shared \ + --enable-dom=shared \ + --with-pgsql=shared \ + --enable-simplexml=shared \ + --enable-xml=shared \ + --enable-wddx=shared \ + --with-snmp=shared,%{_prefix} \ + --enable-soap=shared \ + --with-xsl=shared,%{_prefix} \ + --enable-xmlreader=shared --enable-xmlwriter=shared \ + --with-curl=shared,%{_prefix} \ + --enable-pdo=shared \ + --with-pdo-odbc=shared,unixODBC,%{_prefix} \ + --with-pdo-mysql=shared,mysqlnd \ + --with-pdo-pgsql=shared,%{_prefix} \ + --with-pdo-sqlite=shared,%{_prefix} \ + --with-pdo-dblib=shared,%{_prefix} \ +%if %{with_sqlite3} + --with-sqlite3=shared,%{_prefix} \ +%else + --without-sqlite3 \ +%endif + --enable-json=shared \ +%if %{with_zip} + --enable-zip=shared \ +%if %{with_libzip} + --with-libzip \ +%endif +%endif + --without-readline \ + --with-libedit \ + --with-pspell=shared \ + --enable-phar=shared \ + --with-tidy=shared,%{_prefix} \ + --enable-sysvmsg=shared --enable-sysvshm=shared --enable-sysvsem=shared \ + --enable-shmop=shared \ + --enable-posix=shared \ + --with-unixODBC=shared,%{_prefix} \ + --enable-fileinfo=shared \ + --with-sodium=shared \ + --enable-intl=shared \ + --with-icu-dir=%{_prefix} \ + --with-enchant=shared,%{_prefix} \ + --with-recode=shared,%{_prefix} +popd + +# Build a special thread-safe Apache SAPI +pushd build-zts +build --with-apxs2=%{_httpd_apxs} \ + --includedir=%{_includedir}/php-zts \ + --libdir=%{_libdir}/php-zts \ + --enable-maintainer-zts \ + --with-config-file-scan-dir=%{_sysconfdir}/php-zts.d \ + --without-mysql \ + --disable-pdo \ + ${without_shared} +popd + +### NOTE!!! EXTENSION_DIR was changed for the -zts build, so it must remain +### the last SAPI to be built. +%endif + + +%check +%if %runselftest +cd build-apache + +# Run tests, using the CLI SAPI +export NO_INTERACTION=1 REPORT_EXIT_STATUS=1 MALLOC_CHECK_=2 +export SKIP_ONLINE_TESTS=1 +export SKIP_IO_CAPTURE_TESTS=1 +unset TZ LANG LC_ALL +if ! make test; then + set +x + for f in $(find .. -name \*.diff -type f -print); do + if ! grep -q XFAIL "${f/.diff/.phpt}" + then + echo "TEST FAILURE: $f --" + head -n 100 "$f" + echo -e "\n-- $f result ends." + fi + done + set -x + #exit 1 +fi +unset NO_INTERACTION REPORT_EXIT_STATUS MALLOC_CHECK_ +%endif + + +%install +%{?dtsenable} + +%if %{with_zts} +# Install the extensions for the ZTS version +make -C build-ztscli install \ + INSTALL_ROOT=$RPM_BUILD_ROOT +%endif + +# Install the version for embedded script language in applications + php_embed.h +make -C build-embedded install-sapi install-headers \ + INSTALL_ROOT=$RPM_BUILD_ROOT + +# Install the php-fpm binary +make -C build-fpm install-fpm \ + INSTALL_ROOT=$RPM_BUILD_ROOT + +# Install everything from the CGI SAPI build +make -C build-cgi install \ + INSTALL_ROOT=$RPM_BUILD_ROOT + +# Install the default configuration file and icons +install -m 755 -d $RPM_BUILD_ROOT%{_sysconfdir}/ +install -m 644 %{SOURCE2} $RPM_BUILD_ROOT%{_sysconfdir}/php.ini +install -m 755 -d $RPM_BUILD_ROOT%{_httpd_contentdir}/icons +install -m 644 php.gif $RPM_BUILD_ROOT%{_httpd_contentdir}/icons/php.gif + +# For third-party packaging: +install -m 755 -d $RPM_BUILD_ROOT%{_datadir}/php + +# install the DSO +install -m 755 -d $RPM_BUILD_ROOT%{_httpd_moddir} +install -m 755 build-apache/libs/libphp7.so $RPM_BUILD_ROOT%{_httpd_moddir}/libphp7.so + +%if %{with_zts} +# install the ZTS DSO +install -m 755 build-zts/libs/libphp7.so $RPM_BUILD_ROOT%{_httpd_moddir}/libphp7-zts.so +%endif + +# Apache config fragment +%if "%{_httpd_modconfdir}" == "%{_httpd_confdir}" +# Single config file with httpd < 2.4 (fedora <= 17) +install -D -m 644 %{SOURCE9} $RPM_BUILD_ROOT%{_httpd_confdir}/php.conf +%if %{with_zts} +cat %{SOURCE10} >>$RPM_BUILD_ROOT%{_httpd_confdir}/php.conf +%endif +cat %{SOURCE1} >>$RPM_BUILD_ROOT%{_httpd_confdir}/php.conf +%else +# Dual config file with httpd >= 2.4 (fedora >= 18) +install -D -m 644 %{SOURCE9} $RPM_BUILD_ROOT%{_httpd_modconfdir}/15-php.conf +%if %{with_zts} +cat %{SOURCE10} >>$RPM_BUILD_ROOT%{_httpd_modconfdir}/15-php.conf +%endif +install -D -m 644 %{SOURCE1} $RPM_BUILD_ROOT%{_httpd_confdir}/php.conf +%endif +%if %{with_httpd2410} +cat %{SOURCE12} >>$RPM_BUILD_ROOT%{_httpd_confdir}/php.conf +%endif + +install -m 755 -d $RPM_BUILD_ROOT%{_sysconfdir}/php.d +%if %{with_zts} +install -m 755 -d $RPM_BUILD_ROOT%{_sysconfdir}/php-zts.d +%endif +install -m 755 -d $RPM_BUILD_ROOT%{_localstatedir}/lib/php +install -m 700 -d $RPM_BUILD_ROOT%{_localstatedir}/lib/php/session +install -m 700 -d $RPM_BUILD_ROOT%{_localstatedir}/lib/php/wsdlcache +install -m 700 -d $RPM_BUILD_ROOT%{_localstatedir}/lib/php/opcache +%if 0%{?fedora} >= 24 +install -m 755 -d $RPM_BUILD_ROOT%{_localstatedir}/lib/php/peclxml +install -m 755 -d $RPM_BUILD_ROOT%{_docdir}/pecl +install -m 755 -d $RPM_BUILD_ROOT%{_datadir}/tests/pecl +%endif + +%if %{with_lsws} +install -m 755 build-apache/sapi/litespeed/php $RPM_BUILD_ROOT%{_bindir}/lsphp +%endif + +# PHP-FPM stuff +# Log +install -m 755 -d $RPM_BUILD_ROOT%{_localstatedir}/log/php-fpm +# Config +install -m 755 -d $RPM_BUILD_ROOT%{_sysconfdir}/php-fpm.d +install -m 644 %{SOURCE4} $RPM_BUILD_ROOT%{_sysconfdir}/php-fpm.conf +install -m 644 %{SOURCE5} $RPM_BUILD_ROOT%{_sysconfdir}/php-fpm.d/www.conf +mv $RPM_BUILD_ROOT%{_sysconfdir}/php-fpm.conf.default . +mv $RPM_BUILD_ROOT%{_sysconfdir}/php-fpm.d/www.conf.default . +# LogRotate +install -m 755 -d $RPM_BUILD_ROOT%{_sysconfdir}/logrotate.d +install -m 644 %{SOURCE7} $RPM_BUILD_ROOT%{_sysconfdir}/logrotate.d/php-fpm + +# Environment file +%if 0%{?fedora} < 26 +install -m 755 -d $RPM_BUILD_ROOT%{_sysconfdir}/sysconfig +install -m 644 %{SOURCE8} $RPM_BUILD_ROOT%{_sysconfdir}/sysconfig/php-fpm +%endif + +%if %{with_systemd} +install -m 755 -d $RPM_BUILD_ROOT/run/php-fpm +# tmpfiles.d +install -m 755 -d $RPM_BUILD_ROOT%{_prefix}/lib/tmpfiles.d +install -m 644 php-fpm.tmpfiles $RPM_BUILD_ROOT%{_prefix}/lib/tmpfiles.d/php-fpm.conf +# install systemd unit files and scripts for handling server startup +sed -e 's/^pid/;pid/' \ + -i $RPM_BUILD_ROOT%{_sysconfdir}/php-fpm.conf +# this folder requires systemd >= 204 +install -m 755 -d $RPM_BUILD_ROOT%{_sysconfdir}/systemd/system/php-fpm.service.d +install -m 755 -d $RPM_BUILD_ROOT%{_unitdir} +install -m 644 %{SOURCE6} $RPM_BUILD_ROOT%{_unitdir}/ +%else +sed -ne '1,2p' -i $RPM_BUILD_ROOT%{_sysconfdir}/sysconfig/php-fpm +install -m 755 -d $RPM_BUILD_ROOT%{_localstatedir}/run/php-fpm +sed -i -e 's:/run:/var/run:' $RPM_BUILD_ROOT%{_sysconfdir}/php-fpm.conf +sed -i -e 's:/run:/var/run:' $RPM_BUILD_ROOT%{_sysconfdir}/logrotate.d/php-fpm +# Service +install -m 755 -d $RPM_BUILD_ROOT%{_initrddir} +install -m 755 %{SOURCE99} $RPM_BUILD_ROOT%{_initrddir}/php-fpm +%endif + +%if 0%{?fedora} >= 26 +sed -e '/EnvironmentFile/d' -i $RPM_BUILD_ROOT%{_unitdir}/php-fpm.service +%endif + +%if %{with_nginx} +# Nginx configuration +install -D -m 644 %{SOURCE13} $RPM_BUILD_ROOT%{_sysconfdir}/nginx/conf.d/php-fpm.conf +install -D -m 644 %{SOURCE14} $RPM_BUILD_ROOT%{_sysconfdir}/nginx/default.d/php.conf + +# Switch to UDS +# FPM +sed -e 's@127.0.0.1:9000@/run/php-fpm/www.sock@' \ + -e 's@^;listen.acl_users@listen.acl_users@' \ + -i $RPM_BUILD_ROOT%{_sysconfdir}/php-fpm.d/www.conf +# Nginx +sed -e 's@127.0.0.1:9000@unix:/run/php-fpm/www.sock@' \ + -i $RPM_BUILD_ROOT%{_sysconfdir}/nginx/conf.d/php-fpm.conf +# Apache +sed -e 's@proxy:fcgi://127.0.0.1:9000@proxy:unix:/run/php-fpm/www.sock|fcgi://localhost@' \ + -i $RPM_BUILD_ROOT%{_httpd_confdir}/php.conf +%endif + +# Generate files lists and stub .ini files for each subpackage +for mod in pgsql odbc ldap snmp xmlrpc imap json \ + mysqlnd mysqli pdo_mysql \ + mbstring gd dom xsl soap bcmath dba xmlreader xmlwriter \ + simplexml bz2 calendar ctype exif ftp gettext gmp iconv \ + sockets tokenizer opcache \ + pdo pdo_pgsql pdo_odbc pdo_sqlite \ +%if %{with_zip} + zip \ +%endif +%if %{with_oci8} + oci8 pdo_oci \ +%endif + interbase pdo_firebird \ +%if %{with_sqlite3} + sqlite3 \ +%endif + enchant phar fileinfo intl \ + tidy pdo_dblib pspell curl wddx \ + sodium \ + posix shmop sysvshm sysvsem sysvmsg recode xml \ + ; do + case $mod in + opcache) + # Zend extensions + ini=10-${mod}.ini;; + pdo_*|mysqli|wddx|xmlreader|xmlrpc) + # Extensions with dependencies on 20-* + ini=30-${mod}.ini;; + *) + # Extensions with no dependency + ini=20-${mod}.ini;; + esac + # some extensions have their own config file + if [ -f ${ini} ]; then + cp -p ${ini} $RPM_BUILD_ROOT%{_sysconfdir}/php.d/${ini} + cp -p ${ini} $RPM_BUILD_ROOT%{_sysconfdir}/php-zts.d/${ini} + else + cat > $RPM_BUILD_ROOT%{_sysconfdir}/php.d/${ini} < $RPM_BUILD_ROOT%{_sysconfdir}/php-zts.d/${ini} < files.${mod} <> files.xml + +# mysqlnd +cat files.mysqli \ + files.pdo_mysql \ + >> files.mysqlnd + +# Split out the PDO modules +cat files.pdo_pgsql >> files.pgsql +cat files.pdo_odbc >> files.odbc +%if %{with_oci8} +cat files.pdo_oci >> files.oci8 +%endif +cat files.pdo_firebird >> files.interbase + +# sysv* and posix in packaged in php-process +cat files.shmop files.sysv* files.posix > files.process + +# Package sqlite3 and pdo_sqlite with pdo; isolating the sqlite dependency +# isn't useful at this time since rpm itself requires sqlite. +cat files.pdo_sqlite >> files.pdo +%if %{with_sqlite3} +cat files.sqlite3 >> files.pdo +%endif + +# Package curl, phar and fileinfo in -common. +cat files.curl files.phar files.fileinfo \ + files.exif files.gettext files.iconv files.calendar \ + files.ftp files.bz2 files.ctype files.sockets \ + files.tokenizer > files.common + +# The default Zend OPcache blacklist file +install -m 644 %{SOURCE51} $RPM_BUILD_ROOT%{_sysconfdir}/php.d/opcache-default.blacklist +install -m 644 %{SOURCE51} $RPM_BUILD_ROOT%{_sysconfdir}/php-zts.d/opcache-default.blacklist +sed -e '/blacklist_filename/s/php.d/php-zts.d/' \ + -i $RPM_BUILD_ROOT%{_sysconfdir}/php-zts.d/10-opcache.ini + +# Install the macros file: +sed -e "s/@PHP_APIVER@/%{apiver}%{isasuffix}/" \ + -e "s/@PHP_ZENDVER@/%{zendver}%{isasuffix}/" \ + -e "s/@PHP_PDOVER@/%{pdover}%{isasuffix}/" \ + -e "s/@PHP_VERSION@/%{upver}/" \ +%if ! %{with_zts} + -e "/zts/d" \ +%endif + < %{SOURCE3} > macros.php +%if 0%{?fedora} >= 24 +echo '%pecl_xmldir %{_localstatedir}/lib/php/peclxml' >>macros.php +%endif +install -m 644 -D macros.php \ + $RPM_BUILD_ROOT%{macrosdir}/macros.php + +# Remove unpackaged files +rm -rf $RPM_BUILD_ROOT%{_libdir}/php/modules/*.a \ + $RPM_BUILD_ROOT%{_libdir}/php-zts/modules/*.a \ + $RPM_BUILD_ROOT%{_bindir}/{phptar} \ + $RPM_BUILD_ROOT%{_datadir}/pear \ + $RPM_BUILD_ROOT%{_libdir}/libphp7.la + +# Remove irrelevant docs +rm -f README.{Zeus,QNX,CVS-RULES} + + +%pre common +%if %{?fedora}%{!?fedora:99} < 25 +echo -e "WARNING : Fedora %{fedora} is now EOL :" +echo -e "You should consider upgrading to a supported release.\n" +%endif + + +%if ! %{with_httpd2410} +%pre fpm +# Add the "apache" user as we don't require httpd +getent group apache >/dev/null || \ + groupadd -g 48 -r apache +getent passwd apache >/dev/null || \ + useradd -r -u 48 -g apache -s /sbin/nologin \ + -d %{_httpd_contentdir} -c "Apache" apache +exit 0 +%endif + +%post fpm +%if %{with_systemd} +%systemd_post php-fpm.service +%else +if [ $1 = 1 ]; then + # Initial installation + /sbin/chkconfig --add php-fpm +fi +%endif + +%preun fpm +%if %{with_systemd} +%systemd_preun php-fpm.service +%else +if [ $1 = 0 ]; then + # Package removal, not upgrade + /sbin/service php-fpm stop >/dev/null 2>&1 + /sbin/chkconfig --del php-fpm +fi +%endif + +%postun fpm +%if %{with_systemd} +%systemd_postun_with_restart php-fpm.service +%else +if [ $1 -ge 1 ]; then + /sbin/service php-fpm condrestart >/dev/null 2>&1 || : +fi +%endif + +# Handle upgrading from SysV initscript to native systemd unit. +# We can tell if a SysV version of php-fpm was previously installed by +# checking to see if the initscript is present. +%triggerun fpm -- php-fpm +%if 0%{?fedora} >= 15 +if [ -f /etc/rc.d/init.d/php-fpm ]; then + # Save the current service runlevel info + # User must manually run systemd-sysv-convert --apply php-fpm + # to migrate them to systemd targets + /usr/bin/systemd-sysv-convert --save php-fpm >/dev/null 2>&1 || : + + # Run these because the SysV package being removed won't do them + /sbin/chkconfig --del php-fpm >/dev/null 2>&1 || : + /bin/systemctl try-restart php-fpm.service >/dev/null 2>&1 || : +fi +%endif + +%post embedded -p /sbin/ldconfig +%postun embedded -p /sbin/ldconfig + + +%{!?_licensedir:%global license %%doc} + +%files +%{_httpd_moddir}/libphp7.so +%if %{with_zts} +%{_httpd_moddir}/libphp7-zts.so +%endif +%attr(0770,root,apache) %dir %{_localstatedir}/lib/php/session +%attr(0770,root,apache) %dir %{_localstatedir}/lib/php/wsdlcache +%attr(0770,root,apache) %dir %{_localstatedir}/lib/php/opcache +%config(noreplace) %{_httpd_confdir}/php.conf +%if "%{_httpd_modconfdir}" != "%{_httpd_confdir}" +%config(noreplace) %{_httpd_modconfdir}/15-php.conf +%endif +%{_httpd_contentdir}/icons/php.gif + +%files common -f files.common +%doc CODING_STANDARDS CREDITS EXTENSIONS NEWS README* +%license LICENSE TSRM_LICENSE +%license libmagic_LICENSE +%license phar_LICENSE +%license timelib_LICENSE +%doc php.ini-* +%config(noreplace) %{_sysconfdir}/php.ini +%dir %{_sysconfdir}/php.d +%dir %{_libdir}/php +%dir %{_libdir}/php/modules +%if %{with_zts} +%dir %{_sysconfdir}/php-zts.d +%dir %{_libdir}/php-zts +%dir %{_libdir}/php-zts/modules +%endif +%dir %{_localstatedir}/lib/php +%if 0%{?fedora} >= 24 +%dir %{_localstatedir}/lib/php/peclxml +%dir %{_docdir}/pecl +%dir %{_datadir}/tests +%dir %{_datadir}/tests/pecl +%endif +%dir %{_datadir}/php + +%files cli +%{_bindir}/php +%{_bindir}/zts-php +%{_bindir}/php-cgi +%{_bindir}/phar.phar +%{_bindir}/phar +# provides phpize here (not in -devel) for pecl command +%{_bindir}/phpize +%{_mandir}/man1/php.1* +%{_mandir}/man1/zts-php.1* +%{_mandir}/man1/php-cgi.1* +%{_mandir}/man1/phar.1* +%{_mandir}/man1/phar.phar.1* +%{_mandir}/man1/phpize.1* +%{_mandir}/man1/zts-phpize.1* +%doc sapi/cgi/README* sapi/cli/README + +%files dbg +%{_bindir}/phpdbg +%{_mandir}/man1/phpdbg.1* +%if %{with_zts} +%{_bindir}/zts-phpdbg +%{_mandir}/man1/zts-phpdbg.1* +%endif +%doc sapi/phpdbg/{README.md,CREDITS} + +%files fpm +%doc php-fpm.conf.default www.conf.default +%license fpm_LICENSE +%attr(0770,root,apache) %dir %{_localstatedir}/lib/php/session +%attr(0770,root,apache) %dir %{_localstatedir}/lib/php/wsdlcache +%attr(0770,root,apache) %dir %{_localstatedir}/lib/php/opcache +%if %{with_httpd2410} +%config(noreplace) %{_httpd_confdir}/php.conf +%endif +%config(noreplace) %{_sysconfdir}/php-fpm.conf +%config(noreplace) %{_sysconfdir}/php-fpm.d/www.conf +%config(noreplace) %{_sysconfdir}/logrotate.d/php-fpm +%if 0%{?fedora} < 26 +%config(noreplace) %{_sysconfdir}/sysconfig/php-fpm +%endif +%if %{with_nginx} +%config(noreplace) %{_sysconfdir}/nginx/conf.d/php-fpm.conf +%config(noreplace) %{_sysconfdir}/nginx/default.d/php.conf +%endif +%if %{with_systemd} +%{_prefix}/lib/tmpfiles.d/php-fpm.conf +%{_unitdir}/php-fpm.service +%dir %{_sysconfdir}/systemd/system/php-fpm.service.d +%dir /run/php-fpm +%else +%{_initrddir}/php-fpm +%dir %{_localstatedir}/run/php-fpm +%endif +%{_sbindir}/php-fpm +%dir %{_sysconfdir}/php-fpm.d +# log owned by apache for log +%attr(770,apache,root) %dir %{_localstatedir}/log/php-fpm +%{_mandir}/man8/php-fpm.8* +%dir %{_datadir}/fpm +%{_datadir}/fpm/status.html + +%if %{with_lsws} +%files litespeed +%{_bindir}/lsphp +%endif + +%files devel +%{_bindir}/php-config +%{_includedir}/php +%{_libdir}/php/build +%if %{with_zts} +%{_bindir}/zts-php-config +%{_includedir}/php-zts +%{_bindir}/zts-phpize +%{_libdir}/php-zts/build +%endif +%{_mandir}/man1/php-config.1* +%{_mandir}/man1/zts-php-config.1* +%{macrosdir}/macros.php + +%files embedded +%{_libdir}/libphp7.so +%{_libdir}/libphp7-%{embed_version}.so + +%files pgsql -f files.pgsql +%files odbc -f files.odbc +%files imap -f files.imap +%files ldap -f files.ldap +%files snmp -f files.snmp +%files xml -f files.xml +%files xmlrpc -f files.xmlrpc +%files mbstring -f files.mbstring +%license libmbfl_LICENSE +%license oniguruma_COPYING +%license ucgendat_LICENSE +%files gd -f files.gd +%if ! %{with_libgd} +%license libgd_README +%license libgd_COPYING +%endif +%files soap -f files.soap +%files bcmath -f files.bcmath +%license libbcmath_COPYING +%files gmp -f files.gmp +%files dba -f files.dba +%files pdo -f files.pdo +%files tidy -f files.tidy +%files pdo-dblib -f files.pdo_dblib +%files pspell -f files.pspell +%files intl -f files.intl +%files process -f files.process +%files recode -f files.recode +%files interbase -f files.interbase +%files enchant -f files.enchant +%files mysqlnd -f files.mysqlnd +%files opcache -f files.opcache +%config(noreplace) %{_sysconfdir}/php.d/opcache-default.blacklist +%config(noreplace) %{_sysconfdir}/php-zts.d/opcache-default.blacklist +%if %{with_oci8} +%files oci8 -f files.oci8 +%endif +%if %{with_zip} +%files zip -f files.zip +%endif +%files json -f files.json +%files sodium -f files.sodium + + +%changelog +* Wed Aug 30 2017 Remi Collet - 7.2.0~RC1-1 +- update to 7.2.0RC1 + +* Tue Aug 22 2017 Remi Collet - 7.1.9~RC1-2 +- disable httpd MPM check +- php-fpm: drop unneeded "pid" from default configuration + +* Wed Aug 16 2017 Remi Collet - 7.1.9~RC1-1 +- Update to 7.1.9RC1 +- oci8 version is now 2.1.7 + +* Wed Aug 2 2017 Remi Collet - 7.1.8-2 +- add patch for EL-6, fix undefined symbol: sqlite3_errstr + +* Wed Aug 2 2017 Remi Collet - 7.1.8-1 +- Update to 7.1.8 - http://www.php.net/releases/7_1_8.php + +* Tue Jul 18 2017 Remi Collet - 7.1.8~RC1-1 +- Update to 7.1.8RC1 +- oci8 version is now 2.1.6 + +* Thu Jul 6 2017 Remi Collet - 7.1.7-1 +- Update to 7.1.7 - http://www.php.net/releases/7_1_7.php + +* Wed Jun 21 2017 Remi Collet - 7.1.7~RC1-1 +- Update to 7.1.7RC1 +- oci8 version is now 2.1.5 +- use oracle instant client version 12.2 + +* Wed Jun 7 2017 Remi Collet - 7.1.6-1 +- Update to 7.1.6 - http://www.php.net/releases/7_1_6.php +- add upstream security patches for oniguruma + +* Wed May 24 2017 Remi Collet - 7.1.6~RC1-1 +- Update to 7.1.6RC1 + +* Tue May 9 2017 Remi Collet - 7.1.5-1 +- Update to 7.1.5 - http://www.php.net/releases/7_1_5.php + +* Thu Apr 27 2017 Remi Collet - 7.1.5~RC1-2 +- new sources from new tag + +* Tue Apr 25 2017 Remi Collet - 7.1.5~RC1-1 +- Update to 7.1.5RC1 +- oci8 version is now 2.1.4 + +* Tue Apr 11 2017 Remi Collet - 7.1.4-1 +- Update to 7.1.4 - http://www.php.net/releases/7_1_4.php + +* Tue Mar 28 2017 Remi Collet - 7.1.4-0.1.RC1 +- Update to 7.1.4RC1 + +* Tue Mar 14 2017 Remi Collet - 7.1.3-1 +- Update to 7.1.3 - http://www.php.net/releases/7_1_3.php + +* Fri Mar 10 2017 Remi Collet - 7.1.3-0.2.RC1 +- fix interbase build on F26 + +* Tue Feb 28 2017 Remi Collet - 7.1.3-0.1.RC1 +- Update to 7.1.3RC1 + +* Wed Feb 15 2017 Remi Collet - 7.1.2-1 +- Update to 7.1.2 - http://www.php.net/releases/7_1_2.php + +* Thu Feb 2 2017 Remi Collet - 7.1.2-0.2.RC1 +- Update to 7.1.2RC1 (new sources) + +* Wed Feb 1 2017 Remi Collet 7.1.2-0.1.RC1 +- Update to 7.1.2RC1 + +* Wed Jan 18 2017 Remi Collet 7.1.1-3 +- EL-7: add patch for https://bugs.php.net/73956 +- switch back to gcc 6.2 + +* Wed Jan 18 2017 Remi Collet 7.1.1-2 +- EL-7: rebuild using gcc 4.8 instead of 6.2 + because of https://bugzilla.redhat.com/1414348 + +* Wed Jan 18 2017 Remi Collet 7.1.1-1 +- Update to 7.1.1 - http://www.php.net/releases/7_1_1.php + +* Thu Jan 5 2017 Remi Collet 7.1.1-0.1.RC1 +- Update to 7.1.1RC1 + +* Mon Dec 26 2016 Remi Collet 7.1.0-2 +- test optimized build using GCC 6.2 + +* Thu Dec 1 2016 Remi Collet 7.1.0-1 +- Update to 7.1.0 - http://www.php.net/releases/7_1_0.php +- use bundled pcre library 8.38 on EL-7 +- disable pcre.jit everywhere as it raise AVC #1398474 +- sync provided configuration with upstream production defaults + +* Wed Nov 9 2016 Remi Collet 7.1.0-0.8.RC6 +- Update to 7.1.0RC6 + +* Wed Oct 26 2016 Remi Collet 7.1.0-0.7.RC5 +- Update to 7.1.0RC5 + +* Mon Oct 17 2016 Remi Collet 7.1.0-0.6.RC4 +- Update to 7.1.0RC4 +- update tzdata patch to v14, improve check for valid tz file +- oci8 version is now 2.1.3 + +* Thu Sep 29 2016 Remi Collet 7.1.0-0.5.RC3 +- Update to 7.1.0RC3 + +* Wed Sep 14 2016 Remi Collet 7.1.0-0.4.RC2 +- Update to 7.1.0RC2 +- API version is now 20160303 + +* Thu Sep 1 2016 Remi Collet 7.1.0-0.3.RC1 +- Update to 7.1.0RC1 +- oci8 version is now 2.1.2 +- json version is now 1.5.0 + +* Wed Aug 3 2016 Remi Collet 7.1.0-0.2.beta2 +- Update to 7.1.0beta2 + +* Sat Jul 23 2016 Remi Collet 7.1.0-0.1.beta1 +- Update to 7.1.0beta1 + +* Wed Jul 20 2016 Remi Collet 7.0.9-1 +- Update to 7.0.9 - http://www.php.net/releases/7_0_9.php +- wddx: add upstream patch for https://bugs.php.net/72564 + +* Wed Jul 6 2016 Remi Collet 7.0.9-0.1.RC1 +- Update to 7.0.9RC1 + +* Thu Jun 30 2016 Remi Collet 7.0.8-1.1 +- own tests/doc directories for pecl packages (f24) + +* Wed Jun 22 2016 Remi Collet 7.0.8-1 +- Update to 7.0.8 - http://www.php.net/releases/7_0_8.php + +* Wed Jun 8 2016 Remi Collet 7.0.8-0.1.RC1 +- Update to 7.0.8RC1 +- opcache version is now php version + +* Wed May 25 2016 Remi Collet 7.0.7-1 +- Update to 7.0.7 - http://www.php.net/releases/7_0_7.php + +* Thu May 12 2016 Remi Collet 7.0.7-0.1.RC1 +- Update to 7.0.7RC1 +- oci8 version is now 2.1.1 + +* Thu Apr 28 2016 Remi Collet 7.0.6-3 +- Update to 7.0.6 - http://www.php.net/releases/7_0_6.php +- rebuild for new sources + +* Wed Apr 27 2016 Remi Collet 7.0.6-1 +- Update to 7.0.6 + http://www.php.net/releases/7_0_6.php + +* Tue Apr 12 2016 Remi Collet 7.0.6-0.1.RC1 +- Update to 7.0.6RC1 + +* Fri Apr 8 2016 Remi Collet 7.0.5-2 +- Fixed bug #71914 (Reference is lost in "switch") + +* Wed Mar 30 2016 Remi Collet 7.0.5-1 +- Update to 7.0.5 + http://www.php.net/releases/7_0_5.php + +* Wed Mar 16 2016 Remi Collet 7.0.5-0.1.RC1 +- Update to 7.0.5RC1 + +* Fri Mar 4 2016 Remi Collet 7.0.4-2 +- adapt for F24: define %%pecl_xmldir and own it + +* Wed Mar 2 2016 Remi Collet 7.0.4-1 +- Update to 7.0.4 + http://www.php.net/releases/7_0_4.php +- pcre: disables JIT compilation of patterns with system pcre < 8.38 + +* Thu Feb 18 2016 Remi Collet 7.0.4-0.1.RC1 +- Update to 7.0.4RC1 + +* Wed Feb 3 2016 Remi Collet 7.0.3-1 +- Update to 7.0.3 + http://www.php.net/releases/7_0_3.php + +* Fri Jan 29 2016 Remi Collet 7.0.3-0.2.RC1 +- FPM: test build for https://bugs.php.net/62172 + +* Wed Jan 20 2016 Remi Collet 7.0.3-0.1.RC1 +- Update to 7.0.3RC1 + +* Wed Jan 6 2016 Remi Collet 7.0.2-1 +- Update to 7.0.2 + http://www.php.net/releases/7_0_2.php + +* Sun Dec 27 2015 Remi Collet 7.0.2-0.1.RC1 +- Update to 7.0.2RC1 +- opcache: build with --disable-huge-code-pages on EL-6 + +* Wed Dec 16 2015 Remi Collet 7.0.1-1 +- Update to 7.0.1 + http://www.php.net/releases/7_0_1.php +- curl: add CURL_SSLVERSION_TLSv1_x constant (EL) + +* Wed Dec 9 2015 Remi Collet 7.0.1-0.1.RC1 +- Update to 7.0.1RC1 +- drop --disable-huge-code-pages build option on EL-6, + but keep it disabled in default configuration +- php-devel obsoletes php-pecl-jsonc-devel + +* Sat Dec 5 2015 Remi Collet 7.0.0-3 +- EL-6 rebuild + +* Thu Dec 3 2015 Remi Collet 7.0.0-2 +- build with --disable-huge-code-pages on EL-6 + +* Tue Dec 1 2015 Remi Collet 7.0.0-1 +- Update to 7.0.0 + http://www.php.net/releases/7_0_0.php + +* Mon Nov 30 2015 Remi Collet 7.0.0-0.16.RC8 +- set opcache.huge_code_pages=0 on EL-6 + see https://bugs.php.net/70973 and https://bugs.php.net/70977 + +* Wed Nov 25 2015 Remi Collet 7.0.0-0.12.RC8 +- Update to 7.0.0RC8 +- set opcache.huge_code_pages=1 on x86_64 + +* Thu Nov 12 2015 Remi Collet 7.0.0-0.11.RC7 +- Update to 7.0.0RC7 (retagged) + +* Wed Nov 11 2015 Remi Collet 7.0.0-0.10.RC7 +- Update to 7.0.0RC7 + +* Wed Oct 28 2015 Remi Collet 7.0.0-0.9.RC6 +- Update to 7.0.0RC6 + +* Wed Oct 14 2015 Remi Collet 7.0.0-0.8.RC5 +- rebuild as retagged + +* Tue Oct 13 2015 Remi Collet 7.0.0-0.7.RC5 +- Update to 7.0.0RC5 +- update php-fpm.d/www.conf comments +- API and Zend API are now set to 20151012 + +* Wed Sep 30 2015 Remi Collet 7.0.0-0.6.RC4 +- Update to 7.0.0RC4 +- php-fpm: set http authorization headers + +* Wed Sep 16 2015 Remi Collet 7.0.0-0.5.RC3 +- Update to 7.0.0RC3 +- disable zip extension (provided in php-pecl-zip) + +* Fri Sep 4 2015 Remi Collet 7.0.0-0.4.RC2 +- Update to 7.0.0RC2 +- enable oci8 and pdo_oci extensions +- sync php.ini with upstream php.ini-production + +* Sat Aug 22 2015 Remi Collet 7.0.0-0.3.RC1 +- Update to 7.0.0RC1 + +* Wed Aug 5 2015 Remi Collet 7.0.0-0.2.beta3 +- update to 7.0.0beta3 + +* Thu Jul 23 2015 Remi Collet 7.0.0-0.1.beta2 +- update to 7.0.0beta2 +- merge changes from php70-php spec file + +* Sun Jul 12 2015 Remi Collet 5.6.11-1 +- Update to 5.6.11 + http://www.php.net/releases/5_6_11.php + +* Thu Jun 11 2015 Remi Collet 5.6.10-1.1 +- don't provide php-sqlite3 on EL-5 +- the phar link is now correctly created +- avoid issue when 2 builds run simultaneously + +* Thu Jun 11 2015 Remi Collet 5.6.10-1 +- Update to 5.6.10 + http://www.php.net/releases/5_6_10.php +- opcache is now 7.0.6-dev + +* Fri May 15 2015 Remi Collet 5.6.9-1 +- Update to 5.6.9 + http://www.php.net/releases/5_6_9.php + +* Thu Apr 16 2015 Remi Collet 5.6.8-1 +- Update to 5.6.8 + http://www.php.net/releases/5_6_8.php + +* Fri Apr 10 2015 Remi Collet 5.6.7-2 +- add upstream patch to drop SSLv3 tests + +* Thu Mar 19 2015 Remi Collet 5.6.7-1 +- Update to 5.6.7 + http://www.php.net/releases/5_6_7.php + +* Fri Feb 20 2015 Remi Collet 5.6.6-1.1 +- rebuild for new tokyocabinet in EL-5 + +* Thu Feb 19 2015 Remi Collet 5.6.6-1 +- Update to 5.6.6 + http://www.php.net/releases/5_6_6.php + +* Wed Jan 21 2015 Remi Collet 5.6.5-1 +- Update to 5.6.5 + http://www.php.net/releases/5_6_5.php + +* Fri Jan 9 2015 Remi Collet 5.6.5-0.1.RC1 +- update to 5.6.5RC1 +- FPM: enable ACL for Unix Domain Socket + +* Wed Dec 17 2014 Remi Collet 5.6.4-2 +- Update to 5.6.4 + http://www.php.net/releases/5_6_4.php +- add sybase_ct extension (in mssql sub-package) +- xmlrpc requires xml + +* Wed Dec 10 2014 Remi Collet 5.6.4-1 +- Update to 5.6.4 + http://www.php.net/releases/5_6_4.php + +* Thu Nov 27 2014 Remi Collet 5.6.4-0.1.RC1 +- php 5.6.4RC1 + +* Sun Nov 16 2014 Remi Collet 5.6.3-3 +- FPM: add upstream patch for https://bugs.php.net/68421 + access.format=R doesn't log ipv6 address +- FPM: add upstream patch for https://bugs.php.net/68420 + listen=9000 listens to ipv6 localhost instead of all addresses +- FPM: add upstream patch for https://bugs.php.net/68423 + will no longer load all pools + +* Thu Nov 13 2014 Remi Collet 5.6.3-1 +- Update to PHP 5.6.3 + http://php.net/releases/5_6_3.php +- GMP: add upstream patch for https://bugs.php.net/68419 + Fix build with libgmp < 4.2 + +* Thu Oct 30 2014 Remi Collet 5.6.3-0.4.RC1 +- php 5.6.3RC1 (refreshed, phpdbg changes reverted) + +* Thu Oct 30 2014 Remi Collet 5.6.3-0.3.RC1 +- new version of systzdata patch, fix case sensitivity +- ignore Factory in date tests + +* Wed Oct 29 2014 Remi Collet 5.6.3-0.2.RC1 +- php 5.6.3RC1 (refreshed) +- enable phpdbg_webhelper new extension (in php-dbg) + +* Tue Oct 28 2014 Remi Collet 5.6.3-0.1.RC1 +- php 5.6.3RC1 +- disable opcache.fast_shutdown in default config +- disable phpdbg_webhelper new extension for now + +* Thu Oct 16 2014 Remi Collet 5.6.1-1 +- Update to PHP 5.6.2 + http://php.net/releases/5_6_2.php + +* Fri Oct 3 2014 Remi Collet 5.6.1-1 +- Update to PHP 5.6.1 + http://php.net/releases/5_6_1.php + +* Fri Sep 26 2014 Remi Collet 5.6.1-0 +- test build for upcoming 5.6.1 +- use default system cipher list by Fedora policy + http://fedoraproject.org/wiki/Changes/CryptoPolicy + +* Wed Sep 24 2014 Remi Collet 5.6.1-0.2.RC1 +- provides nginx configuration (see #1142298) + +* Fri Sep 12 2014 Remi Collet 5.6.1-0.1.RC1 +- php 5.6.1RC1 + +* Wed Sep 3 2014 Remi Collet 5.6.0-1.2 +- ensure gd-last 2.1.0-3, with libvpx support, is used + +* Fri Aug 29 2014 Remi Collet 5.6.0-1.1 +- enable libvpx on EL 6 (with libvpx 1.3.0) + +* Thu Aug 28 2014 Remi Collet 5.6.0-1 +- PHP 5.6.0 is GA +- fix ZTS man pages, upstream patch for 67878 + +* Wed Aug 20 2014 Remi Collet 5.6.0-0.22.RC4 +- backport rawhide stuff for F21+ and httpd-filesystem + with support for SetHandler to proxy_fcgi + +* Thu Aug 14 2014 Remi Collet 5.6.0-0.21.RC4 +- php 5.6.0RC4 + +* Wed Jul 30 2014 Remi Collet 5.6.0-0.20.RC3 +- php 5.6.0RC3 +- fix license handling +- fix zts-php-config --php-binary output #1124605 +- cleanup with_libmysql +- add php-litespeed subpackage (/usr/bin/lsphp) + +* Fri Jul 25 2014 Remi Collet 5.6.0-0.18.RC2 +- dont display timezone version in phpinfo (tzdata patch v11) + +* Sat Jul 19 2014 Remi Collet 5.6.0-0.17.RC2 +- test build for #67635 + +* Mon Jul 7 2014 Remi Collet 5.6.0-0.16.RC2 +- php 5.6.0RC2 + +* Mon Jun 23 2014 Remi Collet 5.6.0-0.15.RC1 +- add workaround for unserialize/mock issue from 5.4/5.5 + +* Mon Jun 23 2014 Remi Collet 5.6.0-0.14.RC1 +- fix phpdbg with libedit https://bugs.php.net/67499 + +* Thu Jun 19 2014 Remi Collet 5.6.0-0.13.RC1 +- php 5.6.0RC1 + +* Mon Jun 16 2014 Remi Collet 5.6.0-0.12.beta4 +- test build for serialize + +* Tue Jun 10 2014 Remi Collet 5.6.0-0.11.beta4 +- test build for bug 67410, 67411, 67412, 67413 +- fix 67392, dtrace breaks argument unpack + +* Thu Jun 5 2014 Remi Collet 5.6.0-0.10.beta4 +- fix regression introduce in fix for #67118 + +* Wed Jun 4 2014 Remi Collet 5.6.0-0.9.beta4 +- php 5.6.0beta4 + +* Wed May 14 2014 Remi Collet 5.6.0-0.8.beta3 +- php 5.6.0beta3 + +* Tue May 6 2014 Remi Collet 5.6.0-0.8.201405061030 +- new snapshot php5.6-201405061030 + +* Sat May 3 2014 Remi Collet 5.6.0-0.7.beta2 +- php 5.6.0beta2 + +* Thu Apr 10 2014 Remi Collet 5.6.0-0.6.beta1 +- php 5.6.0beta1 + +* Wed Apr 9 2014 Remi Collet 5.6.0-0.5.201404090430 +- new snapshot php5.6-201404090430 +- add numerical prefix to extension configuration files +- prevent .user.ini files from being viewed by Web clients +- load php directives only when mod_php is active + +* Wed Mar 26 2014 Remi Collet 5.6.0-0.4.201403261230 +- new snapshot php5.6-201403261230 +- oci8 version 2.0.9 +- opcache version 7.0.4-dev + +* Mon Mar 17 2014 Remi Collet 5.6.0-0.4.201403170630 +- new snapshot php5.6-201403170630 + +* Wed Mar 12 2014 Remi Collet 5.6.0-0.3.201403120830 +- new snapshot php5.6-201403120830 +- rebuild against gd-last without libvpx on EL < 7 +- oci8 version 2.0.8 + +* Fri Feb 28 2014 Remi Collet 5.6.0-0.2.alpha3 +- php 5.6.0alpha3 +- add php-dbg subpackage +- update php.ini from upstream production template +- move /usr/bin/zts-php to php-cli subpackage + +* Wed Feb 26 2014 Remi Collet 5.5.10-0.4.RC1 +- php-fpm should own /var/lib/php/session and wsdlcache + +* Tue Feb 25 2014 Remi Collet 5.5.10-0.3.RC1 +- test build for https://bugs.php.net/66762 + +* Fri Feb 21 2014 Remi Collet 5.5.10-0.2.RC1 +- another test build of 5.5.10RC1 +- fix memleak in fileinfo ext +- revert test changes for pcre 8.34 + +* Thu Feb 20 2014 Remi Collet 5.5.10-0.1.RC1 +- test build of 5.5.10RC1 + +* Tue Feb 18 2014 Remi Collet 5.5.9-2 +- upstream patch for https://bugs.php.net/66731 + +* Tue Feb 11 2014 Remi Collet 5.5.9-1 +- Update to 5.5.9 + http://www.php.net/ChangeLog-5.php#5.5.9 +- Install macros to /usr/lib/rpm/macros.d where available. +- Add configtest option to php-fpm ini script (EL) + +* Thu Jan 23 2014 Remi Collet 5.5.9-0.1.RC1 +- test build of 5.5.9RC1 + +* Thu Jan 23 2014 Joe Orton - 5.5.8-2 +- fix _httpd_mmn expansion in absence of httpd-devel + +* Mon Jan 20 2014 Remi Collet 5.5.8-2 +- test build for https://bugs.php.net/66412 + +* Wed Jan 8 2014 Remi Collet 5.5.8-1 +- update to 5.5.8 +- drop conflicts with other opcode caches as both can + be used only for user data cache + +* Wed Jan 8 2014 Remi Collet 5.5.8-0.2.RC1 +- another test build of 5.5.8RC1 + +* Sat Dec 28 2013 Remi Collet 5.5.8-0.1.RC1 +- test build of 5.5.8RC1 + +* Fri Dec 20 2013 Remi Collet 5.5.7-1.1 +- test build for https://bugs.php.net/66331 + +* Wed Dec 11 2013 Remi Collet 5.5.7-1 +- update to 5.5.7, fix for CVE-2013-6420 +- fix zend_register_functions breaks reflection, php bug 66218 +- fix Heap buffer over-read in DateInterval, php bug 66060 +- fix fix overflow handling bug in non-x86 + +* Tue Dec 10 2013 Remi Collet 5.5.7-0.4.RC1 +- test build + +* Wed Dec 04 2013 Remi Collet 5.5.7-0.3.RC1 +- test build + +* Mon Dec 02 2013 Remi Collet 5.5.7-0.2.RC1 +- test build for https://bugs.php.net/66218 + zend_register_functions breaks reflection + +* Thu Nov 28 2013 Remi Collet 5.5.7-0.1.RC1 +- test build of 5.5.7RC1 + +* Wed Nov 13 2013 Remi Collet 5.5.6-1 +- update to 5.5.6 + +* Tue Nov 12 2013 Remi Collet 5.5.6-0.7 +- update to 5.5.6, test build + +* Fri Nov 8 2013 Remi Collet 5.5.6-0.6.RC1 +- add --with debug option for debug build + +* Wed Nov 6 2013 Remi Collet 5.5.6-0.5.RC1 +- test buid with opcache changes reverted + +* Mon Nov 4 2013 Remi Collet 5.5.6-0.4.RC1 +- test build opcache with phar build shared + https://github.com/zendtech/ZendOptimizerPlus/issues/147 + +* Mon Nov 4 2013 Remi Collet 5.5.6-0.3.RC1 +- build phar shared, opcache loaded with RTLD_LAZY + +* Sat Nov 2 2013 Remi Collet 5.5.6-0.2.RC1 +- build phar static for opcache dep. + +* Sat Nov 2 2013 Remi Collet 5.5.6-0.1.RC1 +- test build of 5.5.6RC1 + +* Sun Oct 27 2013 Remi Collet 5.5.5-2 +- rebuild using libicu-last 50.1.2 + +* Tue Oct 15 2013 Remi Collet - 5.5.5-1 +- update to 5.5.5 + +* Mon Sep 23 2013 Remi Collet - 5.5.4-2 +- test build + +* Thu Sep 19 2013 Remi Collet - 5.5.4-1 +- update to 5.5.4 +- improve security, use specific soap.wsdl_cache_dir + use /var/lib/php/wsdlcache for mod_php and php-fpm +- sync short_tag comments in php.ini with upstream + +* Fri Aug 30 2013 Remi Collet - 5.5.4.0.1-201308300430 +- test build with -fsanitize=address +- test build for https://bugs.php.net/65564 + +* Wed Aug 21 2013 Remi Collet - 5.5.3-1 +- update to 5.5.3 +- build without zip extension, requires php-pecl-zip +- fix typo and add missing entries in php.ini + +* Tue Aug 20 2013 Remi Collet - 5.5.3-0 +- update to 5.5.3 +- test build without zip extension +- fix typo and add missing entries in php.ini + +* Mon Aug 19 2013 Remi Collet - 5.5.2-1 +- update to 5.5.2 + +* Thu Aug 8 2013 Remi Collet - 5.5.2-0.2.RC1 +- improve system libzip patch + +* Thu Aug 1 2013 Remi Collet - 5.5.2-0.1.RC1 +- 5.5.2RC1 + +* Fri Jul 26 2013 Remi Collet - 5.5.1-2 +- test build with oracle instantclient 12.1 + +* Mon Jul 22 2013 Remi Collet - 5.5.1-1 +- update to 5.5.1 +- add Provides: php(pdo-abi), for consistency with php(api) + and php(zend-abi) +- improved description for mod_php +- fix opcache ZTS configuration (blacklists in /etc/php-zts.d) +- add missing man pages (phar, php-cgi) +- fix php-enchant summary and description + +* Fri Jul 12 2013 Remi Collet - 5.5.0-2 +- add security fix for CVE-2013-4113 +- add missing ASL 1.0 license +- 32k stack size seems ok for tests on both 32/64bits build + +* Mon Jun 24 2013 Remi Collet 5.5.1-0.1.201306240630 +- test build (bundled libgd) + +* Thu Jun 20 2013 Remi Collet 5.5.0-1 +- update to 5.5.0 final + +* Fri Jun 14 2013 Remi Collet 5.5.0-0.11.RC3 +- also drop JSON from sources +- clean conditional for JSON (as removed from the sources) +- clean conditional for FPM (always build) + +* Fri Jun 14 2013 Remi Collet 5.5.0-0.36.RC3.1 +- EL-5 rebuild with gd-last + +* Thu Jun 13 2013 Remi Collet 5.5.0-0.36.RC3 +- drop JSON extension +- build with system GD when 2.1.0 is available + +* Thu Jun 6 2013 Remi Collet 5.5.0-0.35.RC3 +- update to 5.5.0RC3 + +* Mon May 27 2013 Remi Collet 5.5.0-0.34.201305271230. +-test build with systemd gd + +* Thu May 23 2013 Remi Collet 5.5.0-0.33.RC2 +- update to 5.5.0RC2 +- add missing options in php-fpm.conf +- improved systemd configuration, documentation about + /etc/sysconfig/php-fpm being deprecated + +* Wed May 22 2013 Remi Collet 5.5.0-0.32.201305220430 +- test build for https://bugs.php.net/64895 + +* Sat May 18 2013 Remi Collet 5.5.0-0.32.201305181030 +- test build with systemd integration (type=notify) + +* Wed May 8 2013 Remi Collet 5.5.0-0.31.RC1 +- update to 5.5.0RC1 + +* Sat Apr 27 2013 Remi Collet 5.5.0-0.30.201305041230 +- test build for libgd + +* Sat Apr 27 2013 Remi Collet 5.5.0-0.29.201304291030 +- new snapshot +- review some sub-packages description +- add option to disable json extension + +* Thu Apr 25 2013 Remi Collet 5.5.0-0.28.beta4 +- update to 5.5.0beta4, rebuild with new sources + +* Thu Apr 25 2013 Remi Collet 5.5.0-0.27.beta4 +- update to 5.5.0beta4 + +* Mon Apr 22 2013 Remi Collet 5.5.0-0.27-201304221230 +- new snapshot +- try build with system gd 2.1.0 + +* Thu Apr 18 2013 Remi Collet 5.5.0-0.26-201304181030 +- new snapshot +- zend_extension doesn't requires full path +- refresh system libzip patch +- drop opcache patch merged upstream + +* Thu Apr 11 2013 Remi Collet 5.5.0-0.25.beta3 +- allow wildcard in opcache.blacklist_filename and provide + default /etc/php.d/opcache-default.blacklist + +* Wed Apr 10 2013 Remi Collet 5.5.0-0.24.beta3 +- update to 5.5.0beta3 + +* Thu Apr 4 2013 Remi Collet 5.5.0-0.23-201304040630 +- new snapshot +- clean old deprecated options + +* Thu Mar 28 2013 Remi Collet 5.5.0-0.22.beta2 +- update to 5.5.0beta2 +- Zend Optimizer+ renamed to Zend OPcache +- sync provided configuration with upstream + +* Mon Mar 25 2013 Remi Collet 5.5.0-0.21-201303251230 +- new snapshot +- generated parser using system bison, test for https://bugs.php.net/64503 + +* Wed Mar 20 2013 Remi Collet 5.5.0-0.20-201303201430 +- new snapshot (beta1) + +* Mon Mar 18 2013 Remi Collet 5.5.0-0.19-201303180830 +- new snapshot +- temporary disable dtrace +- new extension opcache in php-opccache sub-package + +* Thu Mar 14 2013 Remi Collet 5.5.0-0.18-201303141230 +- new snapshot +- hardened build (links with -z now option) +- remove %%config from /etc/rpm/macros.php + +* Fri Mar 8 2013 Remi Collet 5.5.0-0.17-201303081230 +- new snapshot (post alpha 6) +- make php-mysql package optional (and disabled) +- make ZTS build optional (still enabled) + +* Thu Feb 28 2013 Remi Collet 5.5.0-0.16-201302281430 +- new snapshot + +* Thu Feb 21 2013 Remi Collet 5.5.0-0.16-201302211230 +- new snapshot (post alpha 5) + +* Wed Feb 13 2013 Remi Collet 5.5.0-0.16-201302131030 +- enable tokyocabinet and gdbm dba handlers + +* Tue Feb 12 2013 Remi Collet 5.5.0-0.15-201302121230 +- new snapshot + +* Mon Feb 4 2013 Remi Collet 5.5.0-0.14-201302040630 +- new snapshot + +* Fri Feb 1 2013 Remi Collet 5.5.0-0.14-201302010630 +- new snapshot + +* Mon Jan 28 2013 Remi Collet 5.5.0-0.13-201301281030 +- new snapshot +- don't display XFAIL tests in report + +* Wed Jan 23 2013 Remi Collet 5.5.0-0.12-201301230630 +- new snapshot, alpha4 + +* Thu Jan 17 2013 Remi Collet 5.5.0-0.11-201301170830 +- new snapshot +- fix php.conf to allow MultiViews managed by php scripts + +* Thu Jan 10 2013 Remi Collet 5.5.0-0.10-201301100830 +- new snapshot, alpha3 + +* Wed Jan 2 2013 Remi Collet 5.5.0-0.10-201301021430 +- new snapshot + +* Mon Dec 24 2012 Remi Collet 5.5.0-0.9.201212241030 +- new snapshot (post alpha2) +- use xz compressed tarball + +* Tue Dec 18 2012 Remi Collet 5.5.0-0.9.201212181230 +- new snapshot + +* Wed Dec 12 2012 Remi Collet 5.5.0-0.8.201212121430 +- new snapshot + +* Tue Dec 11 2012 Remi Collet 5.5.0-0.8.201212110630 +- patch for unpack + +* Tue Dec 11 2012 Remi Collet 5.5.0-0.7.201212110630 +- prevent php_config.h changes across (otherwise identical) rebuilds +- drop "Configure Command" from phpinfo output + +* Tue Dec 11 2012 Remi Collet 5.5.0-0.6.201212110630 +- new snapshot +- move gmp in new sub-package + +* Mon Dec 10 2012 Remi Collet 5.5.0-0.6.201212100830 +- build sockets, tokenizer extensions shared + +* Mon Dec 10 2012 Remi Collet 5.5.0-0.5.201212100830 +- new snapshot +- enable dtrace + +* Tue Dec 4 2012 Remi Collet 5.5.0-0.4.201211301534 +- build simplexml and xml extensions shared (in php-xml) +- build bz2, calendar, ctype, exif, ftp, gettext and iconv + extensions shared (in php-common) +- build gmp extension shared (in php-bcmath) +- build shmop extension shared (in php-process) + +* Mon Dec 3 2012 Remi Collet 5.5.0-0.3.201211301534 +- drop some old compatibility provides (php-api, php-zend-abi, php-pecl-*) +- obsoletes php55-* + +* Fri Nov 30 2012 Remi Collet 5.5.0-0.2.201211301534 +- update to have zend_execute_ex for xDebug + +* Fri Nov 30 2012 Remi Collet 5.5.0-0.1.201211300857 +- Initial work on 5.5.0-dev + +* Fri Nov 23 2012 Remi Collet 5.4.9-2 +- add patch for https://bugs.php.net/63588 + duplicated implementation of php_next_utf8_char + +* Thu Nov 22 2012 Remi Collet 5.4.9-1 +- update to 5.4.9 + +* Thu Nov 15 2012 Remi Collet 5.4.9-0.5.RC1 +- switch back to upstream generated scanner/parser + +* Thu Nov 15 2012 Remi Collet 5.4.9-0.4.RC1 +- use _httpd_contentdir macro and fix php.gif path + +* Wed Nov 14 2012 Remi Collet 5.4.9-0.3.RC1 +- improve system libzip patch to use pkg-config + +* Wed Nov 14 2012 Remi Collet 5.4.9-0.2.RC1 +- use _httpd_moddir macro + +* Wed Nov 14 2012 Remi Collet 5.4.9-0.1.RC1 +- update to 5.4.9RC1 +- improves php.conf (use FilesMatch + SetHandler) +- improves filter (httpd module) +- apply ldap_r patch on fedora >= 18 only + +* Fri Nov 9 2012 Remi Collet 5.4.9-0.2.RC1 +- sync with rawhide + +* Fri Nov 9 2012 Remi Collet 5.4.8-6 +- clarify Licenses +- missing provides xmlreader and xmlwriter +- modernize spec + +* Thu Nov 8 2012 Remi Collet 5.4.9-0.1.RC1 +- update to 5.4.9RC1 +- change php embedded library soname version to 5.4 + +* Tue Nov 6 2012 Remi Collet 5.4.8-5 +- fix _httpd_mmn macro definition + +* Mon Nov 5 2012 Remi Collet 5.4.8-4 +- fix mysql_sock macro definition + +* Thu Oct 25 2012 Remi Collet 5.4.8-3 +- fix installed headers + +* Tue Oct 23 2012 Joe Orton - 5.4.8-2 +- use libldap_r for ldap extension + +* Thu Oct 18 2012 Remi Collet 5.4.8-1 +- update to 5.4.8 +- define both session.save_handler and session.save_path +- fix possible segfault in libxml (#828526) +- php-fpm: create apache user if needed +- use SKIP_ONLINE_TEST during make test +- php-devel requires pcre-devel and php-cli (instead of php) + +* Fri Oct 5 2012 Remi Collet 5.4.8-0.3.RC1 +- provides php-phar + +* Thu Oct 4 2012 Remi Collet 5.4.8-0.2.RC1 +- update systzdata patch to v10, timezone are case insensitive + +* Thu Oct 4 2012 Remi Collet 5.4.8-0.1.RC1 +- update to 5.4.8RC1 + +* Mon Oct 1 2012 Remi Collet 5.4.7-10 +- fix typo in systemd macro + +* Mon Oct 1 2012 Remi Collet 5.4.7-9 +- php-fpm: enable PrivateTmp +- php-fpm: new systemd macros (#850268) +- php-fpm: add upstream patch for startup issue (#846858) + +* Fri Sep 28 2012 Remi Collet 5.4.7-8 +- systemd integration, https://bugs.php.net/63085 +- no odbc call during timeout, https://bugs.php.net/63171 +- check sqlite3_column_table_name, https://bugs.php.net/63149 + +* Mon Sep 24 2012 Remi Collet 5.4.7-7 +- most failed tests explained (i386, x86_64) + +* Wed Sep 19 2012 Remi Collet 5.4.7-6 +- fix for http://bugs.php.net/63126 (#783967) + +* Wed Sep 19 2012 Remi Collet 5.4.7-6 +- add --daemonize / --nodaemonize options to php-fpm + upstream RFE: https://bugs.php.net/63085 + +* Wed Sep 19 2012 Remi Collet 5.4.7-5 +- sync with rawhide +- patch to report libdb version https://bugs.php.net/63117 + +* Wed Sep 19 2012 Remi Collet 5.4.7-5 +- patch to ensure we use latest libdb (not libdb4) + +* Wed Sep 19 2012 Remi Collet 5.4.7-4 +- really fix rhel tests (use libzip and libdb) + +* Tue Sep 18 2012 Remi Collet 5.4.7-3 +- fix test to enable zip extension on RHEL-7 + +* Mon Sep 17 2012 Remi Collet 5.4.7-2 +- remove session.save_path from php.ini + move it to apache and php-fpm configuration files + +* Fri Sep 14 2012 Remi Collet 5.4.7-1 +- update to 5.4.7 + http://www.php.net/releases/5_4_7.php +- php-fpm: don't daemonize + +* Thu Sep 13 2012 Remi Collet 5.4.7-1 +- update to 5.4.7 + +* Mon Sep 3 2012 Remi Collet 5.4.7-0.2.RC1 +- obsoletes php53* and php54* + +* Fri Aug 31 2012 Remi Collet 5.4.7-0.1.RC1 +- update to 5.4.7RC1 + +* Mon Aug 20 2012 Remi Collet 5.4.6-2 +- enable php-fpm on secondary arch (#849490) + +* Thu Aug 16 2012 Remi Collet 5.4.6-1 +- update to 5.4.6 + +* Thu Aug 02 2012 Remi Collet 5.4.6-0.1.RC1 +- update to 5.4.6RC1 + +* Fri Jul 20 2012 Remi Collet 5.4.5-1 +- update to 5.4.5 + +* Sat Jul 07 2012 Remi Collet 5.4.5-0.2.RC1 +- update patch for system libzip + +* Wed Jul 04 2012 Remi Collet 5.4.5-0.1.RC1 +- update to 5.4.5RC1 with bundled libzip. + +* Mon Jul 02 2012 Remi Collet 5.4.4-4 +- use system pcre only on fedora >= 14 (version 8.10) +- drop BR for libevent (#835671) +- provide php(language) to allow version check +- define %%{php_version} + +* Thu Jun 21 2012 Remi Collet 5.4.4-2 +- clean spec, sync with rawhide +- add missing provides (core, ereg, filter, standard) + +* Wed Jun 13 2012 Remi Collet 5.4.4-1 +- update to 5.4.4 finale +- fedora >= 15: use /usr/lib/tmpfiles.d instead of /etc/tmpfiles.d +- fedora >= 15: use /run/php-fpm instead of /var/run/php-fpm + +* Thu May 31 2012 Remi Collet 5.4.4-0.2.RC2 +- update to 5.4.4RC2 + +* Thu May 17 2012 Remi Collet 5.4.4-0.1.RC1 +- update to 5.4.4RC1 + +* Wed May 09 2012 Remi Collet 5.4.3-1 +- update to 5.4.3 (CVE-2012-2311, CVE-2012-2329) + +* Thu May 03 2012 Remi Collet 5.4.2-1 +- update to 5.4.2 (CVE-2012-1823) + +* Fri Apr 27 2012 Remi Collet 5.4.1-1 +- update to 5.4.1 +- use libdb in fedora >= 18 instead of db4 + +* Fri Apr 13 2012 Remi Collet 5.4.1-0.3.RC2 +- update to 5.4.1RC2 + +* Sat Mar 31 2012 Remi Collet 5.4.1-0.2.RC1 +- rebuild + +* Sat Mar 31 2012 Remi Collet 5.4.1-0.1.RC1 +- update to 5.4.1RC1, split php conf when httpd 2.4 + +* Tue Mar 27 2012 Remi Collet 5.4.0-1.1 +- sync with rawhide (httpd 2.4 stuff) + +* Mon Mar 26 2012 Joe Orton - 5.4.0-2 +- rebuild against httpd 2.4 +- use _httpd_mmn, _httpd_apxs macros +- fix --without-system-tzdata build for Debian et al + +* Fri Mar 02 2012 Remi Collet 5.4.0-1 +- update to PHP 5.4.0 finale + +* Sat Feb 18 2012 Remi Collet 5.4.0-0.16.RC8 +- update to 5.4.0RC8 + +* Sat Feb 04 2012 Remi Collet 5.4.0-0.15.RC7 +- update to 5.4.0RC7 + +* Fri Jan 27 2012 Remi Collet 5.4.0-0.14.RC6 +- build against system libzip (fedora >= 17), patch from spot + +* Thu Jan 26 2012 Remi Collet 5.4.0-0.13.RC6 +- add /etc/sysconfig/php-fpm environment file (#784770) + +* Wed Jan 25 2012 Remi Collet 5.4.0-0.12.RC6 +- keep all ZTS binaries in /usr/bin (with zts prefix) + +* Thu Jan 19 2012 Remi Collet 5.4.0-0.11.RC6 +- update to 5.4.0RC6 + +* Wed Jan 18 2012 Remi Collet 5.4.0-0.10.RC5 +- add some fedora patches back (dlopen, easter, phpize) + +* Mon Jan 16 2012 Remi Collet 5.4.0-0.9.RC5 +- improves mysql.sock default path + +* Fri Jan 13 2012 Remi Collet 5.4.0-0.8.RC5 +- update to 5.4.0RC5 +- patch for https://bugs.php.net/60748 (mysql.sock hardcoded) +- move session.path from php.ini to httpd/conf.d/php.conf +- provides both ZTS mysql extensions (libmysql/mysqlnd) +- build php cli ZTS binary, in -devel, mainly for test + +* Wed Jan 04 2012 Remi Collet 5.4.0-0.7.201201041830 +- new snapshot (5.4.0RC5-dev) with fix for https://bugs.php.net/60627 + +* Fri Dec 30 2011 Remi Collet 5.4.0-0.6.201112300630 +- new snapshot (5.4.0RC5-dev) + +* Mon Dec 26 2011 Remi Collet 5.4.0-0.6.201112261030 +- new snapshot (5.4.0RC5-dev) + +* Sat Dec 17 2011 Remi Collet 5.4.0-0.5.201112170630 +- new snapshot (5.4.0RC4-dev) + +* Mon Dec 12 2011 Remi Collet 5.4.0-0.4.201112121330 +- new snapshot (5.4.0RC4-dev) +- switch to systemd + +* Fri Dec 09 2011 Remi Collet 5.4.0-0.3.201112091730 +- new snapshot (5.4.0RC4-dev) +- removed patch merged upstream for https://bugs.php.net/60392 +- clean ini (from upstream production default) + +* Sun Nov 13 2011 Remi Collet 5.4.0-0.3.201111260730 +- new snapshot (5.4.0RC3-dev) +- patch for https://bugs.php.net/60392 (old libicu on EL-5) + +* Sun Nov 13 2011 Remi Collet 5.4.0-0.3.201111130730 +- new snapshot (5.4.0RC2-dev) +- sync with latest changes in 5.3 spec + +* Thu Sep 08 2011 Remi Collet 5.4.0-0.2.201109081430 +- new snapshot +- build mysql/mysqli against both libmysql and mysqlnd (new mysqlnd sub-package) + +* Sat Sep 03 2011 Remi Collet 5.4.0-0.1.201109031230 +- first work on php 5.4 +- remove -sqlite subpackage +- move php/modules-zts to php-zts/modules + -- cgit