2023-06-14 14:32:20 +03:00
|
|
|
FROM --platform=$BUILDPLATFORM docker.io/tonistiigi/xx AS xx
|
|
|
|
|
|
|
|
FROM --platform=$BUILDPLATFORM docker.io/library/golang:1.21-alpine3.18 as build-env
|
2018-03-12 12:59:13 +03:00
|
|
|
|
2019-08-05 00:58:16 +03:00
|
|
|
ARG GOPROXY
|
|
|
|
ENV GOPROXY ${GOPROXY:-direct}
|
|
|
|
|
2018-03-12 12:59:13 +03:00
|
|
|
ARG GITEA_VERSION
|
2018-10-23 14:47:59 +03:00
|
|
|
ARG TAGS="sqlite sqlite_unlock_notify"
|
2020-09-28 01:52:22 +03:00
|
|
|
ENV TAGS "bindata timetzdata $TAGS"
|
2020-06-07 00:42:32 +03:00
|
|
|
ARG CGO_EXTRA_CFLAGS
|
2018-03-12 12:59:13 +03:00
|
|
|
|
2023-06-14 14:32:20 +03:00
|
|
|
#
|
|
|
|
# Transparently cross compile for the target platform
|
|
|
|
#
|
|
|
|
COPY --from=xx / /
|
|
|
|
ARG TARGETPLATFORM
|
|
|
|
RUN apk --no-cache add clang lld
|
|
|
|
RUN xx-apk --no-cache add gcc musl-dev
|
|
|
|
ENV CGO_ENABLED=1
|
|
|
|
RUN xx-go --wrap
|
|
|
|
#
|
|
|
|
# for go generate and binfmt to find
|
|
|
|
# without it the generate phase will fail with
|
|
|
|
# #19 25.04 modules/public/public_bindata.go:8: running "go": exit status 1
|
|
|
|
# #19 25.39 aarch64-binfmt-P: Could not open '/lib/ld-musl-aarch64.so.1': No such file or directory
|
|
|
|
# why exactly is it needed? where is binfmt involved?
|
|
|
|
#
|
|
|
|
RUN cp /*-alpine-linux-musl*/lib/ld-musl-*.so.1 /lib || true
|
|
|
|
|
|
|
|
RUN apk --no-cache add build-base git nodejs npm
|
2018-03-12 12:59:13 +03:00
|
|
|
|
|
|
|
COPY . ${GOPATH}/src/code.gitea.io/gitea
|
|
|
|
WORKDIR ${GOPATH}/src/code.gitea.io/gitea
|
|
|
|
|
2023-06-14 14:32:20 +03:00
|
|
|
RUN make clean-all
|
|
|
|
RUN make frontend
|
|
|
|
RUN go build contrib/environment-to-ini/environment-to-ini.go && xx-verify environment-to-ini
|
|
|
|
RUN make go-check generate-backend static-executable && xx-verify gitea
|
2023-10-29 15:20:54 +03:00
|
|
|
|
2023-05-14 04:49:00 +03:00
|
|
|
FROM docker.io/library/alpine:3.18
|
2022-11-25 12:11:23 +03:00
|
|
|
LABEL maintainer="contact@forgejo.org"
|
2015-08-25 07:41:01 +03:00
|
|
|
|
2016-11-28 16:13:18 +03:00
|
|
|
EXPOSE 22 3000
|
2015-08-25 07:41:01 +03:00
|
|
|
|
2017-05-08 14:09:20 +03:00
|
|
|
RUN apk --no-cache add \
|
2016-11-28 16:13:18 +03:00
|
|
|
bash \
|
2018-03-12 12:59:13 +03:00
|
|
|
ca-certificates \
|
|
|
|
curl \
|
|
|
|
gettext \
|
2016-11-28 16:13:18 +03:00
|
|
|
git \
|
|
|
|
linux-pam \
|
|
|
|
openssh \
|
2018-03-12 12:59:13 +03:00
|
|
|
s6 \
|
|
|
|
sqlite \
|
|
|
|
su-exec \
|
2023-06-14 14:32:20 +03:00
|
|
|
gnupg
|
2018-03-12 12:59:13 +03:00
|
|
|
|
2017-06-30 09:10:37 +03:00
|
|
|
RUN addgroup \
|
2016-11-28 19:37:31 +03:00
|
|
|
-S -g 1000 \
|
2016-11-28 16:13:18 +03:00
|
|
|
git && \
|
2016-11-28 19:22:22 +03:00
|
|
|
adduser \
|
|
|
|
-S -H -D \
|
|
|
|
-h /data/git \
|
2016-11-28 16:13:18 +03:00
|
|
|
-s /bin/bash \
|
|
|
|
-u 1000 \
|
2016-11-28 19:22:22 +03:00
|
|
|
-G git \
|
2016-12-15 12:16:55 +03:00
|
|
|
git && \
|
2021-04-29 20:48:52 +03:00
|
|
|
echo "git:*" | chpasswd -e
|
2015-08-17 10:10:23 +03:00
|
|
|
|
2017-06-30 09:10:37 +03:00
|
|
|
ENV USER git
|
|
|
|
ENV GITEA_CUSTOM /data/gitea
|
2016-01-25 16:07:37 +03:00
|
|
|
|
2015-10-02 12:56:36 +03:00
|
|
|
VOLUME ["/data"]
|
2016-11-28 16:13:18 +03:00
|
|
|
|
|
|
|
ENTRYPOINT ["/usr/bin/entrypoint"]
|
|
|
|
CMD ["/bin/s6-svscan", "/etc/s6"]
|
|
|
|
|
2023-06-14 14:32:20 +03:00
|
|
|
COPY docker/root /
|
2018-03-12 12:59:13 +03:00
|
|
|
COPY --from=build-env /go/src/code.gitea.io/gitea/gitea /app/gitea/gitea
|
2021-02-23 22:21:44 +03:00
|
|
|
COPY --from=build-env /go/src/code.gitea.io/gitea/environment-to-ini /usr/local/bin/environment-to-ini
|
2023-02-21 20:32:24 +03:00
|
|
|
COPY --from=build-env /go/src/code.gitea.io/gitea/contrib/autocompletion/bash_autocomplete /etc/profile.d/gitea_bash_autocomplete.sh
|
2023-06-14 14:32:20 +03:00
|
|
|
RUN chmod 755 /usr/bin/entrypoint /app/gitea/gitea /usr/local/bin/gitea /usr/local/bin/environment-to-ini
|
|
|
|
RUN chmod 755 /etc/s6/gitea/* /etc/s6/openssh/* /etc/s6/.s6-svscan/*
|
|
|
|
RUN chmod 644 /etc/profile.d/gitea_bash_autocomplete.sh
|