]> git.immae.eu Git - github/bastienwirtz/homer.git/blobdiff - Dockerfile
Merge pull request #421 from bastienwirtz/docker-rework
[github/bastienwirtz/homer.git] / Dockerfile
index 7621639c17956b6c95fdf5147fad9877d484daea..0e9d51a30ce240177c0306ca29d5892e08685e9b 100644 (file)
@@ -1,15 +1,39 @@
-FROM alpine:3.11
+# build stage
+FROM node:lts-alpine as build-stage
 
-COPY ./ /www/
+WORKDIR /app
 
-ENV USER darkhttpd
-ENV GROUP darkhttpd
-ENV GID 911
-ENV UID 911
+COPY package*.json ./
+RUN yarn install --frozen-lockfile
 
-RUN addgroup -S ${GROUP} -g ${GID} && adduser -D -S -u ${UID} ${USER} ${GROUP} && \
-    apk add -U darkhttpd
+COPY . .
+RUN yarn build
 
-USER darkhttpd
+# production stage
+FROM alpine:3.15
 
-ENTRYPOINT ["darkhttpd","/www/", "--no-listing"]
+ENV GID 1000
+ENV UID 1000
+ENV PORT 8080
+ENV SUBFOLDER "/_"
+ENV INIT_ASSETS 1
+
+RUN addgroup -S lighttpd -g ${GID} && adduser -D -S -u ${UID} lighttpd lighttpd && \
+    apk add -U --no-cache lighttpd
+
+WORKDIR /www
+
+COPY lighttpd.conf /lighttpd.conf
+COPY entrypoint.sh /entrypoint.sh
+COPY --from=build-stage --chown=${UID}:${GID} /app/dist /www/
+COPY --from=build-stage --chown=${USER}:${GROUP} /app/dist/assets /www/default-assets
+
+USER ${UID}:${GID}
+
+HEALTHCHECK --interval=30s --timeout=5s --retries=3 \
+    CMD wget --no-verbose --tries=1 --spider http://127.0.0.1:${PORT}/ || exit 1
+
+EXPOSE ${PORT}
+VOLUME /www/assets
+
+ENTRYPOINT ["/bin/sh", "/entrypoint.sh"]