Adjust prod Docker

This commit is contained in:
cytopia
2018-02-27 23:38:09 +01:00
parent f5491d91fc
commit 6d35b06c45
33 changed files with 914 additions and 470 deletions

View File

@@ -1,4 +1,4 @@
# Auto-generated via Ansible # Auto-generated via Ansible: edit build/ansible/DOCKERFILES/Dockerfile-base.j2 instead.
FROM php:5.4-fpm FROM php:5.4-fpm
MAINTAINER "cytopia" <cytopia@everythingcli.org> MAINTAINER "cytopia" <cytopia@everythingcli.org>

View File

@@ -1,4 +1,4 @@
# Auto-generated via Ansible # Auto-generated via Ansible: edit build/ansible/DOCKERFILES/Dockerfile-base.j2 instead.
FROM php:5.5-fpm FROM php:5.5-fpm
MAINTAINER "cytopia" <cytopia@everythingcli.org> MAINTAINER "cytopia" <cytopia@everythingcli.org>

View File

@@ -1,4 +1,4 @@
# Auto-generated via Ansible # Auto-generated via Ansible: edit build/ansible/DOCKERFILES/Dockerfile-base.j2 instead.
FROM php:5.6-fpm FROM php:5.6-fpm
MAINTAINER "cytopia" <cytopia@everythingcli.org> MAINTAINER "cytopia" <cytopia@everythingcli.org>

View File

@@ -1,4 +1,4 @@
# Auto-generated via Ansible # Auto-generated via Ansible: edit build/ansible/DOCKERFILES/Dockerfile-base.j2 instead.
FROM php:7.0-fpm FROM php:7.0-fpm
MAINTAINER "cytopia" <cytopia@everythingcli.org> MAINTAINER "cytopia" <cytopia@everythingcli.org>

View File

@@ -1,4 +1,4 @@
# Auto-generated via Ansible # Auto-generated via Ansible: edit build/ansible/DOCKERFILES/Dockerfile-base.j2 instead.
FROM php:7.1-fpm FROM php:7.1-fpm
MAINTAINER "cytopia" <cytopia@everythingcli.org> MAINTAINER "cytopia" <cytopia@everythingcli.org>

View File

@@ -1,4 +1,4 @@
# Auto-generated via Ansible # Auto-generated via Ansible: edit build/ansible/DOCKERFILES/Dockerfile-base.j2 instead.
FROM php:7.2-fpm FROM php:7.2-fpm
MAINTAINER "cytopia" <cytopia@everythingcli.org> MAINTAINER "cytopia" <cytopia@everythingcli.org>

View File

@@ -1,4 +1,4 @@
# Auto-generated via Ansible # Auto-generated via Ansible: edit build/ansible/DOCKERFILES/Dockerfile-mods.j2 instead.
FROM devilbox/php-fpm:5.4-base FROM devilbox/php-fpm:5.4-base
MAINTAINER "cytopia" <cytopia@everythingcli.org> MAINTAINER "cytopia" <cytopia@everythingcli.org>

View File

@@ -1,4 +1,4 @@
# Auto-generated via Ansible # Auto-generated via Ansible: edit build/ansible/DOCKERFILES/Dockerfile-mods.j2 instead.
FROM devilbox/php-fpm:5.5-base FROM devilbox/php-fpm:5.5-base
MAINTAINER "cytopia" <cytopia@everythingcli.org> MAINTAINER "cytopia" <cytopia@everythingcli.org>

View File

@@ -1,4 +1,4 @@
# Auto-generated via Ansible # Auto-generated via Ansible: edit build/ansible/DOCKERFILES/Dockerfile-mods.j2 instead.
FROM devilbox/php-fpm:5.6-base FROM devilbox/php-fpm:5.6-base
MAINTAINER "cytopia" <cytopia@everythingcli.org> MAINTAINER "cytopia" <cytopia@everythingcli.org>

View File

@@ -1,4 +1,4 @@
# Auto-generated via Ansible # Auto-generated via Ansible: edit build/ansible/DOCKERFILES/Dockerfile-mods.j2 instead.
FROM devilbox/php-fpm:7.0-base FROM devilbox/php-fpm:7.0-base
MAINTAINER "cytopia" <cytopia@everythingcli.org> MAINTAINER "cytopia" <cytopia@everythingcli.org>

View File

@@ -1,4 +1,4 @@
# Auto-generated via Ansible # Auto-generated via Ansible: edit build/ansible/DOCKERFILES/Dockerfile-mods.j2 instead.
FROM devilbox/php-fpm:7.1-base FROM devilbox/php-fpm:7.1-base
MAINTAINER "cytopia" <cytopia@everythingcli.org> MAINTAINER "cytopia" <cytopia@everythingcli.org>

View File

@@ -1,4 +1,4 @@
# Auto-generated via Ansible # Auto-generated via Ansible: edit build/ansible/DOCKERFILES/Dockerfile-mods.j2 instead.
FROM devilbox/php-fpm:7.2-base FROM devilbox/php-fpm:7.2-base
MAINTAINER "cytopia" <cytopia@everythingcli.org> MAINTAINER "cytopia" <cytopia@everythingcli.org>

View File

@@ -1,4 +1,4 @@
# Auto-generated via Ansible # Auto-generated via Ansible: edit build/ansible/DOCKERFILES/Dockerfile-prod.j2 instead.
FROM devilbox/php-fpm:5.4-mods FROM devilbox/php-fpm:5.4-mods
MAINTAINER "cytopia" <cytopia@everythingcli.org> MAINTAINER "cytopia" <cytopia@everythingcli.org>
@@ -35,19 +35,6 @@ RUN set -x \
###
### Configure
###
RUN set -x \
&& { \
echo "[mail function]"; \
echo "sendmail_path = /usr/sbin/sendmail -t -i"; \
echo ";mail.force_extra_parameters ="; \
echo "mail.add_x_header = On"; \
echo "mail.log = /var/log/php/mail.log"; \
} > /usr/local/etc/php/conf.d/devilbox-mail.ini
### ###
### Verify ### Verify
### ###

View File

@@ -1,4 +1,4 @@
# Auto-generated via Ansible # Auto-generated via Ansible: edit build/ansible/DOCKERFILES/Dockerfile-prod.j2 instead.
FROM devilbox/php-fpm:5.5-mods FROM devilbox/php-fpm:5.5-mods
MAINTAINER "cytopia" <cytopia@everythingcli.org> MAINTAINER "cytopia" <cytopia@everythingcli.org>
@@ -35,19 +35,6 @@ RUN set -x \
###
### Configure
###
RUN set -x \
&& { \
echo "[mail function]"; \
echo "sendmail_path = /usr/sbin/sendmail -t -i"; \
echo ";mail.force_extra_parameters ="; \
echo "mail.add_x_header = On"; \
echo "mail.log = /var/log/php/mail.log"; \
} > /usr/local/etc/php/conf.d/devilbox-mail.ini
### ###
### Verify ### Verify
### ###

View File

@@ -1,4 +1,4 @@
# Auto-generated via Ansible # Auto-generated via Ansible: edit build/ansible/DOCKERFILES/Dockerfile-prod.j2 instead.
FROM devilbox/php-fpm:5.6-mods FROM devilbox/php-fpm:5.6-mods
MAINTAINER "cytopia" <cytopia@everythingcli.org> MAINTAINER "cytopia" <cytopia@everythingcli.org>
@@ -35,19 +35,6 @@ RUN set -x \
###
### Configure
###
RUN set -x \
&& { \
echo "[mail function]"; \
echo "sendmail_path = /usr/sbin/sendmail -t -i"; \
echo ";mail.force_extra_parameters ="; \
echo "mail.add_x_header = On"; \
echo "mail.log = /var/log/php/mail.log"; \
} > /usr/local/etc/php/conf.d/devilbox-mail.ini
### ###
### Verify ### Verify
### ###

View File

@@ -1,4 +1,4 @@
# Auto-generated via Ansible # Auto-generated via Ansible: edit build/ansible/DOCKERFILES/Dockerfile-prod.j2 instead.
FROM devilbox/php-fpm:7.0-mods FROM devilbox/php-fpm:7.0-mods
MAINTAINER "cytopia" <cytopia@everythingcli.org> MAINTAINER "cytopia" <cytopia@everythingcli.org>
@@ -35,19 +35,6 @@ RUN set -x \
###
### Configure
###
RUN set -x \
&& { \
echo "[mail function]"; \
echo "sendmail_path = /usr/sbin/sendmail -t -i"; \
echo ";mail.force_extra_parameters ="; \
echo "mail.add_x_header = On"; \
echo "mail.log = /var/log/php/mail.log"; \
} > /usr/local/etc/php/conf.d/devilbox-mail.ini
### ###
### Verify ### Verify
### ###

View File

@@ -1,4 +1,4 @@
# Auto-generated via Ansible # Auto-generated via Ansible: edit build/ansible/DOCKERFILES/Dockerfile-prod.j2 instead.
FROM devilbox/php-fpm:7.1-mods FROM devilbox/php-fpm:7.1-mods
MAINTAINER "cytopia" <cytopia@everythingcli.org> MAINTAINER "cytopia" <cytopia@everythingcli.org>
@@ -35,19 +35,6 @@ RUN set -x \
###
### Configure
###
RUN set -x \
&& { \
echo "[mail function]"; \
echo "sendmail_path = /usr/sbin/sendmail -t -i"; \
echo ";mail.force_extra_parameters ="; \
echo "mail.add_x_header = On"; \
echo "mail.log = /var/log/php/mail.log"; \
} > /usr/local/etc/php/conf.d/devilbox-mail.ini
### ###
### Verify ### Verify
### ###

View File

@@ -1,4 +1,4 @@
# Auto-generated via Ansible # Auto-generated via Ansible: edit build/ansible/DOCKERFILES/Dockerfile-prod.j2 instead.
FROM devilbox/php-fpm:7.2-mods FROM devilbox/php-fpm:7.2-mods
MAINTAINER "cytopia" <cytopia@everythingcli.org> MAINTAINER "cytopia" <cytopia@everythingcli.org>
@@ -35,19 +35,6 @@ RUN set -x \
###
### Configure
###
RUN set -x \
&& { \
echo "[mail function]"; \
echo "sendmail_path = /usr/sbin/sendmail -t -i"; \
echo ";mail.force_extra_parameters ="; \
echo "mail.add_x_header = On"; \
echo "mail.log = /var/log/php/mail.log"; \
} > /usr/local/etc/php/conf.d/devilbox-mail.ini
### ###
### Verify ### Verify
### ###

View File

