diff --git a/Dockerfile b/Dockerfile index 785763b..2f47663 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,11 +1,13 @@ -FROM php:7.1-apache +FROM php:7.2-apache ADD root/ / # Fix the original permissions of /tmp, the PHP default upload tmp dir. RUN chmod 777 /tmp && chmod +t /tmp # Setup the required extensions. +ARG DEBIAN_FRONTEND=noninteractive RUN /tmp/setup/php-extensions.sh RUN /tmp/setup/oci8-extension.sh +ENV LD_LIBRARY_PATH /usr/local/instantclient RUN mkdir /var/www/moodledata && chown www-data /var/www/moodledata && \ mkdir /var/www/phpunitdata && chown www-data /var/www/phpunitdata && \ diff --git a/README.md b/README.md index 9e5c142..e1a87c4 100644 --- a/README.md +++ b/README.md @@ -6,6 +6,7 @@ A Moodle PHP environment configured for Moodle development based on [Official PH | PHP Version | Tag | Status | |--------------|-----|--------| +| PHP 7.2 | 7.2 | [![Build Status](https://travis-ci.org/moodlehq/moodle-php-apache.svg?branch=php72)](https://travis-ci.org/moodlehq/moodle-php-apache)| | PHP 7.1 | 7.1 | [![Build Status](https://travis-ci.org/moodlehq/moodle-php-apache.svg?branch=php71)](https://travis-ci.org/moodlehq/moodle-php-apache)| | PHP 7.0 | 7.0 | [![Build Status](https://travis-ci.org/moodlehq/moodle-php-apache.svg?branch=php70)](https://travis-ci.org/moodlehq/moodle-php-apache)| |PHP 5.6 | 5.6 | [![Build Status](https://travis-ci.org/moodlehq/moodle-php-apache.svg?branch=php56)](https://travis-ci.org/moodlehq/moodle-php-apache)| diff --git a/root/tmp/setup/oci8-extension.sh b/root/tmp/setup/oci8-extension.sh index b6ced11..3ae7770 100755 --- a/root/tmp/setup/oci8-extension.sh +++ b/root/tmp/setup/oci8-extension.sh @@ -3,23 +3,28 @@ set -e echo "Downloading oracle files" -curl https://raw.githubusercontent.com/AminMkh/docker-php7-oci8-apache/b7c740638776552f00178a5d12905cefb50c7848/oracle/instantclient-basic-linux.x64-12.1.0.2.0.zip\ - -o /tmp/instantclient-basic-linux.x64-12.1.0.2.0.zip -curl https://raw.githubusercontent.com/AminMkh/docker-php7-oci8-apache/b7c740638776552f00178a5d12905cefb50c7848/oracle/instantclient-sdk-linux.x64-12.1.0.2.0.zip\ - -o /tmp/instantclient-sdk-linux.x64-12.1.0.2.0.zip -curl https://raw.githubusercontent.com/AminMkh/docker-php7-oci8-apache/b7c740638776552f00178a5d12905cefb50c7848/oracle/instantclient-sqlplus-linux.x64-12.1.0.2.0.zip\ - -o /tmp/instantclient-sqlplus-linux.x64-12.1.0.2.0.zip - -unzip /tmp/instantclient-basic-linux.x64-12.1.0.2.0.zip -d /usr/local/ -rm /tmp/instantclient-basic-linux.x64-12.1.0.2.0.zip -unzip /tmp/instantclient-sdk-linux.x64-12.1.0.2.0.zip -d /usr/local/ -rm /tmp/instantclient-sdk-linux.x64-12.1.0.2.0.zip -unzip /tmp/instantclient-sqlplus-linux.x64-12.1.0.2.0.zip -d /usr/local/ -rm /tmp/instantclient-sqlplus-linux.x64-12.1.0.2.0.zip - -ln -s /usr/local/instantclient_12_1 /usr/local/instantclient + +curl https://raw.githubusercontent.com/bumpx/oracle-instantclient/6aa46afa7a/instantclient-basic-linux.x64-12.2.0.1.0.zip \ + -o /tmp/instantclient-basic-linux.x64-12.2.0.1.0.zip +unzip /tmp/instantclient-basic-linux.x64-12.2.0.1.0.zip -d /usr/local/ +rm /tmp/instantclient-basic-linux.x64-12.2.0.1.0.zip + +curl https://raw.githubusercontent.com/bumpx/oracle-instantclient/6aa46afa7a/instantclient-sdk-linux.x64-12.2.0.1.0.zip \ + -o /tmp/instantclient-sdk-linux.x64-12.2.0.1.0.zip +unzip /tmp/instantclient-sdk-linux.x64-12.2.0.1.0.zip -d /usr/local/ +rm /tmp/instantclient-sdk-linux.x64-12.2.0.1.0.zip + +curl https://raw.githubusercontent.com/bumpx/oracle-instantclient/6aa46afa7a/instantclient-sqlplus-linux.x64-12.2.0.1.0.zip \ + -o /tmp/instantclient-sqlplus-linux.x64-12.2.0.1.0.zip +unzip /tmp/instantclient-sqlplus-linux.x64-12.2.0.1.0.zip -d /usr/local/ +rm /tmp/instantclient-sqlplus-linux.x64-12.2.0.1.0.zip + +ln -s /usr/local/instantclient_12_2 /usr/local/instantclient ln -s /usr/local/instantclient/libclntsh.so.12.1 /usr/local/instantclient/libclntsh.so ln -s /usr/local/instantclient/sqlplus /usr/bin/sqlplus +#echo 'export LD_LIBRARY_PATH="/usr/local/instantclient"' >> /root/.bashrc +#echo 'umask 002' >> /root/.bashrc + echo 'instantclient,/usr/local/instantclient' | pecl install oci8 && docker-php-ext-enable oci8 echo 'oci8.statement_cache_size = 0' >> /usr/local/etc/php/conf.d/docker-php-ext-oci8.ini diff --git a/root/tmp/setup/php-extensions.sh b/root/tmp/setup/php-extensions.sh index e479f9a..6355ece 100755 --- a/root/tmp/setup/php-extensions.sh +++ b/root/tmp/setup/php-extensions.sh @@ -2,13 +2,13 @@ set -e -echo "Installing apt depdencies" +echo "Installing apt dependencies" -BUILD_PACKAGES="gettext libcurl4-openssl-dev libpq-dev libmysqlclient-dev libldap2-dev libxslt-dev \ +BUILD_PACKAGES="gettext libcurl4-openssl-dev libpq-dev default-libmysqlclient-dev libldap2-dev libxslt-dev \ libxml2-dev libicu-dev libfreetype6-dev libjpeg62-turbo-dev libmemcached-dev \ - zlib1g-dev libpng12-dev unixodbc-dev" + zlib1g-dev libpng-dev unixodbc-dev gnupg2" -LIBS="locales libaio1 libcurl3 libgss3 libicu52 libmysqlclient18 libpq5 libmemcached11 libmemcachedutil2 libldap-2.4-2 libxml2 libxslt1.1 unixodbc libmcrypt-dev" +LIBS="locales libaio1 libcurl3 libgss3 libicu57 libpq5 libmemcached11 libmemcachedutil2 libldap-2.4-2 libxml2 libxslt1.1 unixodbc libmcrypt-dev" apt-get update apt-get install -y --no-install-recommends $BUILD_PACKAGES $LIBS unzip ghostscript locales apt-transport-https @@ -34,19 +34,14 @@ docker-php-ext-install -j$(nproc) gd docker-php-ext-configure ldap --with-libdir=lib/x86_64-linux-gnu/ docker-php-ext-install -j$(nproc) ldap -pecl install solr memcached redis apcu igbinary -docker-php-ext-enable solr memcached redis apcu igbinary +pecl install memcached redis apcu igbinary +docker-php-ext-enable memcached redis apcu igbinary echo 'apc.enable_cli = On' >> /usr/local/etc/php/conf.d/docker-php-ext-apcu.ini -# Install Microsoft depdencises for sqlsrv -curl https://packages.microsoft.com/keys/microsoft.asc | apt-key add - -curl https://packages.microsoft.com/config/debian/8/prod.list -o /etc/apt/sources.list.d/mssql-release.list -apt-get update -ACCEPT_EULA=Y apt-get install -y msodbcsql - -pecl install sqlsrv-4.3.0 -docker-php-ext-enable sqlsrv +# Go for sqlsrv extension now (kept apart for clarity, still need to be run here +# before some build packages are deleted. +/tmp/setup/sqlsrv-extension.sh # Keep our image size down.. pecl clear-cache diff --git a/root/tmp/setup/sqlsrv-extension.sh b/root/tmp/setup/sqlsrv-extension.sh new file mode 100755 index 0000000..13fafe0 --- /dev/null +++ b/root/tmp/setup/sqlsrv-extension.sh @@ -0,0 +1,33 @@ +#!/usr/bin/env bash + +set -e + +# Install Microsoft dependencies for sqlsrv +# Debian 9 requires ODBC driver 17, still not package available in repos, so followed this +# https://github.com/Microsoft/msphpsql/wiki/Install-and-configuration#user-content-odbc-17-linux-installation +echo "Downloading sqlsrv files" +curl https://packages.microsoft.com/keys/microsoft.asc | apt-key add - +curl https://packages.microsoft.com/config/debian/8/prod.list -o /etc/apt/sources.list.d/mssql-release.list +apt-get update + +echo "Install msodbcsql" +ACCEPT_EULA=Y apt-get install -y msodbcsql + +# now remove ODBC driver 13.1, then download and install 17 from Github +apt-get purge -y msodbcsql + +curl https://raw.githubusercontent.com/Microsoft/msphpsql/dev/ODBC%2017%20binaries%20preview/Debian%209/msodbcsql_17.0.0.5-1_amd64.deb \ + -o /tmp/msodbcsql_17.0.0.5-1_amd64.deb +curl https://raw.githubusercontent.com/Microsoft/msphpsql/dev/ODBC%2017%20binaries%20preview/Debian%209/mssql-tools_17.0.0.5-1_amd64.deb \ + -o /tmp/mssql-tools_17.0.0.5-1_amd64.deb + +ACCEPT_EULA=Y dpkg -i /tmp/msodbcsql_17.0.0.5-1_amd64.deb +ACCEPT_EULA=Y dpkg -i /tmp/mssql-tools_17.0.0.5-1_amd64.deb + +rm /tmp/msodbcsql_17.0.0.5-1_amd64.deb +rm /tmp/mssql-tools_17.0.0.5-1_amd64.deb + +ln -fsv /opt/mssql-tools/bin/* /usr/bin + +pecl install sqlsrv-5.2.0RC1 +docker-php-ext-enable sqlsrv diff --git a/tests/fixtures/test.php b/tests/fixtures/test.php index dbff555..949100e 100644 --- a/tests/fixtures/test.php +++ b/tests/fixtures/test.php @@ -11,7 +11,7 @@ 'oci8', 'pgsql', 'redis', - 'solr', +# Disabled because it's not available for php72 yet 'solr', 'soap', 'sqlsrv', 'xsl',