]> git.immae.eu Git - github/bastienwirtz/homer.git/blobdiff - Dockerfile.arm64v8
Merge pull request #85 from bastienwirtz/splitted-documentation
[github/bastienwirtz/homer.git] / Dockerfile.arm64v8
index b7c0484f54c3e1316ae34c6287e4385d099ceb6d..0175341d9ed490bd6603cdf7b213fd5558608ca0 100644 (file)
@@ -1,14 +1,25 @@
+# build stage
+FROM node:lts-alpine as build-stage
+
+WORKDIR /app
+
+COPY package*.json ./
+RUN yarn install --frozen-lockfile
+
+COPY . .
+RUN yarn build
+
+# Multi arch build support
 FROM alpine as qemu
 
-ARG QEMU_VERSION "v4.2.0-7"
+ARG QEMU_VERSION="v4.2.0-7"
 
 RUN wget https://github.com/multiarch/qemu-user-static/releases/download/${QEMU_VERSION}/qemu-aarch64-static && chmod +x qemu-aarch64-static
 
+# production stage
 FROM arm64v8/alpine:3.11
-COPY qemu-arm-static /usr/bin
 
 COPY --from=qemu qemu-aarch64-static /usr/bin/
-COPY ./ /www/
 
 ENV USER darkhttpd
 ENV GROUP darkhttpd
@@ -19,6 +30,8 @@ RUN addgroup -S ${GROUP} -g ${GID} && adduser -D -S -u ${UID} ${USER} ${GROUP} &
     apk add -U darkhttpd && \
     rm /usr/bin/qemu-aarch64-static
 
-USER darkhttpd
+USER ${USER}
+
+COPY --from=build-stage --chown=${USER}:${GROUP} /app/dist /www/
 
-ENTRYPOINT ["darkhttpd","/www/"]
+ENTRYPOINT ["darkhttpd","/www/","--no-listing"]