X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=Dockerfile;h=19d01f810aab9ac58277190be5ead17ea4ed9f0e;hb=92d899bd4809183f1cd1cec302d66fa32461aac5;hp=df889349839d9ba4c0369706f33a50deeec7ed3f;hpb=7d5c71d7aeb8f6405410c5c17de196bf10f0e285;p=github%2Fbastienwirtz%2Fhomer.git diff --git a/Dockerfile b/Dockerfile index df88934..19d01f8 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,15 +1,30 @@ -FROM alpine:3.11 +# build stage +FROM node:lts-alpine as build-stage + +WORKDIR /app + +COPY package*.json ./ +RUN yarn install --frozen-lockfile -COPY ./ /www/ +COPY . . +RUN yarn build + +# production stage +FROM alpine:3.11 -ENV USER abc -ENV GROUP abc +ENV USER darkhttpd +ENV GROUP darkhttpd ENV GID 911 ENV UID 911 +ENV PORT 8080 RUN addgroup -S ${GROUP} -g ${GID} && adduser -D -S -u ${UID} ${USER} ${GROUP} && \ - apk add -U darkhttpd + apk add -U --no-cache su-exec darkhttpd -USER abc +COPY --from=build-stage --chown=${USER}:${GROUP} /app/dist /www/ +COPY --from=build-stage --chown=${USER}:${GROUP} /app/dist/assets /www/default-assets +COPY entrypoint.sh /entrypoint.sh -ENTRYPOINT ["darkhttpd","/www/"] +EXPOSE ${PORT} +VOLUME /www/assets +ENTRYPOINT ["/bin/sh", "/entrypoint.sh"]