mirror of
https://github.com/joomla-docker/docker-joomla.git
synced 2025-01-10 08:34:04 +00:00
Remove PHP 5.6
This commit is contained in:
parent
fc73e6a1fe
commit
7094d565ff
@ -2,9 +2,6 @@ language: bash
|
|||||||
services: docker
|
services: docker
|
||||||
|
|
||||||
env:
|
env:
|
||||||
- VARIANT=php5.6/apache
|
|
||||||
- VARIANT=php5.6/fpm
|
|
||||||
- VARIANT=php5.6/fpm-alpine
|
|
||||||
- VARIANT=php7.1/apache
|
- VARIANT=php7.1/apache
|
||||||
- VARIANT=php7.1/fpm
|
- VARIANT=php7.1/fpm
|
||||||
- VARIANT=php7.1/fpm-alpine
|
- VARIANT=php7.1/fpm-alpine
|
||||||
|
@ -1,85 +0,0 @@
|
|||||||
FROM php:5.6-apache
|
|
||||||
LABEL maintainer="Michael Babker <michael.babker@joomla.org> (@mbabker)"
|
|
||||||
|
|
||||||
# Disable remote database security requirements.
|
|
||||||
ENV JOOMLA_INSTALLATION_DISABLE_LOCALHOST_CHECK=1
|
|
||||||
|
|
||||||
# Enable Apache Rewrite Module
|
|
||||||
RUN a2enmod rewrite
|
|
||||||
|
|
||||||
# Install PHP extensions
|
|
||||||
RUN set -ex; \
|
|
||||||
\
|
|
||||||
savedAptMark="$(apt-mark showmanual)"; \
|
|
||||||
\
|
|
||||||
apt-get update; \
|
|
||||||
apt-get install -y --no-install-recommends \
|
|
||||||
libbz2-dev \
|
|
||||||
libjpeg-dev \
|
|
||||||
libldap2-dev \
|
|
||||||
libmcrypt-dev \
|
|
||||||
libmemcached-dev \
|
|
||||||
libpng-dev \
|
|
||||||
libpq-dev \
|
|
||||||
; \
|
|
||||||
\
|
|
||||||
docker-php-ext-configure gd --with-png-dir=/usr --with-jpeg-dir=/usr; \
|
|
||||||
debMultiarch="$(dpkg-architecture --query DEB_BUILD_MULTIARCH)"; \
|
|
||||||
docker-php-ext-configure ldap --with-libdir="lib/$debMultiarch"; \
|
|
||||||
docker-php-ext-install \
|
|
||||||
bz2 \
|
|
||||||
gd \
|
|
||||||
ldap \
|
|
||||||
mcrypt \
|
|
||||||
mysqli \
|
|
||||||
pdo_mysql \
|
|
||||||
pdo_pgsql \
|
|
||||||
pgsql \
|
|
||||||
zip \
|
|
||||||
; \
|
|
||||||
\
|
|
||||||
# pecl will claim success even if one install fails, so we need to perform each install separately
|
|
||||||
pecl install APCu-4.0.11; \
|
|
||||||
pecl install memcached-2.2.0; \
|
|
||||||
pecl install redis-4.2.0; \
|
|
||||||
\
|
|
||||||
docker-php-ext-enable \
|
|
||||||
apcu \
|
|
||||||
memcached \
|
|
||||||
redis \
|
|
||||||
; \
|
|
||||||
\
|
|
||||||
# reset apt-mark's "manual" list so that "purge --auto-remove" will remove all build dependencies
|
|
||||||
apt-mark auto '.*' > /dev/null; \
|
|
||||||
apt-mark manual $savedAptMark; \
|
|
||||||
ldd "$(php -r 'echo ini_get("extension_dir");')"/*.so \
|
|
||||||
| awk '/=>/ { print $3 }' \
|
|
||||||
| sort -u \
|
|
||||||
| xargs -r dpkg-query -S \
|
|
||||||
| cut -d: -f1 \
|
|
||||||
| sort -u \
|
|
||||||
| xargs -rt apt-mark manual; \
|
|
||||||
\
|
|
||||||
apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false; \
|
|
||||||
rm -rf /var/lib/apt/lists/*
|
|
||||||
|
|
||||||
VOLUME /var/www/html
|
|
||||||
|
|
||||||
# Define Joomla version and expected SHA1 signature
|
|
||||||
ENV JOOMLA_VERSION 3.9.1
|
|
||||||
ENV JOOMLA_SHA1 aec0f602f93064d55cc06917329abdeef2e0f820
|
|
||||||
|
|
||||||
# Download package and extract to web volume
|
|
||||||
RUN curl -o joomla.tar.bz2 -SL https://github.com/joomla/joomla-cms/releases/download/${JOOMLA_VERSION}/Joomla_${JOOMLA_VERSION}-Stable-Full_Package.tar.bz2 \
|
|
||||||
&& echo "$JOOMLA_SHA1 *joomla.tar.bz2" | sha1sum -c - \
|
|
||||||
&& mkdir /usr/src/joomla \
|
|
||||||
&& tar -xf joomla.tar.bz2 -C /usr/src/joomla \
|
|
||||||
&& rm joomla.tar.bz2 \
|
|
||||||
&& chown -R www-data:www-data /usr/src/joomla
|
|
||||||
|
|
||||||
# Copy init scripts and custom .htaccess
|
|
||||||
COPY docker-entrypoint.sh /entrypoint.sh
|
|
||||||
COPY makedb.php /makedb.php
|
|
||||||
|
|
||||||
ENTRYPOINT ["/entrypoint.sh"]
|
|
||||||
CMD ["apache2-foreground"]
|
|
@ -1,70 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
set -e
|
|
||||||
|
|
||||||
if [[ "$1" == apache2* ]] || [ "$1" == php-fpm ]; then
|
|
||||||
if [ -n "$MYSQL_PORT_3306_TCP" ]; then
|
|
||||||
if [ -z "$JOOMLA_DB_HOST" ]; then
|
|
||||||
JOOMLA_DB_HOST='mysql'
|
|
||||||
else
|
|
||||||
echo >&2 "warning: both JOOMLA_DB_HOST and MYSQL_PORT_3306_TCP found"
|
|
||||||
echo >&2 " Connecting to JOOMLA_DB_HOST ($JOOMLA_DB_HOST)"
|
|
||||||
echo >&2 " instead of the linked mysql container"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z "$JOOMLA_DB_HOST" ]; then
|
|
||||||
echo >&2 "error: missing JOOMLA_DB_HOST and MYSQL_PORT_3306_TCP environment variables"
|
|
||||||
echo >&2 " Did you forget to --link some_mysql_container:mysql or set an external db"
|
|
||||||
echo >&2 " with -e JOOMLA_DB_HOST=hostname:port?"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# If the DB user is 'root' then use the MySQL root password env var
|
|
||||||
: ${JOOMLA_DB_USER:=root}
|
|
||||||
if [ "$JOOMLA_DB_USER" = 'root' ]; then
|
|
||||||
: ${JOOMLA_DB_PASSWORD:=$MYSQL_ENV_MYSQL_ROOT_PASSWORD}
|
|
||||||
fi
|
|
||||||
: ${JOOMLA_DB_NAME:=joomla}
|
|
||||||
|
|
||||||
if [ -z "$JOOMLA_DB_PASSWORD" ] && [ "$JOOMLA_DB_PASSWORD_ALLOW_EMPTY" != 'yes' ]; then
|
|
||||||
echo >&2 "error: missing required JOOMLA_DB_PASSWORD environment variable"
|
|
||||||
echo >&2 " Did you forget to -e JOOMLA_DB_PASSWORD=... ?"
|
|
||||||
echo >&2
|
|
||||||
echo >&2 " (Also of interest might be JOOMLA_DB_USER and JOOMLA_DB_NAME.)"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! [ -e index.php -a \( -e libraries/cms/version/version.php -o -e libraries/src/Version.php \) ]; then
|
|
||||||
echo >&2 "Joomla not found in $(pwd) - copying now..."
|
|
||||||
|
|
||||||
if [ "$(ls -A)" ]; then
|
|
||||||
echo >&2 "WARNING: $(pwd) is not empty - press Ctrl+C now if this is an error!"
|
|
||||||
( set -x; ls -A; sleep 10 )
|
|
||||||
fi
|
|
||||||
|
|
||||||
tar cf - --one-file-system -C /usr/src/joomla . | tar xf -
|
|
||||||
|
|
||||||
if [ ! -e .htaccess ]; then
|
|
||||||
# NOTE: The "Indexes" option is disabled in the php:apache base image so remove it as we enable .htaccess
|
|
||||||
sed -r 's/^(Options -Indexes.*)$/#\1/' htaccess.txt > .htaccess
|
|
||||||
chown www-data:www-data .htaccess
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo >&2 "Complete! Joomla has been successfully copied to $(pwd)"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Ensure the MySQL Database is created
|
|
||||||
php /makedb.php "$JOOMLA_DB_HOST" "$JOOMLA_DB_USER" "$JOOMLA_DB_PASSWORD" "$JOOMLA_DB_NAME"
|
|
||||||
|
|
||||||
echo >&2 "========================================================================"
|
|
||||||
echo >&2
|
|
||||||
echo >&2 "This server is now configured to run Joomla!"
|
|
||||||
echo >&2
|
|
||||||
echo >&2 "NOTE: You will need your database server address, database name,"
|
|
||||||
echo >&2 "and database user credentials to install Joomla."
|
|
||||||
echo >&2
|
|
||||||
echo >&2 "========================================================================"
|
|
||||||
fi
|
|
||||||
|
|
||||||
exec "$@"
|
|
@ -1,46 +0,0 @@
|
|||||||
<?php
|
|
||||||
// Args: 0 => makedb.php, 1 => "$JOOMLA_DB_HOST", 2 => "$JOOMLA_DB_USER", 3 => "$JOOMLA_DB_PASSWORD", 4 => "$JOOMLA_DB_NAME"
|
|
||||||
$stderr = fopen('php://stderr', 'w');
|
|
||||||
fwrite($stderr, "\nEnsuring Joomla database is present\n");
|
|
||||||
|
|
||||||
if (strpos($argv[1], ':') !== false)
|
|
||||||
{
|
|
||||||
list($host, $port) = explode(':', $argv[1], 2);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
$host = $argv[1];
|
|
||||||
$port = 3306;
|
|
||||||
}
|
|
||||||
|
|
||||||
$maxTries = 10;
|
|
||||||
|
|
||||||
do
|
|
||||||
{
|
|
||||||
$mysql = new mysqli($host, $argv[2], $argv[3], '', (int) $port);
|
|
||||||
|
|
||||||
if ($mysql->connect_error)
|
|
||||||
{
|
|
||||||
fwrite($stderr, "\nMySQL Connection Error: ({$mysql->connect_errno}) {$mysql->connect_error}\n");
|
|
||||||
--$maxTries;
|
|
||||||
|
|
||||||
if ($maxTries <= 0)
|
|
||||||
{
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
sleep(3);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
while ($mysql->connect_error);
|
|
||||||
|
|
||||||
if (!$mysql->query('CREATE DATABASE IF NOT EXISTS `' . $mysql->real_escape_string($argv[4]) . '`'))
|
|
||||||
{
|
|
||||||
fwrite($stderr, "\nMySQL 'CREATE DATABASE' Error: " . $mysql->error . "\n");
|
|
||||||
$mysql->close();
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
fwrite($stderr, "\nMySQL Database Created\n");
|
|
||||||
|
|
||||||
$mysql->close();
|
|
@ -1,80 +0,0 @@
|
|||||||
FROM php:5.6-fpm-alpine
|
|
||||||
LABEL maintainer="Michael Babker <michael.babker@joomla.org> (@mbabker)"
|
|
||||||
|
|
||||||
# Disable remote database security requirements.
|
|
||||||
ENV JOOMLA_INSTALLATION_DISABLE_LOCALHOST_CHECK=1
|
|
||||||
|
|
||||||
# entrypoint.sh dependencies
|
|
||||||
RUN apk add --no-cache \
|
|
||||||
bash
|
|
||||||
|
|
||||||
# Install PHP extensions
|
|
||||||
RUN set -ex; \
|
|
||||||
\
|
|
||||||
apk add --no-cache --virtual .build-deps \
|
|
||||||
$PHPIZE_DEPS \
|
|
||||||
autoconf \
|
|
||||||
bzip2-dev \
|
|
||||||
libjpeg-turbo-dev \
|
|
||||||
libmcrypt-dev \
|
|
||||||
libmemcached-dev \
|
|
||||||
libpng-dev \
|
|
||||||
openldap-dev \
|
|
||||||
pcre-dev \
|
|
||||||
postgresql-dev \
|
|
||||||
; \
|
|
||||||
\
|
|
||||||
docker-php-ext-configure gd --with-png-dir=/usr --with-jpeg-dir=/usr; \
|
|
||||||
docker-php-ext-configure ldap; \
|
|
||||||
docker-php-ext-install \
|
|
||||||
bz2 \
|
|
||||||
gd \
|
|
||||||
ldap \
|
|
||||||
mcrypt \
|
|
||||||
mysqli \
|
|
||||||
pdo_mysql \
|
|
||||||
pdo_pgsql \
|
|
||||||
pgsql \
|
|
||||||
zip \
|
|
||||||
; \
|
|
||||||
\
|
|
||||||
# pecl will claim success even if one install fails, so we need to perform each install separately
|
|
||||||
pecl install APCu-4.0.11; \
|
|
||||||
pecl install memcached-2.2.0; \
|
|
||||||
pecl install redis-4.2.0; \
|
|
||||||
\
|
|
||||||
docker-php-ext-enable \
|
|
||||||
apcu \
|
|
||||||
memcached \
|
|
||||||
redis \
|
|
||||||
; \
|
|
||||||
\
|
|
||||||
runDeps="$( \
|
|
||||||
scanelf --needed --nobanner --format '%n#p' --recursive /usr/local/lib/php/extensions \
|
|
||||||
| tr ',' '\n' \
|
|
||||||
| sort -u \
|
|
||||||
| awk 'system("[ -e /usr/local/lib/" $1 " ]") == 0 { next } { print "so:" $1 }' \
|
|
||||||
)"; \
|
|
||||||
apk add --virtual .joomla-phpext-rundeps $runDeps; \
|
|
||||||
apk del .build-deps
|
|
||||||
|
|
||||||
VOLUME /var/www/html
|
|
||||||
|
|
||||||
# Define Joomla version and expected SHA1 signature
|
|
||||||
ENV JOOMLA_VERSION 3.9.1
|
|
||||||
ENV JOOMLA_SHA1 aec0f602f93064d55cc06917329abdeef2e0f820
|
|
||||||
|
|
||||||
# Download package and extract to web volume
|
|
||||||
RUN curl -o joomla.tar.bz2 -SL https://github.com/joomla/joomla-cms/releases/download/${JOOMLA_VERSION}/Joomla_${JOOMLA_VERSION}-Stable-Full_Package.tar.bz2 \
|
|
||||||
&& echo "$JOOMLA_SHA1 *joomla.tar.bz2" | sha1sum -c - \
|
|
||||||
&& mkdir /usr/src/joomla \
|
|
||||||
&& tar -xf joomla.tar.bz2 -C /usr/src/joomla \
|
|
||||||
&& rm joomla.tar.bz2 \
|
|
||||||
&& chown -R www-data:www-data /usr/src/joomla
|
|
||||||
|
|
||||||
# Copy init scripts and custom .htaccess
|
|
||||||
COPY docker-entrypoint.sh /entrypoint.sh
|
|
||||||
COPY makedb.php /makedb.php
|
|
||||||
|
|
||||||
ENTRYPOINT ["/entrypoint.sh"]
|
|
||||||
CMD ["php-fpm"]
|
|
@ -1,70 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
set -e
|
|
||||||
|
|
||||||
if [[ "$1" == apache2* ]] || [ "$1" == php-fpm ]; then
|
|
||||||
if [ -n "$MYSQL_PORT_3306_TCP" ]; then
|
|
||||||
if [ -z "$JOOMLA_DB_HOST" ]; then
|
|
||||||
JOOMLA_DB_HOST='mysql'
|
|
||||||
else
|
|
||||||
echo >&2 "warning: both JOOMLA_DB_HOST and MYSQL_PORT_3306_TCP found"
|
|
||||||
echo >&2 " Connecting to JOOMLA_DB_HOST ($JOOMLA_DB_HOST)"
|
|
||||||
echo >&2 " instead of the linked mysql container"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z "$JOOMLA_DB_HOST" ]; then
|
|
||||||
echo >&2 "error: missing JOOMLA_DB_HOST and MYSQL_PORT_3306_TCP environment variables"
|
|
||||||
echo >&2 " Did you forget to --link some_mysql_container:mysql or set an external db"
|
|
||||||
echo >&2 " with -e JOOMLA_DB_HOST=hostname:port?"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# If the DB user is 'root' then use the MySQL root password env var
|
|
||||||
: ${JOOMLA_DB_USER:=root}
|
|
||||||
if [ "$JOOMLA_DB_USER" = 'root' ]; then
|
|
||||||
: ${JOOMLA_DB_PASSWORD:=$MYSQL_ENV_MYSQL_ROOT_PASSWORD}
|
|
||||||
fi
|
|
||||||
: ${JOOMLA_DB_NAME:=joomla}
|
|
||||||
|
|
||||||
if [ -z "$JOOMLA_DB_PASSWORD" ] && [ "$JOOMLA_DB_PASSWORD_ALLOW_EMPTY" != 'yes' ]; then
|
|
||||||
echo >&2 "error: missing required JOOMLA_DB_PASSWORD environment variable"
|
|
||||||
echo >&2 " Did you forget to -e JOOMLA_DB_PASSWORD=... ?"
|
|
||||||
echo >&2
|
|
||||||
echo >&2 " (Also of interest might be JOOMLA_DB_USER and JOOMLA_DB_NAME.)"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! [ -e index.php -a \( -e libraries/cms/version/version.php -o -e libraries/src/Version.php \) ]; then
|
|
||||||
echo >&2 "Joomla not found in $(pwd) - copying now..."
|
|
||||||
|
|
||||||
if [ "$(ls -A)" ]; then
|
|
||||||
echo >&2 "WARNING: $(pwd) is not empty - press Ctrl+C now if this is an error!"
|
|
||||||
( set -x; ls -A; sleep 10 )
|
|
||||||
fi
|
|
||||||
|
|
||||||
tar cf - --one-file-system -C /usr/src/joomla . | tar xf -
|
|
||||||
|
|
||||||
if [ ! -e .htaccess ]; then
|
|
||||||
# NOTE: The "Indexes" option is disabled in the php:apache base image so remove it as we enable .htaccess
|
|
||||||
sed -r 's/^(Options -Indexes.*)$/#\1/' htaccess.txt > .htaccess
|
|
||||||
chown www-data:www-data .htaccess
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo >&2 "Complete! Joomla has been successfully copied to $(pwd)"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Ensure the MySQL Database is created
|
|
||||||
php /makedb.php "$JOOMLA_DB_HOST" "$JOOMLA_DB_USER" "$JOOMLA_DB_PASSWORD" "$JOOMLA_DB_NAME"
|
|
||||||
|
|
||||||
echo >&2 "========================================================================"
|
|
||||||
echo >&2
|
|
||||||
echo >&2 "This server is now configured to run Joomla!"
|
|
||||||
echo >&2
|
|
||||||
echo >&2 "NOTE: You will need your database server address, database name,"
|
|
||||||
echo >&2 "and database user credentials to install Joomla."
|
|
||||||
echo >&2
|
|
||||||
echo >&2 "========================================================================"
|
|
||||||
fi
|
|
||||||
|
|
||||||
exec "$@"
|
|
@ -1,46 +0,0 @@
|
|||||||
<?php
|
|
||||||
// Args: 0 => makedb.php, 1 => "$JOOMLA_DB_HOST", 2 => "$JOOMLA_DB_USER", 3 => "$JOOMLA_DB_PASSWORD", 4 => "$JOOMLA_DB_NAME"
|
|
||||||
$stderr = fopen('php://stderr', 'w');
|
|
||||||
fwrite($stderr, "\nEnsuring Joomla database is present\n");
|
|
||||||
|
|
||||||
if (strpos($argv[1], ':') !== false)
|
|
||||||
{
|
|
||||||
list($host, $port) = explode(':', $argv[1], 2);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
$host = $argv[1];
|
|
||||||
$port = 3306;
|
|
||||||
}
|
|
||||||
|
|
||||||
$maxTries = 10;
|
|
||||||
|
|
||||||
do
|
|
||||||
{
|
|
||||||
$mysql = new mysqli($host, $argv[2], $argv[3], '', (int) $port);
|
|
||||||
|
|
||||||
if ($mysql->connect_error)
|
|
||||||
{
|
|
||||||
fwrite($stderr, "\nMySQL Connection Error: ({$mysql->connect_errno}) {$mysql->connect_error}\n");
|
|
||||||
--$maxTries;
|
|
||||||
|
|
||||||
if ($maxTries <= 0)
|
|
||||||
{
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
sleep(3);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
while ($mysql->connect_error);
|
|
||||||
|
|
||||||
if (!$mysql->query('CREATE DATABASE IF NOT EXISTS `' . $mysql->real_escape_string($argv[4]) . '`'))
|
|
||||||
{
|
|
||||||
fwrite($stderr, "\nMySQL 'CREATE DATABASE' Error: " . $mysql->error . "\n");
|
|
||||||
$mysql->close();
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
fwrite($stderr, "\nMySQL Database Created\n");
|
|
||||||
|
|
||||||
$mysql->close();
|
|
@ -1,82 +0,0 @@
|
|||||||
FROM php:5.6-fpm
|
|
||||||
LABEL maintainer="Michael Babker <michael.babker@joomla.org> (@mbabker)"
|
|
||||||
|
|
||||||
# Disable remote database security requirements.
|
|
||||||
ENV JOOMLA_INSTALLATION_DISABLE_LOCALHOST_CHECK=1
|
|
||||||
|
|
||||||
# Install PHP extensions
|
|
||||||
RUN set -ex; \
|
|
||||||
\
|
|
||||||
savedAptMark="$(apt-mark showmanual)"; \
|
|
||||||
\
|
|
||||||
apt-get update; \
|
|
||||||
apt-get install -y --no-install-recommends \
|
|
||||||
libbz2-dev \
|
|
||||||
libjpeg-dev \
|
|
||||||
libldap2-dev \
|
|
||||||
libmcrypt-dev \
|
|
||||||
libmemcached-dev \
|
|
||||||
libpng-dev \
|
|
||||||
libpq-dev \
|
|
||||||
; \
|
|
||||||
\
|
|
||||||
docker-php-ext-configure gd --with-png-dir=/usr --with-jpeg-dir=/usr; \
|
|
||||||
debMultiarch="$(dpkg-architecture --query DEB_BUILD_MULTIARCH)"; \
|
|
||||||
docker-php-ext-configure ldap --with-libdir="lib/$debMultiarch"; \
|
|
||||||
docker-php-ext-install \
|
|
||||||
bz2 \
|
|
||||||
gd \
|
|
||||||
ldap \
|
|
||||||
mcrypt \
|
|
||||||
mysqli \
|
|
||||||
pdo_mysql \
|
|
||||||
pdo_pgsql \
|
|
||||||
pgsql \
|
|
||||||
zip \
|
|
||||||
; \
|
|
||||||
\
|
|
||||||
# pecl will claim success even if one install fails, so we need to perform each install separately
|
|
||||||
pecl install APCu-4.0.11; \
|
|
||||||
pecl install memcached-2.2.0; \
|
|
||||||
pecl install redis-4.2.0; \
|
|
||||||
\
|
|
||||||
docker-php-ext-enable \
|
|
||||||
apcu \
|
|
||||||
memcached \
|
|
||||||
redis \
|
|
||||||
; \
|
|
||||||
\
|
|
||||||
# reset apt-mark's "manual" list so that "purge --auto-remove" will remove all build dependencies
|
|
||||||
apt-mark auto '.*' > /dev/null; \
|
|
||||||
apt-mark manual $savedAptMark; \
|
|
||||||
ldd "$(php -r 'echo ini_get("extension_dir");')"/*.so \
|
|
||||||
| awk '/=>/ { print $3 }' \
|
|
||||||
| sort -u \
|
|
||||||
| xargs -r dpkg-query -S \
|
|
||||||
| cut -d: -f1 \
|
|
||||||
| sort -u \
|
|
||||||
| xargs -rt apt-mark manual; \
|
|
||||||
\
|
|
||||||
apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false; \
|
|
||||||
rm -rf /var/lib/apt/lists/*
|
|
||||||
|
|
||||||
VOLUME /var/www/html
|
|
||||||
|
|
||||||
# Define Joomla version and expected SHA1 signature
|
|
||||||
ENV JOOMLA_VERSION 3.9.1
|
|
||||||
ENV JOOMLA_SHA1 aec0f602f93064d55cc06917329abdeef2e0f820
|
|
||||||
|
|
||||||
# Download package and extract to web volume
|
|
||||||
RUN curl -o joomla.tar.bz2 -SL https://github.com/joomla/joomla-cms/releases/download/${JOOMLA_VERSION}/Joomla_${JOOMLA_VERSION}-Stable-Full_Package.tar.bz2 \
|
|
||||||
&& echo "$JOOMLA_SHA1 *joomla.tar.bz2" | sha1sum -c - \
|
|
||||||
&& mkdir /usr/src/joomla \
|
|
||||||
&& tar -xf joomla.tar.bz2 -C /usr/src/joomla \
|
|
||||||
&& rm joomla.tar.bz2 \
|
|
||||||
&& chown -R www-data:www-data /usr/src/joomla
|
|
||||||
|
|
||||||
# Copy init scripts and custom .htaccess
|
|
||||||
COPY docker-entrypoint.sh /entrypoint.sh
|
|
||||||
COPY makedb.php /makedb.php
|
|
||||||
|
|
||||||
ENTRYPOINT ["/entrypoint.sh"]
|
|
||||||
CMD ["php-fpm"]
|
|
@ -1,70 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
set -e
|
|
||||||
|
|
||||||
if [[ "$1" == apache2* ]] || [ "$1" == php-fpm ]; then
|
|
||||||
if [ -n "$MYSQL_PORT_3306_TCP" ]; then
|
|
||||||
if [ -z "$JOOMLA_DB_HOST" ]; then
|
|
||||||
JOOMLA_DB_HOST='mysql'
|
|
||||||
else
|
|
||||||
echo >&2 "warning: both JOOMLA_DB_HOST and MYSQL_PORT_3306_TCP found"
|
|
||||||
echo >&2 " Connecting to JOOMLA_DB_HOST ($JOOMLA_DB_HOST)"
|
|
||||||
echo >&2 " instead of the linked mysql container"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z "$JOOMLA_DB_HOST" ]; then
|
|
||||||
echo >&2 "error: missing JOOMLA_DB_HOST and MYSQL_PORT_3306_TCP environment variables"
|
|
||||||
echo >&2 " Did you forget to --link some_mysql_container:mysql or set an external db"
|
|
||||||
echo >&2 " with -e JOOMLA_DB_HOST=hostname:port?"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# If the DB user is 'root' then use the MySQL root password env var
|
|
||||||
: ${JOOMLA_DB_USER:=root}
|
|
||||||
if [ "$JOOMLA_DB_USER" = 'root' ]; then
|
|
||||||
: ${JOOMLA_DB_PASSWORD:=$MYSQL_ENV_MYSQL_ROOT_PASSWORD}
|
|
||||||
fi
|
|
||||||
: ${JOOMLA_DB_NAME:=joomla}
|
|
||||||
|
|
||||||
if [ -z "$JOOMLA_DB_PASSWORD" ] && [ "$JOOMLA_DB_PASSWORD_ALLOW_EMPTY" != 'yes' ]; then
|
|
||||||
echo >&2 "error: missing required JOOMLA_DB_PASSWORD environment variable"
|
|
||||||
echo >&2 " Did you forget to -e JOOMLA_DB_PASSWORD=... ?"
|
|
||||||
echo >&2
|
|
||||||
echo >&2 " (Also of interest might be JOOMLA_DB_USER and JOOMLA_DB_NAME.)"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! [ -e index.php -a \( -e libraries/cms/version/version.php -o -e libraries/src/Version.php \) ]; then
|
|
||||||
echo >&2 "Joomla not found in $(pwd) - copying now..."
|
|
||||||
|
|
||||||
if [ "$(ls -A)" ]; then
|
|
||||||
echo >&2 "WARNING: $(pwd) is not empty - press Ctrl+C now if this is an error!"
|
|
||||||
( set -x; ls -A; sleep 10 )
|
|
||||||
fi
|
|
||||||
|
|
||||||
tar cf - --one-file-system -C /usr/src/joomla . | tar xf -
|
|
||||||
|
|
||||||
if [ ! -e .htaccess ]; then
|
|
||||||
# NOTE: The "Indexes" option is disabled in the php:apache base image so remove it as we enable .htaccess
|
|
||||||
sed -r 's/^(Options -Indexes.*)$/#\1/' htaccess.txt > .htaccess
|
|
||||||
chown www-data:www-data .htaccess
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo >&2 "Complete! Joomla has been successfully copied to $(pwd)"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Ensure the MySQL Database is created
|
|
||||||
php /makedb.php "$JOOMLA_DB_HOST" "$JOOMLA_DB_USER" "$JOOMLA_DB_PASSWORD" "$JOOMLA_DB_NAME"
|
|
||||||
|
|
||||||
echo >&2 "========================================================================"
|
|
||||||
echo >&2
|
|
||||||
echo >&2 "This server is now configured to run Joomla!"
|
|
||||||
echo >&2
|
|
||||||
echo >&2 "NOTE: You will need your database server address, database name,"
|
|
||||||
echo >&2 "and database user credentials to install Joomla."
|
|
||||||
echo >&2
|
|
||||||
echo >&2 "========================================================================"
|
|
||||||
fi
|
|
||||||
|
|
||||||
exec "$@"
|
|
@ -1,46 +0,0 @@
|
|||||||
<?php
|
|
||||||
// Args: 0 => makedb.php, 1 => "$JOOMLA_DB_HOST", 2 => "$JOOMLA_DB_USER", 3 => "$JOOMLA_DB_PASSWORD", 4 => "$JOOMLA_DB_NAME"
|
|
||||||
$stderr = fopen('php://stderr', 'w');
|
|
||||||
fwrite($stderr, "\nEnsuring Joomla database is present\n");
|
|
||||||
|
|
||||||
if (strpos($argv[1], ':') !== false)
|
|
||||||
{
|
|
||||||
list($host, $port) = explode(':', $argv[1], 2);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
$host = $argv[1];
|
|
||||||
$port = 3306;
|
|
||||||
}
|
|
||||||
|
|
||||||
$maxTries = 10;
|
|
||||||
|
|
||||||
do
|
|
||||||
{
|
|
||||||
$mysql = new mysqli($host, $argv[2], $argv[3], '', (int) $port);
|
|
||||||
|
|
||||||
if ($mysql->connect_error)
|
|
||||||
{
|
|
||||||
fwrite($stderr, "\nMySQL Connection Error: ({$mysql->connect_errno}) {$mysql->connect_error}\n");
|
|
||||||
--$maxTries;
|
|
||||||
|
|
||||||
if ($maxTries <= 0)
|
|
||||||
{
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
sleep(3);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
while ($mysql->connect_error);
|
|
||||||
|
|
||||||
if (!$mysql->query('CREATE DATABASE IF NOT EXISTS `' . $mysql->real_escape_string($argv[4]) . '`'))
|
|
||||||
{
|
|
||||||
fwrite($stderr, "\nMySQL 'CREATE DATABASE' Error: " . $mysql->error . "\n");
|
|
||||||
$mysql->close();
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
fwrite($stderr, "\nMySQL Database Created\n");
|
|
||||||
|
|
||||||
$mysql->close();
|
|
@ -29,9 +29,6 @@ declare -A variantBases=(
|
|||||||
[fpm-alpine]='alpine'
|
[fpm-alpine]='alpine'
|
||||||
)
|
)
|
||||||
declare -A pecl_versions=(
|
declare -A pecl_versions=(
|
||||||
[php5-APCu]='4.0.11'
|
|
||||||
[php5-memcached]='2.2.0'
|
|
||||||
[php5-redis]='4.2.0'
|
|
||||||
[php7-APCu]='5.1.16'
|
[php7-APCu]='5.1.16'
|
||||||
[php7-memcached]='3.1.2'
|
[php7-memcached]='3.1.2'
|
||||||
[php7-redis]='4.2.0'
|
[php7-redis]='4.2.0'
|
||||||
|
Loading…
Reference in New Issue
Block a user