Docker-PHP/php/Dockerfile

243 lines
12 KiB
Text
Raw Normal View History

Trunk linter (#17) * linting is fun * mis-detection of missing healthcheck staements. * typo * disable tagging vanity tags on non-main branch * Unbugger node build? * Add gitleaks detector, remove an expired secret. * More linting-derived cleanup * Fiddle with trivy * Fiddle with trivy * add a readme * Fix build bug with php flavours * Marshall should build other flavours of ubuntu. * Fiddle with act cache location. * Add concurrency checks * Composer version gubbins for 7.0/7.1 * ubuntu is just a label, and injected over the top of. * Composer version gubbins for 7.0/7.1 * Run when workflow is altered too please. * Hopefully fix composer stage. * setup tooling meta-tooling. * Add trunk * Disable mirror mode, its being problematic, and increase retries to 5. * Revisit how ghcr login works. * Add trunk checks. * All hail the linter * Heavilly revise workflow * Fettling * Fettling * Fettling * Fettling * Fettling * Cleanup * Cleanup * Fettling.. Why does mitm build but not redis? * Fettling.. Why does mitm build but not redis? * Debuggin * Fettling. * Fix build? * Permissions are a pain * Switch around some should_push logic because envs aren't available that early. * Permissionssssss * Trivy, bane of my life * Fix merge? * Fix labels * Help node along, among other things * Redis 6.1 & 7.1 aren't a thing any more. * Ffff USER nonsense * latest-openssl doesn't exist. * fixup mysqlproxy. * Fix labels * uurrgh * uurrgh * Didn't need to add the mitmproxy user, it exists * Missing ghcr login * Missing backtick * Fix build? * Add validate build step to bouncer. * Fix bouncer build * Disable laravel build * Missing env * Fix swarm mon build * Scout just doesn't seem to work.
2024-02-07 15:21:14 +00:00
# checkov:skip=CKV_DOCKER_3 user cannot be determined at this stage.
FROM marshall:build AS php-core
2021-05-30 13:45:30 +00:00
LABEL maintainer="Matthew Baggett <matthew@baggett.me>" \
2021-06-06 22:08:12 +00:00
org.label-schema.vcs-url="https://github.com/benzine-framework/docker" \
org.opencontainers.image.source="https://github.com/benzine-framework/docker"
Trunk linter (#17) * linting is fun * mis-detection of missing healthcheck staements. * typo * disable tagging vanity tags on non-main branch * Unbugger node build? * Add gitleaks detector, remove an expired secret. * More linting-derived cleanup * Fiddle with trivy * Fiddle with trivy * add a readme * Fix build bug with php flavours * Marshall should build other flavours of ubuntu. * Fiddle with act cache location. * Add concurrency checks * Composer version gubbins for 7.0/7.1 * ubuntu is just a label, and injected over the top of. * Composer version gubbins for 7.0/7.1 * Run when workflow is altered too please. * Hopefully fix composer stage. * setup tooling meta-tooling. * Add trunk * Disable mirror mode, its being problematic, and increase retries to 5. * Revisit how ghcr login works. * Add trunk checks. * All hail the linter * Heavilly revise workflow * Fettling * Fettling * Fettling * Fettling * Fettling * Cleanup * Cleanup * Fettling.. Why does mitm build but not redis? * Fettling.. Why does mitm build but not redis? * Debuggin * Fettling. * Fix build? * Permissions are a pain * Switch around some should_push logic because envs aren't available that early. * Permissionssssss * Trivy, bane of my life * Fix merge? * Fix labels * Help node along, among other things * Redis 6.1 & 7.1 aren't a thing any more. * Ffff USER nonsense * latest-openssl doesn't exist. * fixup mysqlproxy. * Fix labels * uurrgh * uurrgh * Didn't need to add the mitmproxy user, it exists * Missing ghcr login * Missing backtick * Fix build? * Add validate build step to bouncer. * Fix bouncer build * Disable laravel build * Missing env * Fix swarm mon build * Scout just doesn't seem to work.
2024-02-07 15:21:14 +00:00
ARG PHP_PACKAGES
ARG COMPOSER_VERSION
ENV COMPOSER_ALLOW_SUPERUSER=1
COPY core/install-report.sh /usr/bin/install-report
SHELL ["/bin/bash", "-o", "pipefail", "-c"]
RUN echo "Acquire::Retries \"5\";" > /etc/apt/apt.conf.d/80-retries && \
echo "Acquire::http::No-Cache=true;" > /etc/apt/apt.conf.d/80-no-cache && \
echo "Acquire::http::Pipeline-Depth=0;" > /etc/apt/apt.conf.d/80-no-pipeline && \
apt-get -qq update && \
apt-get -yqq upgrade && \
apt-get -yqq install --no-install-recommends \
python3-software-properties \
software-properties-common \
&& \
echo "PHP packages to install:" && echo $PHP_PACKAGES && \
add-apt-repository -y ppa:ondrej/php && \
apt-get -qq update && \
apt-get -yqq install --no-install-recommends $PHP_PACKAGES &&\
apt-get remove -yqq \
software-properties-common \
python-apt-common \
python3-software-properties \
python3.5 python3.5-minimal libpython3.5-minimal \
&& \
apt-get autoremove -yqq && \
apt-get clean && \
rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/* /var/lib/dpkg/status.old /var/cache/debconf/templates.dat /var/log/dpkg.log /var/log/lastlog /var/log/apt/*.log && \
rm -rf /usr/bin/mariabackup \
/usr/bin/mysql_embedded \
/usr/bin/mysql_find_rows \
/usr/bin/mysql_fix_extensions \
/usr/bin/mysql_waitpid \
/usr/bin/mysqlaccess \
/usr/bin/mysqlanalyze \
/usr/bin/mysqlcheck \
/usr/bin/mysqldump \
/usr/bin/mysqldumpslow \
/usr/bin/mysqlimport \
/usr/bin/mysqloptimize \
/usr/bin/mysqlrepair \
/usr/bin/mysqlreport \
/usr/bin/mysqlshow \
/usr/bin/mysqlslap \
/usr/bin/mytop
RUN chmod +x /usr/bin/install-report && \
/usr/bin/install-report
RUN curl https://getcomposer.org/download/$COMPOSER_VERSION/composer.phar --output /usr/local/bin/composer && \
chmod +x /usr/local/bin/composer /usr/bin/install-report && \
composer self-update
# Healthcheck is nonsensical for this container.
HEALTHCHECK NONE
2021-06-06 22:08:12 +00:00
Trunk linter (#17) * linting is fun * mis-detection of missing healthcheck staements. * typo * disable tagging vanity tags on non-main branch * Unbugger node build? * Add gitleaks detector, remove an expired secret. * More linting-derived cleanup * Fiddle with trivy * Fiddle with trivy * add a readme * Fix build bug with php flavours * Marshall should build other flavours of ubuntu. * Fiddle with act cache location. * Add concurrency checks * Composer version gubbins for 7.0/7.1 * ubuntu is just a label, and injected over the top of. * Composer version gubbins for 7.0/7.1 * Run when workflow is altered too please. * Hopefully fix composer stage. * setup tooling meta-tooling. * Add trunk * Disable mirror mode, its being problematic, and increase retries to 5. * Revisit how ghcr login works. * Add trunk checks. * All hail the linter * Heavilly revise workflow * Fettling * Fettling * Fettling * Fettling * Fettling * Cleanup * Cleanup * Fettling.. Why does mitm build but not redis? * Fettling.. Why does mitm build but not redis? * Debuggin * Fettling. * Fix build? * Permissions are a pain * Switch around some should_push logic because envs aren't available that early. * Permissionssssss * Trivy, bane of my life * Fix merge? * Fix labels * Help node along, among other things * Redis 6.1 & 7.1 aren't a thing any more. * Ffff USER nonsense * latest-openssl doesn't exist. * fixup mysqlproxy. * Fix labels * uurrgh * uurrgh * Didn't need to add the mitmproxy user, it exists * Missing ghcr login * Missing backtick * Fix build? * Add validate build step to bouncer. * Fix bouncer build * Disable laravel build * Missing env * Fix swarm mon build * Scout just doesn't seem to work.
2024-02-07 15:21:14 +00:00
# checkov:skip=CKV_DOCKER_3 user cannot be determined at this stage.
FROM php-core AS php-cli
LABEL maintainer="Matthew Baggett <matthew@baggett.me>" \
org.label-schema.vcs-url="https://github.com/benzine-framework/docker" \
org.opencontainers.image.source="https://github.com/benzine-framework/docker"
2019-08-14 15:34:54 +00:00
# Install a funky cool repl.
RUN composer global require -q psy/psysh:@stable && \
ln -s /root/.composer/vendor/psy/psysh/bin/psysh /usr/local/bin/repl && \
Feature/multiplat (#2) * Fuckin' Perl. Marshall 199MB => 130MB * Down to 122MB. I'll take it. * Multiplatform rewrite * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Squash this. * Squash this * Squash this * Squash this * Squash this * Squash this * Squash this * Squash this * Squash this * Squash this * Apparently github registry doesn't support multi-platform images :facepalm: * gchr.io replaced github registry containers, who knew. * GHCR not GHPR * Skip GHCR? * Probably should copy the login action changes across. * Fire ze cannons * Re-enable lint. Enable Marshall. Disable GHCR, its just broken jank. * Rename * Probably don't care about -onbuild builds right now. * The full matrix isn't building yet :/ * Typo. * I can't spell, evidently * This is causing some strange behaviour. * This is causing some strange behaviour. * Turn off fail fast. * Add PHP_VERSION ENVAR * Add vanity tag functionality * 7.4 all built right... Build all the other images? * Tabzilla * Fix issues with 8.0/7.0 being truncated to 8/7. Phase out 5.6 builder. * Vanity tags might run on a different instance oops. * Why was php7.4-redis/php8.0-redis removed in the first place. I have no idea.
2020-12-02 11:27:31 +00:00
/usr/local/bin/repl -v && \
composer clear-cache
2019-08-14 15:34:54 +00:00
COPY cli/psysh-config.php /root/.config/psysh/config.php
2019-08-14 15:34:54 +00:00
Trunk linter (#17) * linting is fun * mis-detection of missing healthcheck staements. * typo * disable tagging vanity tags on non-main branch * Unbugger node build? * Add gitleaks detector, remove an expired secret. * More linting-derived cleanup * Fiddle with trivy * Fiddle with trivy * add a readme * Fix build bug with php flavours * Marshall should build other flavours of ubuntu. * Fiddle with act cache location. * Add concurrency checks * Composer version gubbins for 7.0/7.1 * ubuntu is just a label, and injected over the top of. * Composer version gubbins for 7.0/7.1 * Run when workflow is altered too please. * Hopefully fix composer stage. * setup tooling meta-tooling. * Add trunk * Disable mirror mode, its being problematic, and increase retries to 5. * Revisit how ghcr login works. * Add trunk checks. * All hail the linter * Heavilly revise workflow * Fettling * Fettling * Fettling * Fettling * Fettling * Cleanup * Cleanup * Fettling.. Why does mitm build but not redis? * Fettling.. Why does mitm build but not redis? * Debuggin * Fettling. * Fix build? * Permissions are a pain * Switch around some should_push logic because envs aren't available that early. * Permissionssssss * Trivy, bane of my life * Fix merge? * Fix labels * Help node along, among other things * Redis 6.1 & 7.1 aren't a thing any more. * Ffff USER nonsense * latest-openssl doesn't exist. * fixup mysqlproxy. * Fix labels * uurrgh * uurrgh * Didn't need to add the mitmproxy user, it exists * Missing ghcr login * Missing backtick * Fix build? * Add validate build step to bouncer. * Fix bouncer build * Disable laravel build * Missing env * Fix swarm mon build * Scout just doesn't seem to work.
2024-02-07 15:21:14 +00:00
RUN composer --version && \
repl --version
# checkov:skip=CKV_DOCKER_3 user cannot be determined at this stage.
FROM php-cli AS php-nginx
2021-05-30 13:45:30 +00:00
LABEL maintainer="Matthew Baggett <matthew@baggett.me>" \
2021-06-06 22:08:12 +00:00
org.label-schema.vcs-url="https://github.com/benzine-framework/docker" \
org.opencontainers.image.source="https://github.com/benzine-framework/docker"
2019-08-14 15:34:54 +00:00
ARG PHP_VERSION
2020-03-17 14:58:56 +00:00
ARG PHP_MEMORY_LIMIT=128M
2020-03-19 11:58:26 +00:00
ARG PHP_DATA_MAX_SIZE=1024M
2019-08-14 15:34:54 +00:00
ENV PHPFPM_MAX_CHILDREN=25
COPY nginx /conf
COPY self-signed-certificates /certs
2019-08-14 15:34:54 +00:00
Trunk linter (#17) * linting is fun * mis-detection of missing healthcheck staements. * typo * disable tagging vanity tags on non-main branch * Unbugger node build? * Add gitleaks detector, remove an expired secret. * More linting-derived cleanup * Fiddle with trivy * Fiddle with trivy * add a readme * Fix build bug with php flavours * Marshall should build other flavours of ubuntu. * Fiddle with act cache location. * Add concurrency checks * Composer version gubbins for 7.0/7.1 * ubuntu is just a label, and injected over the top of. * Composer version gubbins for 7.0/7.1 * Run when workflow is altered too please. * Hopefully fix composer stage. * setup tooling meta-tooling. * Add trunk * Disable mirror mode, its being problematic, and increase retries to 5. * Revisit how ghcr login works. * Add trunk checks. * All hail the linter * Heavilly revise workflow * Fettling * Fettling * Fettling * Fettling * Fettling * Cleanup * Cleanup * Fettling.. Why does mitm build but not redis? * Fettling.. Why does mitm build but not redis? * Debuggin * Fettling. * Fix build? * Permissions are a pain * Switch around some should_push logic because envs aren't available that early. * Permissionssssss * Trivy, bane of my life * Fix merge? * Fix labels * Help node along, among other things * Redis 6.1 & 7.1 aren't a thing any more. * Ffff USER nonsense * latest-openssl doesn't exist. * fixup mysqlproxy. * Fix labels * uurrgh * uurrgh * Didn't need to add the mitmproxy user, it exists * Missing ghcr login * Missing backtick * Fix build? * Add validate build step to bouncer. * Fix bouncer build * Disable laravel build * Missing env * Fix swarm mon build * Scout just doesn't seem to work.
2024-02-07 15:21:14 +00:00
# ts:skip=AC_DOCKER_0002 Mis-detecting usage of apt instead of apt-get
2019-08-14 15:34:54 +00:00
RUN apt-get -qq update && \
2021-05-30 14:36:16 +00:00
# Install pre-dependencies to use apt-key.
2019-08-14 15:34:54 +00:00
apt-get -yqq install --no-install-recommends \
lsb-core \
gnupg \
&& \
2021-05-30 14:36:16 +00:00
# Add nginx ppa
2019-08-14 15:34:54 +00:00
sh -c 'echo "deb http://ppa.launchpad.net/nginx/stable/ubuntu $(lsb_release -sc) main" \
> /etc/apt/sources.list.d/nginx-stable.list' && \
2021-05-30 14:36:16 +00:00
# Add nginx key
2019-08-14 15:34:54 +00:00
apt-key adv --keyserver keyserver.ubuntu.com --recv-keys C300EE8C && \
apt-get -qq update && \
apt-get -yqq install --no-install-recommends \
nginx \
php$PHP_VERSION-fpm \
2021-05-30 12:40:12 +00:00
certbot \
python3-certbot-nginx \
2019-08-14 15:34:54 +00:00
&& \
apt-get remove -yqq \
2019-08-14 15:34:54 +00:00
lsb-core \
cups-common \
&& \
apt-get autoremove -yqq && \
2019-08-14 15:34:54 +00:00
apt-get clean && \
Feature/multiplat (#2) * Fuckin' Perl. Marshall 199MB => 130MB * Down to 122MB. I'll take it. * Multiplatform rewrite * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Squash this. * Squash this * Squash this * Squash this * Squash this * Squash this * Squash this * Squash this * Squash this * Squash this * Apparently github registry doesn't support multi-platform images :facepalm: * gchr.io replaced github registry containers, who knew. * GHCR not GHPR * Skip GHCR? * Probably should copy the login action changes across. * Fire ze cannons * Re-enable lint. Enable Marshall. Disable GHCR, its just broken jank. * Rename * Probably don't care about -onbuild builds right now. * The full matrix isn't building yet :/ * Typo. * I can't spell, evidently * This is causing some strange behaviour. * This is causing some strange behaviour. * Turn off fail fast. * Add PHP_VERSION ENVAR * Add vanity tag functionality * 7.4 all built right... Build all the other images? * Tabzilla * Fix issues with 8.0/7.0 being truncated to 8/7. Phase out 5.6 builder. * Vanity tags might run on a different instance oops. * Why was php7.4-redis/php8.0-redis removed in the first place. I have no idea.
2020-12-02 11:27:31 +00:00
rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/* /var/lib/dpkg/status.old /var/cache/debconf/templates.dat /var/log/dpkg.log /var/log/lastlog /var/log/apt/*.log && \
2020-03-19 11:58:41 +00:00
# Configure FPM
2019-08-14 15:34:54 +00:00
sed -i "s/cgi.fix_pathinfo.*/cgi.fix_pathinfo=0/g" /etc/php/$PHP_VERSION/fpm/php.ini && \
2020-03-17 14:56:04 +00:00
sed -i "s|memory_limit.*|memory_limit = $PHP_MEMORY_LIMIT|g" /etc/php/$PHP_VERSION/fpm/php.ini && \
2020-03-19 11:58:26 +00:00
sed -i "s/upload_max_filesize.*/upload_max_filesize = $PHP_DATA_MAX_SIZE/g" /etc/php/$PHP_VERSION/fpm/php.ini && \
sed -i "s/post_max_size.*/post_max_size = $PHP_DATA_MAX_SIZE/g" /etc/php/$PHP_VERSION/fpm/php.ini && \
2019-08-14 15:34:54 +00:00
sed -i "s/max_execution_time.*/max_execution_time = 0/g" /etc/php/$PHP_VERSION/fpm/php.ini && \
sed -i "s/variables_order.*/variables_order = \"EGPCS\"/g" /etc/php/$PHP_VERSION/fpm/php.ini && \
sed -i "s/error_reporting.*/error_reporting = E_ALL \& \~E_DEPRECATED \& \~E_STRICT \& \~E_CORE_WARNING/g" /etc/php/$PHP_VERSION/fpm/php.ini && \
2020-03-17 14:56:04 +00:00
# FPM logging to file
sed -i "s|;catch_workers_output.*|catch_workers_output = yes|g" /etc/php/$PHP_VERSION/fpm/pool.d/www.conf && \
sed -i "s|;php_flag\[display_errors\].*|php_flag\[display_errors\] = on|g" /etc/php/$PHP_VERSION/fpm/pool.d/www.conf && \
sed -i "s|;php_admin_value\[error_log\].*|php_admin_value\[error_log\] = /var/log/fpm-php.log|g" /etc/php/$PHP_VERSION/fpm/pool.d/www.conf && \
sed -i "s|;php_admin_flag\[log_errors\].*|php_admin_flag\[log_errors\] = on|g" /etc/php/$PHP_VERSION/fpm/pool.d/www.conf && \
2020-03-17 16:47:31 +00:00
sed -i "s|;php_admin_value\[memory_limit\].*|php_admin_value\[memory_limit\] = $PHP_MEMORY_LIMIT|g" /etc/php/$PHP_VERSION/fpm/pool.d/www.conf && \
2020-03-19 11:58:41 +00:00
# Symlink FPM config to CLI & PHPDBG
2021-04-12 07:17:10 +00:00
rm -f /etc/php/$PHP_VERSION/cli/php.ini && \
2020-03-19 11:58:41 +00:00
ln -s /etc/php/$PHP_VERSION/fpm/php.ini /etc/php/$PHP_VERSION/cli/php.ini && \
2021-04-12 07:17:10 +00:00
# Configuration step for clear_env=no
echo "clear_env=no" >> /etc/php/$PHP_VERSION/fpm/php-fpm.conf; \
echo "clear_env=no" >> /etc/php/$PHP_VERSION/fpm/pool.d/www.ini; \
2020-03-19 11:58:41 +00:00
# Create run lock dir for php
mkdir -p /run/php && \
2020-03-19 11:58:41 +00:00
# Destroy default html root, and link /app in its place.
2019-08-14 15:34:54 +00:00
rm -fr /var/www/html && \
mkdir -p /var/www && \
2019-08-14 15:34:54 +00:00
ln -s /app /var/www/html && \
2019-11-09 03:00:40 +00:00
# Move nginx configuration into place
2019-08-14 15:34:54 +00:00
mv /conf/NginxDefault /etc/nginx/sites-enabled/default && \
mv /conf/NginxSSL /etc/nginx/sites-enabled/default-ssl && \
# Generate self-signed certificates
#mkdir /certs && \
#openssl req -x509 -nodes -days 36500 -newkey rsa:2048 \
# -subj "/C=US/ST=Florida/L=Miami/O=Example Group/CN=example.org" \
# -keyout /certs/example.key \
# -out /certs/example.crt \
#&& \
2019-11-09 03:00:40 +00:00
# Create runit service directories
mkdir -p /etc/service/nginx \
/etc/service/php-fpm \
2021-05-30 12:40:12 +00:00
/etc/service/letsencrypt \
2021-05-30 20:33:47 +00:00
#/etc/service/logs-letsencrypt \
/etc/service/logs-nginx-access \
/etc/service/logs-nginx-error \
/etc/service/logs-phpfpm-error && \
2019-11-09 03:00:40 +00:00
# Copy our new service runits into location
2019-08-14 15:34:54 +00:00
mv /conf/nginx.runit /etc/service/nginx/run && \
mv /conf/php-fpm.runit /etc/service/php-fpm/run && \
2021-05-30 12:40:12 +00:00
mv /conf/letsencrypt.runit /etc/service/letsencrypt/run && \
2021-05-30 19:25:14 +00:00
#mv /conf/logs-letsencrypt.runit /etc/service/logs-letsencrypt/run && \
Trunk linter (#17) * linting is fun * mis-detection of missing healthcheck staements. * typo * disable tagging vanity tags on non-main branch * Unbugger node build? * Add gitleaks detector, remove an expired secret. * More linting-derived cleanup * Fiddle with trivy * Fiddle with trivy * add a readme * Fix build bug with php flavours * Marshall should build other flavours of ubuntu. * Fiddle with act cache location. * Add concurrency checks * Composer version gubbins for 7.0/7.1 * ubuntu is just a label, and injected over the top of. * Composer version gubbins for 7.0/7.1 * Run when workflow is altered too please. * Hopefully fix composer stage. * setup tooling meta-tooling. * Add trunk * Disable mirror mode, its being problematic, and increase retries to 5. * Revisit how ghcr login works. * Add trunk checks. * All hail the linter * Heavilly revise workflow * Fettling * Fettling * Fettling * Fettling * Fettling * Cleanup * Cleanup * Fettling.. Why does mitm build but not redis? * Fettling.. Why does mitm build but not redis? * Debuggin * Fettling. * Fix build? * Permissions are a pain * Switch around some should_push logic because envs aren't available that early. * Permissionssssss * Trivy, bane of my life * Fix merge? * Fix labels * Help node along, among other things * Redis 6.1 & 7.1 aren't a thing any more. * Ffff USER nonsense * latest-openssl doesn't exist. * fixup mysqlproxy. * Fix labels * uurrgh * uurrgh * Didn't need to add the mitmproxy user, it exists * Missing ghcr login * Missing backtick * Fix build? * Add validate build step to bouncer. * Fix bouncer build * Disable laravel build * Missing env * Fix swarm mon build * Scout just doesn't seem to work.
2024-02-07 15:21:14 +00:00
#mv /conf/logs-letsencrypt.finish /etc/service/logs-letsencrypt/finish && \
2019-11-09 00:13:01 +00:00
mv /conf/logs-nginx-access.runit /etc/service/logs-nginx-access/run && \
mv /conf/logs-nginx-error.runit /etc/service/logs-nginx-error/run && \
mv /conf/logs-phpfpm-error.runit /etc/service/logs-phpfpm-error/run && \
Trunk linter (#17) * linting is fun * mis-detection of missing healthcheck staements. * typo * disable tagging vanity tags on non-main branch * Unbugger node build? * Add gitleaks detector, remove an expired secret. * More linting-derived cleanup * Fiddle with trivy * Fiddle with trivy * add a readme * Fix build bug with php flavours * Marshall should build other flavours of ubuntu. * Fiddle with act cache location. * Add concurrency checks * Composer version gubbins for 7.0/7.1 * ubuntu is just a label, and injected over the top of. * Composer version gubbins for 7.0/7.1 * Run when workflow is altered too please. * Hopefully fix composer stage. * setup tooling meta-tooling. * Add trunk * Disable mirror mode, its being problematic, and increase retries to 5. * Revisit how ghcr login works. * Add trunk checks. * All hail the linter * Heavilly revise workflow * Fettling * Fettling * Fettling * Fettling * Fettling * Cleanup * Cleanup * Fettling.. Why does mitm build but not redis? * Fettling.. Why does mitm build but not redis? * Debuggin * Fettling. * Fix build? * Permissions are a pain * Switch around some should_push logic because envs aren't available that early. * Permissionssssss * Trivy, bane of my life * Fix merge? * Fix labels * Help node along, among other things * Redis 6.1 & 7.1 aren't a thing any more. * Ffff USER nonsense * latest-openssl doesn't exist. * fixup mysqlproxy. * Fix labels * uurrgh * uurrgh * Didn't need to add the mitmproxy user, it exists * Missing ghcr login * Missing backtick * Fix build? * Add validate build step to bouncer. * Fix bouncer build * Disable laravel build * Missing env * Fix swarm mon build * Scout just doesn't seem to work.
2024-02-07 15:21:14 +00:00
mv /conf/logs-phpfpm-error.finish /etc/service/logs-phpfpm-error/finish && \
# Make sure all our new services are using unix line endings
Trunk linter (#17) * linting is fun * mis-detection of missing healthcheck staements. * typo * disable tagging vanity tags on non-main branch * Unbugger node build? * Add gitleaks detector, remove an expired secret. * More linting-derived cleanup * Fiddle with trivy * Fiddle with trivy * add a readme * Fix build bug with php flavours * Marshall should build other flavours of ubuntu. * Fiddle with act cache location. * Add concurrency checks * Composer version gubbins for 7.0/7.1 * ubuntu is just a label, and injected over the top of. * Composer version gubbins for 7.0/7.1 * Run when workflow is altered too please. * Hopefully fix composer stage. * setup tooling meta-tooling. * Add trunk * Disable mirror mode, its being problematic, and increase retries to 5. * Revisit how ghcr login works. * Add trunk checks. * All hail the linter * Heavilly revise workflow * Fettling * Fettling * Fettling * Fettling * Fettling * Cleanup * Cleanup * Fettling.. Why does mitm build but not redis? * Fettling.. Why does mitm build but not redis? * Debuggin * Fettling. * Fix build? * Permissions are a pain * Switch around some should_push logic because envs aren't available that early. * Permissionssssss * Trivy, bane of my life * Fix merge? * Fix labels * Help node along, among other things * Redis 6.1 & 7.1 aren't a thing any more. * Ffff USER nonsense * latest-openssl doesn't exist. * fixup mysqlproxy. * Fix labels * uurrgh * uurrgh * Didn't need to add the mitmproxy user, it exists * Missing ghcr login * Missing backtick * Fix build? * Add validate build step to bouncer. * Fix bouncer build * Disable laravel build * Missing env * Fix swarm mon build * Scout just doesn't seem to work.
2024-02-07 15:21:14 +00:00
dos2unix -q /etc/service/*/run /etc/service/*/finish && \
2019-11-09 03:00:40 +00:00
# Make sure all our new services are executable
Trunk linter (#17) * linting is fun * mis-detection of missing healthcheck staements. * typo * disable tagging vanity tags on non-main branch * Unbugger node build? * Add gitleaks detector, remove an expired secret. * More linting-derived cleanup * Fiddle with trivy * Fiddle with trivy * add a readme * Fix build bug with php flavours * Marshall should build other flavours of ubuntu. * Fiddle with act cache location. * Add concurrency checks * Composer version gubbins for 7.0/7.1 * ubuntu is just a label, and injected over the top of. * Composer version gubbins for 7.0/7.1 * Run when workflow is altered too please. * Hopefully fix composer stage. * setup tooling meta-tooling. * Add trunk * Disable mirror mode, its being problematic, and increase retries to 5. * Revisit how ghcr login works. * Add trunk checks. * All hail the linter * Heavilly revise workflow * Fettling * Fettling * Fettling * Fettling * Fettling * Cleanup * Cleanup * Fettling.. Why does mitm build but not redis? * Fettling.. Why does mitm build but not redis? * Debuggin * Fettling. * Fix build? * Permissions are a pain * Switch around some should_push logic because envs aren't available that early. * Permissionssssss * Trivy, bane of my life * Fix merge? * Fix labels * Help node along, among other things * Redis 6.1 & 7.1 aren't a thing any more. * Ffff USER nonsense * latest-openssl doesn't exist. * fixup mysqlproxy. * Fix labels * uurrgh * uurrgh * Didn't need to add the mitmproxy user, it exists * Missing ghcr login * Missing backtick * Fix build? * Add validate build step to bouncer. * Fix bouncer build * Disable laravel build * Missing env * Fix swarm mon build * Scout just doesn't seem to work.
2024-02-07 15:21:14 +00:00
chmod +x /etc/service/*/run /etc/service/*/finish && \
2019-11-09 03:00:40 +00:00
# Cleanup the /conf dir
2019-08-14 15:34:54 +00:00
rm -R /conf && \
2019-11-09 03:00:40 +00:00
# Write the PHP version into some template locations
2019-08-14 15:34:54 +00:00
sed -i "s/{{PHP}}/$PHP_VERSION/g" /etc/nginx/sites-enabled/default && \
sed -i "s/{{PHP}}/$PHP_VERSION/g" /etc/nginx/sites-enabled/default-ssl && \
2019-08-14 15:34:54 +00:00
sed -i "s/{{PHP}}/$PHP_VERSION/g" /etc/service/php-fpm/run && \
sed -i "s/{{PHP}}/$PHP_VERSION/g" /etc/service/logs-phpfpm-error/run && \
2019-11-09 00:14:13 +00:00
# Enable PHP-FPM status & PHP-FPM ping
sed -i -e "s|;pm.status_path =.*|pm.status_path = /fpm-status|g" /etc/php/*/fpm/pool.d/www.conf && \
sed -i -e "s|;ping.path =.*|ping.path = /fpm-ping|g" /etc/php/*/fpm/pool.d/www.conf && \
2019-08-14 15:34:54 +00:00
# Using environment variables in config files works, it would seem. Neat!
2019-11-09 00:13:01 +00:00
sed -i -e "s|pm.max_children = 5|pm.max_children = \${PHPFPM_MAX_CHILDREN}|g" /etc/php/*/fpm/pool.d/www.conf && \
# Disable daemonising in nginx
sed -i '1s;^;daemon off\;\n;' /etc/nginx/nginx.conf
2019-08-14 15:34:54 +00:00
# Expose ports.
EXPOSE 80/tcp
EXPOSE 443/tcp
2019-08-14 15:34:54 +00:00
2021-05-30 12:40:12 +00:00
# Make a volume for letsencrypt certs
VOLUME /etc/letsencrypt
2019-08-14 15:34:54 +00:00
# Create a healthcheck that makes sure our httpd is up
HEALTHCHECK --interval=30s --timeout=3s \
CMD curl -f http://localhost/ || exit 1
Trunk linter (#17) * linting is fun * mis-detection of missing healthcheck staements. * typo * disable tagging vanity tags on non-main branch * Unbugger node build? * Add gitleaks detector, remove an expired secret. * More linting-derived cleanup * Fiddle with trivy * Fiddle with trivy * add a readme * Fix build bug with php flavours * Marshall should build other flavours of ubuntu. * Fiddle with act cache location. * Add concurrency checks * Composer version gubbins for 7.0/7.1 * ubuntu is just a label, and injected over the top of. * Composer version gubbins for 7.0/7.1 * Run when workflow is altered too please. * Hopefully fix composer stage. * setup tooling meta-tooling. * Add trunk * Disable mirror mode, its being problematic, and increase retries to 5. * Revisit how ghcr login works. * Add trunk checks. * All hail the linter * Heavilly revise workflow * Fettling * Fettling * Fettling * Fettling * Fettling * Cleanup * Cleanup * Fettling.. Why does mitm build but not redis? * Fettling.. Why does mitm build but not redis? * Debuggin * Fettling. * Fix build? * Permissions are a pain * Switch around some should_push logic because envs aren't available that early. * Permissionssssss * Trivy, bane of my life * Fix merge? * Fix labels * Help node along, among other things * Redis 6.1 & 7.1 aren't a thing any more. * Ffff USER nonsense * latest-openssl doesn't exist. * fixup mysqlproxy. * Fix labels * uurrgh * uurrgh * Didn't need to add the mitmproxy user, it exists * Missing ghcr login * Missing backtick * Fix build? * Add validate build step to bouncer. * Fix bouncer build * Disable laravel build * Missing env * Fix swarm mon build * Scout just doesn't seem to work.
2024-02-07 15:21:14 +00:00
# checkov:skip=CKV_DOCKER_3 user cannot be determined at this stage.
FROM php-cli AS php-apache
2021-05-30 13:45:30 +00:00
LABEL maintainer="Matthew Baggett <matthew@baggett.me>" \
2021-06-06 22:08:12 +00:00
org.label-schema.vcs-url="https://github.com/benzine-framework/docker" \
org.opencontainers.image.source="https://github.com/benzine-framework/docker"
2019-08-15 16:16:45 +00:00
ARG PHP_VERSION
Trunk linter (#17) * linting is fun * mis-detection of missing healthcheck staements. * typo * disable tagging vanity tags on non-main branch * Unbugger node build? * Add gitleaks detector, remove an expired secret. * More linting-derived cleanup * Fiddle with trivy * Fiddle with trivy * add a readme * Fix build bug with php flavours * Marshall should build other flavours of ubuntu. * Fiddle with act cache location. * Add concurrency checks * Composer version gubbins for 7.0/7.1 * ubuntu is just a label, and injected over the top of. * Composer version gubbins for 7.0/7.1 * Run when workflow is altered too please. * Hopefully fix composer stage. * setup tooling meta-tooling. * Add trunk * Disable mirror mode, its being problematic, and increase retries to 5. * Revisit how ghcr login works. * Add trunk checks. * All hail the linter * Heavilly revise workflow * Fettling * Fettling * Fettling * Fettling * Fettling * Cleanup * Cleanup * Fettling.. Why does mitm build but not redis? * Fettling.. Why does mitm build but not redis? * Debuggin * Fettling. * Fix build? * Permissions are a pain * Switch around some should_push logic because envs aren't available that early. * Permissionssssss * Trivy, bane of my life * Fix merge? * Fix labels * Help node along, among other things * Redis 6.1 & 7.1 aren't a thing any more. * Ffff USER nonsense * latest-openssl doesn't exist. * fixup mysqlproxy. * Fix labels * uurrgh * uurrgh * Didn't need to add the mitmproxy user, it exists * Missing ghcr login * Missing backtick * Fix build? * Add validate build step to bouncer. * Fix bouncer build * Disable laravel build * Missing env * Fix swarm mon build * Scout just doesn't seem to work.
2024-02-07 15:21:14 +00:00
# ts:skip=AC_DOCKER_0002 Mis-detecting usage of apt instead of apt-get
2019-08-14 15:34:54 +00:00
RUN apt-get -qq update && \
apt-get -yqq install --no-install-recommends \
2019-08-14 15:34:54 +00:00
apache2 \
libapache2-mod-php$PHP_VERSION \
&& \
apt-get clean && \
Feature/multiplat (#2) * Fuckin' Perl. Marshall 199MB => 130MB * Down to 122MB. I'll take it. * Multiplatform rewrite * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Multiplatform rewrite. Squash me. * Squash this. * Squash this * Squash this * Squash this * Squash this * Squash this * Squash this * Squash this * Squash this * Squash this * Apparently github registry doesn't support multi-platform images :facepalm: * gchr.io replaced github registry containers, who knew. * GHCR not GHPR * Skip GHCR? * Probably should copy the login action changes across. * Fire ze cannons * Re-enable lint. Enable Marshall. Disable GHCR, its just broken jank. * Rename * Probably don't care about -onbuild builds right now. * The full matrix isn't building yet :/ * Typo. * I can't spell, evidently * This is causing some strange behaviour. * This is causing some strange behaviour. * Turn off fail fast. * Add PHP_VERSION ENVAR * Add vanity tag functionality * 7.4 all built right... Build all the other images? * Tabzilla * Fix issues with 8.0/7.0 being truncated to 8/7. Phase out 5.6 builder. * Vanity tags might run on a different instance oops. * Why was php7.4-redis/php8.0-redis removed in the first place. I have no idea.
2020-12-02 11:27:31 +00:00
rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/* /var/lib/dpkg/status.old /var/cache/debconf/templates.dat /var/log/dpkg.log /var/log/lastlog /var/log/apt/*.log && \
2020-03-19 11:58:26 +00:00
sed -i "s/upload_max_filesize.*/upload_max_filesize = $PHP_DATA_MAX_SIZE/g" /etc/php/$PHP_VERSION/apache2/php.ini && \
sed -i "s/post_max_size.*/post_max_size = $PHP_DATA_MAX_SIZE/g" /etc/php/$PHP_VERSION/apache2/php.ini && \
2019-08-14 15:34:54 +00:00
sed -i "s/max_execution_time.*/max_execution_time = 0/g" /etc/php/$PHP_VERSION/apache2/php.ini && \
sed -i "s/variables_order.*/variables_order = \"EGPCS\"/g" /etc/php/$PHP_VERSION/apache2/php.ini && \
sed -i "s/error_reporting.*/error_reporting = E_ALL \& \~E_DEPRECATED \& \~E_STRICT \& \~E_CORE_WARNING/g" /etc/php/$PHP_VERSION/apache2/php.ini && \
cp /etc/php/$PHP_VERSION/apache2/php.ini /etc/php/$PHP_VERSION/cli/php.ini && \
sed -i "s/ServerSignature On/ServerSignature Off/g" /etc/apache2/conf-enabled/security.conf && \
sed -i "s/ServerTokens OS/ServerTokens Prod/g" /etc/apache2/conf-enabled/security.conf
# Expose ports.
EXPOSE 80
# Create a healthcheck that makes sure our httpd is up
HEALTHCHECK --interval=30s --timeout=3s \
CMD curl -f http://localhost/ || exit 1
COPY apache /conf
2019-08-14 15:34:54 +00:00
RUN rm -fr /var/www/html && \
ln -s /app /var/www/html && \
mv /conf/ApacheConfig.conf /etc/apache2/sites-enabled/000-default.conf && \
mv /conf/envvars /etc/apache2/ && \
mv /conf/apache2.conf /etc/apache2/ && \
mkdir -p /etc/service/apache && \
mkdir -p /etc/service/show_logs && \
mv /conf/apache.runit /etc/service/apache/run && \
mv /conf/show_logs.runit /etc/service/show_logs/run && \
chmod +x /etc/service/*/run && \
2019-08-15 16:58:37 +00:00
rm -Rf /conf && \
2019-08-14 15:34:54 +00:00
a2enmod rewrite