mirror of https://github.com/lissy93/dashy
Attempt 1
This commit is contained in:
parent
ba247f7f9f
commit
c1092e12c0
32
Dockerfile
32
Dockerfile
|
@ -1,26 +1,30 @@
|
||||||
|
# build stage
|
||||||
# Build Stage
|
|
||||||
FROM node:lts-alpine as build-stage
|
FROM node:lts-alpine as build-stage
|
||||||
LABEL Maintainer Alicia Sykes <alicia@omg.lol>
|
|
||||||
|
|
||||||
RUN apk update
|
|
||||||
|
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
|
|
||||||
COPY package.json ./
|
COPY package*.json ./
|
||||||
COPY yarn.lock ./
|
RUN yarn install --frozen-lockfile
|
||||||
RUN yarn install
|
|
||||||
|
|
||||||
COPY . .
|
COPY . .
|
||||||
RUN yarn build
|
RUN yarn build
|
||||||
|
|
||||||
# Production Stage
|
# production stage
|
||||||
ENV PORT 80
|
FROM alpine:3.11
|
||||||
|
|
||||||
FROM nginx:1.15.7-alpine as production-stage
|
ENV USER darkhttpd
|
||||||
|
ENV GROUP darkhttpd
|
||||||
|
ENV GID 911
|
||||||
|
ENV UID 911
|
||||||
|
ENV PORT 8080
|
||||||
|
|
||||||
COPY --from=build-stage /app/dist /usr/share/nginx/html
|
RUN addgroup -S ${GROUP} -g ${GID} && adduser -D -S -u ${UID} ${USER} ${GROUP} && \
|
||||||
|
apk add -U --no-cache su-exec 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 entrypoint.sh /entrypoint.sh
|
||||||
|
|
||||||
EXPOSE ${PORT}
|
EXPOSE ${PORT}
|
||||||
VOLUME /usr/share/nginx/html/item-icons
|
VOLUME /www/assets
|
||||||
CMD ["nginx", "-g", "daemon off;"]
|
ENTRYPOINT ["/bin/sh", "/entrypoint.sh"]
|
|
@ -0,0 +1,15 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
# Ensure default assets are present.
|
||||||
|
while true; do echo n; done | cp -Ri /www/default-assets/* /www/assets/ &> /dev/null
|
||||||
|
|
||||||
|
# Ensure compatibility with previous version (config.yml was in the root directory)
|
||||||
|
if [ -f "/www/config.yml" ]; then
|
||||||
|
yes n | cp -i /www/config.yml /www/assets/ &> /dev/null
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Install default config if no one is available.
|
||||||
|
yes n | cp -i /www/default-assets/config.yml.dist /www/assets/config.yml &> /dev/null
|
||||||
|
|
||||||
|
chown -R $UID:$GID /www/assets
|
||||||
|
exec su-exec $UID:$GID darkhttpd /www/ --no-listing --port "$PORT"
|
Loading…
Reference in New Issue