forked from vikunja/vikunja
Refactored Dockerfile
This commit is contained in:
parent
40411e4100
commit
aaaa50a75a
60
Dockerfile
60
Dockerfile
|
@ -1,51 +1,39 @@
|
||||||
|
# syntax=docker/dockerfile:1
|
||||||
|
# ┬─┐┬ ┐o┬ ┬─┐
|
||||||
|
# │─││ │││ │ │
|
||||||
|
# ┘─┘┘─┘┘┘─┘┘─┘
|
||||||
|
|
||||||
##############
|
FROM techknowlogick/xgo:go-1.19.2 AS builder
|
||||||
# Build stage
|
|
||||||
FROM --platform=$BUILDPLATFORM techknowlogick/xgo:go-1.19.2 AS build-env
|
|
||||||
|
|
||||||
RUN \
|
RUN go install github.com/magefile/mage@latest && \
|
||||||
go install github.com/magefile/mage@latest && \
|
mv /go/bin/mage /usr/local/go/bin
|
||||||
mv /go/bin/mage /usr/local/go/bin
|
|
||||||
|
|
||||||
ARG VIKUNJA_VERSION
|
|
||||||
|
|
||||||
# Setup repo
|
|
||||||
COPY . /go/src/code.vikunja.io/api
|
|
||||||
WORKDIR /go/src/code.vikunja.io/api
|
WORKDIR /go/src/code.vikunja.io/api
|
||||||
|
COPY . ./
|
||||||
|
|
||||||
ARG TARGETOS TARGETARCH TARGETVARIANT
|
ARG TARGETOS TARGETARCH TARGETVARIANT
|
||||||
# Checkout version if set
|
|
||||||
RUN if [ -n "${VIKUNJA_VERSION}" ]; then git checkout "${VIKUNJA_VERSION}"; fi && \
|
|
||||||
mage build:clean && \
|
|
||||||
mage release:xgo $TARGETOS/$TARGETARCH/$TARGETVARIANT
|
|
||||||
|
|
||||||
###################
|
RUN mage build:clean && \
|
||||||
|
mage release:xgo "${TARGETOS}/${TARGETARCH}/${TARGETVARIANT}"
|
||||||
|
|
||||||
|
# ┬─┐┬ ┐┌┐┐┌┐┐┬─┐┬─┐
|
||||||
|
# │┬┘│ │││││││├─ │┬┘
|
||||||
|
# ┘└┘┘─┘┘└┘┘└┘┴─┘┘└┘
|
||||||
|
|
||||||
# The actual image
|
# The actual image
|
||||||
# Note: I wanted to use the scratch image here, but unfortunatly the go-sqlite bindings require cgo and
|
# Note: I wanted to use the scratch image here, but unfortunatly the go-sqlite bindings require cgo and
|
||||||
# because of this, the container would not start when I compiled the image without cgo.
|
# because of this, the container would not start when I compiled the image without cgo.
|
||||||
FROM alpine:3.16
|
FROM alpine:3.16 AS runner
|
||||||
LABEL maintainer="maintainers@vikunja.io"
|
LABEL maintainer="maintainers@vikunja.io"
|
||||||
|
|
||||||
WORKDIR /app/vikunja/
|
WORKDIR /app/vikunja/
|
||||||
COPY --from=build-env /build/vikunja-* vikunja
|
|
||||||
|
ENTRYPOINT [ "/app/vikunja/vikunja" ]
|
||||||
ENV VIKUNJA_SERVICE_ROOTPATH=/app/vikunja/
|
ENV VIKUNJA_SERVICE_ROOTPATH=/app/vikunja/
|
||||||
|
|
||||||
# Dynamic permission changing stuff
|
RUN apk --update --no-cache add tzdata && \
|
||||||
ENV PUID 1000
|
addgroup -g 1000 vikunja && \
|
||||||
ENV PGID 1000
|
adduser -s /bin/sh -D -G vikunja -u 1000 vikunja -h /app/vikunja -H && \
|
||||||
RUN apk --no-cache add shadow && \
|
mkdir files && \
|
||||||
addgroup -g ${PGID} vikunja && \
|
chown vikunja:vikunja files
|
||||||
adduser -s /bin/sh -D -G vikunja -u ${PUID} vikunja -h /app/vikunja -H && \
|
|
||||||
chown vikunja -R /app/vikunja
|
|
||||||
COPY run.sh /run.sh
|
|
||||||
|
|
||||||
# Add time zone data
|
COPY --from=builder --chown=vikunja:vikunja /build/vikunja-* vikunja
|
||||||
RUN apk --no-cache add tzdata
|
|
||||||
|
|
||||||
# Files permissions
|
|
||||||
RUN mkdir /app/vikunja/files && \
|
|
||||||
chown -R vikunja /app/vikunja/files
|
|
||||||
VOLUME /app/vikunja/files
|
|
||||||
|
|
||||||
CMD ["/run.sh"]
|
|
||||||
EXPOSE 3456
|
|
||||||
|
|
Loading…
Reference in New Issue