Merge branch 'master' into php-fpm-install-imap
This commit is contained in:
		
							
								
								
									
										16
									
								
								.travis.yml
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								.travis.yml
									
									
									
									
									
								
							@@ -10,29 +10,21 @@ env:
 | 
			
		||||
    - PHP_VERSION=56 BUILD_SERVICE=workspace
 | 
			
		||||
    - PHP_VERSION=70 BUILD_SERVICE=workspace
 | 
			
		||||
    - PHP_VERSION=71 BUILD_SERVICE=workspace
 | 
			
		||||
    - PHP_VERSION=72 BUILD_SERVICE=workspace
 | 
			
		||||
 | 
			
		||||
    - PHP_VERSION=56 BUILD_SERVICE=php-fpm
 | 
			
		||||
    - PHP_VERSION=70 BUILD_SERVICE=php-fpm
 | 
			
		||||
    - PHP_VERSION=71 BUILD_SERVICE=php-fpm
 | 
			
		||||
    - PHP_VERSION=72 BUILD_SERVICE=php-fpm
 | 
			
		||||
 | 
			
		||||
    - PHP_VERSION=hhvm BUILD_SERVICE=hhvm
 | 
			
		||||
 | 
			
		||||
    # - PHP_VERSION=56 BUILD_SERVICE=php-worker
 | 
			
		||||
    - PHP_VERSION=70 BUILD_SERVICE=php-worker
 | 
			
		||||
    - PHP_VERSION=71 BUILD_SERVICE=php-worker
 | 
			
		||||
    - PHP_VERSION=72 BUILD_SERVICE=php-worker
 | 
			
		||||
 | 
			
		||||
    - PHP_VERSION=56 BUILD_SERVICE=mssql
 | 
			
		||||
    - PHP_VERSION=70 BUILD_SERVICE=mssql
 | 
			
		||||
    - PHP_VERSION=71 BUILD_SERVICE=mssql
 | 
			
		||||
 | 
			
		||||
    - PHP_VERSION=56 BUILD_SERVICE=rethinkdb
 | 
			
		||||
    - PHP_VERSION=70 BUILD_SERVICE=rethinkdb
 | 
			
		||||
    - PHP_VERSION=71 BUILD_SERVICE=rethinkdb
 | 
			
		||||
 | 
			
		||||
    - PHP_VERSION=56 BUILD_SERVICE=aerospike
 | 
			
		||||
    - PHP_VERSION=70 BUILD_SERVICE=aerospike
 | 
			
		||||
    - PHP_VERSION=71 BUILD_SERVICE=aerospike
 | 
			
		||||
 | 
			
		||||
    - PHP_VERSION=NA BUILD_SERVICE="mssql rethinkdb aerospike"
 | 
			
		||||
    - PHP_VERSION=NA BUILD_SERVICE="applications blackfire minio percona nginx caddy apache2 mysql mariadb postgres postgres-postgis neo4j mongo redis"
 | 
			
		||||
    - PHP_VERSION=NA BUILD_SERVICE="adminer phpmyadmin pgadmin"
 | 
			
		||||
    - PHP_VERSION=NA BUILD_SERVICE="memcached beanstalkd beanstalkd-console rabbitmq elasticsearch certbot mailhog maildev selenium jenkins proxy proxy2 haproxy"
 | 
			
		||||
 
 | 
			
		||||
@@ -1729,3 +1729,13 @@ This error sometimes happens because your Laravel application isn't running on t
 | 
			
		||||
## I get stuck when building nginx on `fetch http://mirrors.aliyun.com/alpine/v3.5/main/x86_64/APKINDEX.tar.gz`
 | 
			
		||||
 | 
			
		||||
