mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-22 01:52:24 +00:00 
			
		
		
		
	The release name, as provided by FORGEJO_RELEASE, is used to build OCI images and binary files. Although it can be the same as the Forgejo version, it is not a requirement. When the FORGEJO_RELEASE environment variable is set, use it as a default for naming the binary file instead of FORGEJO_VERSION. For instance, when building from the forgejo branch here is what is desired: FORGEJO_VERSION=7.0.0-g2343 GITEA_VERSION=1.22.0 VERSION=vforgejo-test The name of the release is also displayed with forgejo --version for sanity check purposes. Before: FORGEJO_VERSION is the computed version GITEA_VERSION is set manually VERSION defaults to FORGEJO_VERSION forgejo --help does not display VERSION After: FORGEJO_VERSION is the computed version GITEA_VERSION is set manually RELEASE_VERSION defaults to FORGEJO_VERSION VERSION defaults to RELEASE_VERSION forgejo --help displays VERSION
		
			
				
	
	
		
			102 lines
		
	
	
	
		
			3 KiB
		
	
	
	
		
			Docker
		
	
	
	
	
	
			
		
		
	
	
			102 lines
		
	
	
	
		
			3 KiB
		
	
	
	
		
			Docker
		
	
	
	
	
	
| FROM --platform=$BUILDPLATFORM docker.io/tonistiigi/xx AS xx
 | |
| 
 | |
| FROM --platform=$BUILDPLATFORM docker.io/library/golang:1.21-alpine3.19 as build-env
 | |
| 
 | |
| ARG GOPROXY
 | |
| ENV GOPROXY ${GOPROXY:-direct}
 | |
| 
 | |
| ARG RELEASE_VERSION
 | |
| ARG TAGS="sqlite sqlite_unlock_notify"
 | |
| ENV TAGS "bindata timetzdata $TAGS"
 | |
| ARG CGO_EXTRA_CFLAGS
 | |
| 
 | |
| #
 | |
| # 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
 | |
| 
 | |
| COPY . ${GOPATH}/src/code.gitea.io/gitea
 | |
| WORKDIR ${GOPATH}/src/code.gitea.io/gitea
 | |
| 
 | |
| 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 RELEASE_VERSION=$RELEASE_VERSION go-check generate-backend static-executable && xx-verify gitea
 | |
| 
 | |
| # Copy local files
 | |
| COPY docker/rootless /tmp/local
 | |
| 
 | |
| # Set permissions
 | |
| RUN chmod 755 /tmp/local/usr/local/bin/docker-entrypoint.sh \
 | |
|               /tmp/local/usr/local/bin/docker-setup.sh \
 | |
|               /tmp/local/usr/local/bin/gitea \
 | |
|               /go/src/code.gitea.io/gitea/gitea \
 | |
|               /go/src/code.gitea.io/gitea/environment-to-ini
 | |
| RUN chmod 644 /go/src/code.gitea.io/gitea/contrib/autocompletion/bash_autocomplete
 | |
| 
 | |
| FROM docker.io/library/alpine:3.19
 | |
| LABEL maintainer="contact@forgejo.org"
 | |
| 
 | |
| EXPOSE 2222 3000
 | |
| 
 | |
| RUN apk --no-cache add \
 | |
|     bash \
 | |
|     ca-certificates \
 | |
|     dumb-init \
 | |
|     gettext \
 | |
|     git \
 | |
|     curl \
 | |
|     gnupg \
 | |
|     && rm -rf /var/cache/apk/*
 | |
| 
 | |
| RUN addgroup \
 | |
|     -S -g 1000 \
 | |
|     git && \
 | |
|   adduser \
 | |
|     -S -H -D \
 | |
|     -h /var/lib/gitea/git \
 | |
|     -s /bin/bash \
 | |
|     -u 1000 \
 | |
|     -G git \
 | |
|     git
 | |
| 
 | |
| RUN mkdir -p /var/lib/gitea /etc/gitea
 | |
| RUN chown git:git /var/lib/gitea /etc/gitea
 | |
| 
 | |
| COPY --from=build-env /tmp/local /
 | |
| RUN cd /usr/local/bin ; ln -s gitea forgejo
 | |
| COPY --from=build-env --chown=root:root /go/src/code.gitea.io/gitea/gitea /app/gitea/gitea
 | |
| COPY --from=build-env --chown=root:root /go/src/code.gitea.io/gitea/environment-to-ini /usr/local/bin/environment-to-ini
 | |
| COPY --from=build-env /go/src/code.gitea.io/gitea/contrib/autocompletion/bash_autocomplete /etc/profile.d/gitea_bash_autocomplete.sh
 | |
| 
 | |
| #git:git
 | |
| USER 1000:1000
 | |
| ENV GITEA_WORK_DIR /var/lib/gitea
 | |
| ENV GITEA_CUSTOM /var/lib/gitea/custom
 | |
| ENV GITEA_TEMP /tmp/gitea
 | |
| ENV TMPDIR /tmp/gitea
 | |
| 
 | |
| #TODO add to docs the ability to define the ini to load (useful to test and revert a config)
 | |
| ENV GITEA_APP_INI /etc/gitea/app.ini
 | |
| ENV HOME "/var/lib/gitea/git"
 | |
| VOLUME ["/var/lib/gitea", "/etc/gitea"]
 | |
| WORKDIR /var/lib/gitea
 | |
| 
 | |
| ENTRYPOINT ["/usr/bin/dumb-init", "--", "/usr/local/bin/docker-entrypoint.sh"]
 | |
| CMD []
 | |
| 
 |