From 8be79780a4d67231c74bfe1f57648a16aea85687 Mon Sep 17 00:00:00 2001 From: Max Rees Date: Mon, 4 Jun 2018 21:47:16 -0400 Subject: user/php7: new package --- user/php7/APKBUILD | 514 +++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 514 insertions(+) create mode 100644 user/php7/APKBUILD (limited to 'user/php7/APKBUILD') diff --git a/user/php7/APKBUILD b/user/php7/APKBUILD new file mode 100644 index 000000000..4c68d7dea --- /dev/null +++ b/user/php7/APKBUILD @@ -0,0 +1,514 @@ +# Contributor: Valery Kartel +# Contributor: Jakub Jirutka +# Maintainer: Max Rees + +# Bundled libraries +# +# Name | License | Location | State +# ----------+---------+------------------------+--------- +# bcmath | LGPL2 | ext/bcmath/libbcmath | used +# date | MIT | ext/date/lib | used +# gd | BSD | ext/gd/libgd | used +# file | BSD | ext/fileinfo/libmagic | used +# libmbfl | LGPLv2 | ext/mbstring/libmbfl | used +# oniguruma | BSD | ext/mbstring/oniguruma | used +# pcre | BSD | ext/pcre/pcrelib | not used +# sqlite3 | Public | ext/sqlite3/libsqlite | not used +# libzip | BSD | ext/zip/lib | not used +# libXMLRPC | BSD | ext/xmlrpc/libxmlrpc | used + +# Static extensions +# +# Name | Reason +# ----------+-------------------------------------------- +# zlib | https://bugs.alpinelinux.org/issues/8299 + +pkgname=php7 +_pkgname=php +pkgver=7.2.6 +pkgrel=0 +_apiver=20170718 +pkgdesc="The PHP7 language runtime engine" +url="http://www.php.net/" +arch="all" +license="PHP-3.0 BSD LGPL-2.0 MIT Zend" +depends="" +depends_dev="$pkgname=$pkgver-r$pkgrel autoconf pcre-dev" +makedepends="autoconf + apache-httpd-dev + aspell-dev + bison + bzip2-dev + curl-dev + db-dev + enchant-dev + freetds-dev + freetype-dev + gdbm-dev + gettext-dev + gmp-dev + icu-dev + krb5-dev + libedit-dev + libical-dev + libjpeg-turbo-dev + libpng-dev + openssl-dev + libwebp-dev + libxml2-dev + libxpm-dev + libxslt-dev + libzip-dev + net-snmp-dev + openldap-dev + pcre-dev + postgresql-dev + re2c + sqlite-dev + unixodbc-dev + zlib-dev" +subpackages="$pkgname-dev $pkgname-doc $pkgname-apache $pkgname-phpdbg + $pkgname-embed $pkgname-litespeed $pkgname-cgi $pkgname-fpm + $pkgname-pear::noarch $pkgname-dbg" +source="http://php.net/distributions/$_pkgname-$pkgver.tar.bz2 + $_pkgname-fpm.initd + $_pkgname-fpm.logrotate + $_pkgname-module.conf + disabled-tests.list + install-pear.patch + fpm-paths.patch + allow-build-recode-and-imap-together.patch + fix-tests-devserver.patch + pwbuflen.patch" +builddir="$srcdir/$_pkgname-$pkgver" +_libdir="/usr/lib/$_pkgname" +_extension_dir="$_libdir/modules" +_extension_confd="/etc/$_pkgname/conf.d" + +_configure_extra_opts="" +declare -A _extensions +# Usage: add_ext [with|enable] name [extension dependencies...] [configure options...] +add_ext() { + local ext="$1" + shift + # add_ext [with|enable] name -> --[with|enable]-name=shared + if [ "$ext" = "with" ] || [ "$ext" = "enable" ]; then + _configure_ext_opts="$_configure_ext_opts --$ext-$1=shared" + ext="$1" + shift + fi + + case "$ext" in + phar) subpackages="$subpackages $pkgname-$ext:$ext";; + *) subpackages="$subpackages $pkgname-$ext:_extension";; + esac + _extensions[$ext]="" + + local opt + for opt in $@; do + if printf '%s' "$opt" | grep -q '^-'; then + # Add more configure options + _configure_ext_opts="$_configure_ext_opts $opt" + else + # Add dependencies + _extensions[$ext]="${_extensions[$ext]} $opt" + fi + done +} +enable_ext() { add_ext enable $@; } +with_ext() { add_ext with $@; } + +enable_ext 'bcmath' +with_ext 'bz2' +enable_ext 'calendar' +enable_ext 'ctype' +with_ext 'curl' +enable_ext 'dba' \ + --with-db4 \ + --with-dbmaker=shared \ + --with-gdbm +enable_ext 'dom' +with_ext 'enchant' +enable_ext 'exif' mbstring +enable_ext 'fileinfo' +enable_ext 'ftp' +with_ext 'gd' \ + --with-freetype-dir=/usr \ + --disable-gd-jis-conv \ + --with-jpeg-dir=/usr \ + --with-png-dir=/usr \ + --with-webp-dir=/usr \ + --with-xpm-dir=/usr +with_ext 'gettext' +with_ext 'gmp' +with_ext 'iconv' +# Needs makedepeneds=imap-dev +#with_ext 'imap' \ +# --with-imap-ssl +enable_ext 'intl' +enable_ext 'json' +with_ext 'ldap' \ + --with-ldap-sasl +enable_ext 'mbstring' +add_ext 'mysqli' mysqlnd openssl \ + --with-mysqli=shared,mysqlnd \ + --with-mysql-sock=/run/mysqld/mysqld.sock +enable_ext 'mysqlnd' openssl +add_ext 'odbc' \ + --with-unixODBC=shared,/usr +enable_ext 'opcache' +with_ext 'openssl' \ + --with-system-ciphers \ + --with-kerberos +enable_ext 'pcntl' +enable_ext 'pdo' +add_ext 'pdo_dblib' pdo \ + --with-pdo-dblib=shared +add_ext 'pdo_mysql' pdo mysqlnd \ + --with-pdo-mysql=shared,mysqlnd +add_ext 'pdo_odbc' pdo \ + --with-pdo-odbc=shared,unixODBC,/usr +add_ext 'pdo_pgsql' pdo \ + --with-pdo-pgsql=shared +add_ext 'pdo_sqlite' pdo \ + --with-pdo-sqlite=shared,/usr +with_ext 'pgsql' +enable_ext 'phar' +enable_ext 'posix' +with_ext 'pspell' +# Needs makedepends=recode-dev +#with_ext 'recode' +enable_ext 'session' +enable_ext 'shmop' +enable_ext 'simplexml' +with_ext 'snmp' +enable_ext 'soap' +# Needs makedepends=libsodium-dev +#with_ext 'sodium' +enable_ext 'sockets' +add_ext 'sqlite3' \ + --with-sqlite3=shared,/usr +enable_ext 'sysvmsg' +enable_ext 'sysvsem' +enable_ext 'sysvshm' +# Needs makedepends=tidyhtml-dev +#with_ext 'tidy' +enable_ext 'tokenizer' +enable_ext 'wddx' xml +enable_ext 'xml' +enable_ext 'xmlreader' dom +with_ext 'xmlrpc' xml +enable_ext 'xmlwriter' +with_ext 'xsl' dom +enable_ext 'zip' \ + --with-libzip=/usr + +# secfixes: +# 7.2.5-r0: +# - CVE-2018-5712 + +prepare() { + cd "$builddir" + + default_prepare + update_config_sub + + local vapi=$(sed -n '/#define PHP_API_VERSION/{s/.* //;p}' main/php.h) + if [ "$vapi" != "$_apiver" ]; then + error "Upstreram API version is now $vapi. Expecting $_apiver" + error "After updating _apiver, all 3rd-party extensions must be rebuilt." + return 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 {} + + + # XXX: Delete failing tests. + sed -n '/^[^#]/p' "$srcdir/disabled-tests.list" | while read item; do + rm $item + done + + autoconf +} + +# Notes: +# * gd-jis-conv breaks any non-latin font rendering (vakartel). +# * libxml cannot be build as shared. +# * Doesn't work with system-provided onigurama, some tests fail (invalid code +# point); probably because bundled onigurama is version 5.x, but we have 6.x. +_build() { + cd "$builddir" + + EXTENSION_DIR=$_extension_dir ./configure \ + --build=$CBUILD \ + --host=$CHOST \ + --prefix=/usr \ + --libdir=$_libdir \ + --datadir=/usr/share/$_pkgname \ + --sysconfdir=/etc/$_pkgname \ + --localstatedir=/var \ + --enable-debug \ + --with-layout=GNU \ + --with-pic \ + --enable-maintainer-zts \ + --with-pear=/usr/share/$_pkgname \ + --with-config-file-path=/etc/$_pkgname \ + --with-config-file-scan-dir=$_extension_confd \ + --disable-short-tags \ + --with-icu-dir=/usr \ + --with-libedit \ + --without-readline \ + --enable-libxml \ + --with-libxml-dir=/usr \ + --with-pcre-regex=/usr \ + --with-zlib \ + --with-zlib-dir=/usr \ + $_configure_ext_opts \ + $@ + + make +} + +build() { + cd "$builddir" + + # phpdbg + _build --enable-phpdbg \ + --enable-phpdbg-webhelper \ + --disable-cgi \ + --disable-cli + + # apache-httpd module + _build --disable-phpdbg \ + --disable-cgi \ + --disable-cli \ + --with-apxs2 + mv libs/libphp7.so sapi/apache2handler/mod_php.so + + # cgi, cli, fpm, embed, litespeed + _build --disable-phpdbg \ + --enable-fpm \ + --enable-embed \ + --with-litespeed +} + +check() { + cd "$builddir" + + # PHP is so stupid that it's not able to resolve dependencies + # between extensions and load them in correct order, so we must + # help it... + # opcache is Zend extension, it's handled specially in Makefile + local php_modules=$(_extensions_by_load_order \ + | grep -vx opcache \ + | xargs -n 1 printf "'$builddir/modules/%s.la' ") + sed -i "/^PHP_TEST_SHARED_EXTENSIONS/,/extension=/ \ + s|in \$(PHP_MODULES)\"*|in $php_modules|" Makefile + + NO_INTERACTION=1 REPORT_EXIT_STATUS=1 \ + SKIP_SLOW_TESTS=1 SKIP_ONLINE_TESTS=1 TEST_TIMEOUT=10 \ + TZ= LANG= LC_ALL= \ + make test + + echo 'NOTE: We have skipped quite a lot tests, see disabled-tests.list.' +} + +package() { + cd "$builddir" + + make -j1 INSTALL_ROOT="$pkgdir" install + + install -Dm644 php.ini-production "$pkgdir"/etc/$_pkgname/php.ini + find "$pkgdir" -name '.*' | xargs rm -rf + rmdir "$pkgdir"/var/run +} + +dev() { + default_dev + cd "$pkgdir" + + _mv usr/bin/phpize "$subpkgdir"/usr/bin/ + _mv ./$_libdir/build "$subpkgdir"/$_libdir/ +} + +doc() { + default_doc + cd "$builddir" + + mkdir -p "$subpkgdir/usr/share/doc/$_pkgname" + cp CODING_STANDARDS CREDITS EXTENSIONS INSTALL LICENSE NEWS \ + README* UPGRADING* \ + "$subpkgdir/usr/share/doc/$_pkgname/" +} + +apache() { + pkgdesc="PHP7 Module for apache-httpd" + depends="$pkgname apache-httpd" + + install -D -m 755 "$builddir"/sapi/apache2handler/mod_php.so \ + "$subpkgdir"/usr/libexec/apache2/mod_php.so + install -D -m 644 "$srcdir"/php-module.conf \ + "$subpkgdir"/etc/apache2/conf.d/php-module.conf +} + +phpdbg() { + pkgdesc="Interactive PHP7 debugger" + #depends="$pkgname" ? + + install -Dm755 "$builddir"/sapi/phpdbg/phpdbg \ + "$subpkgdir"/usr/bin/phpdbg +} + +embed() { + pkgdesc="PHP7 Embedded Library" + #depends="$pkgname" ? + + _mv "$pkgdir"/usr/lib/libphp*.so "$subpkgdir"/usr/lib/ +} + +litespeed() { + pkgdesc="PHP7 LiteSpeed SAPI" + #depends="$pkgname" ? + + mkdir -p "$subpkgdir"/usr/bin + mv "$pkgdir"/usr/bin/lsphp "$subpkgdir"/usr/bin +} + +cgi() { + pkgdesc="PHP7 Common Gateway Interface" + depends="$pkgname" + + _mv "$pkgdir"/usr/bin/php-cgi "$subpkgdir"/usr/bin/ +} + +fpm() { + pkgdesc="PHP7 FastCGI Process Manager" + depends="$pkgname" + cd "$pkgdir" + + _mv var "$subpkgdir"/ + _mv usr/share/$_pkgname/fpm "$subpkgdir"/var/lib/$_pkgname/ + _mv usr/sbin "$subpkgdir"/usr/ + _mv etc/$_pkgname/php-fpm* "$subpkgdir"/etc/$_pkgname/ + + local file; for file in php-fpm.conf php-fpm.d/www.conf; do + mv "$subpkgdir"/etc/$_pkgname/$file.default \ + "$subpkgdir"/etc/$_pkgname/$file + done + + install -D -m 755 "$srcdir"/$_pkgname-fpm.initd \ + "$subpkgdir"/etc/init.d/php-fpm + + install -D -m 644 "$srcdir"/$_pkgname-fpm.logrotate \ + "$subpkgdir"/etc/logrotate.d/php-fpm + + mkdir -p "$subpkgdir"/var/log/$_pkgname +} + +pear() { + pkgdesc="PHP7 Extension and Application Repository" + depends="$pkgname $pkgname-xml" + cd "$pkgdir" + + # pecl needs xml extension and since we build it as shared, it must be + # explicitly declared to be loaded. + sed -i 's/\$INCARG/& -d extension=xml.so/' usr/bin/pecl + + mkdir -p "$subpkgdir"/usr/bin + local file; for file in pecl pear peardev; do + mv usr/bin/$file "$subpkgdir"/usr/bin/$file + done + + _mv etc/php/pear.conf "$subpkgdir"/etc/php/ + _mv usr/share "$subpkgdir"/usr/ +} + +phar() { + _extension + cd "$pkgdir" + + mkdir -p "$subpkgdir"/usr/bin + mv usr/bin/phar.phar "$subpkgdir"/usr/bin/phar.phar + + rm usr/bin/phar + ln -s phar.phar "$subpkgdir"/usr/bin/phar +} + +_extension() { + local ext="${subpkgname#$pkgname-}" + local extdesc="$(head -n1 "$builddir"/ext/$ext/CREDITS 2>/dev/null ||:)" + depends="$pkgname" + local dep; for dep in ${_extensions[$ext]}; do + depends="$depends $pkgname-$dep" + done + pkgdesc="PHP7 extension: ${extdesc:-$ext}" + + local load_order=$(_extension_load_order "$ext") + + # extension prefix + local prefix= + [ "$ext" = "opcache" ] && prefix="zend_" + + _mv "$pkgdir"/$_extension_dir/$ext.so \ + "$subpkgdir"/$_extension_dir/ + + mkdir -p "$subpkgdir"/$_extension_confd + echo "${prefix}extension=$ext.so" \ + > "$subpkgdir"/$_extension_confd/$(printf %02d $load_order)_$ext.ini +} + +# Prints a load order (0-based integer) for the given extension name. Extension +# with lower load order should be loaded before exts with higher load order. +# It's based on number of dependencies of the extension (with exception for +# "imap"), which is flawed, but simple and good enough for now. +_extension_load_order() { + local ext="$1" + local deps="${_extensions[$ext]}" + + case "$ext" in + # This must be loaded after recode, even though it does + # not depend on it. + imap) echo 1;; + # depends=$pkgname + phar) echo 1;; + *) echo "$deps" | wc -w;; + esac +} + +# Prints $_extensions sorted by load order and name. +_extensions_by_load_order() { + local deps list ext + + for ext in ${!_extensions[@]}; do + list="$list $(_extension_load_order $ext);$ext" + done + printf '%s\n' $list | sort -t ';' -k 1 | sed -E 's/\d+;//' +} + +_mv() { + local dest; for dest; do true; done # get last argument + mkdir -p "$dest" + mv $@ +} + +sha512sums="aace53b0b523484715b218e8e77ede355e73c6433e18ebd960a07c371940568d576f54455040c201b95856fa607febc19ef6539bc661a4db7984edc804c50408 php-7.2.6.tar.bz2 +23df4e779c809db3e3b8e5b0353b1aafaad2f3dc56f2d1cd45f9b0e3ad71b32e40700d6ebfe914b3c87e8e0b670d0dc862ded1e5c898adf160e33dea372e044f php-fpm.initd +01d4ba3ef104ea378eb0e8cbb7bdee3fdf65e4bd6865eb3bc6c0dc4af31c2d52887abdf0150b5ef984b877860285a3b1af84b11ffebb5b8b722ea9faf83edfeb php-fpm.logrotate +a7f9ba5e11652fd1cb9e756c3269269a95de083ecb5be936a85c7a09c1396db9088e0251c6a643c40235c0e776fce2a471e5c7f5a033b85c7d3b3110c2b39e48 php-module.conf +d90595261686e7bdabc7f406c10b468df88e97742a2dff517eec94c8ff20cce7fbe5236ee8463d60cd563bdcad22c0d94d702ca5c65b738b4767abea2f6156dc disabled-tests.list +f1177cbf6b1f44402f421c3d317aab1a2a40d0b1209c11519c1158df337c8945f3a313d689c939768584f3e4edbe52e8bd6103fb6777462326a9d94e8ab1f505 install-pear.patch +a77dd3bdf9dc7a0f2c06ff3e7c425d062bbaa29902c17402ce98701dc99499be863ad543aa5e6a7d1c249702d6afb193398dd3199ae58e42b32b95d434fb1883 fpm-paths.patch +f8ecae241a90cbc3e98aa4deb3d5d35ef555f51380e29f4e182a8060dffeb84be74f030a14c6b452668471030d78964f52795ca74275db05543ccad20ef1f2cc allow-build-recode-and-imap-together.patch +f8bb322e56df79dd9f391737fb8737945cc730b14c7dc2ae8688979c565a9b97f5f2a12c9fcd0d8124624a9d09bd10228147d9e999bb94909bbe249f0a50646c fix-tests-devserver.patch +8e538063d872f6770a57cdb844226a771ccda3d387dd1f199bb08c274b94fbe12ec0ef6df75c32071f308cb8f4ab51b91b520c7c2ed687adf96d0d322788e463 pwbuflen.patch" -- cgit v1.2.3-60-g2f50