mirror of
https://github.com/syncthing/syncthing.git
synced 2024-11-15 18:08:45 -07:00
e988978fa1
### Purpose The OCI image spec specifies well-defined [annotations](https://github.com/opencontainers/image-spec/blob/main/annotations.md) that can be added to images. Theses annotations can then be used by other tools to gather more information of an image. This PR adds the `org.opencontainers.image.source` to allow tools such as [renovate](https://github.com/renovatebot/renovate) to find the release notes of a give version. ~~I've only done this change for `Dockerfile`. Should I also add the label to the other dockerfiles?~~ I've now added the source annotations to all `Dockerfile`s & action workflows. ### Testing None, change was done by following the [renovate documentation](https://docs.renovatebot.com/modules/datasource/docker/).
58 lines
1.7 KiB
Docker
58 lines
1.7 KiB
Docker
ARG GOVERSION=latest
|
|
|
|
#
|
|
# Maybe build Syncthing. This is a bit ugly as we can't make an entire
|
|
# section of the Dockerfile conditional, so we end up always pulling the
|
|
# golang image as builder. Then we check if the executable we need already
|
|
# exists (pre-built) otherwise we build it.
|
|
#
|
|
|
|
FROM golang:$GOVERSION AS builder
|
|
ARG BUILD_USER
|
|
ARG BUILD_HOST
|
|
ARG TARGETARCH
|
|
|
|
WORKDIR /src
|
|
COPY . .
|
|
|
|
ENV CGO_ENABLED=0
|
|
RUN if [ ! -f syncthing-linux-$TARGETARCH ] ; then \
|
|
go run build.go -no-upgrade build syncthing ; \
|
|
mv syncthing syncthing-linux-$TARGETARCH ; \
|
|
fi
|
|
|
|
#
|
|
# The rest of the Dockerfile uses the binary from the builder, prebuilt or
|
|
# not.
|
|
#
|
|
|
|
FROM alpine
|
|
ARG TARGETARCH
|
|
|
|
LABEL org.opencontainers.image.authors="The Syncthing Project" \
|
|
org.opencontainers.image.url="https://syncthing.net" \
|
|
org.opencontainers.image.documentation="https://docs.syncthing.net" \
|
|
org.opencontainers.image.source="https://github.com/syncthing/syncthing" \
|
|
org.opencontainers.image.vendor="The Syncthing Project"
|
|
org.opencontainers.image.licenses="MPL-2.0"
|
|
org.opencontainers.image.title="Syncthing"
|
|
|
|
EXPOSE 8384 22000/tcp 22000/udp 21027/udp
|
|
|
|
VOLUME ["/var/syncthing"]
|
|
|
|
RUN apk add --no-cache ca-certificates curl libcap su-exec tzdata
|
|
|
|
COPY --from=builder /src/syncthing-linux-$TARGETARCH /bin/syncthing
|
|
COPY --from=builder /src/script/docker-entrypoint.sh /bin/entrypoint.sh
|
|
|
|
ENV PUID=1000 PGID=1000 HOME=/var/syncthing
|
|
|
|
HEALTHCHECK --interval=1m --timeout=10s \
|
|
CMD curl -fkLsS -m 2 127.0.0.1:8384/rest/noauth/health | grep -o --color=never OK || exit 1
|
|
|
|
ENV STGUIADDRESS=0.0.0.0:8384
|
|
ENV STHOMEDIR=/var/syncthing/config
|
|
RUN chmod 755 /bin/entrypoint.sh
|
|
ENTRYPOINT ["/bin/entrypoint.sh", "/bin/syncthing"]
|