149defddda
Reviewed-on: https://kolaente.dev/vikunja/frontend/pulls/883 Co-authored-by: renovate <renovatebot@kolaente.de> Co-committed-by: renovate <renovatebot@kolaente.de>
45 lines
1.3 KiB
Docker
45 lines
1.3 KiB
Docker
# Stage 1: Build application
|
|
FROM node:17 AS compile-image
|
|
|
|
WORKDIR /build
|
|
|
|
ARG USE_RELEASE=false
|
|
ARG RELEASE_VERSION=main
|
|
|
|
ENV YARN_CACHE_FOLDER .cache/yarn/
|
|
COPY . ./
|
|
|
|
RUN \
|
|
if [ $USE_RELEASE = true ]; then \
|
|
rm -rf dist/ && \
|
|
wget https://dl.vikunja.io/frontend/vikunja-frontend-$RELEASE_VERSION.zip -O frontend-release.zip && \
|
|
unzip frontend-release.zip -d dist/ && \
|
|
exit 0; \
|
|
fi && \
|
|
# Build the frontend
|
|
yarn install --frozen-lockfile --network-timeout 100000 && \
|
|
echo '{"VERSION": "'$(git describe --tags --always --abbrev=10 | sed 's/-/+/' | sed 's/^v//' | sed 's/-g/-/')'"}' > src/version.json && \
|
|
yarn run build
|
|
|
|
# Stage 2: copy
|
|
FROM nginx
|
|
|
|
RUN apt-get update && apt-get install -y apt-utils openssl && \
|
|
mkdir -p /etc/nginx/ssl && \
|
|
openssl genrsa -out /etc/nginx/ssl/dummy.key 2048 && \
|
|
openssl req -new -key /etc/nginx/ssl/dummy.key -out /etc/nginx/ssl/dummy.csr -subj "/C=DE/L=Berlin/O=Vikunja/CN=Vikunja Snakeoil" && \
|
|
openssl x509 -req -days 3650 -in /etc/nginx/ssl/dummy.csr -signkey /etc/nginx/ssl/dummy.key -out /etc/nginx/ssl/dummy.crt
|
|
|
|
COPY nginx.conf /etc/nginx/nginx.conf
|
|
COPY run.sh /run.sh
|
|
|
|
# copy compiled files from stage 1
|
|
COPY --from=compile-image /build/dist /usr/share/nginx/html
|
|
|
|
# Unprivileged user
|
|
ENV PUID 1000
|
|
ENV PGID 1000
|
|
|
|
LABEL maintainer="maintainers@vikunja.io"
|
|
|
|
CMD "/run.sh"
|