mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-26 12:01:08 +00:00 
			
		
		
		
	* When building rootless docker image move chown&chmod to build stage Fixes #13577 * Fix command newlines * Move chown to COPY command * Seems to be working also without chmod Co-authored-by: techknowlogick <techknowlogick@gitea.io>
		
			
				
	
	
		
			67 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			67 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| 
 | |
| ###################################
 | |
| #Build stage
 | |
| FROM golang:1.15-alpine3.12 AS build-env
 | |
| 
 | |
| ARG GOPROXY
 | |
| ENV GOPROXY ${GOPROXY:-direct}
 | |
| 
 | |
| ARG GITEA_VERSION
 | |
| ARG TAGS="sqlite sqlite_unlock_notify"
 | |
| ENV TAGS "bindata timetzdata $TAGS"
 | |
| ARG CGO_EXTRA_CFLAGS 
 | |
| 
 | |
| #Build deps
 | |
| RUN apk --no-cache add build-base git nodejs npm
 | |
| 
 | |
| #Setup repo
 | |
| COPY . ${GOPATH}/src/code.gitea.io/gitea
 | |
| WORKDIR ${GOPATH}/src/code.gitea.io/gitea
 | |
| 
 | |
| #Checkout version if set
 | |
| RUN if [ -n "${GITEA_VERSION}" ]; then git checkout "${GITEA_VERSION}"; fi \
 | |
|  && make clean-all build
 | |
| 
 | |
| FROM alpine:3.12
 | |
| LABEL maintainer="maintainers@gitea.io"
 | |
| 
 | |
| EXPOSE 2222 3000
 | |
| 
 | |
| RUN apk --no-cache add \
 | |
|     bash \
 | |
|     ca-certificates \
 | |
|     gettext \
 | |
|     git \
 | |
|     gnupg
 | |
| 
 | |
| RUN addgroup \
 | |
|     -S -g 1000 \
 | |
|     git && \
 | |
|   adduser \
 | |
|     -S -H -D \
 | |
|     -h /var/lib/gitea/git \
 | |
|     -s /bin/bash \
 | |
|     -u 1000 \
 | |
|     -G git \
 | |
|     git && \
 | |
|   echo "git:$(dd if=/dev/urandom bs=24 count=1 status=none | base64)" | chpasswd
 | |
| 
 | |
| RUN mkdir -p /var/lib/gitea /etc/gitea
 | |
| RUN chown git:git /var/lib/gitea /etc/gitea
 | |
| 
 | |
| COPY docker/rootless /
 | |
| COPY --from=build-env --chown=root:root /go/src/code.gitea.io/gitea/gitea /usr/local/bin/gitea
 | |
| 
 | |
| USER git:git
 | |
| ENV GITEA_WORK_DIR /var/lib/gitea
 | |
| ENV GITEA_CUSTOM /var/lib/gitea/custom
 | |
| ENV GITEA_TEMP /tmp/gitea
 | |
| #TODO add to docs the ability to define the ini to load (usefull 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/local/bin/docker-entrypoint.sh"]
 | |
| CMD []
 | |
| 
 |