As stated on [#749](https://github.com/laradock/laradock/issues/749#issuecomment-293296687), removing the line `RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/' /etc/apk/repositories` from `nginx/Dockerfile` solves the problem.		
 | 
			
		||||
 | 
			
		||||
## Custom composer repo packagist url and npm registry url
 | 
			
		||||
 | 
			
		||||
In China, the origin source of composer and npm is very slow. You can add `WORKSPACE_NPM_REGISTRY` and `WORKSPACE_COMPOSER_REPO_PACKAGIST` config in `.env` to use your custom source.
 | 
			
		||||
 | 
			
		||||
Example:
 | 
			
		||||
```bash
 | 
			
		||||
WORKSPACE_NPM_REGISTRY=https://registry.npm.taobao.org
 | 
			
		||||
WORKSPACE_COMPOSER_REPO_PACKAGIST=https://packagist.phpcomposer.com
 | 
			
		||||
```
 | 
			
		||||
@@ -23,12 +23,14 @@ services:
 | 
			
		||||
          - INSTALL_PHPREDIS=${WORKSPACE_INSTALL_PHPREDIS}
 | 
			
		||||
          - INSTALL_MSSQL=${WORKSPACE_INSTALL_MSSQL}
 | 
			
		||||
          - INSTALL_NODE=${WORKSPACE_INSTALL_NODE}
 | 
			
		||||
          - NPM_REGISTRY=${WORKSPACE_NPM_REGISTRY}
 | 
			
		||||
          - INSTALL_YARN=${WORKSPACE_INSTALL_YARN}
 | 
			
		||||
          - INSTALL_DRUSH=${WORKSPACE_INSTALL_DRUSH}
 | 
			
		||||
          - INSTALL_DRUPAL_CONSOLE=${WORKSPACE_INSTALL_DRUPAL_CONSOLE}
 | 
			
		||||
          - INSTALL_AEROSPIKE=${WORKSPACE_INSTALL_AEROSPIKE}
 | 
			
		||||
          - INSTALL_V8JS=${WORKSPACE_INSTALL_V8JS}
 | 
			
		||||
          - COMPOSER_GLOBAL_INSTALL=${WORKSPACE_COMPOSER_GLOBAL_INSTALL}
 | 
			
		||||
          - COMPOSER_REPO_PACKAGIST=${WORKSPACE_COMPOSER_REPO_PACKAGIST}
 | 
			
		||||
          - INSTALL_WORKSPACE_SSH=${WORKSPACE_INSTALL_WORKSPACE_SSH}
 | 
			
		||||
          - INSTALL_LARAVEL_ENVOY=${WORKSPACE_INSTALL_LARAVEL_ENVOY}
 | 
			
		||||
          - INSTALL_LARAVEL_INSTALLER=${WORKSPACE_INSTALL_LARAVEL_INSTALLER}
 | 
			
		||||
 
 | 
			
		||||
@@ -8,9 +8,9 @@
 | 
			
		||||
APPLICATION=../
 | 
			
		||||
 | 
			
		||||
### PHP Version ########################################################################################################
 | 
			
		||||
# Select a PHP version of the Workspace and PHP-FPM containers (Does not apply to HHVM). Accepted values: 71 - 70 - 56
 | 
			
		||||
# Select a PHP version of the Workspace and PHP-FPM containers (Does not apply to HHVM). Accepted values: 72 - 71 - 70 - 56
 | 
			
		||||
 | 
			
		||||
PHP_VERSION=71
 | 
			
		||||
PHP_VERSION=72
 | 
			
		||||
 | 
			
		||||
### PHP Interpreter ####################################################################################################
 | 
			
		||||
# Select the PHP Interpreter. Accepted values: hhvm - php-fpm
 | 
			
		||||
@@ -67,12 +67,14 @@ WORKSPACE_INSTALL_AMQP=false
 | 
			
		||||
WORKSPACE_INSTALL_PHPREDIS=false
 | 
			
		||||
WORKSPACE_INSTALL_MSSQL=false
 | 
			
		||||
WORKSPACE_INSTALL_NODE=false
 | 
			
		||||
WORKSPACE_NPM_REGISTRY=
 | 
			
		||||
WORKSPACE_INSTALL_YARN=false
 | 
			
		||||
WORKSPACE_INSTALL_DRUSH=false
 | 
			
		||||
WORKSPACE_INSTALL_DRUPAL_CONSOLE=false
 | 
			
		||||
WORKSPACE_INSTALL_AEROSPIKE=false
 | 
			
		||||
WORKSPACE_INSTALL_V8JS=false
 | 
			
		||||
WORKSPACE_COMPOSER_GLOBAL_INSTALL=false
 | 
			
		||||
WORKSPACE_COMPOSER_REPO_PACKAGIST=
 | 
			
		||||
WORKSPACE_INSTALL_WORKSPACE_SSH=false
 | 
			
		||||
WORKSPACE_INSTALL_LARAVEL_ENVOY=false
 | 
			
		||||
WORKSPACE_INSTALL_LARAVEL_INSTALLER=false
 | 
			
		||||
 
 | 
			
		||||
@@ -18,6 +18,8 @@ server {
 | 
			
		||||
        fastcgi_buffers 16 16k;
 | 
			
		||||
        fastcgi_buffer_size 32k;
 | 
			
		||||
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
 | 
			
		||||
        #fixes timeouts
 | 
			
		||||
        fastcgi_read_timeout 600;
 | 
			
		||||
        include fastcgi_params;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -18,6 +18,8 @@ server {
 | 
			
		||||
        fastcgi_buffers 16 16k;
 | 
			
		||||
        fastcgi_buffer_size 32k;
 | 
			
		||||
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
 | 
			
		||||
        #fixes timeouts
 | 
			
		||||
        fastcgi_read_timeout 600;
 | 
			
		||||
        include fastcgi_params;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -18,6 +18,8 @@ server {
 | 
			
		||||
        fastcgi_buffers 16 16k;
 | 
			
		||||
        fastcgi_buffer_size 32k;
 | 
			
		||||
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
 | 
			
		||||
        #fixes timeouts
 | 
			
		||||
        fastcgi_read_timeout 600;
 | 
			
		||||
        include fastcgi_params;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -20,6 +20,8 @@ server {
 | 
			
		||||
        fastcgi_split_path_info ^(.+\.php)(/.*)$;
 | 
			
		||||
        include fastcgi_params;
 | 
			
		||||
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
 | 
			
		||||
        #fixes timeouts
 | 
			
		||||
        fastcgi_read_timeout 600;
 | 
			
		||||
        fastcgi_param HTTPS off;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -177,7 +177,8 @@ ARG INSTALL_GMP=false
 | 
			
		||||
RUN if [ ${INSTALL_GMP} = true ]; then \
 | 
			
		||||
    # Install the GMP extension
 | 
			
		||||
	apt-get update -yqq && \
 | 
			
		||||
	apt-get install -y libgmp-dev && \ 
 | 
			
		||||
	apt-get install -y libgmp-dev && \
 | 
			
		||||
	ln -s /usr/include/x86_64-linux-gnu/gmp.h /usr/include/gmp.h && \
 | 
			
		||||
    docker-php-ext-install gmp \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
@@ -324,7 +325,7 @@ ARG INSTALL_IMAGEMAGICK=false
 | 
			
		||||
ENV INSTALL_IMAGEMAGICK ${INSTALL_IMAGEMAGICK}
 | 
			
		||||
RUN if [ ${INSTALL_IMAGEMAGICK} = true ]; then \
 | 
			
		||||
    apt-get update -y && \
 | 
			
		||||
    apt-get install -y libmagickwand-dev imagemagick && \ 
 | 
			
		||||
    apt-get install -y libmagickwand-dev imagemagick && \
 | 
			
		||||
    pecl install imagick && \
 | 
			
		||||
    docker-php-ext-enable imagick \
 | 
			
		||||
;fi
 | 
			
		||||
@@ -342,6 +343,12 @@ RUN if [ ${INSTALL_IMAP} = true ]; then \
 | 
			
		||||
    docker-php-ext-install imap \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Check PHP version:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
RUN php -v | head -n 1 | grep -q "PHP 5.6."
 | 
			
		||||
 | 
			
		||||
#
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
# Final Touch
 | 
			
		||||
 
 | 
			
		||||
@@ -318,12 +318,10 @@ RUN if [ ${INSTALL_MSSQL} = true ]; then \
 | 
			
		||||
        && curl https://packages.microsoft.com/keys/microsoft.asc | apt-key add - \
 | 
			
		||||
        && curl https://packages.microsoft.com/config/debian/8/prod.list > /etc/apt/sources.list.d/mssql-release.list \
 | 
			
		||||
        && apt-get update -yqq \
 | 
			
		||||
 | 
			
		||||
    # Install Dependencies
 | 
			
		||||
        && ACCEPT_EULA=Y apt-get install -y unixodbc unixodbc-dev libgss3 odbcinst msodbcsql locales \
 | 
			
		||||
        && echo "en_US.UTF-8 UTF-8" > /etc/locale.gen \
 | 
			
		||||
        && locale-gen \
 | 
			
		||||
 | 
			
		||||
    # Install pdo_sqlsrv and sqlsrv from PECL. Replace pdo_sqlsrv-4.1.8preview with preferred version.
 | 
			
		||||
        && pecl install pdo_sqlsrv-4.1.8preview sqlsrv-4.1.8preview \
 | 
			
		||||
        && docker-php-ext-enable pdo_sqlsrv sqlsrv \
 | 
			
		||||
@@ -366,6 +364,12 @@ RUN if [ ${INSTALL_IMAP} = true ]; then \
 | 
			
		||||
    docker-php-ext-install imap \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Check PHP version:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
RUN php -v | head -n 1 | grep -q "PHP 7.0."
 | 
			
		||||
 | 
			
		||||
#
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
# Final Touch
 | 
			
		||||
 
 | 
			
		||||
@@ -224,7 +224,6 @@ RUN if [ ${INSTALL_AEROSPIKE} = true ]; then \
 | 
			
		||||
    # Fix dependencies for PHPUnit within aerospike extension
 | 
			
		||||
    apt-get update -yqq && \
 | 
			
		||||
    apt-get -y install sudo wget && \
 | 
			
		||||
 | 
			
		||||
    # Install the php aerospike extension
 | 
			
		||||
    curl -L -o /tmp/aerospike-client-php.tar.gz "https://github.com/aerospike/aerospike-client-php/archive/master.tar.gz" \
 | 
			
		||||
    && mkdir -p aerospike-client-php \
 | 
			
		||||
@@ -326,11 +325,9 @@ RUN if [ ${INSTALL_MSSQL} = true ]; then \
 | 
			
		||||
        && curl https://packages.microsoft.com/keys/microsoft.asc | apt-key add - \
 | 
			
		||||
        && curl https://packages.microsoft.com/config/debian/8/prod.list > /etc/apt/sources.list.d/mssql-release.list \
 | 
			
		||||
        && apt-get update -yqq \
 | 
			
		||||
 | 
			
		||||
    # Install Dependencies
 | 
			
		||||
        && ACCEPT_EULA=Y apt-get install -y unixodbc unixodbc-dev libgss3 odbcinst msodbcsql locales \
 | 
			
		||||
        && echo "en_US.UTF-8 UTF-8" > /etc/locale.gen && locale-gen \
 | 
			
		||||
 | 
			
		||||
    # Install pdo_sqlsrv and sqlsrv from PECL. Replace pdo_sqlsrv-4.1.8preview with preferred version.
 | 
			
		||||
        && pecl install pdo_sqlsrv-4.1.8preview sqlsrv-4.1.8preview \
 | 
			
		||||
        && docker-php-ext-enable pdo_sqlsrv sqlsrv \
 | 
			
		||||
@@ -373,6 +370,12 @@ RUN if [ ${INSTALL_IMAP} = true ]; then \
 | 
			
		||||
    docker-php-ext-install imap \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Check PHP version:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
RUN php -v | head -n 1 | grep -q "PHP 7.1."
 | 
			
		||||
 | 
			
		||||
#
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
# Final Touch
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										389
									
								
								php-fpm/Dockerfile-72
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										389
									
								
								php-fpm/Dockerfile-72
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,389 @@
 | 
			
		||||
#
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
# Image Setup
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
#
 | 
			
		||||
# To edit the 'php-fpm' base Image, visit its repository on Github
 | 
			
		||||
#    https://github.com/Laradock/php-fpm
 | 
			
		||||
#
 | 
			
		||||
# To change its version, see the available Tags on the Docker Hub:
 | 
			
		||||
#    https://hub.docker.com/r/laradock/php-fpm/tags/
 | 
			
		||||
#
 | 
			
		||||
# Note: Base Image name format {image-tag}-{php-version}
 | 
			
		||||
#
 | 
			
		||||
 | 
			
		||||
FROM laradock/php-fpm:2.0-72
 | 
			
		||||
 | 
			
		||||
MAINTAINER Mahmoud Zalt <mahmoud@zalt.me>
 | 
			
		||||
 | 
			
		||||
#
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
# Mandatory Software's Installation
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
#
 | 
			
		||||
# Mandatory Software's such as ("mcrypt", "pdo_mysql", "libssl-dev", ....)
 | 
			
		||||
# are installed on the base image 'laradock/php-fpm' image. If you want
 | 
			
		||||
# to add more Software's or remove existing one, you need to edit the
 | 
			
		||||
# base image (https://github.com/Laradock/php-fpm).
 | 
			
		||||
#
 | 
			
		||||
 | 
			
		||||
#
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
# Optional Software's Installation
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
#
 | 
			
		||||
# Optional Software's will only be installed if you set them to `true`
 | 
			
		||||
# in the `docker-compose.yml` before the build.
 | 
			
		||||
# Example:
 | 
			
		||||
#   - INSTALL_ZIP_ARCHIVE=true
 | 
			
		||||
#
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# SOAP:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_SOAP=false
 | 
			
		||||
RUN if [ ${INSTALL_SOAP} = true ]; then \
 | 
			
		||||
    # Install the soap extension
 | 
			
		||||
    apt-get update -yqq && \
 | 
			
		||||
    apt-get -y install libxml2-dev php-soap && \
 | 
			
		||||
    docker-php-ext-install soap \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# pgsql
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_PGSQL=false
 | 
			
		||||
RUN if [ ${INSTALL_PGSQL} = true ]; then \
 | 
			
		||||
    # Install the pgsql extension
 | 
			
		||||
    apt-get update -yqq && \
 | 
			
		||||
    docker-php-ext-install pgsql \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# pgsql client
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_PG_CLIENT=false
 | 
			
		||||
RUN if [ ${INSTALL_PG_CLIENT} = true ]; then \
 | 
			
		||||
    # Create folders if not exists (https://github.com/tianon/docker-brew-debian/issues/65)
 | 
			
		||||
    mkdir -p /usr/share/man/man1 && \
 | 
			
		||||
    mkdir -p /usr/share/man/man7 && \
 | 
			
		||||
    # Install the pgsql client
 | 
			
		||||
    apt-get update -yqq && \
 | 
			
		||||
    apt-get install -y postgresql-client \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# xDebug:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_XDEBUG=false
 | 
			
		||||
RUN if [ ${INSTALL_XDEBUG} = true ]; then \
 | 
			
		||||
    # Install the xdebug extension
 | 
			
		||||
    pecl install xdebug && \
 | 
			
		||||
    docker-php-ext-enable xdebug \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
# Copy xdebug configuration for remote debugging
 | 
			
		||||
COPY ./xdebug.ini /usr/local/etc/php/conf.d/xdebug.ini
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Blackfire:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_BLACKFIRE=false
 | 
			
		||||
RUN if [ ${INSTALL_XDEBUG} = false -a ${INSTALL_BLACKFIRE} = true ]; then \
 | 
			
		||||
    version=$(php -r "echo PHP_MAJOR_VERSION.PHP_MINOR_VERSION;") \
 | 
			
		||||
    && curl -A "Docker" -o /tmp/blackfire-probe.tar.gz -D - -L -s https://blackfire.io/api/v1/releases/probe/php/linux/amd64/$version \
 | 
			
		||||
    && tar zxpf /tmp/blackfire-probe.tar.gz -C /tmp \
 | 
			
		||||
    && mv /tmp/blackfire-*.so $(php -r "echo ini_get('extension_dir');")/blackfire.so \
 | 
			
		||||
    && printf "extension=blackfire.so\nblackfire.agent_socket=tcp://blackfire:8707\n" > $PHP_INI_DIR/conf.d/blackfire.ini \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# PHP REDIS EXTENSION FOR PHP 7.0
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_PHPREDIS=false
 | 
			
		||||
RUN if [ ${INSTALL_PHPREDIS} = true ]; then \
 | 
			
		||||
    # Install Php Redis Extension
 | 
			
		||||
    printf "\n" | pecl install -o -f redis \
 | 
			
		||||
    &&  rm -rf /tmp/pear \
 | 
			
		||||
    &&  docker-php-ext-enable redis \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Swoole EXTENSION FOR PHP 7
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_SWOOLE=false
 | 
			
		||||
RUN if [ ${INSTALL_SWOOLE} = true ]; then \
 | 
			
		||||
    # Install Php Swoole Extension
 | 
			
		||||
    pecl install swoole \
 | 
			
		||||
    &&  docker-php-ext-enable swoole \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# MongoDB:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_MONGO=false
 | 
			
		||||
RUN if [ ${INSTALL_MONGO} = true ]; then \
 | 
			
		||||
    # Install the mongodb extension
 | 
			
		||||
    pecl install mongodb && \
 | 
			
		||||
    docker-php-ext-enable mongodb \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# AMQP:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_AMQP=false
 | 
			
		||||
RUN if [ ${INSTALL_AMQP} = true ]; then \
 | 
			
		||||
    apt-get update && \
 | 
			
		||||
    apt-get install librabbitmq-dev -y && \
 | 
			
		||||
    # Install the amqp extension
 | 
			
		||||
    pecl install amqp && \
 | 
			
		||||
    docker-php-ext-enable amqp \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# ZipArchive:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_ZIP_ARCHIVE=false
 | 
			
		||||
RUN if [ ${INSTALL_ZIP_ARCHIVE} = true ]; then \
 | 
			
		||||
    # Install the zip extension
 | 
			
		||||
    docker-php-ext-install zip \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# bcmath:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_BCMATH=false
 | 
			
		||||
RUN if [ ${INSTALL_BCMATH} = true ]; then \
 | 
			
		||||
    # Install the bcmath extension
 | 
			
		||||
    docker-php-ext-install bcmath \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# GMP (GNU Multiple Precision):
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_GMP=false
 | 
			
		||||
RUN if [ ${INSTALL_GMP} = true ]; then \
 | 
			
		||||
    # Install the GMP extension
 | 
			
		||||
	apt-get update -yqq && \
 | 
			
		||||
	apt-get install -y libgmp-dev && \
 | 
			
		||||
    docker-php-ext-install gmp \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# PHP Memcached:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_MEMCACHED=false
 | 
			
		||||
RUN if [ ${INSTALL_MEMCACHED} = true ]; then \
 | 
			
		||||
    # Install the php memcached extension
 | 
			
		||||
    curl -L -o /tmp/memcached.tar.gz "https://github.com/php-memcached-dev/php-memcached/archive/php7.tar.gz" \
 | 
			
		||||
    && mkdir -p memcached \
 | 
			
		||||
    && tar -C memcached -zxvf /tmp/memcached.tar.gz --strip 1 \
 | 
			
		||||
    && ( \
 | 
			
		||||
        cd memcached \
 | 
			
		||||
        && phpize \
 | 
			
		||||
        && ./configure \
 | 
			
		||||
        && make -j$(nproc) \
 | 
			
		||||
        && make install \
 | 
			
		||||
    ) \
 | 
			
		||||
    && rm -r memcached \
 | 
			
		||||
    && rm /tmp/memcached.tar.gz \
 | 
			
		||||
    && docker-php-ext-enable memcached \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Exif:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_EXIF=false
 | 
			
		||||
RUN if [ ${INSTALL_EXIF} = true ]; then \
 | 
			
		||||
    # Enable Exif PHP extentions requirements
 | 
			
		||||
    docker-php-ext-install exif \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# PHP Aerospike:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_AEROSPIKE=false
 | 
			
		||||
ENV INSTALL_AEROSPIKE ${INSTALL_AEROSPIKE}
 | 
			
		||||
 | 
			
		||||
# Copy aerospike configration for remote debugging
 | 
			
		||||
COPY ./aerospike.ini /usr/local/etc/php/conf.d/aerospike.ini
 | 
			
		||||
 | 
			
		||||
RUN if [ ${INSTALL_AEROSPIKE} = true ]; then \
 | 
			
		||||
    # Fix dependencies for PHPUnit within aerospike extension
 | 
			
		||||
    apt-get update -yqq && \
 | 
			
		||||
    apt-get -y install sudo wget && \
 | 
			
		||||
 | 
			
		||||
    # Install the php aerospike extension (using 7.2.0-in-progress branch until support for 7.2 on master)
 | 
			
		||||
    curl -L -o /tmp/aerospike-client-php.tar.gz "https://github.com/aerospike/aerospike-client-php/archive/7.2.0-in-progress.tar.gz" \
 | 
			
		||||
    && mkdir -p aerospike-client-php \
 | 
			
		||||
    && tar -C aerospike-client-php -zxvf /tmp/aerospike-client-php.tar.gz --strip 1 \
 | 
			
		||||
    && ( \
 | 
			
		||||
        cd aerospike-client-php/src \
 | 
			
		||||
        && phpize \
 | 
			
		||||
        && ./build.sh \
 | 
			
		||||
        && make install \
 | 
			
		||||
    ) \
 | 
			
		||||
    && rm /tmp/aerospike-client-php.tar.gz \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
RUN if [ ${INSTALL_AEROSPIKE} = false ]; then \
 | 
			
		||||
    rm /usr/local/etc/php/conf.d/aerospike.ini \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Opcache:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_OPCACHE=false
 | 
			
		||||
RUN if [ ${INSTALL_OPCACHE} = true ]; then \
 | 
			
		||||
    docker-php-ext-install opcache \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
# Copy opcache configration
 | 
			
		||||
COPY ./opcache.ini /usr/local/etc/php/conf.d/opcache.ini
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Mysqli Modifications:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_MYSQLI=false
 | 
			
		||||
RUN if [ ${INSTALL_MYSQLI} = true ]; then \
 | 
			
		||||
    docker-php-ext-install mysqli \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Tokenizer Modifications:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_TOKENIZER=false
 | 
			
		||||
RUN if [ ${INSTALL_TOKENIZER} = true ]; then \
 | 
			
		||||
    docker-php-ext-install tokenizer \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Human Language and Character Encoding Support:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_INTL=false
 | 
			
		||||
RUN if [ ${INSTALL_INTL} = true ]; then \
 | 
			
		||||
    # Install intl and requirements
 | 
			
		||||
    apt-get update -yqq && \
 | 
			
		||||
    apt-get install -y zlib1g-dev libicu-dev g++ && \
 | 
			
		||||
    docker-php-ext-configure intl && \
 | 
			
		||||
    docker-php-ext-install intl \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# GHOSTSCRIPT:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_GHOSTSCRIPT=false
 | 
			
		||||
RUN if [ ${INSTALL_GHOSTSCRIPT} = true ]; then \
 | 
			
		||||
    # Install the ghostscript extension
 | 
			
		||||
    # for PDF editing
 | 
			
		||||
    apt-get update -yqq \
 | 
			
		||||
    && apt-get install -y \
 | 
			
		||||
    poppler-utils \
 | 
			
		||||
    ghostscript \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# LDAP:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_LDAP=false
 | 
			
		||||
RUN if [ ${INSTALL_LDAP} = true ]; then \
 | 
			
		||||
    apt-get update -yqq && \
 | 
			
		||||
    apt-get install -y libldap2-dev && \
 | 
			
		||||
    docker-php-ext-configure ldap --with-libdir=lib/x86_64-linux-gnu/ && \
 | 
			
		||||
    docker-php-ext-install ldap \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# SQL SERVER:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_MSSQL=false
 | 
			
		||||
ENV INSTALL_MSSQL ${INSTALL_MSSQL}
 | 
			
		||||
RUN if [ ${INSTALL_MSSQL} = true ]; then \
 | 
			
		||||
    #####################################
 | 
			
		||||
    # Ref from https://github.com/Microsoft/msphpsql/wiki/Dockerfile-for-adding-pdo_sqlsrv-and-sqlsrv-to-official-php-image
 | 
			
		||||
    #####################################
 | 
			
		||||
    # Add Microsoft repo for Microsoft ODBC Driver 13 for Linux
 | 
			
		||||
    apt-get update -yqq && apt-get install -y apt-transport-https gnupg \
 | 
			
		||||
        && curl https://packages.microsoft.com/keys/microsoft.asc | apt-key add - \
 | 
			
		||||
        && curl https://packages.microsoft.com/config/debian/8/prod.list > /etc/apt/sources.list.d/mssql-release.list \
 | 
			
		||||
        && apt-get update -yqq \
 | 
			
		||||
 | 
			
		||||
    # Install Dependencies
 | 
			
		||||
        && ACCEPT_EULA=Y apt-get install -y unixodbc unixodbc-dev libgss3 odbcinst msodbcsql locales \
 | 
			
		||||
        && echo "en_US.UTF-8 UTF-8" > /etc/locale.gen && locale-gen \
 | 
			
		||||
 | 
			
		||||
    # Install pdo_sqlsrv and sqlsrv from PECL. Replace pdo_sqlsrv-4.1.8preview with preferred version.
 | 
			
		||||
        && pecl install pdo_sqlsrv-4.1.8preview sqlsrv-4.1.8preview \
 | 
			
		||||
        && docker-php-ext-enable pdo_sqlsrv sqlsrv \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Image optimizers:
 | 
			
		||||
#####################################
 | 
			
		||||
USER root
 | 
			
		||||
ARG INSTALL_IMAGE_OPTIMIZERS=false
 | 
			
		||||
ENV INSTALL_IMAGE_OPTIMIZERS ${INSTALL_IMAGE_OPTIMIZERS}
 | 
			
		||||
RUN if [ ${INSTALL_IMAGE_OPTIMIZERS} = true ]; then \
 | 
			
		||||
    apt-get update -yqq && \
 | 
			
		||||
    apt-get install -y --force-yes jpegoptim optipng pngquant gifsicle \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# ImageMagick:
 | 
			
		||||
#####################################
 | 
			
		||||
USER root
 | 
			
		||||
ARG INSTALL_IMAGEMAGICK=false
 | 
			
		||||
ENV INSTALL_IMAGEMAGICK ${INSTALL_IMAGEMAGICK}
 | 
			
		||||
RUN if [ ${INSTALL_IMAGEMAGICK} = true ]; then \
 | 
			
		||||
    apt-get update -y && \
 | 
			
		||||
    apt-get install -y libmagickwand-dev imagemagick && \
 | 
			
		||||
    pecl install imagick && \
 | 
			
		||||
    docker-php-ext-enable imagick \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Check PHP version:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
RUN php -v | head -n 1 | grep -q "PHP 7.2."
 | 
			
		||||
 | 
			
		||||
#
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
# Final Touch
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
#
 | 
			
		||||
 | 
			
		||||
ADD ./laravel.ini /usr/local/etc/php/conf.d
 | 
			
		||||
ADD ./xlaravel.pool.conf /usr/local/etc/php-fpm.d/
 | 
			
		||||
 | 
			
		||||
#RUN rm -r /var/lib/apt/lists/*
 | 
			
		||||
 | 
			
		||||
RUN usermod -u 1000 www-data
 | 
			
		||||
 | 
			
		||||
WORKDIR /var/www
 | 
			
		||||
 | 
			
		||||
CMD ["php-fpm"]
 | 
			
		||||
 | 
			
		||||
EXPOSE 9000
 | 
			
		||||
@@ -4,10 +4,13 @@ log_errors=On
 | 
			
		||||
 | 
			
		||||
; Maximum amount of memory a script may consume (128MB)
 | 
			
		||||
; http://php.net/memory-limit
 | 
			
		||||
memory_limit = 128M
 | 
			
		||||
memory_limit = 256M
 | 
			
		||||
; Maximum allowed size for uploaded files.
 | 
			
		||||
; http://php.net/upload-max-filesize
 | 
			
		||||
upload_max_filesize = 20M
 | 
			
		||||
; Sets max size of post data allowed.
 | 
			
		||||
; http://php.net/post-max-size
 | 
			
		||||
post_max_size = 20M
 | 
			
		||||
max_execution_time=600
 | 
			
		||||
default_socket_timeout=3600
 | 
			
		||||
request_terminate_timeout=600
 | 
			
		||||
 
 | 
			
		||||
@@ -380,7 +380,7 @@ expose_php = On
 | 
			
		||||
; Maximum execution time of each script, in seconds
 | 
			
		||||
; http://php.net/max-execution-time
 | 
			
		||||
; Note: This directive is hardcoded to 0 for the CLI SAPI
 | 
			
		||||
max_execution_time = 30
 | 
			
		||||
max_execution_time = 600
 | 
			
		||||
 | 
			
		||||
; Maximum amount of time each script may spend parsing request data. It's a good
 | 
			
		||||
; idea to limit this time on productions servers in order to eliminate unexpectedly
 | 
			
		||||
@@ -390,7 +390,7 @@ max_execution_time = 30
 | 
			
		||||
; Development Value: 60 (60 seconds)
 | 
			
		||||
; Production Value: 60 (60 seconds)
 | 
			
		||||
; http://php.net/max-input-time
 | 
			
		||||
max_input_time = 60
 | 
			
		||||
max_input_time = 120
 | 
			
		||||
 | 
			
		||||
; Maximum input variable nesting level
 | 
			
		||||
; http://php.net/max-input-nesting-level
 | 
			
		||||
@@ -401,7 +401,7 @@ max_input_time = 60
 | 
			
		||||
 | 
			
		||||
; Maximum amount of memory a script may consume (128MB)
 | 
			
		||||
; http://php.net/memory-limit
 | 
			
		||||
memory_limit = 128M
 | 
			
		||||
memory_limit = 256M
 | 
			
		||||
 | 
			
		||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
 | 
			
		||||
; Error handling and logging ;
 | 
			
		||||
 
 | 
			
		||||
@@ -380,7 +380,7 @@ expose_php = On
 | 
			
		||||
; Maximum execution time of each script, in seconds
 | 
			
		||||
; http://php.net/max-execution-time
 | 
			
		||||
; Note: This directive is hardcoded to 0 for the CLI SAPI
 | 
			
		||||
max_execution_time = 30
 | 
			
		||||
max_execution_time = 600
 | 
			
		||||
 | 
			
		||||
; Maximum amount of time each script may spend parsing request data. It's a good
 | 
			
		||||
; idea to limit this time on productions servers in order to eliminate unexpectedly
 | 
			
		||||
@@ -390,7 +390,7 @@ max_execution_time = 30
 | 
			
		||||
; Development Value: 60 (60 seconds)
 | 
			
		||||
; Production Value: 60 (60 seconds)
 | 
			
		||||
; http://php.net/max-input-time
 | 
			
		||||
max_input_time = 60
 | 
			
		||||
max_input_time = 120
 | 
			
		||||
 | 
			
		||||
; Maximum input variable nesting level
 | 
			
		||||
; http://php.net/max-input-nesting-level
 | 
			
		||||
@@ -401,7 +401,7 @@ max_input_time = 60
 | 
			
		||||
 | 
			
		||||
; Maximum amount of memory a script may consume (128MB)
 | 
			
		||||
; http://php.net/memory-limit
 | 
			
		||||
memory_limit = 128M
 | 
			
		||||
memory_limit = 256M
 | 
			
		||||
 | 
			
		||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
 | 
			
		||||
; Error handling and logging ;
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										1918
									
								
								php-fpm/php72.ini
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1918
									
								
								php-fpm/php72.ini
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							@@ -56,6 +56,13 @@ ENTRYPOINT ["/usr/bin/supervisord", "-n", "-c",  "/etc/supervisord.conf"]
 | 
			
		||||
#
 | 
			
		||||
	# -- Your awesome modifications go here -- #
 | 
			
		||||
 | 
			
		||||
#
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
# Check PHP version
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
#
 | 
			
		||||
 | 
			
		||||
RUN php -v | head -n 1 | grep -q "PHP 7.0."
 | 
			
		||||
 | 
			
		||||
#
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
 
 | 
			
		||||
@@ -56,6 +56,13 @@ ENTRYPOINT ["/usr/bin/supervisord", "-n", "-c",  "/etc/supervisord.conf"]
 | 
			
		||||
#
 | 
			
		||||
    # -- Your awesome modifications go here -- #
 | 
			
		||||
 | 
			
		||||
#
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
# Check PHP version
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
#
 | 
			
		||||
 | 
			
		||||
RUN php -v | head -n 1 | grep -q "PHP 7.1."
 | 
			
		||||
 | 
			
		||||
#
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										73
									
								
								php-worker/Dockerfile-72
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										73
									
								
								php-worker/Dockerfile-72
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,73 @@
 | 
			
		||||
#
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
# Image Setup
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
#
 | 
			
		||||
 | 
			
		||||
FROM php:7.2-alpine
 | 
			
		||||
 | 
			
		||||
MAINTAINER Mahmoud Zalt <mahmoud@zalt.me>
 | 
			
		||||
 | 
			
		||||
RUN apk --update add wget \
 | 
			
		||||
  curl \
 | 
			
		||||
  git \
 | 
			
		||||
  build-base \
 | 
			
		||||
  libmemcached-dev \
 | 
			
		||||
  libmcrypt-dev \
 | 
			
		||||
  libxml2-dev \
 | 
			
		||||
  zlib-dev \
 | 
			
		||||
  autoconf \
 | 
			
		||||
  cyrus-sasl-dev \
 | 
			
		||||
  libgsasl-dev \
 | 
			
		||||
  supervisor
 | 
			
		||||
 | 
			
		||||
RUN docker-php-ext-install mysqli mbstring pdo pdo_mysql tokenizer xml
 | 
			
		||||
RUN pecl channel-update pecl.php.net && pecl install memcached mcrypt-1.0.1 && docker-php-ext-enable memcached
 | 
			
		||||
 | 
			
		||||
# Install PostgreSQL drivers:
 | 
			
		||||
ARG INSTALL_PGSQL=false
 | 
			
		||||
RUN if [ ${INSTALL_PGSQL} = true ]; then \
 | 
			
		||||
    apk --update add postgresql-dev \
 | 
			
		||||
        && docker-php-ext-install pdo_pgsql \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
RUN rm /var/cache/apk/* \
 | 
			
		||||
    && mkdir -p /var/www
 | 
			
		||||
 | 
			
		||||
#
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
# Optional Supervisord Configuration
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
#
 | 
			
		||||
# Modify the ./supervisor.conf file to match your App's requirements.
 | 
			
		||||
# Make sure you rebuild your container with every change.
 | 
			
		||||
#
 | 
			
		||||
 | 
			
		||||
COPY supervisord.conf /etc/supervisord.conf
 | 
			
		||||
 | 
			
		||||
ENTRYPOINT ["/usr/bin/supervisord", "-n", "-c",  "/etc/supervisord.conf"]
 | 
			
		||||
 | 
			
		||||
#
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
# Optional Software's Installation
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
#
 | 
			
		||||
# If you need to modify this image, feel free to do it right here.
 | 
			
		||||
#
 | 
			
		||||
    # -- Your awesome modifications go here -- #
 | 
			
		||||
 | 
			
		||||
#
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
# Check PHP version
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
#
 | 
			
		||||
 | 
			
		||||
RUN php -v | head -n 1 | grep -q "PHP 7.2."
 | 
			
		||||
 | 
			
		||||
#
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
# Final Touch
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
#
 | 
			
		||||
 | 
			
		||||
WORKDIR /etc/supervisor/conf.d/
 | 
			
		||||
@@ -127,6 +127,13 @@ RUN if [ ${COMPOSER_GLOBAL_INSTALL} = true ]; then \
 | 
			
		||||
    composer global install \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
ARG COMPOSER_REPO_PACKAGIST
 | 
			
		||||
ENV COMPOSER_REPO_PACKAGIST ${COMPOSER_REPO_PACKAGIST}
 | 
			
		||||
 | 
			
		||||
RUN if [ ${COMPOSER_REPO_PACKAGIST} ]; then \
 | 
			
		||||
    composer config -g repo.packagist composer ${COMPOSER_REPO_PACKAGIST} \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
# Export composer vendor path
 | 
			
		||||
RUN echo "" >> ~/.bashrc && \
 | 
			
		||||
echo 'export PATH="~/.composer/vendor/bin:$PATH"' >> ~/.bashrc
 | 
			
		||||
@@ -263,7 +270,7 @@ RUN if [ ${INSTALL_PHPREDIS} = true ]; then \
 | 
			
		||||
ARG INSTALL_SWOOLE=false
 | 
			
		||||
RUN if [ ${INSTALL_SWOOLE} = true ]; then \
 | 
			
		||||
    # Install Php Swoole Extension
 | 
			
		||||
    pecl -q install swoole-2.0.11 && \
 | 
			
		||||
    pecl -q install -f swoole-1.10.1 && \
 | 
			
		||||
    echo "extension=swoole.so" >> /etc/php/5.6/mods-available/swoole.ini && \
 | 
			
		||||
    ln -s /etc/php/5.6/mods-available/swoole.ini /etc/php/5.6/cli/conf.d/20-swoole.ini \
 | 
			
		||||
;fi
 | 
			
		||||
@@ -309,14 +316,19 @@ ARG NODE_VERSION=stable
 | 
			
		||||
ENV NODE_VERSION ${NODE_VERSION}
 | 
			
		||||
ARG INSTALL_NODE=false
 | 
			
		||||
ENV INSTALL_NODE ${INSTALL_NODE}
 | 
			
		||||
ARG NPM_REGISTRY
 | 
			
		||||
ENV NPM_REGISTRY ${NPM_REGISTRY}
 | 
			
		||||
ENV NVM_DIR /home/laradock/.nvm
 | 
			
		||||
RUN if [ ${INSTALL_NODE} = true ]; then \
 | 
			
		||||
    # Install nvm (A Node Version Manager)
 | 
			
		||||
    curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.33.1/install.sh | bash && \
 | 
			
		||||
    curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.33.8/install.sh | bash && \
 | 
			
		||||
        . $NVM_DIR/nvm.sh && \
 | 
			
		||||
        nvm install ${NODE_VERSION} && \
 | 
			
		||||
        nvm use ${NODE_VERSION} && \
 | 
			
		||||
        nvm alias ${NODE_VERSION} && \
 | 
			
		||||
        if [ ${NPM_REGISTRY} ]; then \
 | 
			
		||||
        npm config set registry ${NPM_REGISTRY} \
 | 
			
		||||
        ;fi && \
 | 
			
		||||
        npm install -g gulp bower vue-cli \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
@@ -340,6 +352,10 @@ RUN if [ ${INSTALL_NODE} = true ]; then \
 | 
			
		||||
# Add PATH for node
 | 
			
		||||
ENV PATH $PATH:$NVM_DIR/versions/node/v${NODE_VERSION}/bin
 | 
			
		||||
 | 
			
		||||
RUN if [ ${NPM_REGISTRY} ]; then \
 | 
			
		||||
    . ~/.bashrc && npm config set registry ${NPM_REGISTRY} \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# YARN:
 | 
			
		||||
#####################################
 | 
			
		||||
@@ -428,6 +444,13 @@ RUN if [ ${INSTALL_LARAVEL_ENVOY} = true ]; then \
 | 
			
		||||
#####################################
 | 
			
		||||
USER root
 | 
			
		||||
 | 
			
		||||
ARG COMPOSER_REPO_PACKAGIST
 | 
			
		||||
ENV COMPOSER_REPO_PACKAGIST ${COMPOSER_REPO_PACKAGIST}
 | 
			
		||||
 | 
			
		||||
RUN if [ ${COMPOSER_REPO_PACKAGIST} ]; then \
 | 
			
		||||
    composer config -g repo.packagist composer ${COMPOSER_REPO_PACKAGIST} \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_LARAVEL_INSTALLER=true
 | 
			
		||||
ENV INSTALL_LARAVEL_INSTALLER ${INSTALL_LARAVEL_INSTALLER}
 | 
			
		||||
 | 
			
		||||
@@ -626,6 +649,12 @@ RUN if [ ${INSTALL_DUSK_DEPS} = true ]; then \
 | 
			
		||||
  && rm chromedriver_linux64.zip \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Check PHP version:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
RUN php -v | head -n 1 | grep -q "PHP 5.6."
 | 
			
		||||
 | 
			
		||||
#
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
# Final Touch
 | 
			
		||||
 
 | 
			
		||||
@@ -124,6 +124,13 @@ RUN if [ ${COMPOSER_GLOBAL_INSTALL} = true ]; then \
 | 
			
		||||
    composer global install \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
ARG COMPOSER_REPO_PACKAGIST
 | 
			
		||||
ENV COMPOSER_REPO_PACKAGIST ${COMPOSER_REPO_PACKAGIST}
 | 
			
		||||
 | 
			
		||||
RUN if [ ${COMPOSER_REPO_PACKAGIST} ]; then \
 | 
			
		||||
    composer config -g repo.packagist composer ${COMPOSER_REPO_PACKAGIST} \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
# Export composer vendor path
 | 
			
		||||
RUN echo "" >> ~/.bashrc && \
 | 
			
		||||
echo 'export PATH="~/.composer/vendor/bin:$PATH"' >> ~/.bashrc
 | 
			
		||||
@@ -305,14 +312,19 @@ ARG NODE_VERSION=stable
 | 
			
		||||
ENV NODE_VERSION ${NODE_VERSION}
 | 
			
		||||
ARG INSTALL_NODE=false
 | 
			
		||||
ENV INSTALL_NODE ${INSTALL_NODE}
 | 
			
		||||
ARG NPM_REGISTRY
 | 
			
		||||
ENV NPM_REGISTRY ${NPM_REGISTRY}
 | 
			
		||||
ENV NVM_DIR /home/laradock/.nvm
 | 
			
		||||
RUN if [ ${INSTALL_NODE} = true ]; then \
 | 
			
		||||
    # Install nvm (A Node Version Manager)
 | 
			
		||||
    curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.33.1/install.sh | bash && \
 | 
			
		||||
    curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.33.8/install.sh | bash && \
 | 
			
		||||
        . $NVM_DIR/nvm.sh && \
 | 
			
		||||
        nvm install ${NODE_VERSION} && \
 | 
			
		||||
        nvm use ${NODE_VERSION} && \
 | 
			
		||||
        nvm alias ${NODE_VERSION} && \
 | 
			
		||||
        if [ ${NPM_REGISTRY} ]; then \
 | 
			
		||||
        npm config set registry ${NPM_REGISTRY} \
 | 
			
		||||
        ;fi && \
 | 
			
		||||
        npm install -g gulp bower vue-cli \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
@@ -336,6 +348,10 @@ RUN if [ ${INSTALL_NODE} = true ]; then \
 | 
			
		||||
# Add PATH for node
 | 
			
		||||
ENV PATH $PATH:$NVM_DIR/versions/node/v${NODE_VERSION}/bin
 | 
			
		||||
 | 
			
		||||
RUN if [ ${NPM_REGISTRY} ]; then \
 | 
			
		||||
    . ~/.bashrc && npm config set registry ${NPM_REGISTRY} \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# YARN:
 | 
			
		||||
#####################################
 | 
			
		||||
@@ -441,6 +457,13 @@ RUN if [ ${INSTALL_LARAVEL_ENVOY} = true ]; then \
 | 
			
		||||
#####################################
 | 
			
		||||
USER root
 | 
			
		||||
 | 
			
		||||
ARG COMPOSER_REPO_PACKAGIST
 | 
			
		||||
ENV COMPOSER_REPO_PACKAGIST ${COMPOSER_REPO_PACKAGIST}
 | 
			
		||||
 | 
			
		||||
RUN if [ ${COMPOSER_REPO_PACKAGIST} ]; then \
 | 
			
		||||
    composer config -g repo.packagist composer ${COMPOSER_REPO_PACKAGIST} \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_LARAVEL_INSTALLER=true
 | 
			
		||||
ENV INSTALL_LARAVEL_INSTALLER ${INSTALL_LARAVEL_INSTALLER}
 | 
			
		||||
 | 
			
		||||
@@ -703,6 +726,12 @@ RUN if [ ${INSTALL_DUSK_DEPS} = true ]; then \
 | 
			
		||||
  && rm chromedriver_linux64.zip \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Check PHP version:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
RUN php -v | head -n 1 | grep -q "PHP 7.0."
 | 
			
		||||
 | 
			
		||||
#
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
# Final Touch
 | 
			
		||||
 
 | 
			
		||||
@@ -123,6 +123,13 @@ RUN if [ ${COMPOSER_GLOBAL_INSTALL} = true ]; then \
 | 
			
		||||
    composer global install \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
ARG COMPOSER_REPO_PACKAGIST
 | 
			
		||||
ENV COMPOSER_REPO_PACKAGIST ${COMPOSER_REPO_PACKAGIST}
 | 
			
		||||
 | 
			
		||||
RUN if [ ${COMPOSER_REPO_PACKAGIST} ]; then \
 | 
			
		||||
    composer config -g repo.packagist composer ${COMPOSER_REPO_PACKAGIST} \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Crontab
 | 
			
		||||
#####################################
 | 
			
		||||
@@ -301,14 +308,19 @@ ARG NODE_VERSION=stable
 | 
			
		||||
ENV NODE_VERSION ${NODE_VERSION}
 | 
			
		||||
ARG INSTALL_NODE=false
 | 
			
		||||
ENV INSTALL_NODE ${INSTALL_NODE}
 | 
			
		||||
ARG NPM_REGISTRY
 | 
			
		||||
ENV NPM_REGISTRY ${NPM_REGISTRY}
 | 
			
		||||
ENV NVM_DIR /home/laradock/.nvm
 | 
			
		||||
RUN if [ ${INSTALL_NODE} = true ]; then \
 | 
			
		||||
    # Install nvm (A Node Version Manager)
 | 
			
		||||
    curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.33.1/install.sh | bash && \
 | 
			
		||||
    curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.33.8/install.sh | bash && \
 | 
			
		||||
        . $NVM_DIR/nvm.sh && \
 | 
			
		||||
        nvm install ${NODE_VERSION} && \
 | 
			
		||||
        nvm use ${NODE_VERSION} && \
 | 
			
		||||
        nvm alias ${NODE_VERSION} && \
 | 
			
		||||
        if [ ${NPM_REGISTRY} ]; then \
 | 
			
		||||
        npm config set registry ${NPM_REGISTRY} \
 | 
			
		||||
        ;fi && \
 | 
			
		||||
        npm install -g gulp bower vue-cli \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
@@ -332,6 +344,9 @@ RUN if [ ${INSTALL_NODE} = true ]; then \
 | 
			
		||||
# Add PATH for node
 | 
			
		||||
ENV PATH $PATH:$NVM_DIR/versions/node/v${NODE_VERSION}/bin
 | 
			
		||||
 | 
			
		||||
RUN if [ ${NPM_REGISTRY} ]; then \
 | 
			
		||||
    . ~/.bashrc && npm config set registry ${NPM_REGISTRY} \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# YARN:
 | 
			
		||||
@@ -409,7 +424,7 @@ RUN if [ ${INSTALL_V8JS} = true ]; then \
 | 
			
		||||
    # Install the php V8JS extension
 | 
			
		||||
    add-apt-repository -y ppa:pinepain/libv8-5.4 \
 | 
			
		||||
    && apt-get update -yqq \
 | 
			
		||||
    && apt-get install -y php-xml php-dev php-pear libv8-5.4 \
 | 
			
		||||
    && apt-get install -y php7.1-xml php7.1-dev php-pear libv8-5.4 \
 | 
			
		||||
    && pecl install v8js \
 | 
			
		||||
    && echo "extension=v8js.so" >> /etc/php/7.1/cli/php.ini \
 | 
			
		||||
;fi
 | 
			
		||||
@@ -427,6 +442,11 @@ RUN echo "" >> ~/.bashrc && \
 | 
			
		||||
#####################################
 | 
			
		||||
# Laravel Envoy:
 | 
			
		||||
#####################################
 | 
			
		||||
USER root
 | 
			
		||||
 | 
			
		||||
RUN apt-get update -yqq \
 | 
			
		||||
    && apt-get install -y php-curl
 | 
			
		||||
 | 
			
		||||
USER laradock
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_LARAVEL_ENVOY=false
 | 
			
		||||
@@ -442,6 +462,13 @@ RUN if [ ${INSTALL_LARAVEL_ENVOY} = true ]; then \
 | 
			
		||||
#####################################
 | 
			
		||||
USER root
 | 
			
		||||
 | 
			
		||||
ARG COMPOSER_REPO_PACKAGIST
 | 
			
		||||
ENV COMPOSER_REPO_PACKAGIST ${COMPOSER_REPO_PACKAGIST}
 | 
			
		||||
 | 
			
		||||
RUN if [ ${COMPOSER_REPO_PACKAGIST} ]; then \
 | 
			
		||||
    composer config -g repo.packagist composer ${COMPOSER_REPO_PACKAGIST} \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_LARAVEL_INSTALLER=false
 | 
			
		||||
ENV INSTALL_LARAVEL_INSTALLER ${INSTALL_LARAVEL_INSTALLER}
 | 
			
		||||
 | 
			
		||||
@@ -457,14 +484,18 @@ USER laradock
 | 
			
		||||
#####################################
 | 
			
		||||
# Deployer:
 | 
			
		||||
#####################################
 | 
			
		||||
USER laradock
 | 
			
		||||
USER root
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_DEPLOYER=false
 | 
			
		||||
ENV INSTALL_DEPLOYER ${INSTALL_DEPLOYER}
 | 
			
		||||
 | 
			
		||||
RUN if [ ${INSTALL_DEPLOYER} = true ]; then \
 | 
			
		||||
    # Install the Deployer
 | 
			
		||||
    composer global require "deployer/deployer" \
 | 
			
		||||
    # Using Phar as currently there is no support for laravel 4 from composer version
 | 
			
		||||
    # Waiting to be resolved on https://github.com/deployphp/deployer/issues/1552
 | 
			
		||||
    curl -LO https://deployer.org/deployer.phar && \
 | 
			
		||||
    mv deployer.phar /usr/local/bin/dep && \
 | 
			
		||||
    chmod +x /usr/local/bin/dep \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
@@ -704,6 +735,12 @@ RUN if [ ${INSTALL_DUSK_DEPS} = true ]; then \
 | 
			
		||||
  && rm chromedriver_linux64.zip \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Check PHP version:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
RUN php -v | head -n 1 | grep -q "PHP 7.1."
 | 
			
		||||
 | 
			
		||||
#
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
# Final Touch
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										729
									
								
								workspace/Dockerfile-72
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										729
									
								
								workspace/Dockerfile-72
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,729 @@
 | 
			
		||||
#
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
# Image Setup
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
#
 | 
			
		||||
# To edit the 'workspace' base Image, visit its repository on Github
 | 
			
		||||
#    https://github.com/Laradock/workspace
 | 
			
		||||
#
 | 
			
		||||
# To change its version, see the available Tags on the Docker Hub:
 | 
			
		||||
#    https://hub.docker.com/r/laradock/workspace/tags/
 | 
			
		||||
#
 | 
			
		||||
# Note: Base Image name format {image-tag}-{php-version}
 | 
			
		||||
#
 | 
			
		||||
 | 
			
		||||
FROM laradock/workspace:2.0-72
 | 
			
		||||
 | 
			
		||||
MAINTAINER Mahmoud Zalt <mahmoud@zalt.me>
 | 
			
		||||
 | 
			
		||||
# Remove Faillog and Lastlog to reduce the size of the final image.
 | 
			
		||||
RUN rm /var/log/lastlog /var/log/faillog
 | 
			
		||||
 | 
			
		||||
#
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
# Mandatory Software's Installation
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
#
 | 
			
		||||
# Mandatory Software's such as ("php7.2-cli", "git", "vim", ....) are
 | 
			
		||||
# installed on the base image 'laradock/workspace' image. If you want
 | 
			
		||||
# to add more Software's or remove existing one, you need to edit the
 | 
			
		||||
# base image (https://github.com/Laradock/workspace).
 | 
			
		||||
#
 | 
			
		||||
 | 
			
		||||
#
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
# Optional Software's Installation
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
#
 | 
			
		||||
# Optional Software's will only be installed if you set them to `true`
 | 
			
		||||
# in the `docker-compose.yml` before the build.
 | 
			
		||||
# Example:
 | 
			
		||||
#   - INSTALL_NODE=false
 | 
			
		||||
#   - ...
 | 
			
		||||
#
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Non-Root User:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
# Add a non-root user to prevent files being created with root permissions on host machine.
 | 
			
		||||
ARG PUID=1000
 | 
			
		||||
ARG PGID=1000
 | 
			
		||||
 | 
			
		||||
ENV PUID ${PUID}
 | 
			
		||||
ENV PGID ${PGID}
 | 
			
		||||
 | 
			
		||||
RUN groupadd -g ${PGID} laradock && \
 | 
			
		||||
    useradd -u ${PUID} -g laradock -m laradock
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# SOAP:
 | 
			
		||||
#####################################
 | 
			
		||||
USER root
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_SOAP=false
 | 
			
		||||
ENV INSTALL_SOAP ${INSTALL_SOAP}
 | 
			
		||||
 | 
			
		||||
RUN if [ ${INSTALL_SOAP} = true ]; then \
 | 
			
		||||
  # Install the PHP SOAP extension
 | 
			
		||||
  add-apt-repository -y ppa:ondrej/php && \
 | 
			
		||||
  apt-get update -yqq && \
 | 
			
		||||
  apt-get -y install libxml2-dev php7.2-soap \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# LDAP:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_LDAP=false
 | 
			
		||||
ENV INSTALL_LDAP ${INSTALL_LDAP}
 | 
			
		||||
 | 
			
		||||
RUN if [ ${INSTALL_LDAP} = true ]; then \
 | 
			
		||||
    apt-get update -yqq && \
 | 
			
		||||
    apt-get install -y libldap2-dev && \
 | 
			
		||||
    apt-get install -y php7.2-ldap \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# IMAP:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_IMAP=false
 | 
			
		||||
ENV INSTALL_IMAP ${INSTALL_IMAP}
 | 
			
		||||
 | 
			
		||||
RUN if [ ${INSTALL_IMAP} = true ]; then \
 | 
			
		||||
    apt-get update -yqq && \
 | 
			
		||||
    apt-get install -y php7.2-imap \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Set Timezone
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG TZ=UTC
 | 
			
		||||
ENV TZ ${TZ}
 | 
			
		||||
RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Composer:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
# Add the composer.json
 | 
			
		||||
COPY ./composer.json /home/laradock/.composer/composer.json
 | 
			
		||||
 | 
			
		||||
# Make sure that ~/.composer belongs to laradock
 | 
			
		||||
RUN chown -R laradock:laradock /home/laradock/.composer
 | 
			
		||||
USER laradock
 | 
			
		||||
 | 
			
		||||
# Check if global install need to be ran
 | 
			
		||||
ARG COMPOSER_GLOBAL_INSTALL=false
 | 
			
		||||
ENV COMPOSER_GLOBAL_INSTALL ${COMPOSER_GLOBAL_INSTALL}
 | 
			
		||||
RUN if [ ${COMPOSER_GLOBAL_INSTALL} = true ]; then \
 | 
			
		||||
    # run the install
 | 
			
		||||
    composer global install \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Crontab
 | 
			
		||||
#####################################
 | 
			
		||||
USER root
 | 
			
		||||
 | 
			
		||||
COPY ./crontab /etc/cron.d
 | 
			
		||||
RUN chmod -R 644 /etc/cron.d
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# User Aliases
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
USER laradock
 | 
			
		||||
COPY ./aliases.sh /home/laradock/aliases.sh
 | 
			
		||||
RUN echo "" >> ~/.bashrc && \
 | 
			
		||||
    echo "# Load Custom Aliases" >> ~/.bashrc && \
 | 
			
		||||
    echo "source /home/laradock/aliases.sh" >> ~/.bashrc && \
 | 
			
		||||
	echo "" >> ~/.bashrc && \
 | 
			
		||||
	sed -i 's/\r//' /home/laradock/aliases.sh && \
 | 
			
		||||
	sed -i 's/^#! \/bin\/sh/#! \/bin\/bash/' /home/laradock/aliases.sh
 | 
			
		||||
 | 
			
		||||
USER root
 | 
			
		||||
RUN echo "" >> ~/.bashrc && \
 | 
			
		||||
    echo "# Load Custom Aliases" >> ~/.bashrc && \
 | 
			
		||||
    echo "source /home/laradock/aliases.sh" >> ~/.bashrc && \
 | 
			
		||||
	echo "" >> ~/.bashrc && \
 | 
			
		||||
	sed -i 's/\r//' /home/laradock/aliases.sh && \
 | 
			
		||||
	sed -i 's/^#! \/bin\/sh/#! \/bin\/bash/' /home/laradock/aliases.sh
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# xDebug:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_XDEBUG=false
 | 
			
		||||
RUN if [ ${INSTALL_XDEBUG} = true ]; then \
 | 
			
		||||
    # Load the xdebug extension only with phpunit commands
 | 
			
		||||
    apt-get update && \
 | 
			
		||||
    apt-get install -y --force-yes php7.2-xdebug && \
 | 
			
		||||
    sed -i 's/^;//g' /etc/php/7.2/cli/conf.d/20-xdebug.ini && \
 | 
			
		||||
    echo "alias phpunit='php -dzend_extension=xdebug.so /var/www/vendor/bin/phpunit'" >> ~/.bashrc \
 | 
			
		||||
;fi
 | 
			
		||||
# ADD for REMOTE debugging
 | 
			
		||||
COPY ./xdebug.ini /etc/php/7.2/cli/conf.d/xdebug.ini
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Blackfire:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_BLACKFIRE=false
 | 
			
		||||
ARG BLACKFIRE_CLIENT_ID
 | 
			
		||||
ARG BLACKFIRE_CLIENT_TOKEN
 | 
			
		||||
 | 
			
		||||
ENV BLACKFIRE_CLIENT_ID ${BLACKFIRE_CLIENT_ID}
 | 
			
		||||
ENV BLACKFIRE_CLIENT_TOKEN ${BLACKFIRE_CLIENT_TOKEN}
 | 
			
		||||
 | 
			
		||||
RUN if [ ${INSTALL_XDEBUG} = false -a ${INSTALL_BLACKFIRE} = true ]; then \
 | 
			
		||||
    curl -L https://packagecloud.io/gpg.key | apt-key add - && \
 | 
			
		||||
    echo "deb http://packages.blackfire.io/debian any main" | tee /etc/apt/sources.list.d/blackfire.list && \
 | 
			
		||||
    apt-get update -yqq && \
 | 
			
		||||
    apt-get install blackfire-agent \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# ssh:
 | 
			
		||||
#####################################
 | 
			
		||||
ARG INSTALL_WORKSPACE_SSH=false
 | 
			
		||||
ENV INSTALL_WORKSPACE_SSH ${INSTALL_WORKSPACE_SSH}
 | 
			
		||||
 | 
			
		||||
ADD insecure_id_rsa /tmp/id_rsa
 | 
			
		||||
ADD insecure_id_rsa.pub /tmp/id_rsa.pub
 | 
			
		||||
 | 
			
		||||
RUN if [ ${INSTALL_WORKSPACE_SSH} = true ]; then \
 | 
			
		||||
    rm -f /etc/service/sshd/down && \
 | 
			
		||||
    cat /tmp/id_rsa.pub >> /root/.ssh/authorized_keys \
 | 
			
		||||
        && cat /tmp/id_rsa.pub >> /root/.ssh/id_rsa.pub \
 | 
			
		||||
        && cat /tmp/id_rsa >> /root/.ssh/id_rsa \
 | 
			
		||||
        && rm -f /tmp/id_rsa* \
 | 
			
		||||
        && chmod 644 /root/.ssh/authorized_keys /root/.ssh/id_rsa.pub \
 | 
			
		||||
    && chmod 400 /root/.ssh/id_rsa \
 | 
			
		||||
    && cp -rf /root/.ssh /home/laradock \
 | 
			
		||||
    && chown -R laradock:laradock /home/laradock/.ssh \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# MongoDB:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
# Check if Mongo needs to be installed
 | 
			
		||||
ARG INSTALL_MONGO=false
 | 
			
		||||
ENV INSTALL_MONGO ${INSTALL_MONGO}
 | 
			
		||||
RUN if [ ${INSTALL_MONGO} = true ]; then \
 | 
			
		||||
    # Install the mongodb extension
 | 
			
		||||
    pecl -q install mongodb && \
 | 
			
		||||
    echo "extension=mongodb.so" >> /etc/php/7.2/mods-available/mongodb.ini && \
 | 
			
		||||
    ln -s /etc/php/7.2/mods-available/mongodb.ini /etc/php/7.2/cli/conf.d/30-mongodb.ini \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# AMQP:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
# Check if Mongo needs to be installed
 | 
			
		||||
ARG INSTALL_AMQP=false
 | 
			
		||||
ENV INSTALL_AMQP ${INSTALL_AMQP}
 | 
			
		||||
RUN if [ ${INSTALL_AMQP} = true ]; then \
 | 
			
		||||
    apt-get install librabbitmq-dev -y && \
 | 
			
		||||
    # Install the mongodb extension
 | 
			
		||||
    pecl -q install amqp && \
 | 
			
		||||
    echo "extension=amqp.so" >> /etc/php/7.2/mods-available/amqp.ini && \
 | 
			
		||||
    ln -s /etc/php/7.2/mods-available/amqp.ini /etc/php/7.2/cli/conf.d/30-amqp.ini \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# PHP REDIS EXTENSION FOR PHP 7.2
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_PHPREDIS=false
 | 
			
		||||
ENV INSTALL_PHPREDIS ${INSTALL_PHPREDIS}
 | 
			
		||||
RUN if [ ${INSTALL_PHPREDIS} = true ]; then \
 | 
			
		||||
    # Install Php Redis extension
 | 
			
		||||
    printf "\n" | pecl -q install -o -f redis && \
 | 
			
		||||
    echo "extension=redis.so" >> /etc/php/7.2/mods-available/redis.ini && \
 | 
			
		||||
    phpenmod redis \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Swoole EXTENSION FOR PHP 7
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_SWOOLE=false
 | 
			
		||||
RUN if [ ${INSTALL_SWOOLE} = true ]; then \
 | 
			
		||||
    # Install Php Swoole Extension
 | 
			
		||||
    pecl -q install swoole && \
 | 
			
		||||
    echo "extension=swoole.so" >> /etc/php/7.2/mods-available/swoole.ini && \
 | 
			
		||||
    ln -s /etc/php/7.2/mods-available/swoole.ini /etc/php/7.2/cli/conf.d/20-swoole.ini \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Drush:
 | 
			
		||||
#####################################
 | 
			
		||||
USER root
 | 
			
		||||
ENV DRUSH_VERSION 8.1.2
 | 
			
		||||
ARG INSTALL_DRUSH=false
 | 
			
		||||
ENV INSTALL_DRUSH ${INSTALL_DRUSH}
 | 
			
		||||
RUN if [ ${INSTALL_DRUSH} = true ]; then \
 | 
			
		||||
    apt-get update -yqq && \
 | 
			
		||||
    apt-get -y install mysql-client && \
 | 
			
		||||
    # Install Drush 8 with the phar file.
 | 
			
		||||
    curl -fsSL -o /usr/local/bin/drush https://github.com/drush-ops/drush/releases/download/$DRUSH_VERSION/drush.phar | bash && \
 | 
			
		||||
    chmod +x /usr/local/bin/drush && \
 | 
			
		||||
    drush core-status \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Drupal Console:
 | 
			
		||||
#####################################
 | 
			
		||||
USER root
 | 
			
		||||
ARG INSTALL_DRUPAL_CONSOLE=false
 | 
			
		||||
ENV INSTALL_DRUPAL_CONSOLE ${INSTALL_DRUPAL_CONSOLE}
 | 
			
		||||
RUN if [ ${INSTALL_DRUPAL_CONSOLE} = true ]; then \
 | 
			
		||||
    apt-get update -yqq && \
 | 
			
		||||
    apt-get -y install mysql-client && \
 | 
			
		||||
    curl https://drupalconsole.com/installer -L -o drupal.phar && \
 | 
			
		||||
    mv drupal.phar /usr/local/bin/drupal && \
 | 
			
		||||
    chmod +x /usr/local/bin/drupal \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
USER laradock
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Node / NVM:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
# Check if NVM needs to be installed
 | 
			
		||||
ARG NODE_VERSION=stable
 | 
			
		||||
ENV NODE_VERSION ${NODE_VERSION}
 | 
			
		||||
ARG INSTALL_NODE=false
 | 
			
		||||
ENV INSTALL_NODE ${INSTALL_NODE}
 | 
			
		||||
ENV NVM_DIR /home/laradock/.nvm
 | 
			
		||||
RUN if [ ${INSTALL_NODE} = true ]; then \
 | 
			
		||||
    # Install nvm (A Node Version Manager)
 | 
			
		||||
    curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.33.1/install.sh | bash && \
 | 
			
		||||
        . $NVM_DIR/nvm.sh && \
 | 
			
		||||
        nvm install ${NODE_VERSION} && \
 | 
			
		||||
        nvm use ${NODE_VERSION} && \
 | 
			
		||||
        nvm alias ${NODE_VERSION} && \
 | 
			
		||||
        npm install -g gulp bower vue-cli \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
# Wouldn't execute when added to the RUN statement in the above block
 | 
			
		||||
# Source NVM when loading bash since ~/.profile isn't loaded on non-login shell
 | 
			
		||||
RUN if [ ${INSTALL_NODE} = true ]; then \
 | 
			
		||||
    echo "" >> ~/.bashrc && \
 | 
			
		||||
    echo 'export NVM_DIR="$HOME/.nvm"' >> ~/.bashrc && \
 | 
			
		||||
    echo '[ -s "$NVM_DIR/nvm.sh" ] && . "$NVM_DIR/nvm.sh"  # This loads nvm' >> ~/.bashrc \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
# Add NVM binaries to root's .bashrc
 | 
			
		||||
USER root
 | 
			
		||||
 | 
			
		||||
RUN if [ ${INSTALL_NODE} = true ]; then \
 | 
			
		||||
    echo "" >> ~/.bashrc && \
 | 
			
		||||
    echo 'export NVM_DIR="/home/laradock/.nvm"' >> ~/.bashrc && \
 | 
			
		||||
    echo '[ -s "$NVM_DIR/nvm.sh" ] && . "$NVM_DIR/nvm.sh"  # This loads nvm' >> ~/.bashrc \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
# Add PATH for node
 | 
			
		||||
ENV PATH $PATH:$NVM_DIR/versions/node/v${NODE_VERSION}/bin
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# YARN:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
USER laradock
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_YARN=false
 | 
			
		||||
ENV INSTALL_YARN ${INSTALL_YARN}
 | 
			
		||||
ARG YARN_VERSION=latest
 | 
			
		||||
ENV YARN_VERSION ${YARN_VERSION}
 | 
			
		||||
 | 
			
		||||
RUN if [ ${INSTALL_YARN} = true ]; then \
 | 
			
		||||
    [ -s "$NVM_DIR/nvm.sh" ] && . "$NVM_DIR/nvm.sh" && \
 | 
			
		||||
    if [ ${YARN_VERSION} = "latest" ]; then \
 | 
			
		||||
        curl -o- -L https://yarnpkg.com/install.sh | bash; \
 | 
			
		||||
    else \
 | 
			
		||||
        curl -o- -L https://yarnpkg.com/install.sh | bash -s -- --version ${YARN_VERSION}; \
 | 
			
		||||
    fi && \
 | 
			
		||||
    echo "" >> ~/.bashrc && \
 | 
			
		||||
    echo 'export PATH="$HOME/.yarn/bin:$PATH"' >> ~/.bashrc \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
# Add YARN binaries to root's .bashrc
 | 
			
		||||
USER root
 | 
			
		||||
 | 
			
		||||
RUN if [ ${INSTALL_YARN} = true ]; then \
 | 
			
		||||
    echo "" >> ~/.bashrc && \
 | 
			
		||||
    echo 'export YARN_DIR="/home/laradock/.yarn"' >> ~/.bashrc && \
 | 
			
		||||
    echo 'export PATH="$YARN_DIR/bin:$PATH"' >> ~/.bashrc \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# PHP Aerospike:
 | 
			
		||||
#####################################
 | 
			
		||||
USER root
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_AEROSPIKE=false
 | 
			
		||||
ENV INSTALL_AEROSPIKE ${INSTALL_AEROSPIKE}
 | 
			
		||||
 | 
			
		||||
# Copy aerospike configration for remote debugging
 | 
			
		||||
COPY ./aerospike.ini /etc/php/7.2/cli/conf.d/aerospike.ini
 | 
			
		||||
 | 
			
		||||
RUN if [ ${INSTALL_AEROSPIKE} = true ]; then \
 | 
			
		||||
    # Fix dependencies for PHPUnit within aerospike extension
 | 
			
		||||
    apt-get update -yqq && \
 | 
			
		||||
    apt-get -y install sudo wget && \
 | 
			
		||||
 | 
			
		||||
    # Install the php aerospike extension
 | 
			
		||||
    curl -L -o /tmp/aerospike-client-php.tar.gz "https://github.com/aerospike/aerospike-client-php/archive/master.tar.gz" \
 | 
			
		||||
    && mkdir -p aerospike-client-php \
 | 
			
		||||
    && tar -C aerospike-client-php -zxvf /tmp/aerospike-client-php.tar.gz --strip 1 \
 | 
			
		||||
    && ( \
 | 
			
		||||
        cd aerospike-client-php/src \
 | 
			
		||||
        && phpize \
 | 
			
		||||
        && ./build.sh \
 | 
			
		||||
        && make install \
 | 
			
		||||
    ) \
 | 
			
		||||
    && rm /tmp/aerospike-client-php.tar.gz \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
RUN if [ ${INSTALL_AEROSPIKE} = false ]; then \
 | 
			
		||||
    rm /etc/php/7.2/cli/conf.d/aerospike.ini \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# PHP V8JS:
 | 
			
		||||
#####################################
 | 
			
		||||
USER root
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_V8JS=false
 | 
			
		||||
ENV INSTALL_V8JS ${INSTALL_V8JS}
 | 
			
		||||
 | 
			
		||||
RUN if [ ${INSTALL_V8JS} = true ]; then \
 | 
			
		||||
    # Install the php V8JS extension
 | 
			
		||||
    add-apt-repository -y ppa:pinepain/libv8-5.4 \
 | 
			
		||||
    && apt-get update -yqq \
 | 
			
		||||
    && apt-get install -y php-xml php-dev php-pear libv8-5.4 \
 | 
			
		||||
    && pecl install v8js \
 | 
			
		||||
    && echo "extension=v8js.so" >> /etc/php/7.2/cli/php.ini \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Non-root user : PHPUnit path
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
# add ./vendor/bin to non-root user's bashrc (needed for phpunit)
 | 
			
		||||
USER laradock
 | 
			
		||||
 | 
			
		||||
RUN echo "" >> ~/.bashrc && \
 | 
			
		||||
    echo 'export PATH="/var/www/vendor/bin:$PATH"' >> ~/.bashrc
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Laravel Envoy:
 | 
			
		||||
#####################################
 | 
			
		||||
USER laradock
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_LARAVEL_ENVOY=false
 | 
			
		||||
ENV INSTALL_LARAVEL_ENVOY ${INSTALL_LARAVEL_ENVOY}
 | 
			
		||||
 | 
			
		||||
RUN if [ ${INSTALL_LARAVEL_ENVOY} = true ]; then \
 | 
			
		||||
    # Install the Laravel Envoy
 | 
			
		||||
    composer global require "laravel/envoy=~1.0" \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Laravel Installer:
 | 
			
		||||
#####################################
 | 
			
		||||
USER root
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_LARAVEL_INSTALLER=false
 | 
			
		||||
ENV INSTALL_LARAVEL_INSTALLER ${INSTALL_LARAVEL_INSTALLER}
 | 
			
		||||
 | 
			
		||||
RUN if [ ${INSTALL_LARAVEL_INSTALLER} = true ]; then \
 | 
			
		||||
    # Install the Laravel Installer
 | 
			
		||||
	echo "" >> ~/.bashrc && \
 | 
			
		||||
	echo 'export PATH="~/.composer/vendor/bin:$PATH"' >> ~/.bashrc \
 | 
			
		||||
	&& composer global require "laravel/installer" \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
USER laradock
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Deployer:
 | 
			
		||||
#####################################
 | 
			
		||||
USER root
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_DEPLOYER=false
 | 
			
		||||
ENV INSTALL_DEPLOYER ${INSTALL_DEPLOYER}
 | 
			
		||||
 | 
			
		||||
RUN if [ ${INSTALL_DEPLOYER} = true ]; then \
 | 
			
		||||
    # Install the Deployer
 | 
			
		||||
    # Using Phar as currently there is no support for laravel 4 from composer version
 | 
			
		||||
    # Waiting to be resolved on https://github.com/deployphp/deployer/issues/1552
 | 
			
		||||
    curl -LO https://deployer.org/deployer.phar && \
 | 
			
		||||
    mv deployer.phar /usr/local/bin/dep && \
 | 
			
		||||
    chmod +x /usr/local/bin/dep \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Linuxbrew:
 | 
			
		||||
#####################################
 | 
			
		||||
USER root
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_LINUXBREW=false
 | 
			
		||||
ENV INSTALL_LINUXBREW ${INSTALL_LINUXBREW}
 | 
			
		||||
 | 
			
		||||
RUN if [ ${INSTALL_LINUXBREW} = true ]; then \
 | 
			
		||||
 | 
			
		||||
    # Preparation
 | 
			
		||||
    apt-get upgrade -y && \
 | 
			
		||||
    apt-get install -y build-essential make cmake scons curl git \
 | 
			
		||||
      ruby autoconf automake autoconf-archive \
 | 
			
		||||
      gettext libtool flex bison \
 | 
			
		||||
      libbz2-dev libcurl4-openssl-dev \
 | 
			
		||||
      libexpat-dev libncurses-dev && \
 | 
			
		||||
 | 
			
		||||
    # Install the Linuxbrew
 | 
			
		||||
    git clone --depth=1 https://github.com/Homebrew/linuxbrew.git ~/.linuxbrew && \
 | 
			
		||||
 | 
			
		||||
    echo "" >> ~/.bashrc && \
 | 
			
		||||
    echo 'export PKG_CONFIG_PATH"=/usr/local/lib/pkgconfig:/usr/local/lib64/pkgconfig:/usr/lib64/pkgconfig:/usr/lib/pkgconfig:/usr/lib/x86_64-linux-gnu/pkgconfig:/usr/lib64/pkgconfig:/usr/share/pkgconfig:$PKG_CONFIG_PATH"' >> ~/.bashrc && \
 | 
			
		||||
 | 
			
		||||
    # Setup linuxbrew
 | 
			
		||||
    echo 'export LINUXBREWHOME="$HOME/.linuxbrew"' >> ~/.bashrc && \
 | 
			
		||||
    echo 'export PATH="$LINUXBREWHOME/bin:$PATH"' >> ~/.bashrc && \
 | 
			
		||||
    echo 'export MANPATH="$LINUXBREWHOME/man:$MANPATH"' >> ~/.bashrc && \
 | 
			
		||||
    echo 'export PKG_CONFIG_PATH="$LINUXBREWHOME/lib64/pkgconfig:$LINUXBREWHOME/lib/pkgconfig:$PKG_CONFIG_PATH"' >> ~/.bashrc && \
 | 
			
		||||
    echo 'export LD_LIBRARY_PATH="$LINUXBREWHOME/lib64:$LINUXBREWHOME/lib:$LD_LIBRARY_PATH"' >> ~/.bashrc \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# SQL SERVER:
 | 
			
		||||
#####################################
 | 
			
		||||
ARG INSTALL_MSSQL=false
 | 
			
		||||
ENV INSTALL_MSSQL ${INSTALL_MSSQL}
 | 
			
		||||
 | 
			
		||||
RUN if [ ${INSTALL_MSSQL} = true ]; then \
 | 
			
		||||
    #####################################
 | 
			
		||||
    # Install Depenencies:
 | 
			
		||||
    #####################################
 | 
			
		||||
        cd / && \
 | 
			
		||||
        apt-get update -yqq && \
 | 
			
		||||
        apt-get install -y --force-yes wget apt-transport-https curl freetds-common libsybdb5 freetds-bin unixodbc unixodbc-dev && \
 | 
			
		||||
 | 
			
		||||
    #####################################
 | 
			
		||||
    #  The following steps were taken from
 | 
			
		||||
    #  Microsoft's github account:
 | 
			
		||||
    #  https://github.com/Microsoft/msphpsql/wiki/Dockerfile-for-getting-pdo_sqlsrv-for-PHP-7.0-on-Debian-in-3-ways
 | 
			
		||||
    #####################################
 | 
			
		||||
 | 
			
		||||
    # Add PHP 7 repository
 | 
			
		||||
    # for Debian jessie
 | 
			
		||||
    # And System upgrade
 | 
			
		||||
        cd / && \
 | 
			
		||||
        echo "deb http://packages.dotdeb.org jessie all" \
 | 
			
		||||
        | tee /etc/apt/sources.list.d/dotdeb.list \
 | 
			
		||||
        && wget -qO- https://www.dotdeb.org/dotdeb.gpg \
 | 
			
		||||
        | apt-key add - \
 | 
			
		||||
        && apt-get update -yqq \
 | 
			
		||||
        && apt-get upgrade -qq && \
 | 
			
		||||
 | 
			
		||||
    # Install UnixODBC
 | 
			
		||||
    # Compile odbc_config as it is not part of unixodbc package
 | 
			
		||||
        cd / && \
 | 
			
		||||
        apt-get update -yqq && \
 | 
			
		||||
        apt-get install -y whiptail \
 | 
			
		||||
        unixodbc libgss3 odbcinst devscripts debhelper dh-exec dh-autoreconf libreadline-dev libltdl-dev \
 | 
			
		||||
        && dget -u -x http://http.debian.net/debian/pool/main/u/unixodbc/unixodbc_2.3.1-3.dsc \
 | 
			
		||||
        && cd unixodbc-*/ \
 | 
			
		||||
        && ./configure && make && make install \
 | 
			
		||||
        && cp -v ./exe/odbc_config /usr/local/bin/ && \
 | 
			
		||||
 | 
			
		||||
    # Fake uname for install.sh
 | 
			
		||||
        printf '#!/bin/bash\nif [ "$*" == "-p" ]; then echo "x86_64"; else /bin/uname "$@"; fi' \
 | 
			
		||||
        | tee /usr/local/bin/uname \
 | 
			
		||||
        && chmod +x /usr/local/bin/uname && \
 | 
			
		||||
 | 
			
		||||
    # Microsoft ODBC Driver 13 for Linux
 | 
			
		||||
    # Note: There's a copy of this tar on my hubiC
 | 
			
		||||
        cd / && \
 | 
			
		||||
        wget -nv -O msodbcsql-13.0.0.0.tar.gz \
 | 
			
		||||
        "https://meetsstorenew.blob.core.windows.net/contianerhd/Ubuntu%2013.0%20Tar/msodbcsql-13.0.0.0.tar.gz?st=2016-10-18T17%3A29%3A00Z&se=2022-10-19T17%3A29%3A00Z&sp=rl&sv=2015-04-05&sr=b&sig=cDwPfrouVeIQf0vi%2BnKt%2BzX8Z8caIYvRCmicDL5oknY%3D" \
 | 
			
		||||
        && tar -xf msodbcsql-13.0.0.0.tar.gz \
 | 
			
		||||
        && cd msodbcsql-*/ \
 | 
			
		||||
        && ldd lib64/libmsodbcsql-13.0.so.0.0 \
 | 
			
		||||
        && ./install.sh install --accept-license \
 | 
			
		||||
        && ls -l /opt/microsoft/msodbcsql/ \
 | 
			
		||||
        && odbcinst -q -d -n "ODBC Driver 13 for SQL Server" && \
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    #####################################
 | 
			
		||||
    # Install sqlsrv y pdo_sqlsrv
 | 
			
		||||
    # extensions:
 | 
			
		||||
    #####################################
 | 
			
		||||
 | 
			
		||||
    pecl install sqlsrv-4.0.8 && \
 | 
			
		||||
    pecl install pdo_sqlsrv-4.0.8 && \
 | 
			
		||||
 | 
			
		||||
    #####################################
 | 
			
		||||
    # Set locales for the container
 | 
			
		||||
    #####################################
 | 
			
		||||
 | 
			
		||||
    apt-get install -y locales \
 | 
			
		||||
    && echo "en_US.UTF-8 UTF-8" > /etc/locale.gen \
 | 
			
		||||
    && locale-gen \
 | 
			
		||||
    && echo "extension=sqlsrv.so" > /etc/php/7.2/cli/conf.d/20-sqlsrv.ini \
 | 
			
		||||
    && echo "extension=pdo_sqlsrv.so" > /etc/php/7.2/cli/conf.d/20-pdo_sqlsrv.ini \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Minio:
 | 
			
		||||
#####################################
 | 
			
		||||
USER root
 | 
			
		||||
ARG INSTALL_MC=false
 | 
			
		||||
ENV INSTALL_MC ${INSTALL_MC}
 | 
			
		||||
 | 
			
		||||
COPY mc/config.json /root/.mc/config.json
 | 
			
		||||
 | 
			
		||||
RUN if [ ${INSTALL_MC} = true ]; then\
 | 
			
		||||
    curl -fsSL -o /usr/local/bin/mc https://dl.minio.io/client/mc/release/linux-amd64/mc && \
 | 
			
		||||
    chmod +x /usr/local/bin/mc \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Image optimizers:
 | 
			
		||||
#####################################
 | 
			
		||||
USER root
 | 
			
		||||
ARG INSTALL_IMAGE_OPTIMIZERS=false
 | 
			
		||||
ENV INSTALL_IMAGE_OPTIMIZERS ${INSTALL_IMAGE_OPTIMIZERS}
 | 
			
		||||
RUN if [ ${INSTALL_IMAGE_OPTIMIZERS} = true ]; then \
 | 
			
		||||
    apt-get install -y --force-yes jpegoptim optipng pngquant gifsicle && \
 | 
			
		||||
    if [ ${INSTALL_NODE} = true ]; then \
 | 
			
		||||
        . ~/.bashrc && npm install -g svgo \
 | 
			
		||||
    ;fi\
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
USER laradock
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Symfony:
 | 
			
		||||
#####################################
 | 
			
		||||
USER root
 | 
			
		||||
ARG INSTALL_SYMFONY=false
 | 
			
		||||
ENV INSTALL_SYMFONY ${INSTALL_SYMFONY}
 | 
			
		||||
RUN if [ ${INSTALL_SYMFONY} = true ]; then \
 | 
			
		||||
 | 
			
		||||
  mkdir -p /usr/local/bin \
 | 
			
		||||
  && curl -LsS https://symfony.com/installer -o /usr/local/bin/symfony \
 | 
			
		||||
  && chmod a+x /usr/local/bin/symfony \
 | 
			
		||||
 | 
			
		||||
  #  Symfony 3 alias
 | 
			
		||||
  && echo 'alias dev="php bin/console -e=dev"' >> ~/.bashrc \
 | 
			
		||||
  && echo 'alias prod="php bin/console -e=prod"' >> ~/.bashrc \
 | 
			
		||||
 | 
			
		||||
  #  Symfony 2 alias
 | 
			
		||||
  #  && echo 'alias dev="php app/console -e=dev"' >> ~/.bashrc \
 | 
			
		||||
  #  && echo 'alias prod="php app/console -e=prod"' >> ~/.bashrc \
 | 
			
		||||
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# PYTHON:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
ARG INSTALL_PYTHON=false
 | 
			
		||||
ENV INSTALL_PYTHON ${INSTALL_PYTHON}
 | 
			
		||||
RUN if [ ${INSTALL_PYTHON} = true ]; then \
 | 
			
		||||
  apt-get update \
 | 
			
		||||
  && apt-get -y install python python-pip python-dev build-essential  \
 | 
			
		||||
  && pip install --upgrade pip  \
 | 
			
		||||
  && pip install --upgrade virtualenv \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# ImageMagick:
 | 
			
		||||
#####################################
 | 
			
		||||
USER root
 | 
			
		||||
ARG INSTALL_IMAGEMAGICK=false
 | 
			
		||||
ENV INSTALL_IMAGEMAGICK ${INSTALL_IMAGEMAGICK}
 | 
			
		||||
RUN if [ ${INSTALL_IMAGEMAGICK} = true ]; then \
 | 
			
		||||
    apt-get install -y --force-yes imagemagick php-imagick \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Terraform:
 | 
			
		||||
#####################################
 | 
			
		||||
USER root
 | 
			
		||||
ARG INSTALL_TERRAFORM=false
 | 
			
		||||
ENV INSTALL_TERRAFORM ${INSTALL_TERRAFORM}
 | 
			
		||||
RUN if [ ${INSTALL_TERRAFORM} = true ]; then \
 | 
			
		||||
    apt-get update -yqq \
 | 
			
		||||
    && apt-get -y install sudo wget unzip \
 | 
			
		||||
    && wget https://releases.hashicorp.com/terraform/0.10.6/terraform_0.10.6_linux_amd64.zip \
 | 
			
		||||
    && unzip terraform_0.10.6_linux_amd64.zip \
 | 
			
		||||
    && mv terraform /usr/local/bin \
 | 
			
		||||
    && rm terraform_0.10.6_linux_amd64.zip \
 | 
			
		||||
;fi
 | 
			
		||||
#####################################
 | 
			
		||||
# pgsql client
 | 
			
		||||
#####################################
 | 
			
		||||
USER root
 | 
			
		||||
ARG INSTALL_PG_CLIENT=false
 | 
			
		||||
ENV INSTALL_PG_CLIENT ${INSTALL_PG_CLIENT}
 | 
			
		||||
RUN if [ ${INSTALL_PG_CLIENT} = true ]; then \
 | 
			
		||||
    # Install the pgsql clint
 | 
			
		||||
    apt-get update -yqq && \
 | 
			
		||||
    apt-get -y install postgresql-client \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Dusk Dependencies:
 | 
			
		||||
#####################################
 | 
			
		||||
USER root
 | 
			
		||||
ARG CHROME_DRIVER_VERSION=stable
 | 
			
		||||
ENV CHROME_DRIVER_VERSION ${CHROME_DRIVER_VERSION}
 | 
			
		||||
ARG INSTALL_DUSK_DEPS=false
 | 
			
		||||
ENV INSTALL_DUSK_DEPS ${INSTALL_DUSK_DEPS}
 | 
			
		||||
RUN if [ ${INSTALL_DUSK_DEPS} = true ]; then \
 | 
			
		||||
  add-apt-repository ppa:ondrej/php \
 | 
			
		||||
  && apt-get update \
 | 
			
		||||
  && apt-get -y install zip wget unzip xdg-utils \
 | 
			
		||||
    libxpm4 libxrender1 libgtk2.0-0 libnss3 libgconf-2-4 xvfb \
 | 
			
		||||
    gtk2-engines-pixbuf xfonts-cyrillic xfonts-100dpi xfonts-75dpi \
 | 
			
		||||
    xfonts-base xfonts-scalable x11-apps \
 | 
			
		||||
  && wget https://dl.google.com/linux/direct/google-chrome-stable_current_amd64.deb \
 | 
			
		||||
  && dpkg -i --force-depends google-chrome-stable_current_amd64.deb \
 | 
			
		||||
  && apt-get -y -f install \
 | 
			
		||||
  && dpkg -i --force-depends google-chrome-stable_current_amd64.deb \
 | 
			
		||||
  && rm google-chrome-stable_current_amd64.deb \
 | 
			
		||||
  && wget https://chromedriver.storage.googleapis.com/${CHROME_DRIVER_VERSION}/chromedriver_linux64.zip \
 | 
			
		||||
  && unzip chromedriver_linux64.zip \
 | 
			
		||||
  && mv chromedriver /usr/local/bin/ \
 | 
			
		||||
  && rm chromedriver_linux64.zip \
 | 
			
		||||
;fi
 | 
			
		||||
 | 
			
		||||
#####################################
 | 
			
		||||
# Check PHP version:
 | 
			
		||||
#####################################
 | 
			
		||||
 | 
			
		||||
RUN php -v | head -n 1 | grep -q "PHP 7.2."
 | 
			
		||||
 | 
			
		||||
#
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
# Final Touch
 | 
			
		||||
#--------------------------------------------------------------------------
 | 
			
		||||
#
 | 
			
		||||
 | 
			
		||||
# Clean up
 | 
			
		||||
USER root
 | 
			
		||||
RUN apt-get clean && \
 | 
			
		||||
    rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
 | 
			
		||||
 | 
			
		||||
# Set default work directory
 | 
			
		||||
WORKDIR /var/www
 | 
			
		||||
		Reference in New Issue
	
	Block a user