|
| 1 | +FROM node:lts-alpine AS templating |
| 2 | + |
| 3 | +ENV WORKDIR=/template |
| 4 | + |
| 5 | +RUN mkdir -p ${WORKDIR} |
| 6 | +WORKDIR ${WORKDIR} |
| 7 | + |
| 8 | +COPY theme-build ${WORKDIR}/ |
| 9 | +COPY resources ${WORKDIR}/resources |
| 10 | + |
| 11 | +RUN yarn install |
| 12 | +RUN node template-colors.js ${WORKDIR}/resources/var/www/html/styles/default.css.tpl ${WORKDIR}/build/default.css |
| 13 | +RUN node template-error-pages.js ${WORKDIR}/resources/var/www/html/errors/error-page.html.tpl ${WORKDIR}/build/errors |
| 14 | + |
| 15 | + |
| 16 | +FROM alpine:3.20 AS builder |
| 17 | + |
| 18 | +# dockerfile is based on https://github.com/dockerfile/nginx and https://github.com/bellycard/docker-loadbalancer |
| 19 | +ENV NGINX_VERSION 1.26.3 |
| 20 | +ENV NGINX_TAR_SHA256="69ee2b237744036e61d24b836668aad3040dda461fe6f570f1787eab570c75aa" |
| 21 | + |
| 22 | +COPY nginx-build / |
| 23 | + |
| 24 | +RUN set -x -o errexit \ |
| 25 | + && set -o nounset \ |
| 26 | + && set -o pipefail \ |
| 27 | + && apk update \ |
| 28 | + && apk upgrade \ |
| 29 | + && apk --update add bash openssl-dev pcre-dev zlib-dev wget build-base \ |
| 30 | + && mkdir /build \ |
| 31 | + && cd /build \ |
| 32 | + && wget http://nginx.org/download/nginx-${NGINX_VERSION}.tar.gz \ |
| 33 | + && echo "${NGINX_TAR_SHA256} *nginx-${NGINX_VERSION}.tar.gz" | sha256sum -c - \ |
| 34 | + && tar -zxvf nginx-${NGINX_VERSION}.tar.gz \ |
| 35 | + && cd /build/nginx-${NGINX_VERSION} \ |
| 36 | + && /build.sh \ |
| 37 | + && rm -rf /var/cache/apk/* /build |
| 38 | + |
| 39 | +FROM alpine:3.20 |
| 40 | + |
| 41 | +LABEL maintainer="hello@cloudogu.com" |
| 42 | + |
| 43 | +ENV WARP_MENU_VERSION=2.0.3 \ |
| 44 | + WARP_MENU_TAR_SHA256="8dfd023579728b6786bdb4664fb6d3e629717d9d2d27cdd4b365f9a844f1858c" \ |
| 45 | + CES_ABOUT_VERSION="0.7.0" \ |
| 46 | + CES_ABOUT_TAR_SHA256="fcfdfb86dac75d5ae751cc0e8c3436ecee12f0d5ed830897c4f61029ae1df27e" \ |
| 47 | + # Used in template to invalidate caches - do not remove. The release script will auto update this line |
| 48 | + VERSION="0.1.0" |
| 49 | + |
| 50 | +# Install required packages |
| 51 | +RUN apk upgrade \ |
| 52 | + && apk --update add \ |
| 53 | + bash \ |
| 54 | + openssl \ |
| 55 | + pcre \ |
| 56 | + musl \ |
| 57 | + zlib |
| 58 | + |
| 59 | + # add nginx user |
| 60 | +RUN adduser nginx -D |
| 61 | + |
| 62 | +# prepare folders |
| 63 | +RUN set -x \ |
| 64 | + && mkdir -p /var/www/html \ |
| 65 | + && mkdir -p /var/www/html/customhtml \ |
| 66 | + && mkdir -p /var/log/nginx \ |
| 67 | + && mkdir -p /etc/nginx/include.d \ |
| 68 | + && mkdir -p /etc/nginx/conf.d |
| 69 | + |
| 70 | +# install ces-about page |
| 71 | +RUN wget -O /tmp/ces-about-v${CES_ABOUT_VERSION}.tar.gz https://github.com/cloudogu/ces-about/releases/download/v${CES_ABOUT_VERSION}/ces-about_v${CES_ABOUT_VERSION}.tar.gz \ |
| 72 | + && echo "${CES_ABOUT_TAR_SHA256} */tmp/ces-about-v${CES_ABOUT_VERSION}.tar.gz" | sha256sum -c - \ |
| 73 | + && tar -xzvf /tmp/ces-about-v${CES_ABOUT_VERSION}.tar.gz -C /var/www/html \ |
| 74 | + && mkdir -p /etc/nginx/include.d/ \ |
| 75 | + && cp /var/www/html/routes/ces-about-routes.conf /etc/nginx/include.d/ \ |
| 76 | + && rm -rf /var/www/html/routes |
| 77 | + |
| 78 | +# install warp menu |
| 79 | +RUN wget https://github.com/cloudogu/warp-menu/releases/download/v${WARP_MENU_VERSION}/warp-v${WARP_MENU_VERSION}.zip -q -O /tmp/warp.zip \ |
| 80 | + && echo "${WARP_MENU_TAR_SHA256} */tmp/warp.zip" | sha256sum -c - \ |
| 81 | + && unzip /tmp/warp.zip -d /var/www/html |
| 82 | + |
| 83 | + # redirect logs |
| 84 | +RUN ln -sf /dev/stdout /var/log/nginx/access.log \ |
| 85 | + && ln -sf /dev/stderr /var/log/nginx/error.log |
| 86 | + |
| 87 | +# cleanup apk cache |
| 88 | +RUN rm -rf /var/cache/apk/* |
| 89 | + |
| 90 | +# copy files |
| 91 | +COPY --from=builder /usr/sbin/nginx /usr/sbin/nginx |
| 92 | + |
| 93 | +# copy files |
| 94 | +COPY resources / |
| 95 | + |
| 96 | +# copy templated files |
| 97 | +COPY --from=templating /template/build/default.css /var/www/html/styles/default.css |
| 98 | +COPY --from=templating /template/build/errors /var/www/html/errors |
| 99 | + |
| 100 | +# Volumes are used to avoid writing to containers writable layer https://docs.docker.com/storage/ |
| 101 | +# Compared to the bind mounted volumes we declare in the dogu.json, |
| 102 | +# the volumes declared here are not mounted to the dogu if the container is destroyed/recreated, |
| 103 | +# e.g. after a dogu upgrade |
| 104 | +VOLUME ["/etc/nginx/app.conf.d", "/var/www/html"] |
| 105 | + |
| 106 | +# Define working directory. |
| 107 | +WORKDIR /etc/nginx |
| 108 | + |
| 109 | +# Expose ports. |
| 110 | +EXPOSE 80 |
| 111 | + |
| 112 | +# Define default command. |
| 113 | +ENTRYPOINT ["/startup.sh"] |
0 commit comments