2017-02-06 13:40:28 -05:00
|
|
|
# Image metadata and config
|
|
|
|
FROM debian:jessie
|
|
|
|
|
|
|
|
LABEL name="angular.io PR preview" \
|
|
|
|
description="This image implements the PR preview functionality for angular.io." \
|
|
|
|
vendor="Angular" \
|
|
|
|
version="1.0"
|
|
|
|
|
2017-02-28 14:09:44 -05:00
|
|
|
VOLUME /aio-secrets
|
2017-02-06 13:40:28 -05:00
|
|
|
VOLUME /var/www/aio-builds
|
2018-05-10 08:56:07 -04:00
|
|
|
VOLUME /dockerbuild
|
2017-02-06 13:40:28 -05:00
|
|
|
|
|
|
|
EXPOSE 80 443
|
|
|
|
|
2017-03-02 07:46:06 -05:00
|
|
|
|
|
|
|
# Build-time args and env vars
|
2018-05-09 13:54:13 -04:00
|
|
|
# The AIO_ARTIFACT_PATH path needs to be kept in synch with the value of
|
|
|
|
# `aio_preview->steps->store_artifacts->destination` property in `.circleci/config.yml`
|
|
|
|
ARG AIO_ARTIFACT_PATH=aio/dist/aio-snapshot.tgz
|
|
|
|
ARG TEST_AIO_ARTIFACT_PATH=$AIO_ARTIFACT_PATH
|
2017-03-02 07:46:06 -05:00
|
|
|
ARG AIO_BUILDS_DIR=/var/www/aio-builds
|
|
|
|
ARG TEST_AIO_BUILDS_DIR=/tmp/aio-builds
|
|
|
|
ARG AIO_DOMAIN_NAME=ngbuilds.io
|
2017-03-05 09:40:37 -05:00
|
|
|
ARG TEST_AIO_DOMAIN_NAME=$AIO_DOMAIN_NAME.localhost
|
2017-03-02 07:46:06 -05:00
|
|
|
ARG AIO_GITHUB_ORGANIZATION=angular
|
2018-05-10 08:56:07 -04:00
|
|
|
ARG TEST_AIO_GITHUB_ORGANIZATION=test-org
|
|
|
|
ARG AIO_GITHUB_REPO=angular
|
|
|
|
ARG TEST_AIO_GITHUB_REPO=test-repo
|
2018-04-05 03:41:27 -04:00
|
|
|
ARG AIO_GITHUB_TEAM_SLUGS=team,aio-contributors
|
|
|
|
ARG TEST_AIO_GITHUB_TEAM_SLUGS=team,aio-contributors
|
2017-03-05 09:40:37 -05:00
|
|
|
ARG AIO_NGINX_HOSTNAME=$AIO_DOMAIN_NAME
|
|
|
|
ARG TEST_AIO_NGINX_HOSTNAME=$TEST_AIO_DOMAIN_NAME
|
2017-03-02 07:46:06 -05:00
|
|
|
ARG AIO_NGINX_PORT_HTTP=80
|
|
|
|
ARG TEST_AIO_NGINX_PORT_HTTP=8080
|
|
|
|
ARG AIO_NGINX_PORT_HTTPS=443
|
|
|
|
ARG TEST_AIO_NGINX_PORT_HTTPS=4433
|
2018-05-10 08:56:07 -04:00
|
|
|
ARG AIO_SIGNIFICANT_FILES_PATTERN='^(?:aio|packages)/(?!.*[._]spec\\.[jt]s$)'
|
|
|
|
ARG TEST_AIO_SIGNIFICANT_FILES_PATTERN=$AIO_SIGNIFICANT_FILES_PATTERN
|
2017-06-18 18:15:07 -04:00
|
|
|
ARG AIO_TRUSTED_PR_LABEL="aio: preview"
|
|
|
|
ARG TEST_AIO_TRUSTED_PR_LABEL="aio: preview"
|
2018-08-15 08:47:45 -04:00
|
|
|
ARG AIO_PREVIEW_SERVER_HOSTNAME=preview.localhost
|
|
|
|
ARG TEST_AIO_PREVIEW_SERVER_HOSTNAME=preview.localhost
|
|
|
|
ARG AIO_ARTIFACT_MAX_SIZE=20971520
|
|
|
|
ARG TEST_AIO_ARTIFACT_MAX_SIZE=200
|
|
|
|
ARG AIO_PREVIEW_SERVER_PORT=3000
|
|
|
|
ARG TEST_AIO_PREVIEW_SERVER_PORT=3001
|
2017-03-02 07:46:06 -05:00
|
|
|
|
2018-05-10 08:56:07 -04:00
|
|
|
ENV AIO_ARTIFACT_PATH=$AIO_ARTIFACT_PATH TEST_AIO_ARTIFACT_PATH=$TEST_AIO_ARTIFACT_PATH \
|
|
|
|
AIO_BUILDS_DIR=$AIO_BUILDS_DIR TEST_AIO_BUILDS_DIR=$TEST_AIO_BUILDS_DIR \
|
|
|
|
AIO_DOMAIN_NAME=$AIO_DOMAIN_NAME TEST_AIO_DOMAIN_NAME=$TEST_AIO_DOMAIN_NAME \
|
|
|
|
AIO_GITHUB_ORGANIZATION=$AIO_GITHUB_ORGANIZATION TEST_AIO_GITHUB_ORGANIZATION=$TEST_AIO_GITHUB_ORGANIZATION \
|
|
|
|
AIO_GITHUB_REPO=$AIO_GITHUB_REPO TEST_AIO_GITHUB_REPO=$TEST_AIO_GITHUB_REPO \
|
|
|
|
AIO_GITHUB_TEAM_SLUGS=$AIO_GITHUB_TEAM_SLUGS TEST_AIO_GITHUB_TEAM_SLUGS=$TEST_AIO_GITHUB_TEAM_SLUGS \
|
|
|
|
AIO_LOCALCERTS_DIR=/etc/ssl/localcerts TEST_AIO_LOCALCERTS_DIR=/etc/ssl/localcerts-test \
|
|
|
|
AIO_NGINX_HOSTNAME=$AIO_NGINX_HOSTNAME TEST_AIO_NGINX_HOSTNAME=$TEST_AIO_NGINX_HOSTNAME \
|
|
|
|
AIO_NGINX_LOGS_DIR=/var/log/aio/nginx TEST_AIO_NGINX_LOGS_DIR=/var/log/aio/nginx-test \
|
|
|
|
AIO_NGINX_PORT_HTTP=$AIO_NGINX_PORT_HTTP TEST_AIO_NGINX_PORT_HTTP=$TEST_AIO_NGINX_PORT_HTTP \
|
|
|
|
AIO_NGINX_PORT_HTTPS=$AIO_NGINX_PORT_HTTPS TEST_AIO_NGINX_PORT_HTTPS=$TEST_AIO_NGINX_PORT_HTTPS \
|
|
|
|
AIO_SCRIPTS_JS_DIR=/usr/share/aio-scripts-js \
|
|
|
|
AIO_SCRIPTS_SH_DIR=/usr/share/aio-scripts-sh \
|
|
|
|
AIO_SIGNIFICANT_FILES_PATTERN=$AIO_SIGNIFICANT_FILES_PATTERN TEST_AIO_SIGNIFICANT_FILES_PATTERN=$TEST_AIO_SIGNIFICANT_FILES_PATTERN \
|
|
|
|
AIO_TRUSTED_PR_LABEL=$AIO_TRUSTED_PR_LABEL TEST_AIO_TRUSTED_PR_LABEL=$TEST_AIO_TRUSTED_PR_LABEL \
|
2018-08-15 08:47:45 -04:00
|
|
|
AIO_PREVIEW_SERVER_HOSTNAME=$AIO_PREVIEW_SERVER_HOSTNAME TEST_AIO_PREVIEW_SERVER_HOSTNAME=$TEST_AIO_PREVIEW_SERVER_HOSTNAME \
|
|
|
|
AIO_ARTIFACT_MAX_SIZE=$AIO_ARTIFACT_MAX_SIZE TEST_AIO_ARTIFACT_MAX_SIZE=$TEST_AIO_ARTIFACT_MAX_SIZE \
|
|
|
|
AIO_PREVIEW_SERVER_PORT=$AIO_PREVIEW_SERVER_PORT TEST_AIO_PREVIEW_SERVER_PORT=$TEST_AIO_PREVIEW_SERVER_PORT \
|
2018-05-10 08:56:07 -04:00
|
|
|
AIO_WWW_USER=www-data \
|
2017-02-06 13:40:28 -05:00
|
|
|
NODE_ENV=production
|
|
|
|
|
|
|
|
|
|
|
|
# Create directory for logs
|
|
|
|
RUN mkdir /var/log/aio
|
|
|
|
|
|
|
|
|
|
|
|
# Add extra package sources
|
|
|
|
RUN apt-get update -y && apt-get install -y curl
|
2018-05-09 13:48:52 -04:00
|
|
|
RUN curl --silent --show-error --location https://deb.nodesource.com/setup_10.x | bash -
|
2017-02-06 13:40:28 -05:00
|
|
|
RUN curl --silent --show-error https://dl.yarnpkg.com/debian/pubkey.gpg | apt-key add -
|
|
|
|
RUN echo "deb https://dl.yarnpkg.com/debian/ stable main" | tee /etc/apt/sources.list.d/yarn.list
|
2017-05-17 00:07:28 -04:00
|
|
|
RUN echo "deb http://ftp.debian.org/debian jessie-backports main" | tee /etc/apt/sources.list.d/backports.list
|
2017-02-06 13:40:28 -05:00
|
|
|
|
|
|
|
|
|
|
|
# Install packages
|
|
|
|
RUN apt-get update -y && apt-get install -y \
|
|
|
|
chkconfig \
|
|
|
|
cron \
|
|
|
|
dnsmasq \
|
|
|
|
nano \
|
|
|
|
nodejs \
|
2017-02-27 05:11:55 -05:00
|
|
|
openssl \
|
2017-02-06 13:40:28 -05:00
|
|
|
rsyslog \
|
|
|
|
yarn
|
2017-05-17 00:07:28 -04:00
|
|
|
RUN apt-get install -t jessie-backports -y nginx
|
2017-03-01 17:05:59 -05:00
|
|
|
RUN yarn global add pm2@2
|
2017-02-06 13:40:28 -05:00
|
|
|
|
|
|
|
|
2017-04-14 07:45:33 -04:00
|
|
|
# Set up log rotation
|
|
|
|
COPY logrotate/* /etc/logrotate.d/
|
|
|
|
RUN chmod 0644 /etc/logrotate.d/*
|
|
|
|
|
|
|
|
|
2017-02-06 13:40:28 -05:00
|
|
|
# Set up cronjobs
|
|
|
|
COPY cronjobs/aio-builds-cleanup /etc/cron.d/
|
|
|
|
RUN chmod 0744 /etc/cron.d/aio-builds-cleanup
|
|
|
|
RUN crontab /etc/cron.d/aio-builds-cleanup
|
2017-03-09 15:15:26 -05:00
|
|
|
RUN printenv | grep AIO_ >> /etc/environment
|
2017-02-06 13:40:28 -05:00
|
|
|
|
|
|
|
|
|
|
|
# Set up dnsmasq
|
2017-03-05 09:40:37 -05:00
|
|
|
COPY dnsmasq/dnsmasq.conf /etc/
|
2017-03-12 05:02:15 -04:00
|
|
|
RUN sed -i "s|{{\$AIO_NGINX_HOSTNAME}}|$AIO_NGINX_HOSTNAME|g" /etc/dnsmasq.conf
|
2018-08-15 08:47:45 -04:00
|
|
|
RUN sed -i "s|{{\$AIO_PREVIEW_SERVER_HOSTNAME}}|$AIO_PREVIEW_SERVER_HOSTNAME|g" /etc/dnsmasq.conf
|
2017-03-12 05:02:15 -04:00
|
|
|
RUN sed -i "s|{{\$TEST_AIO_NGINX_HOSTNAME}}|$TEST_AIO_NGINX_HOSTNAME|g" /etc/dnsmasq.conf
|
2018-08-15 08:47:45 -04:00
|
|
|
RUN sed -i "s|{{\$TEST_AIO_PREVIEW_SERVER_HOSTNAME}}|$TEST_AIO_PREVIEW_SERVER_HOSTNAME|g" /etc/dnsmasq.conf
|
2017-02-06 13:40:28 -05:00
|
|
|
|
|
|
|
|
2017-02-27 05:11:55 -05:00
|
|
|
# Set up SSL/TLS certificates
|
2017-03-05 09:40:37 -05:00
|
|
|
COPY nginx/create-selfsigned-cert.sh /tmp/
|
|
|
|
RUN chmod a+x /tmp/create-selfsigned-cert.sh
|
|
|
|
RUN /tmp/create-selfsigned-cert.sh "selfcert-prod" "$AIO_NGINX_HOSTNAME" "$AIO_LOCALCERTS_DIR"
|
|
|
|
RUN /tmp/create-selfsigned-cert.sh "selfcert-test" "$TEST_AIO_NGINX_HOSTNAME" "$TEST_AIO_LOCALCERTS_DIR"
|
|
|
|
RUN rm /tmp/create-selfsigned-cert.sh
|
2017-02-27 05:11:55 -05:00
|
|
|
RUN update-ca-certificates
|
|
|
|
|
|
|
|
|
2017-02-06 13:40:28 -05:00
|
|
|
# Set up nginx (for production and testing)
|
2017-05-17 00:07:28 -04:00
|
|
|
RUN sed -i -E "s|^user\s+\S+;|user $AIO_WWW_USER;|" /etc/nginx/nginx.conf
|
2017-05-17 10:09:33 -04:00
|
|
|
RUN rm -f /etc/nginx/conf.d/*
|
|
|
|
RUN rm -f /etc/nginx/sites-enabled/*
|
2017-05-17 00:07:28 -04:00
|
|
|
|
|
|
|
COPY nginx/aio-builds.conf /etc/nginx/conf.d/aio-builds-prod.conf
|
|
|
|
RUN sed -i "s|{{\$AIO_BUILDS_DIR}}|$AIO_BUILDS_DIR|g" /etc/nginx/conf.d/aio-builds-prod.conf
|
|
|
|
RUN sed -i "s|{{\$AIO_DOMAIN_NAME}}|$AIO_DOMAIN_NAME|g" /etc/nginx/conf.d/aio-builds-prod.conf
|
|
|
|
RUN sed -i "s|{{\$AIO_LOCALCERTS_DIR}}|$AIO_LOCALCERTS_DIR|g" /etc/nginx/conf.d/aio-builds-prod.conf
|
|
|
|
RUN sed -i "s|{{\$AIO_NGINX_LOGS_DIR}}|$AIO_NGINX_LOGS_DIR|g" /etc/nginx/conf.d/aio-builds-prod.conf
|
|
|
|
RUN sed -i "s|{{\$AIO_NGINX_PORT_HTTP}}|$AIO_NGINX_PORT_HTTP|g" /etc/nginx/conf.d/aio-builds-prod.conf
|
|
|
|
RUN sed -i "s|{{\$AIO_NGINX_PORT_HTTPS}}|$AIO_NGINX_PORT_HTTPS|g" /etc/nginx/conf.d/aio-builds-prod.conf
|
2018-08-15 08:47:45 -04:00
|
|
|
RUN sed -i "s|{{\$AIO_PREVIEW_SERVER_HOSTNAME}}|$AIO_PREVIEW_SERVER_HOSTNAME|g" /etc/nginx/conf.d/aio-builds-prod.conf
|
|
|
|
RUN sed -i "s|{{\$AIO_ARTIFACT_MAX_SIZE}}|$AIO_ARTIFACT_MAX_SIZE|g" /etc/nginx/conf.d/aio-builds-prod.conf
|
|
|
|
RUN sed -i "s|{{\$AIO_PREVIEW_SERVER_PORT}}|$AIO_PREVIEW_SERVER_PORT|g" /etc/nginx/conf.d/aio-builds-prod.conf
|
2017-05-17 00:07:28 -04:00
|
|
|
|
|
|
|
COPY nginx/aio-builds.conf /etc/nginx/conf.d/aio-builds-test.conf
|
|
|
|
RUN sed -i "s|{{\$AIO_BUILDS_DIR}}|$TEST_AIO_BUILDS_DIR|g" /etc/nginx/conf.d/aio-builds-test.conf
|
|
|
|
RUN sed -i "s|{{\$AIO_DOMAIN_NAME}}|$TEST_AIO_DOMAIN_NAME|g" /etc/nginx/conf.d/aio-builds-test.conf
|
|
|
|
RUN sed -i "s|{{\$AIO_LOCALCERTS_DIR}}|$TEST_AIO_LOCALCERTS_DIR|g" /etc/nginx/conf.d/aio-builds-test.conf
|
|
|
|
RUN sed -i "s|{{\$AIO_NGINX_LOGS_DIR}}|$TEST_AIO_NGINX_LOGS_DIR|g" /etc/nginx/conf.d/aio-builds-test.conf
|
|
|
|
RUN sed -i "s|{{\$AIO_NGINX_PORT_HTTP}}|$TEST_AIO_NGINX_PORT_HTTP|g" /etc/nginx/conf.d/aio-builds-test.conf
|
|
|
|
RUN sed -i "s|{{\$AIO_NGINX_PORT_HTTPS}}|$TEST_AIO_NGINX_PORT_HTTPS|g" /etc/nginx/conf.d/aio-builds-test.conf
|
2018-08-15 08:47:45 -04:00
|
|
|
RUN sed -i "s|{{\$AIO_PREVIEW_SERVER_HOSTNAME}}|$TEST_AIO_PREVIEW_SERVER_HOSTNAME|g" /etc/nginx/conf.d/aio-builds-test.conf
|
|
|
|
RUN sed -i "s|{{\$AIO_ARTIFACT_MAX_SIZE}}|$TEST_AIO_ARTIFACT_MAX_SIZE|g" /etc/nginx/conf.d/aio-builds-test.conf
|
|
|
|
RUN sed -i "s|{{\$AIO_PREVIEW_SERVER_PORT}}|$TEST_AIO_PREVIEW_SERVER_PORT|g" /etc/nginx/conf.d/aio-builds-test.conf
|
2017-02-06 13:40:28 -05:00
|
|
|
|
|
|
|
|
|
|
|
# Set up pm2
|
2017-03-01 17:05:59 -05:00
|
|
|
RUN pm2 startup systemv -u root > /dev/null
|
|
|
|
RUN chkconfig pm2-root on
|
2017-02-06 13:40:28 -05:00
|
|
|
|
|
|
|
|
|
|
|
# Set up the shell scripts
|
|
|
|
COPY scripts-sh/ $AIO_SCRIPTS_SH_DIR/
|
|
|
|
RUN chmod a+x $AIO_SCRIPTS_SH_DIR/*
|
|
|
|
RUN find $AIO_SCRIPTS_SH_DIR -maxdepth 1 -type f -printf "%P\n" \
|
|
|
|
| while read file; do ln -s $AIO_SCRIPTS_SH_DIR/$file /usr/local/bin/aio-${file%.*}; done
|
|
|
|
|
|
|
|
|
|
|
|
# Set up the Node.js scripts
|
|
|
|
COPY scripts-js/ $AIO_SCRIPTS_JS_DIR/
|
|
|
|
WORKDIR $AIO_SCRIPTS_JS_DIR/
|
2017-10-19 05:19:45 -04:00
|
|
|
RUN yarn install --production --frozen-lockfile
|
2017-02-06 13:40:28 -05:00
|
|
|
|
|
|
|
|
|
|
|
# Set up health check
|
|
|
|
HEALTHCHECK --interval=5m CMD /usr/local/bin/aio-health-check
|
|
|
|
|
|
|
|
|
|
|
|
# Go!
|
|
|
|
WORKDIR /
|
|
|
|
CMD aio-init && tail -f /dev/null
|