@@ -14,9 +14,10 @@ set -o pipefail
### ###
set_timezone() { set_timezone() {
local env_varname="${1}" local env_varname="${1}"
local php_conf_dir="${2}" local php_ini_dir="${2}"
local debug="${3}" local debug="${3}"
local timezone= local timezone=
local php_ini_file="${php_ini_dir}/devilbox-runtime-timezone.ini"
if ! env_set "${env_varname}"; then if ! env_set "${env_varname}"; then
log "info" "\$${env_varname} not set." "${debug}" log "info" "\$${env_varname} not set." "${debug}"
@@ -25,7 +26,7 @@ set_timezone() {
run "ln -sf /usr/share/zoneinfo/UTC /etc/localtime" "${debug}" run "ln -sf /usr/share/zoneinfo/UTC /etc/localtime" "${debug}"
# PHP Time # PHP Time
log "info" "Setting PHP: timezone=UTC" "${debug}" log "info" "Setting PHP: timezone=UTC" "${debug}"
run "echo 'date.timezone = UTC' > ${php_conf_dir}/devilbox-runtime.ini" "${debug}" run "echo 'date.timezone = UTC' > ${php_ini_file}" "${debug}"
else else
timezone="$( env_get "${env_varname}" )" timezone="$( env_get "${env_varname}" )"
if [ -f "/usr/share/zoneinfo/${timezone}" ]; then if [ -f "/usr/share/zoneinfo/${timezone}" ]; then
@@ -34,7 +35,7 @@ set_timezone() {
run "ln -sf /usr/share/zoneinfo/${timezone} /etc/localtime" "${debug}" run "ln -sf /usr/share/zoneinfo/${timezone} /etc/localtime" "${debug}"
# PHP Time # PHP Time
log "info" "Setting PHP: timezone=${timezone}" "${debug}" log "info" "Setting PHP: timezone=${timezone}" "${debug}"
run "echo 'date.timezone = ${timezone}' > ${php_conf_dir}/devilbox-runtime.ini" "${debug}" run "echo 'date.timezone = ${timezone}' > ${php_ini_file}" "${debug}"
else else
log "err" "Invalid timezone for \$${env_varname}." "${debug}" log "err" "Invalid timezone for \$${env_varname}." "${debug}"
log "err" "Timezone '${timezone}' does not exist." "${debug}" log "err" "Timezone '${timezone}' does not exist." "${debug}"

View File

@@ -16,18 +16,30 @@ set_postfix() {
local env_varname="${1}" local env_varname="${1}"
local username="${2}" local username="${2}"
local groupname="${3}" local groupname="${3}"
local debug="${4}" local php_ini_dir="${4}"
local debug="${5}"
local php_ini_file="${php_ini_dir}/devilbox-runtime-sendmail.ini"
local catch_all= local catch_all=
if ! env_set "${env_varname}"; then if ! env_set "${env_varname}"; then
log "info" "\$${env_varname} not set." "${debug}" log "info" "\$${env_varname} not set." "${debug}"
log "info" "Postfix will not be started." "${debug}" log "info" "Postfix will not be started." "${debug}"
echo "" > "${php_ini_file}"
else else
catch_all="$( env_get "${env_varname}" )" catch_all="$( env_get "${env_varname}" )"
if [ "${catch_all}" = "1" ]; then if [ "${catch_all}" = "1" ]; then
log "info" "Enabling postfix catch-all" "${debug}" log "info" "Enabling postfix catch-all" "${debug}"
# Configure PHP
{
echo "[mail function]";
echo "sendmail_path = $( which sendmail ) -t -i";
echo ";mail.force_extra_parameters =";
echo "mail.add_x_header = On";
echo "mail.log = /var/log/php/mail.log";
} > "${php_ini_file}"
# Add Mail dir/file if it does not exist # Add Mail dir/file if it does not exist
if [ ! -d "/var/mail" ]; then if [ ! -d "/var/mail" ]; then
run "mkdir /var/mail" "${debug}" run "mkdir /var/mail" "${debug}"
@@ -64,6 +76,10 @@ set_postfix() {
# Sanity Checks # Sanity Checks
############################################################ ############################################################
if ! command -v sendmail >/dev/null 2>&1; then
log "err" "sendmail not found, but required." "1"
exit 1
fi
if ! command -v postconf >/dev/null 2>&1; then if ! command -v postconf >/dev/null 2>&1; then
log "err" "postconf not found, but required." "1" log "err" "postconf not found, but required." "1"
exit 1 exit 1

View File

@@ -72,7 +72,7 @@ set_timezone "TIMEZONE" "${PHP_INI_DIR}" "${DEBUG_LEVEL}"
### ###
### Setup postfix ### Setup postfix
### ###
set_postfix "ENABLE_MAIL" "${MY_USER}" "${MY_GROUP}" "${DEBUG_LEVEL}" set_postfix "ENABLE_MAIL" "${MY_USER}" "${MY_GROUP}" "${PHP_INI_DIR}" "${DEBUG_LEVEL}"
### ###

View File

@@ -1,4 +1,4 @@
# Auto-generated via Ansible # Auto-generated via Ansible: edit build/ansible/DOCKERFILES/Dockerfile-work.j2 instead.
FROM devilbox/php-fpm:5.4-prod FROM devilbox/php-fpm:5.4-prod
MAINTAINER "cytopia" <cytopia@everythingcli.org> MAINTAINER "cytopia" <cytopia@everythingcli.org>
@@ -15,7 +15,7 @@ LABEL \
### ###
### Envs (Already set in parent container) ### Envs
### ###
ENV BASH_PROFILE=".bashrc" ENV BASH_PROFILE=".bashrc"
@@ -23,9 +23,20 @@ ENV BASH_PROFILE=".bashrc"
### ###
### Install Tools ### Install Tools
### ###
# System dev tools
RUN set -x \ RUN set -x \
&& apt-get update \
&& apt-get install --no-install-recommends --no-install-suggests -y \
dirmngr \
gnupg \
&& echo "deb http://ftp.debian.org/debian jessie-backports main" > /etc/apt/sources.list.d/backports.list \
&& apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv A1715D88E1DF1F24 \
&& echo "deb http://ppa.launchpad.net/git-core/ppa/ubuntu wily main" > /etc/apt/sources.list.d/git.list \
&& apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 2930ADAE8CAF5059EE73BB4B58712A2291FA4AD5 \
&& echo "deb http://repo.mongodb.org/apt/debian jessie/mongodb-org/3.6 main" > /etc/apt/sources.list.d/mongo.list \
&& curl -q "https://deb.nodesource.com/gpgkey/nodesource.gpg.key" 2>/dev/null | apt-key add - \
&& echo "deb http://deb.nodesource.com/node_8.x jessie main" > /etc/apt/sources.list.d/node.list \
&& curl -q https://www.postgresql.org/media/keys/ACCC4CF8.asc 2>/dev/null | apt-key add - \
&& echo "deb http://apt.postgresql.org/pub/repos/apt/ jessie-pgdg main" > /etc/apt/sources.list.d/pgsql.list \
&& apt-get update \ && apt-get update \
&& apt-get install --no-install-recommends --no-install-suggests -y \ && apt-get install --no-install-recommends --no-install-suggests -y \
ack-grep \ ack-grep \
@@ -49,14 +60,15 @@ RUN set -x \
less \ less \
libc-dev \ libc-dev \
make \ make \
# mongo-tools \ mongodb-org-shell \
mongodb-clients \ mongodb-org-tools \
moreutils \ moreutils \
mysql-client \ mysql-client \
nano \ nano \
net-tools \ net-tools \
netcat \ netcat \
# postgresql-client \ nodejs \
postgresql-client \
python-pip \ python-pip \
rubygems \ rubygems \
ruby-dev \ ruby-dev \
@@ -73,33 +85,64 @@ RUN set -x \
&& apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false $fetchDeps \ && apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false $fetchDeps \
&& rm -rf /var/lib/apt/lists/* && rm -rf /var/lib/apt/lists/*
## Node / NPM
#RUN set -x \ # composer
# && mkdir -p /usr/local/src \ RUN set -x true \
# && VERSION="$( curl -Lq https://nodejs.org 2>/dev/null | grep LTS | grep -Eo 'data-version.*.' | grep -oE 'v[0-9.]+' )" \ && curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/local/bin --filename=composer \
# && wget --retry-connrefused --waitretry=1 --read-timeout=20 --timeout=15 --tries=30 \ && true
# -P /usr/local/src https://nodejs.org/dist/${VERSION}/node-${VERSION}-linux-x64.tar.xz \ # drush
# && unxz /usr/local/src/node-${VERSION}-linux-x64.tar.xz \ RUN set -x true \
# && tar xvf /usr/local/src/node-${VERSION}-linux-x64.tar -C /usr/local/src \ && git clone https://github.com/drush-ops/drush.git /usr/local/src/drush \
# && ln -s /usr/local/src/node-${VERSION}-linux-x64 /usr/local/node \ && cd /usr/local/src/drush \
# && ln -s /usr/local/node/bin/* /usr/local/bin/ \ && git checkout $(git for-each-ref --format='%(*creatordate:raw)%(creatordate:raw) %(refname)' refs/tags | sort -n | sed 's/^.*tags\///g' | grep ^8 | tail -1) \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64.tar* \ \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64/LICENSE \ && chown -R ${MY_USER}:${MY_GROUP} /usr/local/src/drush \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64/*.md \ && su - ${MY_USER} -c 'PATH=/usr/local/bin:$PATH; cd /usr/local/src/drush && composer install --no-interaction --no-progress' \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64/include \ && ln -s /usr/local/src/drush/drush /usr/local/bin/drush \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64/share \ && rm -rf /usr/local/src/drush/.git \
# && npm --version | grep -E '[.0-9]+' \ && rm -rf /usr/local/src/drush/docs \
# && node --version | grep -E '[.0-9]+' \ && rm -rf /usr/local/src/drush/examples \
# && rm -rf /root/.config && rm -rf /usr/local/src/drush/misc \
# && rm -rf /usr/local/src/drush/tests \
## Composer && rm -rf /home/${MY_USER}/.composer \
#RUN set -x \ \
# && curl -sS https://getcomposer.org/installer | php \ && true
# && mv composer.phar /usr/local/bin/composer \ # wpcli
# && composer self-update RUN set -x true \
## && composer --version 2>/dev/null | grep -E 'version\s*[.0-9]+' \ && curl https://raw.githubusercontent.com/wp-cli/builds/gh-pages/phar/wp-cli.phar -L -o /usr/local/bin/wp \
## && rm -rf /root/.composer && chmod +x /usr/local/bin/wp \
# && true
# symfony
RUN set -x true \
&& curl https://symfony.com/installer -L -o /usr/local/bin/symfony \
&& chmod +x /usr/local/bin/symfony \
&& true
# laravel
RUN set -x true \
&& git clone https://github.com/laravel/installer /usr/local/src/laravel-installer \
&& cd /usr/local/src/laravel-installer \
&& git checkout v1.3.7 \
\
&& chown -R ${MY_USER}:${MY_GROUP} /usr/local/src/laravel-installer \
&& su - ${MY_USER} -c 'PATH=/usr/local/bin:$PATH; cd /usr/local/src/laravel-installer && composer install' \
&& ln -s /usr/local/src/laravel-installer/laravel /usr/local/bin/laravel \
&& rm -rf /usr/local/src/laravel-installer/laravel/.git \
\
&& true
# phalcon
RUN set -x true \
&& git clone https://github.com/phalcon/phalcon-devtools /usr/local/src/phalcon-devtools \
&& cd /usr/local/src/phalcon-devtools \
&& git checkout v2.0.9 \
\
&& chown -R ${MY_USER}:${MY_GROUP} /usr/local/src/phalcon-devtools \
&& su - ${MY_USER} -c 'cd /usr/local/src/phalcon-devtools && ./phalcon.sh' \
&& ln -s /usr/local/src/phalcon-devtools/phalcon.php /usr/local/bin/phalcon \
&& cd / \
&& rm -rf /usr/local/src/phalcon-devtools/.git \
\
&& true
## Drush ## Drush
#RUN set -x \ #RUN set -x \
# && DRUSH_VERSION="$( curl -q https://api.github.com/repos/drush-ops/drush/releases 2>/dev/null | grep tag_name | grep -Eo '\"[0-9.]+\"' | head -1 | sed 's/\"//g' )" \ # && DRUSH_VERSION="$( curl -q https://api.github.com/repos/drush-ops/drush/releases 2>/dev/null | grep tag_name | grep -Eo '\"[0-9.]+\"' | head -1 | sed 's/\"//g' )" \
@@ -278,6 +321,15 @@ RUN set -x \
&& PHP_ERROR="$( php -v 2>&1 1>/dev/null )" \ && PHP_ERROR="$( php -v 2>&1 1>/dev/null )" \
&& if [ -n "${PHP_ERROR}" ]; then echo "${PHP_ERROR}"; false; fi && if [ -n "${PHP_ERROR}" ]; then echo "${PHP_ERROR}"; false; fi
RUN set -x \
&& composer --version 2>/dev/null | grep -E 'version\s*[.0-9]+' && rm -rf /root/.composer \
&& drush --version | grep -E '[.0-9]+' && rm -rf /root/.drush \
&& wp --allow-root --version | grep -E '[.0-9]+' \
&& symfony --version | grep -E 'version\s*[.0-9]+' \
&& laravel --version | grep -E '(Installer|version)\s*[.0-9]+' \
&& phalcon commands | grep -E '[.0-9]+' \
&& true
### ###
### Copy files ### Copy files

View File

@@ -1,4 +1,4 @@
# Auto-generated via Ansible # Auto-generated via Ansible: edit build/ansible/DOCKERFILES/Dockerfile-work.j2 instead.
FROM devilbox/php-fpm:5.5-prod FROM devilbox/php-fpm:5.5-prod
MAINTAINER "cytopia" <cytopia@everythingcli.org> MAINTAINER "cytopia" <cytopia@everythingcli.org>
@@ -15,7 +15,7 @@ LABEL \
### ###
### Envs (Already set in parent container) ### Envs
### ###
ENV BASH_PROFILE=".bashrc" ENV BASH_PROFILE=".bashrc"
@@ -23,9 +23,20 @@ ENV BASH_PROFILE=".bashrc"
### ###
### Install Tools ### Install Tools
### ###
# System dev tools
RUN set -x \ RUN set -x \
&& apt-get update \
&& apt-get install --no-install-recommends --no-install-suggests -y \
dirmngr \
gnupg \
&& echo "deb http://ftp.debian.org/debian jessie-backports main" > /etc/apt/sources.list.d/backports.list \
&& apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv A1715D88E1DF1F24 \
&& echo "deb http://ppa.launchpad.net/git-core/ppa/ubuntu wily main" > /etc/apt/sources.list.d/git.list \
&& apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 2930ADAE8CAF5059EE73BB4B58712A2291FA4AD5 \
&& echo "deb http://repo.mongodb.org/apt/debian jessie/mongodb-org/3.6 main" > /etc/apt/sources.list.d/mongo.list \
&& curl -q "https://deb.nodesource.com/gpgkey/nodesource.gpg.key" 2>/dev/null | apt-key add - \
&& echo "deb http://deb.nodesource.com/node_8.x jessie main" > /etc/apt/sources.list.d/node.list \
&& curl -q https://www.postgresql.org/media/keys/ACCC4CF8.asc 2>/dev/null | apt-key add - \
&& echo "deb http://apt.postgresql.org/pub/repos/apt/ jessie-pgdg main" > /etc/apt/sources.list.d/pgsql.list \
&& apt-get update \ && apt-get update \
&& apt-get install --no-install-recommends --no-install-suggests -y \ && apt-get install --no-install-recommends --no-install-suggests -y \
ack-grep \ ack-grep \
@@ -49,14 +60,15 @@ RUN set -x \
less \ less \
libc-dev \ libc-dev \
make \ make \
# mongo-tools \ mongodb-org-shell \
mongodb-clients \ mongodb-org-tools \
moreutils \ moreutils \
mysql-client \ mysql-client \
nano \ nano \
net-tools \ net-tools \
netcat \ netcat \
# postgresql-client \ nodejs \
postgresql-client \
python-pip \ python-pip \
rubygems \ rubygems \
ruby-dev \ ruby-dev \
@@ -73,33 +85,69 @@ RUN set -x \
&& apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false $fetchDeps \ && apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false $fetchDeps \
&& rm -rf /var/lib/apt/lists/* && rm -rf /var/lib/apt/lists/*
## Node / NPM
#RUN set -x \ # composer
# && mkdir -p /usr/local/src \ RUN set -x true \
# && VERSION="$( curl -Lq https://nodejs.org 2>/dev/null | grep LTS | grep -Eo 'data-version.*.' | grep -oE 'v[0-9.]+' )" \ && curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/local/bin --filename=composer \
# && wget --retry-connrefused --waitretry=1 --read-timeout=20 --timeout=15 --tries=30 \ && true
# -P /usr/local/src https://nodejs.org/dist/${VERSION}/node-${VERSION}-linux-x64.tar.xz \ # drush
# && unxz /usr/local/src/node-${VERSION}-linux-x64.tar.xz \ RUN set -x true \
# && tar xvf /usr/local/src/node-${VERSION}-linux-x64.tar -C /usr/local/src \ && git clone https://github.com/drush-ops/drush.git /usr/local/src/drush \
# && ln -s /usr/local/src/node-${VERSION}-linux-x64 /usr/local/node \ && cd /usr/local/src/drush \
# && ln -s /usr/local/node/bin/* /usr/local/bin/ \ && git checkout $(git for-each-ref --format='%(*creatordate:raw)%(creatordate:raw) %(refname)' refs/tags | sort -n | sed 's/^.*tags\///g' | grep ^8 | tail -1) \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64.tar* \ \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64/LICENSE \ && chown -R ${MY_USER}:${MY_GROUP} /usr/local/src/drush \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64/*.md \ && su - ${MY_USER} -c 'PATH=/usr/local/bin:$PATH; cd /usr/local/src/drush && composer install --no-interaction --no-progress' \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64/include \ && ln -s /usr/local/src/drush/drush /usr/local/bin/drush \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64/share \ && rm -rf /usr/local/src/drush/.git \
# && npm --version | grep -E '[.0-9]+' \ && rm -rf /usr/local/src/drush/docs \
# && node --version | grep -E '[.0-9]+' \ && rm -rf /usr/local/src/drush/examples \
# && rm -rf /root/.config && rm -rf /usr/local/src/drush/misc \
# && rm -rf /usr/local/src/drush/tests \
## Composer && rm -rf /home/${MY_USER}/.composer \
#RUN set -x \ \
# && curl -sS https://getcomposer.org/installer | php \ && true
# && mv composer.phar /usr/local/bin/composer \ # drupalconsole
# && composer self-update RUN set -x true \
## && composer --version 2>/dev/null | grep -E 'version\s*[.0-9]+' \ && curl https://drupalconsole.com/installer -L -o /usr/local/bin/drupal \
## && rm -rf /root/.composer && chmod +x /usr/local/bin/drupal \
# && true
# wpcli
RUN set -x true \
&& curl https://raw.githubusercontent.com/wp-cli/builds/gh-pages/phar/wp-cli.phar -L -o /usr/local/bin/wp \
&& chmod +x /usr/local/bin/wp \
&& true
# symfony
RUN set -x true \
&& curl https://symfony.com/installer -L -o /usr/local/bin/symfony \
&& chmod +x /usr/local/bin/symfony \
&& true
# laravel
RUN set -x true \
&& git clone https://github.com/laravel/installer /usr/local/src/laravel-installer \
&& cd /usr/local/src/laravel-installer \
&& git checkout v2.0.0 \
\
&& chown -R ${MY_USER}:${MY_GROUP} /usr/local/src/laravel-installer \
&& su - ${MY_USER} -c 'PATH=/usr/local/bin:$PATH; cd /usr/local/src/laravel-installer && composer install' \
&& ln -s /usr/local/src/laravel-installer/laravel /usr/local/bin/laravel \
&& rm -rf /usr/local/src/laravel-installer/laravel/.git \
\
&& true
# phalcon
RUN set -x true \
&& git clone https://github.com/phalcon/phalcon-devtools /usr/local/src/phalcon-devtools \
&& cd /usr/local/src/phalcon-devtools \
&& git checkout $(git describe --abbrev=0 --tags) \
\
&& chown -R ${MY_USER}:${MY_GROUP} /usr/local/src/phalcon-devtools \
&& su - ${MY_USER} -c 'cd /usr/local/src/phalcon-devtools && ./phalcon.sh' \
&& ln -s /usr/local/src/phalcon-devtools/phalcon.php /usr/local/bin/phalcon \
&& cd / \
&& rm -rf /usr/local/src/phalcon-devtools/.git \
\
&& true
## Drush ## Drush
#RUN set -x \ #RUN set -x \
# && DRUSH_VERSION="$( curl -q https://api.github.com/repos/drush-ops/drush/releases 2>/dev/null | grep tag_name | grep -Eo '\"[0-9.]+\"' | head -1 | sed 's/\"//g' )" \ # && DRUSH_VERSION="$( curl -q https://api.github.com/repos/drush-ops/drush/releases 2>/dev/null | grep tag_name | grep -Eo '\"[0-9.]+\"' | head -1 | sed 's/\"//g' )" \
@@ -278,6 +326,16 @@ RUN set -x \
&& PHP_ERROR="$( php -v 2>&1 1>/dev/null )" \ && PHP_ERROR="$( php -v 2>&1 1>/dev/null )" \
&& if [ -n "${PHP_ERROR}" ]; then echo "${PHP_ERROR}"; false; fi && if [ -n "${PHP_ERROR}" ]; then echo "${PHP_ERROR}"; false; fi
RUN set -x \
&& composer --version 2>/dev/null | grep -E 'version\s*[.0-9]+' && rm -rf /root/.composer \
&& drush --version | grep -E '[.0-9]+' && rm -rf /root/.drush \
&& drupal --version | grep -E 'Drupal Console Launcher\s*[.0-9]' \
&& wp --allow-root --version | grep -E '[.0-9]+' \
&& symfony --version | grep -E 'version\s*[.0-9]+' \
&& laravel --version | grep -E '(Installer|version)\s*[.0-9]+' \
&& phalcon commands | grep -E '[.0-9]+' \
&& true
### ###
### Copy files ### Copy files

View File

@@ -1,4 +1,4 @@
# Auto-generated via Ansible # Auto-generated via Ansible: edit build/ansible/DOCKERFILES/Dockerfile-work.j2 instead.
FROM devilbox/php-fpm:5.6-prod FROM devilbox/php-fpm:5.6-prod
MAINTAINER "cytopia" <cytopia@everythingcli.org> MAINTAINER "cytopia" <cytopia@everythingcli.org>
@@ -15,7 +15,7 @@ LABEL \
### ###
### Envs (Already set in parent container) ### Envs
### ###
ENV BASH_PROFILE=".bashrc" ENV BASH_PROFILE=".bashrc"
@@ -23,9 +23,20 @@ ENV BASH_PROFILE=".bashrc"
### ###
### Install Tools ### Install Tools
### ###
# System dev tools
RUN set -x \ RUN set -x \
&& apt-get update \
&& apt-get install --no-install-recommends --no-install-suggests -y \
dirmngr \
gnupg \
&& echo "deb http://ftp.debian.org/debian jessie-backports main" > /etc/apt/sources.list.d/backports.list \
&& apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv A1715D88E1DF1F24 \
&& echo "deb http://ppa.launchpad.net/git-core/ppa/ubuntu wily main" > /etc/apt/sources.list.d/git.list \
&& apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 2930ADAE8CAF5059EE73BB4B58712A2291FA4AD5 \
&& echo "deb http://repo.mongodb.org/apt/debian jessie/mongodb-org/3.6 main" > /etc/apt/sources.list.d/mongo.list \
&& curl -q "https://deb.nodesource.com/gpgkey/nodesource.gpg.key" 2>/dev/null | apt-key add - \
&& echo "deb http://deb.nodesource.com/node_8.x jessie main" > /etc/apt/sources.list.d/node.list \
&& curl -q https://www.postgresql.org/media/keys/ACCC4CF8.asc 2>/dev/null | apt-key add - \
&& echo "deb http://apt.postgresql.org/pub/repos/apt/ jessie-pgdg main" > /etc/apt/sources.list.d/pgsql.list \
&& apt-get update \ && apt-get update \
&& apt-get install --no-install-recommends --no-install-suggests -y \ && apt-get install --no-install-recommends --no-install-suggests -y \
ack-grep \ ack-grep \
@@ -49,14 +60,15 @@ RUN set -x \
less \ less \
libc-dev \ libc-dev \
make \ make \
# mongo-tools \ mongodb-org-shell \
mongodb-clients \ mongodb-org-tools \
moreutils \ moreutils \
mysql-client \ mysql-client \
nano \ nano \
net-tools \ net-tools \
netcat \ netcat \
# postgresql-client \ nodejs \
postgresql-client \
python-pip \ python-pip \
rubygems \ rubygems \
ruby-dev \ ruby-dev \
@@ -73,33 +85,69 @@ RUN set -x \
&& apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false $fetchDeps \ && apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false $fetchDeps \
&& rm -rf /var/lib/apt/lists/* && rm -rf /var/lib/apt/lists/*
## Node / NPM
#RUN set -x \ # composer
# && mkdir -p /usr/local/src \ RUN set -x true \
# && VERSION="$( curl -Lq https://nodejs.org 2>/dev/null | grep LTS | grep -Eo 'data-version.*.' | grep -oE 'v[0-9.]+' )" \ && curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/local/bin --filename=composer \
# && wget --retry-connrefused --waitretry=1 --read-timeout=20 --timeout=15 --tries=30 \ && true
# -P /usr/local/src https://nodejs.org/dist/${VERSION}/node-${VERSION}-linux-x64.tar.xz \ # drush
# && unxz /usr/local/src/node-${VERSION}-linux-x64.tar.xz \ RUN set -x true \
# && tar xvf /usr/local/src/node-${VERSION}-linux-x64.tar -C /usr/local/src \ && git clone https://github.com/drush-ops/drush.git /usr/local/src/drush \
# && ln -s /usr/local/src/node-${VERSION}-linux-x64 /usr/local/node \ && cd /usr/local/src/drush \
# && ln -s /usr/local/node/bin/* /usr/local/bin/ \ && git checkout $(git for-each-ref --format='%(*creatordate:raw)%(creatordate:raw) %(refname)' refs/tags | sort -n | tail -1 | sed 's/^.*tags\///g') \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64.tar* \ \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64/LICENSE \ && chown -R ${MY_USER}:${MY_GROUP} /usr/local/src/drush \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64/*.md \ && su - ${MY_USER} -c 'PATH=/usr/local/bin:$PATH; cd /usr/local/src/drush && composer install --no-interaction --no-progress' \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64/include \ && ln -s /usr/local/src/drush/drush /usr/local/bin/drush \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64/share \ && rm -rf /usr/local/src/drush/.git \
# && npm --version | grep -E '[.0-9]+' \ && rm -rf /usr/local/src/drush/docs \
# && node --version | grep -E '[.0-9]+' \ && rm -rf /usr/local/src/drush/examples \
# && rm -rf /root/.config && rm -rf /usr/local/src/drush/misc \
# && rm -rf /usr/local/src/drush/tests \
## Composer && rm -rf /home/${MY_USER}/.composer \
#RUN set -x \ \
# && curl -sS https://getcomposer.org/installer | php \ && true
# && mv composer.phar /usr/local/bin/composer \ # drupalconsole
# && composer self-update RUN set -x true \
## && composer --version 2>/dev/null | grep -E 'version\s*[.0-9]+' \ && curl https://drupalconsole.com/installer -L -o /usr/local/bin/drupal \
## && rm -rf /root/.composer && chmod +x /usr/local/bin/drupal \
# && true
# wpcli
RUN set -x true \
&& curl https://raw.githubusercontent.com/wp-cli/builds/gh-pages/phar/wp-cli.phar -L -o /usr/local/bin/wp \
&& chmod +x /usr/local/bin/wp \
&& true
# symfony
RUN set -x true \
&& curl https://symfony.com/installer -L -o /usr/local/bin/symfony \
&& chmod +x /usr/local/bin/symfony \
&& true
# laravel
RUN set -x true \
&& git clone https://github.com/laravel/installer /usr/local/src/laravel-installer \
&& cd /usr/local/src/laravel-installer \
&& git checkout v2.0.0 \
\
&& chown -R ${MY_USER}:${MY_GROUP} /usr/local/src/laravel-installer \
&& su - ${MY_USER} -c 'PATH=/usr/local/bin:$PATH; cd /usr/local/src/laravel-installer && composer install' \
&& ln -s /usr/local/src/laravel-installer/laravel /usr/local/bin/laravel \
&& rm -rf /usr/local/src/laravel-installer/laravel/.git \
\
&& true
# phalcon
RUN set -x true \
&& git clone https://github.com/phalcon/phalcon-devtools /usr/local/src/phalcon-devtools \
&& cd /usr/local/src/phalcon-devtools \
&& git checkout $(git describe --abbrev=0 --tags) \
\
&& chown -R ${MY_USER}:${MY_GROUP} /usr/local/src/phalcon-devtools \
&& su - ${MY_USER} -c 'cd /usr/local/src/phalcon-devtools && ./phalcon.sh' \
&& ln -s /usr/local/src/phalcon-devtools/phalcon.php /usr/local/bin/phalcon \
&& cd / \
&& rm -rf /usr/local/src/phalcon-devtools/.git \
\
&& true
## Drush ## Drush
#RUN set -x \ #RUN set -x \
# && DRUSH_VERSION="$( curl -q https://api.github.com/repos/drush-ops/drush/releases 2>/dev/null | grep tag_name | grep -Eo '\"[0-9.]+\"' | head -1 | sed 's/\"//g' )" \ # && DRUSH_VERSION="$( curl -q https://api.github.com/repos/drush-ops/drush/releases 2>/dev/null | grep tag_name | grep -Eo '\"[0-9.]+\"' | head -1 | sed 's/\"//g' )" \
@@ -278,6 +326,16 @@ RUN set -x \
&& PHP_ERROR="$( php -v 2>&1 1>/dev/null )" \ && PHP_ERROR="$( php -v 2>&1 1>/dev/null )" \
&& if [ -n "${PHP_ERROR}" ]; then echo "${PHP_ERROR}"; false; fi && if [ -n "${PHP_ERROR}" ]; then echo "${PHP_ERROR}"; false; fi
RUN set -x \
&& composer --version 2>/dev/null | grep -E 'version\s*[.0-9]+' && rm -rf /root/.composer \
&& drush --version | grep -E '[.0-9]+' && rm -rf /root/.drush \
&& drupal --version | grep -E 'Drupal Console Launcher\s*[.0-9]' \
&& wp --allow-root --version | grep -E '[.0-9]+' \
&& symfony --version | grep -E 'version\s*[.0-9]+' \
&& laravel --version | grep -E '(Installer|version)\s*[.0-9]+' \
&& phalcon commands | grep -E '[.0-9]+' \
&& true
### ###
### Copy files ### Copy files

View File

@@ -1,4 +1,4 @@
# Auto-generated via Ansible # Auto-generated via Ansible: edit build/ansible/DOCKERFILES/Dockerfile-work.j2 instead.
FROM devilbox/php-fpm:7.0-prod FROM devilbox/php-fpm:7.0-prod
MAINTAINER "cytopia" <cytopia@everythingcli.org> MAINTAINER "cytopia" <cytopia@everythingcli.org>
@@ -15,7 +15,7 @@ LABEL \
### ###
### Envs (Already set in parent container) ### Envs
### ###
ENV BASH_PROFILE=".bashrc" ENV BASH_PROFILE=".bashrc"
@@ -23,9 +23,20 @@ ENV BASH_PROFILE=".bashrc"
### ###
### Install Tools ### Install Tools
### ###
# System dev tools
RUN set -x \ RUN set -x \
&& apt-get update \
&& apt-get install --no-install-recommends --no-install-suggests -y \
dirmngr \
gnupg \
&& echo "deb http://ftp.debian.org/debian jessie-backports main" > /etc/apt/sources.list.d/backports.list \
&& apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv A1715D88E1DF1F24 \
&& echo "deb http://ppa.launchpad.net/git-core/ppa/ubuntu wily main" > /etc/apt/sources.list.d/git.list \
&& apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 2930ADAE8CAF5059EE73BB4B58712A2291FA4AD5 \
&& echo "deb http://repo.mongodb.org/apt/debian jessie/mongodb-org/3.6 main" > /etc/apt/sources.list.d/mongo.list \
&& curl -q "https://deb.nodesource.com/gpgkey/nodesource.gpg.key" 2>/dev/null | apt-key add - \
&& echo "deb http://deb.nodesource.com/node_8.x jessie main" > /etc/apt/sources.list.d/node.list \
&& curl -q https://www.postgresql.org/media/keys/ACCC4CF8.asc 2>/dev/null | apt-key add - \
&& echo "deb http://apt.postgresql.org/pub/repos/apt/ jessie-pgdg main" > /etc/apt/sources.list.d/pgsql.list \
&& apt-get update \ && apt-get update \
&& apt-get install --no-install-recommends --no-install-suggests -y \ && apt-get install --no-install-recommends --no-install-suggests -y \
ack-grep \ ack-grep \
@@ -49,14 +60,15 @@ RUN set -x \
less \ less \
libc-dev \ libc-dev \
make \ make \
# mongo-tools \ mongodb-org-shell \
mongodb-clients \ mongodb-org-tools \
moreutils \ moreutils \
mysql-client \ mysql-client \
nano \ nano \
net-tools \ net-tools \
netcat \ netcat \
# postgresql-client \ nodejs \
postgresql-client \
python-pip \ python-pip \
rubygems \ rubygems \
ruby-dev \ ruby-dev \
@@ -73,33 +85,69 @@ RUN set -x \
&& apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false $fetchDeps \ && apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false $fetchDeps \
&& rm -rf /var/lib/apt/lists/* && rm -rf /var/lib/apt/lists/*
## Node / NPM
#RUN set -x \ # composer
# && mkdir -p /usr/local/src \ RUN set -x true \
# && VERSION="$( curl -Lq https://nodejs.org 2>/dev/null | grep LTS | grep -Eo 'data-version.*.' | grep -oE 'v[0-9.]+' )" \ && curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/local/bin --filename=composer \
# && wget --retry-connrefused --waitretry=1 --read-timeout=20 --timeout=15 --tries=30 \ && true
# -P /usr/local/src https://nodejs.org/dist/${VERSION}/node-${VERSION}-linux-x64.tar.xz \ # drush
# && unxz /usr/local/src/node-${VERSION}-linux-x64.tar.xz \ RUN set -x true \
# && tar xvf /usr/local/src/node-${VERSION}-linux-x64.tar -C /usr/local/src \ && git clone https://github.com/drush-ops/drush.git /usr/local/src/drush \
# && ln -s /usr/local/src/node-${VERSION}-linux-x64 /usr/local/node \ && cd /usr/local/src/drush \
# && ln -s /usr/local/node/bin/* /usr/local/bin/ \ && git checkout $(git for-each-ref --format='%(*creatordate:raw)%(creatordate:raw) %(refname)' refs/tags | sort -n | tail -1 | sed 's/^.*tags\///g') \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64.tar* \ \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64/LICENSE \ && chown -R ${MY_USER}:${MY_GROUP} /usr/local/src/drush \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64/*.md \ && su - ${MY_USER} -c 'PATH=/usr/local/bin:$PATH; cd /usr/local/src/drush && composer install --no-interaction --no-progress' \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64/include \ && ln -s /usr/local/src/drush/drush /usr/local/bin/drush \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64/share \ && rm -rf /usr/local/src/drush/.git \
# && npm --version | grep -E '[.0-9]+' \ && rm -rf /usr/local/src/drush/docs \
# && node --version | grep -E '[.0-9]+' \ && rm -rf /usr/local/src/drush/examples \
# && rm -rf /root/.config && rm -rf /usr/local/src/drush/misc \
# && rm -rf /usr/local/src/drush/tests \
## Composer && rm -rf /home/${MY_USER}/.composer \
#RUN set -x \ \
# && curl -sS https://getcomposer.org/installer | php \ && true
# && mv composer.phar /usr/local/bin/composer \ # drupalconsole
# && composer self-update RUN set -x true \
## && composer --version 2>/dev/null | grep -E 'version\s*[.0-9]+' \ && curl https://drupalconsole.com/installer -L -o /usr/local/bin/drupal \
## && rm -rf /root/.composer && chmod +x /usr/local/bin/drupal \
# && true
# wpcli
RUN set -x true \
&& curl https://raw.githubusercontent.com/wp-cli/builds/gh-pages/phar/wp-cli.phar -L -o /usr/local/bin/wp \
&& chmod +x /usr/local/bin/wp \
&& true
# symfony
RUN set -x true \
&& curl https://symfony.com/installer -L -o /usr/local/bin/symfony \
&& chmod +x /usr/local/bin/symfony \
&& true
# laravel
RUN set -x true \
&& git clone https://github.com/laravel/installer /usr/local/src/laravel-installer \
&& cd /usr/local/src/laravel-installer \
&& git checkout v2.0.0 \
\
&& chown -R ${MY_USER}:${MY_GROUP} /usr/local/src/laravel-installer \
&& su - ${MY_USER} -c 'PATH=/usr/local/bin:$PATH; cd /usr/local/src/laravel-installer && composer install' \
&& ln -s /usr/local/src/laravel-installer/laravel /usr/local/bin/laravel \
&& rm -rf /usr/local/src/laravel-installer/laravel/.git \
\
&& true
# phalcon
RUN set -x true \
&& git clone https://github.com/phalcon/phalcon-devtools /usr/local/src/phalcon-devtools \
&& cd /usr/local/src/phalcon-devtools \
&& git checkout $(git describe --abbrev=0 --tags) \
\
&& chown -R ${MY_USER}:${MY_GROUP} /usr/local/src/phalcon-devtools \
&& su - ${MY_USER} -c 'cd /usr/local/src/phalcon-devtools && ./phalcon.sh' \
&& ln -s /usr/local/src/phalcon-devtools/phalcon.php /usr/local/bin/phalcon \
&& cd / \
&& rm -rf /usr/local/src/phalcon-devtools/.git \
\
&& true
## Drush ## Drush
#RUN set -x \ #RUN set -x \
# && DRUSH_VERSION="$( curl -q https://api.github.com/repos/drush-ops/drush/releases 2>/dev/null | grep tag_name | grep -Eo '\"[0-9.]+\"' | head -1 | sed 's/\"//g' )" \ # && DRUSH_VERSION="$( curl -q https://api.github.com/repos/drush-ops/drush/releases 2>/dev/null | grep tag_name | grep -Eo '\"[0-9.]+\"' | head -1 | sed 's/\"//g' )" \
@@ -278,6 +326,16 @@ RUN set -x \
&& PHP_ERROR="$( php -v 2>&1 1>/dev/null )" \ && PHP_ERROR="$( php -v 2>&1 1>/dev/null )" \
&& if [ -n "${PHP_ERROR}" ]; then echo "${PHP_ERROR}"; false; fi && if [ -n "${PHP_ERROR}" ]; then echo "${PHP_ERROR}"; false; fi
RUN set -x \
&& composer --version 2>/dev/null | grep -E 'version\s*[.0-9]+' && rm -rf /root/.composer \
&& drush --version | grep -E '[.0-9]+' && rm -rf /root/.drush \
&& drupal --version | grep -E 'Drupal Console Launcher\s*[.0-9]' \
&& wp --allow-root --version | grep -E '[.0-9]+' \
&& symfony --version | grep -E 'version\s*[.0-9]+' \
&& laravel --version | grep -E '(Installer|version)\s*[.0-9]+' \
&& phalcon commands | grep -E '[.0-9]+' \
&& true
### ###
### Copy files ### Copy files

View File

@@ -1,4 +1,4 @@
# Auto-generated via Ansible # Auto-generated via Ansible: edit build/ansible/DOCKERFILES/Dockerfile-work.j2 instead.
FROM devilbox/php-fpm:7.1-prod FROM devilbox/php-fpm:7.1-prod
MAINTAINER "cytopia" <cytopia@everythingcli.org> MAINTAINER "cytopia" <cytopia@everythingcli.org>
@@ -15,7 +15,7 @@ LABEL \
### ###
### Envs (Already set in parent container) ### Envs
### ###
ENV BASH_PROFILE=".bashrc" ENV BASH_PROFILE=".bashrc"
@@ -23,9 +23,20 @@ ENV BASH_PROFILE=".bashrc"
### ###
### Install Tools ### Install Tools
### ###
# System dev tools
RUN set -x \ RUN set -x \
&& apt-get update \
&& apt-get install --no-install-recommends --no-install-suggests -y \
dirmngr \
gnupg \
&& echo "deb http://ftp.debian.org/debian jessie-backports main" > /etc/apt/sources.list.d/backports.list \
&& apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv A1715D88E1DF1F24 \
&& echo "deb http://ppa.launchpad.net/git-core/ppa/ubuntu wily main" > /etc/apt/sources.list.d/git.list \
&& apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 2930ADAE8CAF5059EE73BB4B58712A2291FA4AD5 \
&& echo "deb http://repo.mongodb.org/apt/debian jessie/mongodb-org/3.6 main" > /etc/apt/sources.list.d/mongo.list \
&& curl -q "https://deb.nodesource.com/gpgkey/nodesource.gpg.key" 2>/dev/null | apt-key add - \
&& echo "deb http://deb.nodesource.com/node_8.x jessie main" > /etc/apt/sources.list.d/node.list \
&& curl -q https://www.postgresql.org/media/keys/ACCC4CF8.asc 2>/dev/null | apt-key add - \
&& echo "deb http://apt.postgresql.org/pub/repos/apt/ jessie-pgdg main" > /etc/apt/sources.list.d/pgsql.list \
&& apt-get update \ && apt-get update \
&& apt-get install --no-install-recommends --no-install-suggests -y \ && apt-get install --no-install-recommends --no-install-suggests -y \
ack-grep \ ack-grep \
@@ -49,14 +60,15 @@ RUN set -x \
less \ less \
libc-dev \ libc-dev \
make \ make \
# mongo-tools \ mongodb-org-shell \
mongodb-clients \ mongodb-org-tools \
moreutils \ moreutils \
mysql-client \ mysql-client \
nano \ nano \
net-tools \ net-tools \
netcat \ netcat \
# postgresql-client \ nodejs \
postgresql-client \
python-pip \ python-pip \
rubygems \ rubygems \
ruby-dev \ ruby-dev \
@@ -73,33 +85,69 @@ RUN set -x \
&& apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false $fetchDeps \ && apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false $fetchDeps \
&& rm -rf /var/lib/apt/lists/* && rm -rf /var/lib/apt/lists/*
## Node / NPM
#RUN set -x \ # composer
# && mkdir -p /usr/local/src \ RUN set -x true \
# && VERSION="$( curl -Lq https://nodejs.org 2>/dev/null | grep LTS | grep -Eo 'data-version.*.' | grep -oE 'v[0-9.]+' )" \ && curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/local/bin --filename=composer \
# && wget --retry-connrefused --waitretry=1 --read-timeout=20 --timeout=15 --tries=30 \ && true
# -P /usr/local/src https://nodejs.org/dist/${VERSION}/node-${VERSION}-linux-x64.tar.xz \ # drush
# && unxz /usr/local/src/node-${VERSION}-linux-x64.tar.xz \ RUN set -x true \
# && tar xvf /usr/local/src/node-${VERSION}-linux-x64.tar -C /usr/local/src \ && git clone https://github.com/drush-ops/drush.git /usr/local/src/drush \
# && ln -s /usr/local/src/node-${VERSION}-linux-x64 /usr/local/node \ && cd /usr/local/src/drush \
# && ln -s /usr/local/node/bin/* /usr/local/bin/ \ && git checkout $(git for-each-ref --format='%(*creatordate:raw)%(creatordate:raw) %(refname)' refs/tags | sort -n | tail -1 | sed 's/^.*tags\///g') \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64.tar* \ \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64/LICENSE \ && chown -R ${MY_USER}:${MY_GROUP} /usr/local/src/drush \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64/*.md \ && su - ${MY_USER} -c 'PATH=/usr/local/bin:$PATH; cd /usr/local/src/drush && composer install --no-interaction --no-progress' \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64/include \ && ln -s /usr/local/src/drush/drush /usr/local/bin/drush \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64/share \ && rm -rf /usr/local/src/drush/.git \
# && npm --version | grep -E '[.0-9]+' \ && rm -rf /usr/local/src/drush/docs \
# && node --version | grep -E '[.0-9]+' \ && rm -rf /usr/local/src/drush/examples \
# && rm -rf /root/.config && rm -rf /usr/local/src/drush/misc \
# && rm -rf /usr/local/src/drush/tests \
## Composer && rm -rf /home/${MY_USER}/.composer \
#RUN set -x \ \
# && curl -sS https://getcomposer.org/installer | php \ && true
# && mv composer.phar /usr/local/bin/composer \ # drupalconsole
# && composer self-update RUN set -x true \
## && composer --version 2>/dev/null | grep -E 'version\s*[.0-9]+' \ && curl https://drupalconsole.com/installer -L -o /usr/local/bin/drupal \
## && rm -rf /root/.composer && chmod +x /usr/local/bin/drupal \
# && true
# wpcli
RUN set -x true \
&& curl https://raw.githubusercontent.com/wp-cli/builds/gh-pages/phar/wp-cli.phar -L -o /usr/local/bin/wp \
&& chmod +x /usr/local/bin/wp \
&& true
# symfony
RUN set -x true \
&& curl https://symfony.com/installer -L -o /usr/local/bin/symfony \
&& chmod +x /usr/local/bin/symfony \
&& true
# laravel
RUN set -x true \
&& git clone https://github.com/laravel/installer /usr/local/src/laravel-installer \
&& cd /usr/local/src/laravel-installer \
&& git checkout $(git describe --abbrev=0 --tags) \
\
&& chown -R ${MY_USER}:${MY_GROUP} /usr/local/src/laravel-installer \
&& su - ${MY_USER} -c 'PATH=/usr/local/bin:$PATH; cd /usr/local/src/laravel-installer && composer install' \
&& ln -s /usr/local/src/laravel-installer/laravel /usr/local/bin/laravel \
&& rm -rf /usr/local/src/laravel-installer/laravel/.git \
\
&& true
# phalcon
RUN set -x true \
&& git clone https://github.com/phalcon/phalcon-devtools /usr/local/src/phalcon-devtools \
&& cd /usr/local/src/phalcon-devtools \
&& git checkout $(git describe --abbrev=0 --tags) \
\
&& chown -R ${MY_USER}:${MY_GROUP} /usr/local/src/phalcon-devtools \
&& su - ${MY_USER} -c 'cd /usr/local/src/phalcon-devtools && ./phalcon.sh' \
&& ln -s /usr/local/src/phalcon-devtools/phalcon.php /usr/local/bin/phalcon \
&& cd / \
&& rm -rf /usr/local/src/phalcon-devtools/.git \
\
&& true
## Drush ## Drush
#RUN set -x \ #RUN set -x \
# && DRUSH_VERSION="$( curl -q https://api.github.com/repos/drush-ops/drush/releases 2>/dev/null | grep tag_name | grep -Eo '\"[0-9.]+\"' | head -1 | sed 's/\"//g' )" \ # && DRUSH_VERSION="$( curl -q https://api.github.com/repos/drush-ops/drush/releases 2>/dev/null | grep tag_name | grep -Eo '\"[0-9.]+\"' | head -1 | sed 's/\"//g' )" \
@@ -278,6 +326,16 @@ RUN set -x \
&& PHP_ERROR="$( php -v 2>&1 1>/dev/null )" \ && PHP_ERROR="$( php -v 2>&1 1>/dev/null )" \
&& if [ -n "${PHP_ERROR}" ]; then echo "${PHP_ERROR}"; false; fi && if [ -n "${PHP_ERROR}" ]; then echo "${PHP_ERROR}"; false; fi
RUN set -x \
&& composer --version 2>/dev/null | grep -E 'version\s*[.0-9]+' && rm -rf /root/.composer \
&& drush --version | grep -E '[.0-9]+' && rm -rf /root/.drush \
&& drupal --version | grep -E 'Drupal Console Launcher\s*[.0-9]' \
&& wp --allow-root --version | grep -E '[.0-9]+' \
&& symfony --version | grep -E 'version\s*[.0-9]+' \
&& laravel --version | grep -E '(Installer|version)\s*[.0-9]+' \
&& phalcon commands | grep -E '[.0-9]+' \
&& true
### ###
### Copy files ### Copy files

View File

@@ -1,4 +1,4 @@
# Auto-generated via Ansible # Auto-generated via Ansible: edit build/ansible/DOCKERFILES/Dockerfile-work.j2 instead.
FROM devilbox/php-fpm:7.2-prod FROM devilbox/php-fpm:7.2-prod
MAINTAINER "cytopia" <cytopia@everythingcli.org> MAINTAINER "cytopia" <cytopia@everythingcli.org>
@@ -15,7 +15,7 @@ LABEL \
### ###
### Envs (Already set in parent container) ### Envs
### ###
ENV BASH_PROFILE=".bashrc" ENV BASH_PROFILE=".bashrc"
@@ -23,9 +23,20 @@ ENV BASH_PROFILE=".bashrc"
### ###
### Install Tools ### Install Tools
### ###
# System dev tools
RUN set -x \ RUN set -x \
&& apt-get update \
&& apt-get install --no-install-recommends --no-install-suggests -y \
dirmngr \
gnupg \
&& echo "deb http://ftp.debian.org/debian jessie-backports main" > /etc/apt/sources.list.d/backports.list \
&& apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv A1715D88E1DF1F24 \
&& echo "deb http://ppa.launchpad.net/git-core/ppa/ubuntu artful main" > /etc/apt/sources.list.d/git.list \
&& apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 2930ADAE8CAF5059EE73BB4B58712A2291FA4AD5 \
&& echo "deb http://repo.mongodb.org/apt/debian jessie/mongodb-org/3.6 main" > /etc/apt/sources.list.d/mongo.list \
&& curl -q "https://deb.nodesource.com/gpgkey/nodesource.gpg.key" 2>/dev/null | apt-key add - \
&& echo "deb http://deb.nodesource.com/node_8.x stretch main" > /etc/apt/sources.list.d/node.list \
&& curl -q https://www.postgresql.org/media/keys/ACCC4CF8.asc 2>/dev/null | apt-key add - \
&& echo "deb http://apt.postgresql.org/pub/repos/apt/ stretch-pgdg main" > /etc/apt/sources.list.d/pgsql.list \
&& apt-get update \ && apt-get update \
&& apt-get install --no-install-recommends --no-install-suggests -y \ && apt-get install --no-install-recommends --no-install-suggests -y \
ack-grep \ ack-grep \
@@ -49,14 +60,15 @@ RUN set -x \
less \ less \
libc-dev \ libc-dev \
make \ make \
# mongo-tools \ mongodb-org-shell \
mongodb-clients \ mongodb-org-tools \
moreutils \ moreutils \
mysql-client \ mysql-client \
nano \ nano \
net-tools \ net-tools \
netcat \ netcat \
# postgresql-client \ nodejs \
postgresql-client \
python-pip \ python-pip \
rubygems \ rubygems \
ruby-dev \ ruby-dev \
@@ -73,33 +85,69 @@ RUN set -x \
&& apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false $fetchDeps \ && apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false $fetchDeps \
&& rm -rf /var/lib/apt/lists/* && rm -rf /var/lib/apt/lists/*
## Node / NPM
#RUN set -x \ # composer
# && mkdir -p /usr/local/src \ RUN set -x true \
# && VERSION="$( curl -Lq https://nodejs.org 2>/dev/null | grep LTS | grep -Eo 'data-version.*.' | grep -oE 'v[0-9.]+' )" \ && curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/local/bin --filename=composer \
# && wget --retry-connrefused --waitretry=1 --read-timeout=20 --timeout=15 --tries=30 \ && true
# -P /usr/local/src https://nodejs.org/dist/${VERSION}/node-${VERSION}-linux-x64.tar.xz \ # drush
# && unxz /usr/local/src/node-${VERSION}-linux-x64.tar.xz \ RUN set -x true \
# && tar xvf /usr/local/src/node-${VERSION}-linux-x64.tar -C /usr/local/src \ && git clone https://github.com/drush-ops/drush.git /usr/local/src/drush \
# && ln -s /usr/local/src/node-${VERSION}-linux-x64 /usr/local/node \ && cd /usr/local/src/drush \
# && ln -s /usr/local/node/bin/* /usr/local/bin/ \ && git checkout $(git for-each-ref --format='%(*creatordate:raw)%(creatordate:raw) %(refname)' refs/tags | sort -n | tail -1 | sed 's/^.*tags\///g') \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64.tar* \ \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64/LICENSE \ && chown -R ${MY_USER}:${MY_GROUP} /usr/local/src/drush \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64/*.md \ && su - ${MY_USER} -c 'PATH=/usr/local/bin:$PATH; cd /usr/local/src/drush && composer install --no-interaction --no-progress' \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64/include \ && ln -s /usr/local/src/drush/drush /usr/local/bin/drush \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64/share \ && rm -rf /usr/local/src/drush/.git \
# && npm --version | grep -E '[.0-9]+' \ && rm -rf /usr/local/src/drush/docs \
# && node --version | grep -E '[.0-9]+' \ && rm -rf /usr/local/src/drush/examples \
# && rm -rf /root/.config && rm -rf /usr/local/src/drush/misc \
# && rm -rf /usr/local/src/drush/tests \
## Composer && rm -rf /home/${MY_USER}/.composer \
#RUN set -x \ \
# && curl -sS https://getcomposer.org/installer | php \ && true
# && mv composer.phar /usr/local/bin/composer \ # drupalconsole
# && composer self-update RUN set -x true \
## && composer --version 2>/dev/null | grep -E 'version\s*[.0-9]+' \ && curl https://drupalconsole.com/installer -L -o /usr/local/bin/drupal \
## && rm -rf /root/.composer && chmod +x /usr/local/bin/drupal \
# && true
# wpcli
RUN set -x true \
&& curl https://raw.githubusercontent.com/wp-cli/builds/gh-pages/phar/wp-cli.phar -L -o /usr/local/bin/wp \
&& chmod +x /usr/local/bin/wp \
&& true
# symfony
RUN set -x true \
&& curl https://symfony.com/installer -L -o /usr/local/bin/symfony \
&& chmod +x /usr/local/bin/symfony \
&& true
# laravel
RUN set -x true \
&& git clone https://github.com/laravel/installer /usr/local/src/laravel-installer \
&& cd /usr/local/src/laravel-installer \
&& git checkout $(git describe --abbrev=0 --tags) \
\
&& chown -R ${MY_USER}:${MY_GROUP} /usr/local/src/laravel-installer \
&& su - ${MY_USER} -c 'PATH=/usr/local/bin:$PATH; cd /usr/local/src/laravel-installer && composer install' \
&& ln -s /usr/local/src/laravel-installer/laravel /usr/local/bin/laravel \
&& rm -rf /usr/local/src/laravel-installer/laravel/.git \
\
&& true
# phalcon
RUN set -x true \
&& git clone https://github.com/phalcon/phalcon-devtools /usr/local/src/phalcon-devtools \
&& cd /usr/local/src/phalcon-devtools \
&& git checkout $(git describe --abbrev=0 --tags) \
\
&& chown -R ${MY_USER}:${MY_GROUP} /usr/local/src/phalcon-devtools \
&& su - ${MY_USER} -c 'cd /usr/local/src/phalcon-devtools && ./phalcon.sh' \
&& ln -s /usr/local/src/phalcon-devtools/phalcon.php /usr/local/bin/phalcon \
&& cd / \
&& rm -rf /usr/local/src/phalcon-devtools/.git \
\
&& true
## Drush ## Drush
#RUN set -x \ #RUN set -x \
# && DRUSH_VERSION="$( curl -q https://api.github.com/repos/drush-ops/drush/releases 2>/dev/null | grep tag_name | grep -Eo '\"[0-9.]+\"' | head -1 | sed 's/\"//g' )" \ # && DRUSH_VERSION="$( curl -q https://api.github.com/repos/drush-ops/drush/releases 2>/dev/null | grep tag_name | grep -Eo '\"[0-9.]+\"' | head -1 | sed 's/\"//g' )" \
@@ -278,6 +326,16 @@ RUN set -x \
&& PHP_ERROR="$( php -v 2>&1 1>/dev/null )" \ && PHP_ERROR="$( php -v 2>&1 1>/dev/null )" \
&& if [ -n "${PHP_ERROR}" ]; then echo "${PHP_ERROR}"; false; fi && if [ -n "${PHP_ERROR}" ]; then echo "${PHP_ERROR}"; false; fi
RUN set -x \
&& composer --version 2>/dev/null | grep -E 'version\s*[.0-9]+' && rm -rf /root/.composer \
&& drush --version | grep -E '[.0-9]+' && rm -rf /root/.drush \
&& drupal --version | grep -E 'Drupal Console Launcher\s*[.0-9]' \
&& wp --allow-root --version | grep -E '[.0-9]+' \
&& symfony --version | grep -E 'version\s*[.0-9]+' \
&& laravel --version | grep -E '(Installer|version)\s*[.0-9]+' \
&& phalcon commands | grep -E '[.0-9]+' \
&& true
### ###
### Copy files ### Copy files

View File

@@ -1,73 +1,78 @@
#!/bin/sh #!/usr/bin/env bash
#
# Available global variables:
# + MY_USER
# + MY_GROUP
set -e set -e
set -u set -u
set -p pipefail
### ###
### Variables ### Globals
### ###
PHP_INI_PATH="/usr/local/etc/php.ini"
FPM_ERROR_LOG_CFG="/usr/local/etc/php-fpm.conf" # The following global variables are available by our Dockerfile itself:
FPM_ACCESS_LOG_CFG="/usr/local/etc/php-fpm.d/zzz-docker.conf" # MY_USER
# MY_GROUP
# MY_UID
# MY_GID
# Path to scripts to source
CONFIG_DIR="/docker-entrypoint.d"
# php.ini.d directory
PHP_INI_DIR="/usr/local/etc/php/conf.d"
# This file holds error and access log definitions
FPM_CONF_LOGFILE="/usr/local/etc/php-fpm.d/logfiles.conf"
# PHP-FPM log dir
FPM_LOG_DIR="/var/log/php" FPM_LOG_DIR="/var/log/php"
#PHP_CUST_MODULE_DIR="/etc/php-modules.d" # Custom ini dir (to be copied to actual ini dir)
PHP_CUST_INI_DIR="/etc/php-custom.d" PHP_CUST_INI_DIR="/etc/php-custom.d"
PHP_REAL_INI_DIR="/usr/local/etc/php.d"
# Supervisord config directory
SUPERVISOR_CONFD="/etc/supervisor/conf.d" SUPERVISOR_CONFD="/etc/supervisor/conf.d"
### ###
### Source libs ### Source libs
### ###
init="$( find /docker-entrypoint.d -name '*.sh' -type f | sort -u )" init="$( find "${CONFIG_DIR}" -name '*.sh' -type f | sort -u )"
for f in ${init}; do for f in ${init}; do
# shellcheck disable=SC1090 # shellcheck disable=SC1090
. "${f}" . "${f}"
done done
###
### Set Debug level
###
DEBUG_LEVEL="$( get_debug_level "DEBUG_ENTRYPOINT" "0" )"
log "info" "Debug level: ${DEBUG_LEVEL}" "${DEBUG_LEVEL}"
#############################################################
## Sanity checks
#############################################################
if ! command -v socat >/dev/null 2>&1; then
log "err" "socat not found, but required." "${DEBUG_LEVEL}"
exit 1
fi
############################################################# #############################################################
## Entry Point ## Entry Point
############################################################# #############################################################
###
### Set Debug level
###
DEBUG_LEVEL="$( env_get "DEBUG_ENTRYPOINT" "0" )"
log "info" "Debug level: ${DEBUG_LEVEL}" "${DEBUG_LEVEL}"
### ###
### Change uid/gid ### Change uid/gid
### ###
set_uid "NEW_UID" set_uid "NEW_UID" "${MY_USER}" "/home/${MY_USER}" "${DEBUG_LEVEL}"
set_gid "NEW_GID" set_gid "NEW_GID" "${MY_GROUP}" "/home/${MY_USER}" "${DEBUG_LEVEL}"
### ###
### Set timezone ### Set timezone
### ###
set_timezone "TIMEZONE" "${PHP_INI_PATH}" set_timezone "TIMEZONE" "${PHP_INI_DIR}" "${DEBUG_LEVEL}"
###
### Setup postfix
###
set_postfix "ENABLE_MAIL" "${MY_USER}" "${MY_GROUP}" "${PHP_INI_DIR}" "${DEBUG_LEVEL}"
### ###
@@ -76,20 +81,16 @@ set_timezone "TIMEZONE" "${PHP_INI_PATH}"
set_docker_logs \ set_docker_logs \
"DOCKER_LOGS" \ "DOCKER_LOGS" \
"${FPM_LOG_DIR}" \ "${FPM_LOG_DIR}" \
"${FPM_ERROR_LOG_CFG}" \ "${FPM_CONF_LOGFILE}" \
"${FPM_ACCESS_LOG_CFG}" "${MY_USER}" \
"${MY_GROUP}" \
"${DEBUG_LEVEL}"
###
### Setup postfix
###
set_postfix "ENABLE_MAIL"
### ###
### Validate socat port forwards ### Validate socat port forwards
### ###
if ! port_forward_validate "FORWARD_PORTS_TO_LOCALHOST"; then if ! port_forward_validate "FORWARD_PORTS_TO_LOCALHOST" "${DEBUG_LEVEL}"; then
exit 1 exit 1
fi fi
@@ -101,7 +102,11 @@ for line in $( port_forward_get_lines "FORWARD_PORTS_TO_LOCALHOST" ); do
lport="$( port_forward_get_lport "${line}" )" lport="$( port_forward_get_lport "${line}" )"
rhost="$( port_forward_get_rhost "${line}" )" rhost="$( port_forward_get_rhost "${line}" )"
rport="$( port_forward_get_rport "${line}" )" rport="$( port_forward_get_rport "${line}" )"
supervisor_add_service "socat-${lport}-${rhost}-${rport}" "/usr/bin/socat tcp-listen:${lport},reuseaddr,fork tcp:${rhost}:${rport}" "${SUPERVISOR_CONFD}" supervisor_add_service \
"socat-${lport}-${rhost}-${rport}" \
"/usr/bin/socat tcp-listen:${lport},reuseaddr,fork tcp:${rhost}:${rport}" \
"${SUPERVISOR_CONFD}" \
"${DEBUG_LEVEL}"
done done
@@ -109,21 +114,21 @@ done
### Supervisor: rsyslogd & postfix ### Supervisor: rsyslogd & postfix
### ###
if [ "$( env_get "ENABLE_MAIL" )" = "1" ]; then if [ "$( env_get "ENABLE_MAIL" )" = "1" ]; then
supervisor_add_service "rsyslogd" "/usr/sbin/rsyslogd -n" "${SUPERVISOR_CONFD}" "1" supervisor_add_service "rsyslogd" "/usr/sbin/rsyslogd -n" "${SUPERVISOR_CONFD}" "${DEBUG_LEVEL}" "1"
supervisor_add_service "postfix" "/usr/local/sbin/postfix.sh" "${SUPERVISOR_CONFD}" supervisor_add_service "postfix" "/usr/local/sbin/postfix.sh" "${SUPERVISOR_CONFD}" "${DEBUG_LEVEL}"
fi fi
### ###
### Supervisor: php-fpm ### Supervisor: php-fpm
### ###
supervisor_add_service "php-fpm" "/usr/local/sbin/php-fpm" "${SUPERVISOR_CONFD}" supervisor_add_service "php-fpm" "/usr/local/sbin/php-fpm" "${SUPERVISOR_CONFD}" "${DEBUG_LEVEL}"
### ###
### Copy custom *.ini files ### Copy custom *.ini files
### ###
copy_ini_files "${PHP_CUST_INI_DIR}" "${PHP_REAL_INI_DIR}" copy_ini_files "${PHP_CUST_INI_DIR}" "${PHP_INI_DIR}" "${DEBUG_LEVEL}"
### ###
@@ -134,6 +139,7 @@ set_mds_settings "MYSQL_BACKUP_USER" "MYSQL_BACKUP_PASS" "MYSQL_BACKUP_HOST"
### ###
### Start ### Startup
### ###
log "info" "Starting supervisord" "${DEBUG_LEVEL}"
exec /usr/bin/supervisord -c /etc/supervisor/supervisord.conf exec /usr/bin/supervisord -c /etc/supervisor/supervisord.conf

View File

@@ -1,4 +1,4 @@
# Auto-generated via Ansible # Auto-generated via Ansible: edit build/ansible/DOCKERFILES/Dockerfile-base.j2 instead.
FROM php:{{ php_version }}-fpm FROM php:{{ php_version }}-fpm
MAINTAINER "cytopia" <cytopia@everythingcli.org> MAINTAINER "cytopia" <cytopia@everythingcli.org>

View File

@@ -1,4 +1,4 @@
# Auto-generated via Ansible # Auto-generated via Ansible: edit build/ansible/DOCKERFILES/Dockerfile-mods.j2 instead.
FROM devilbox/php-fpm:{{ php_version }}-base FROM devilbox/php-fpm:{{ php_version }}-base
MAINTAINER "cytopia" <cytopia@everythingcli.org> MAINTAINER "cytopia" <cytopia@everythingcli.org>

View File

@@ -1,4 +1,4 @@
# Auto-generated via Ansible # Auto-generated via Ansible: edit build/ansible/DOCKERFILES/Dockerfile-prod.j2 instead.
FROM devilbox/php-fpm:{{ php_version }}-mods FROM devilbox/php-fpm:{{ php_version }}-mods
MAINTAINER "cytopia" <cytopia@everythingcli.org> MAINTAINER "cytopia" <cytopia@everythingcli.org>
@@ -35,19 +35,6 @@ RUN set -x \
###
### Configure
###
RUN set -x \
&& { \
echo "[mail function]"; \
echo "sendmail_path = /usr/sbin/sendmail -t -i"; \
echo ";mail.force_extra_parameters ="; \
echo "mail.add_x_header = On"; \
echo "mail.log = /var/log/php/mail.log"; \
} > /usr/local/etc/php/conf.d/devilbox-mail.ini
{% if debug %} {% if debug %}
### ###
### Verify ### Verify

View File

@@ -1,4 +1,4 @@
# Auto-generated via Ansible # Auto-generated via Ansible: edit build/ansible/DOCKERFILES/Dockerfile-work.j2 instead.
FROM devilbox/php-fpm:{{ php_version }}-prod FROM devilbox/php-fpm:{{ php_version }}-prod
MAINTAINER "cytopia" <cytopia@everythingcli.org> MAINTAINER "cytopia" <cytopia@everythingcli.org>
@@ -15,7 +15,7 @@ LABEL \
### ###
### Envs (Already set in parent container) ### Envs
### ###
ENV BASH_PROFILE=".bashrc" ENV BASH_PROFILE=".bashrc"
@@ -23,9 +23,37 @@ ENV BASH_PROFILE=".bashrc"
### ###
### Install Tools ### Install Tools
### ###
# System dev tools
RUN set -x \ RUN set -x \
&& apt-get update \
&& apt-get install --no-install-recommends --no-install-suggests -y \
dirmngr \
gnupg \
{% for repo in apt_repositories_enabled %}
{# Not disabled #}
{% if ('disabled' not in apt_repositories_available[repo]) or (php_version not in apt_repositories_available[repo]['disabled']) %}
{# Version specific pre-command available? #}
{% if php_version in apt_repositories_available[repo] and 'pre' in apt_repositories_available[repo][php_version] %}
&& {{ apt_repositories_available[repo][php_version]['pre'] }} \
{# Generic pre-command available? #}
{% elif 'all' in apt_repositories_available[repo] and 'pre' in apt_repositories_available[repo]['all'] %}
&& {{ apt_repositories_available[repo]['all']['pre'] }} \
{% endif %}
{# Version specific key available? #}
{% if php_version in apt_repositories_available[repo] and 'key' in apt_repositories_available[repo][php_version] %}
&& apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv {{ apt_repositories_available[repo][php_version]['key'] }} \
{# Generic key available? #}
{% elif 'all' in apt_repositories_available[repo] and 'key' in apt_repositories_available[repo]['all'] %}
&& apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv {{ apt_repositories_available[repo]['all']['key'] }} \
{% endif %}
{# Version specific repository available? #}
{% if php_version in apt_repositories_available[repo] and 'deb' in apt_repositories_available[repo][php_version] %}
&& echo "{{ apt_repositories_available[repo][php_version]['deb'] }}" > /etc/apt/sources.list.d/{{ repo }}.list \
{# Generic repository available? #}
{% else %}
&& echo "{{ apt_repositories_available[repo]['all']['deb'] }}" > /etc/apt/sources.list.d/{{ repo }}.list \
{% endif %}
{% endif %}
{% endfor %}
&& apt-get update \ && apt-get update \
&& apt-get install --no-install-recommends --no-install-suggests -y \ && apt-get install --no-install-recommends --no-install-suggests -y \
ack-grep \ ack-grep \
@@ -49,14 +77,15 @@ RUN set -x \
less \ less \
libc-dev \ libc-dev \
make \ make \
# mongo-tools \ mongodb-org-shell \
mongodb-clients \ mongodb-org-tools \
moreutils \ moreutils \
mysql-client \ mysql-client \
nano \ nano \
net-tools \ net-tools \
netcat \ netcat \
# postgresql-client \ nodejs \
postgresql-client \
python-pip \ python-pip \
rubygems \ rubygems \
ruby-dev \ ruby-dev \
@@ -73,97 +102,37 @@ RUN set -x \
&& apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false $fetchDeps \ && apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false $fetchDeps \
&& rm -rf /var/lib/apt/lists/* && rm -rf /var/lib/apt/lists/*
## Node / NPM
#RUN set -x \ {% for tool in software_enabled %}
# && mkdir -p /usr/local/src \ {# Not disabled #}
# && VERSION="$( curl -Lq https://nodejs.org 2>/dev/null | grep LTS | grep -Eo 'data-version.*.' | grep -oE 'v[0-9.]+' )" \ {% if ('disabled' not in software_available[tool]) or (php_version not in software_available[tool]['disabled']) %}
# && wget --retry-connrefused --waitretry=1 --read-timeout=20 --timeout=15 --tries=30 \ # {{ tool }}
# -P /usr/local/src https://nodejs.org/dist/${VERSION}/node-${VERSION}-linux-x64.tar.xz \ RUN set -x true \
# && unxz /usr/local/src/node-${VERSION}-linux-x64.tar.xz \ {# Version specific pre-command available? #}
# && tar xvf /usr/local/src/node-${VERSION}-linux-x64.tar -C /usr/local/src \ {% if php_version in software_available[tool] and 'pre' in software_available[tool][php_version] %}
# && ln -s /usr/local/src/node-${VERSION}-linux-x64 /usr/local/node \ && {{ software_available[tool][php_version]['pre'] }} \
# && ln -s /usr/local/node/bin/* /usr/local/bin/ \ {# Generic pre-command available? #}
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64.tar* \ {% elif 'all' in software_available[tool] and 'pre' in software_available[tool]['all'] %}
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64/LICENSE \ && {{ software_available[tool]['all']['pre'] }} \
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64/*.md \ {% endif %}
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64/include \ {# Version specific command available? #}
# && rm -rf /usr/local/src/node-${VERSION}-linux-x64/share \ {% if php_version in software_available[tool] and 'command' in software_available[tool][php_version] %}
# && npm --version | grep -E '[.0-9]+' \ && {{ software_available[tool][php_version]['command'] }} \
# && node --version | grep -E '[.0-9]+' \ {# Generic command available? #}
# && rm -rf /root/.config {% else %}
# && {{ software_available[tool]['all']['command'] }} \
## Composer {% endif %}
#RUN set -x \ {# Version specific post-command available? #}
# && curl -sS https://getcomposer.org/installer | php \ {% if php_version in software_available[tool] and 'post' in software_available[tool][php_version] %}
# && mv composer.phar /usr/local/bin/composer \ && {{ software_available[tool][php_version]['post'] }} \
# && composer self-update {# Generic post-command available? #}
## && composer --version 2>/dev/null | grep -E 'version\s*[.0-9]+' \ {% elif 'all' in software_available[tool] and 'post' in software_available[tool]['all'] %}
## && rm -rf /root/.composer && {{ software_available[tool]['all']['post'] }} \
# {% endif %}
## Drush && true
#RUN set -x \ {% endif %}
# && DRUSH_VERSION="$( curl -q https://api.github.com/repos/drush-ops/drush/releases 2>/dev/null | grep tag_name | grep -Eo '\"[0-9.]+\"' | head -1 | sed 's/\"//g' )" \ {% endfor %}
# && mkdir -p /usr/local/src \
# && git clone https://github.com/drush-ops/drush.git /usr/local/src/drush \
# && chown -R ${MY_USER}:${MY_GROUP} /usr/local/src/drush \
# && v="${DRUSH_VERSION}" su ${MY_USER} -p -c 'cd /usr/local/src/drush && git checkout ${v}' \
# && su - ${MY_USER} -c 'PATH=/usr/local/bin:$PATH; cd /usr/local/src/drush && composer install --no-interaction --no-progress' \
# && ln -s /usr/local/src/drush/drush /usr/local/bin/drush \
# && drush --version | grep -E '[.0-9]+' \
# && rm -rf /usr/local/src/drush/.git \
# && rm -rf /usr/local/src/drush/docs \
# && rm -rf /usr/local/src/drush/examples \
# && rm -rf /usr/local/src/drush/misc \
# && rm -rf /usr/local/src/drush/tests \
# && rm -rf /root/.drush \
# && rm -rf /home/${MY_USER}/.composer
#
## Drupal Console
#RUN set -x \
# && curl https://drupalconsole.com/installer -L -o drupal.phar \
# && mv drupal.phar /usr/local/bin/drupal \
# && chmod +x /usr/local/bin/drupal
## && drupal --version | grep -E 'version\s*[.0-9]'
#
## WP-CLI
#RUN set -x \
# && curl -O https://raw.githubusercontent.com/wp-cli/builds/gh-pages/phar/wp-cli.phar \
# && mv wp-cli.phar /usr/local/bin/wp \
# && chmod +x /usr/local/bin/wp \
# && wp cli update \
# && wp --allow-root --version | grep -E '[.0-9]+'
#
## Symfony CLI
#RUN set -x \
# && curl -LsS https://symfony.com/installer -o /usr/local/bin/symfony \
# && chmod +x /usr/local/bin/symfony \
# && symfony --version | grep -E 'version\s*[.0-9]+'
#
## Laravel CLI
#RUN set -x \
# && mkdir -p /usr/local/src \
# && git clone https://github.com/laravel/installer /usr/local/src/laravel-installer \
# && cd /usr/local/src/laravel-installer \
# && git checkout $(git describe --abbrev=0 --tags) \
# && chown -R ${MY_USER}:${MY_GROUP} /usr/local/src/laravel-installer \
# && su - ${MY_USER} -c 'PATH=/usr/local/bin:$PATH; cd /usr/local/src/laravel-installer && composer install' \
# && ln -s /usr/local/src/laravel-installer/laravel /usr/local/bin/laravel \
# && rm -rf /usr/local/src/laravel-installer/laravel/.git
## && laravel --version | grep -E 'version\s*[.0-9]+' \
## && rm -rf /home/${MY_USER}/.composer
#
## Phalcon DevTools
##RUN set -x \
## && mkdir -p /usr/local/src \
## && git clone https://github.com/phalcon/phalcon-devtools /usr/local/src/phalcon-devtools \
## && cd /usr/local/src/phalcon-devtools \
## && git checkout $(git tag | grep 'v3.0' | sort -V | tail -1) \
## && su - ${MY_USER} -c 'cd /usr/local/src/phalcon-devtools && ./phalcon.sh' \
## && ln -s /usr/local/src/phalcon-devtools/phalcon.php /usr/local/bin/phalcon \
## && cd / \
## && rm -rf /usr/local/src/phalcon-devtools/.git \
## && phalcon commands | grep -E '[.0-9]+'
#
## Mysqldump-secure ## Mysqldump-secure
#RUN set -x \ #RUN set -x \
# && mkdir -p /usr/local/src \ # && mkdir -p /usr/local/src \
@@ -279,6 +248,15 @@ RUN set -x \
&& PHP_ERROR="$( php -v 2>&1 1>/dev/null )" \ && PHP_ERROR="$( php -v 2>&1 1>/dev/null )" \
&& if [ -n "${PHP_ERROR}" ]; then echo "${PHP_ERROR}"; false; fi && if [ -n "${PHP_ERROR}" ]; then echo "${PHP_ERROR}"; false; fi
RUN set -x \
{% for tool in software_enabled %}
{# Not disabled #}
{% if ('disabled' not in software_available[tool]) or (php_version not in software_available[tool]['disabled']) %}
&& {{ software_available[tool]['check'] }} \
{% endif %}
{% endfor %}
&& true
{% endif %} {% endif %}
### ###

View File

@@ -27,8 +27,201 @@ php_all_versions:
- 7.2 - 7.2
php_conf_dir: /usr/local/etc/php.d
################################################################################
# Defines for Dockerfile "work"
################################################################################
###
### Apt repositories to actually enable
###
apt_repositories_enabled:
- backports
- git
- mongo
- node
- pgsql
###
### Software to actually install
###
software_enabled:
- composer
- drush
- drupalconsole
- wpcli
- symfony
- laravel
- phalcon
###
### All available extra repositories
###
# all: is generic version of defines
# 7.2: is specific version of defines
# disabled: [optional] Array of PHP versions for which to disable this module
#
# all, 7.2, 7.1, 7.0, 5.6, 5.5, 5.4:
# deb: Deb line to add to sources list
# key: [optional] Key id to add for repository
# pre: [optional] Run custom command to add gpg key for repository
#
apt_repositories_available:
backports:
all:
deb: deb http://ftp.debian.org/debian jessie-backports main
git:
disabled: []
7.2:
deb: deb http://ppa.launchpad.net/git-core/ppa/ubuntu artful main
all:
deb: deb http://ppa.launchpad.net/git-core/ppa/ubuntu wily main
key: A1715D88E1DF1F24
mongo:
#disabled: [7.2]
all:
deb: deb http://repo.mongodb.org/apt/debian jessie/mongodb-org/3.6 main
key: 2930ADAE8CAF5059EE73BB4B58712A2291FA4AD5
node:
disabled: []
7.2:
deb: deb http://deb.nodesource.com/node_8.x stretch main
all:
deb: deb http://deb.nodesource.com/node_8.x jessie main
pre: curl -q "https://deb.nodesource.com/gpgkey/nodesource.gpg.key" 2>/dev/null | apt-key add -
pgsql:
#disabled: [7.2]
7.2:
deb: deb http://apt.postgresql.org/pub/repos/apt/ stretch-pgdg main
all:
deb: deb http://apt.postgresql.org/pub/repos/apt/ jessie-pgdg main
pre: curl -q https://www.postgresql.org/media/keys/ACCC4CF8.asc 2>/dev/null | apt-key add -
###
### All available software
###
# all: is generic version of defines
# 7.2: is specific version of defines
# disabled: [optional] Array of PHP versions for which to disable this module
#
# all, 7.2, 7.1, 7.0, 5.6, 5.5, 5.4:
# pre: [optional] Run command before 'command:' statement
# command: Command to execute
# pre: [optional] Run command after 'command:' statement
#
software_available:
composer:
check: composer --version 2>/dev/null | grep -E 'version\s*[.0-9]+' && rm -rf /root/.composer
all:
command: curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/local/bin --filename=composer
drush:
check: drush --version | grep -E '[.0-9]+' && rm -rf /root/.drush
5.5:
pre: |
git clone https://github.com/drush-ops/drush.git /usr/local/src/drush \
&& cd /usr/local/src/drush \
&& git checkout $(git for-each-ref --format='%(*creatordate:raw)%(creatordate:raw) %(refname)' refs/tags | sort -n | sed 's/^.*tags\///g' | grep ^8 | tail -1) \
5.4:
pre: |
git clone https://github.com/drush-ops/drush.git /usr/local/src/drush \
&& cd /usr/local/src/drush \
&& git checkout $(git for-each-ref --format='%(*creatordate:raw)%(creatordate:raw) %(refname)' refs/tags | sort -n | sed 's/^.*tags\///g' | grep ^8 | tail -1) \
all:
pre: |
git clone https://github.com/drush-ops/drush.git /usr/local/src/drush \
&& cd /usr/local/src/drush \
&& git checkout $(git for-each-ref --format='%(*creatordate:raw)%(creatordate:raw) %(refname)' refs/tags | sort -n | tail -1 | sed 's/^.*tags\///g') \
command: |
chown -R ${MY_USER}:${MY_GROUP} /usr/local/src/drush \
&& su - ${MY_USER} -c 'PATH=/usr/local/bin:$PATH; cd /usr/local/src/drush && composer install --no-interaction --no-progress' \
&& ln -s /usr/local/src/drush/drush /usr/local/bin/drush \
&& rm -rf /usr/local/src/drush/.git \
&& rm -rf /usr/local/src/drush/docs \
&& rm -rf /usr/local/src/drush/examples \
&& rm -rf /usr/local/src/drush/misc \
&& rm -rf /usr/local/src/drush/tests \
&& rm -rf /home/${MY_USER}/.composer \
drupalconsole:
disabled: [5.4]
check: drupal --version | grep -E 'Drupal Console Launcher\s*[.0-9]'
all:
command: curl https://drupalconsole.com/installer -L -o /usr/local/bin/drupal
post: chmod +x /usr/local/bin/drupal
laravel:
check: laravel --version | grep -E '(Installer|version)\s*[.0-9]+'
7.0:
pre: |
git clone https://github.com/laravel/installer /usr/local/src/laravel-installer \
&& cd /usr/local/src/laravel-installer \
&& git checkout v2.0.0 \
5.6:
pre: |
git clone https://github.com/laravel/installer /usr/local/src/laravel-installer \
&& cd /usr/local/src/laravel-installer \
&& git checkout v2.0.0 \
5.5:
pre: |
git clone https://github.com/laravel/installer /usr/local/src/laravel-installer \
&& cd /usr/local/src/laravel-installer \
&& git checkout v2.0.0 \
5.4:
pre: |
git clone https://github.com/laravel/installer /usr/local/src/laravel-installer \
&& cd /usr/local/src/laravel-installer \
&& git checkout v1.3.7 \
all:
pre: |
git clone https://github.com/laravel/installer /usr/local/src/laravel-installer \
&& cd /usr/local/src/laravel-installer \
&& git checkout $(git describe --abbrev=0 --tags) \
command: |
chown -R ${MY_USER}:${MY_GROUP} /usr/local/src/laravel-installer \
&& su - ${MY_USER} -c 'PATH=/usr/local/bin:$PATH; cd /usr/local/src/laravel-installer && composer install' \
&& ln -s /usr/local/src/laravel-installer/laravel /usr/local/bin/laravel \
&& rm -rf /usr/local/src/laravel-installer/laravel/.git \
phalcon:
check: phalcon commands | grep -E '[.0-9]+'
5.4:
pre: |
git clone https://github.com/phalcon/phalcon-devtools /usr/local/src/phalcon-devtools \
&& cd /usr/local/src/phalcon-devtools \
&& git checkout v2.0.9 \
all:
pre: |
git clone https://github.com/phalcon/phalcon-devtools /usr/local/src/phalcon-devtools \
&& cd /usr/local/src/phalcon-devtools \
&& git checkout $(git describe --abbrev=0 --tags) \
command: |
chown -R ${MY_USER}:${MY_GROUP} /usr/local/src/phalcon-devtools \
&& su - ${MY_USER} -c 'cd /usr/local/src/phalcon-devtools && ./phalcon.sh' \
&& ln -s /usr/local/src/phalcon-devtools/phalcon.php /usr/local/bin/phalcon \
&& cd / \
&& rm -rf /usr/local/src/phalcon-devtools/.git \
symfony:
check: symfony --version | grep -E 'version\s*[.0-9]+'
all:
command: curl https://symfony.com/installer -L -o /usr/local/bin/symfony
post: chmod +x /usr/local/bin/symfony
wpcli:
check: wp --allow-root --version | grep -E '[.0-9]+'
all:
command: curl https://raw.githubusercontent.com/wp-cli/builds/gh-pages/phar/wp-cli.phar -L -o /usr/local/bin/wp
post: chmod +x /usr/local/bin/wp
################################################################################
# Defines for Dockerfile "mods"
################################################################################
### ###
### Extensions to actually enable ### Extensions to actually enable
@@ -120,7 +313,6 @@ extensions_enabled:
### ###
### All available php modules ### All available php modules
### ###
# all: is generic version of defines # all: is generic version of defines
# 7.2: is specific version of defines # 7.2: is specific version of defines
# disabled: [optional] Array of PHP versions for which to disable this module # disabled: [optional] Array of PHP versions for which to disable this module