X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=Dockerfile;h=03751124aebfe2a0df8a084c1ea6681c4bbb9b33;hb=b102c9b2b3aaa4d66bda8d932ba2d6bd4575c044;hp=66788b483963f6d583e53426c1bc24f32152b6f6;hpb=672bd42a799abf6fb39a0763188d8dbc88fbda66;p=github%2Fbastienwirtz%2Fhomer.git diff --git a/Dockerfile b/Dockerfile index 66788b4..0375112 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 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 darkhttpd +COPY --from=build-stage --chown=${USER}:${GROUP} /app/dist /www/ +COPY --from=build-stage --chown=${USER}:${GROUP} /app/dist/assets /www/default-assets +COPY --chown=${USER}:${GROUP} entrypoint.sh /entrypoint.sh -ENTRYPOINT ["darkhttpd","/www/"] +EXPOSE ${PORT} +VOLUME /www/assets +ENTRYPOINT ["/bin/sh", "/entrypoint.sh"]