migrated docker image to debian based php-fpm image

This commit is contained in:
Diego Lendoiro 2018-03-28 20:39:33 +02:00
parent 492ce3bec7
commit ef3da2c60e
1 changed files with 60 additions and 61 deletions

View File

@ -1,73 +1,72 @@
FROM alpine:3.6 FROM php:5-fpm
LABEL maintainer="diego@passbolt.com" LABEL maintainer="diego@passbolt.com"
ENV PASSBOLT_VERSION 1.6.9 ENV PASSBOLT_VERSION 1.6.10
ENV PASSBOLT_URL https://github.com/passbolt/passbolt_api/archive/v${PASSBOLT_VERSION}.tar.gz ENV PASSBOLT_URL https://github.com/passbolt/passbolt_api/archive/v${PASSBOLT_VERSION}.tar.gz
ARG BASE_PHP_DEPS="php5-curl \ ARG PHP_EXTENSIONS="gd \
php5-common \ intl \
php5-gd \ pdo_mysql \
php5-intl \ mcrypt \
php5-json \ xsl"
php5-mcrypt \
php5-mysql \
php5-xsl \
php5-fpm \
php5-phar \
php5-posix \
php5-xml \
php5-openssl \
php5-zlib \
php5-ctype \
php5-pdo \
php5-pdo_mysql \
php5-pear"
ARG PHP_GNUPG_DEPS="php5-dev \ ARG PECL_PASSBOLT_EXTENSIONS="gnupg \
make \ redis"
gcc \
g++ \
libc-dev \
pkgconfig \
re2c \
gpgme-dev \
autoconf \
zlib-dev \
file"
RUN apk add --no-cache $BASE_PHP_DEPS \ ARG PASSBOLT_DEV_PACKAGES="libgpgme11-dev \
sed \ libpng-dev \
coreutils \ libxslt1-dev \
tar \ libmcrypt-dev \
bash \ unzip \
curl \ git"
ENV PECL_BASE_URL="https://pecl.php.net/get"
ENV PHP_EXT_DIR="/usr/src/php/ext"
WORKDIR /var/www/passbolt
RUN apt-get update \
&& apt-get -y install --no-install-recommends $PASSBOLT_DEV_PACKAGES \
nginx \ nginx \
gpgme \ gnupg \
gnupg1 \ libgpgme11 \
recode \ libmcrypt4 \
libxml2 \ libicu-dev \
openssl \
libpcre32 \
mysql-client \ mysql-client \
ca-certificates supervisor \
netcat \
RUN apk add --no-cache $PHP_GNUPG_DEPS \ cron \
&& ln -s /usr/bin/php5 /usr/bin/php \ && mkdir /home/www-data \
&& ln -s /usr/bin/phpize5 /usr/bin/phpize \ && chown -R www-data:www-data /home/www-data \
&& sed -i "s/ -n / /" $(which pecl) \ && usermod -d /home/www-data www-data \
&& pecl install gnupg \ && docker-php-source extract \
&& pecl install redis \ && for i in $PECL_PASSBOLT_EXTENSIONS; do \
&& echo "extension=gnupg.so" > /etc/php5/conf.d/gnupg.ini \ mkdir $PHP_EXT_DIR/$i; \
&& echo "extension=redis.so" > /etc/php5/conf.d/redis.ini \ curl -sSL $PECL_BASE_URL/$i | tar zxf - -C $PHP_EXT_DIR/$i --strip-components 1; \
&& apk del $PHP_GNUPG_DEPS \ done \
&& curl -sS https://getcomposer.org/installer | php \ && docker-php-ext-install -j4 $PHP_EXTENSIONS $PECL_PASSBOLT_EXTENSIONS \
&& docker-php-ext-enable $PHP_EXTENSIONS $PECL_PASSBOLT_EXTENSIONS \
&& docker-php-source delete \
&& EXPECTED_SIGNATURE=$(curl -s https://composer.github.io/installer.sig) \
&& php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');" \
&& ACTUAL_SIGNATURE=$(php -r "echo hash_file('SHA384', 'composer-setup.php');") \
&& if [ "$EXPECTED_SIGNATURE" != "$ACTUAL_SIGNATURE" ]; then \
>&2 echo 'ERROR: Invalid installer signature'; \
rm composer-setup.php; \
exit 1; \
fi \
&& php composer-setup.php \
&& mv composer.phar /usr/local/bin/composer \ && mv composer.phar /usr/local/bin/composer \
&& mkdir /var/www/passbolt \ && curl -sSL $PASSBOLT_URL | tar zxf - -C . --strip-components 1 \
&& curl -sSL $PASSBOLT_URL | tar zxf - -C /var/www/passbolt --strip-components 1 \ && composer install -n --no-dev --optimize-autoloader \
&& chown -R nginx:nginx /var/www/passbolt \ && chown -R www-data:www-data . \
&& chmod -R +w /var/www/passbolt/app/tmp \ && chmod 775 $(find /var/www/passbolt/app/tmp -type d) \
&& chmod +w /var/www/passbolt/app/webroot/img/public && chmod 664 $(find /var/www/passbolt/app/tmp -type f) \
&& chmod 775 $(find /var/www/passbolt/app/webroot/img/public -type d) \
&& chmod 664 $(find /var/www/passbolt/app/webroot/img/public -type f) \
&& rm /etc/nginx/sites-enabled/default \
&& apt-get purge -y --auto-remove $PASSBOLT_DEV_PACKAGES \
&& rm -rf /var/lib/apt/lists/*
COPY conf/passbolt.conf /etc/nginx/conf.d/default.conf COPY conf/passbolt.conf /etc/nginx/conf.d/default.conf
COPY bin/docker-entrypoint.sh /docker-entrypoint.sh COPY bin/docker-entrypoint.sh /docker-entrypoint.sh