This commit is contained in:
2024-02-20 17:15:27 +08:00
committed by huty
parent 6706e1a633
commit 34158042ad
1529 changed files with 177765 additions and 0 deletions

View File

@@ -0,0 +1,84 @@
ARG ALPINE_VERSION="3.15"
FROM golang:1.14-alpine3.13 AS builder
ARG GOGS_VERSION="v0.12.3"
RUN apk --no-cache --no-progress add --virtual \
build-deps \
build-base \
git \
linux-pam-dev
WORKDIR /go/src/github.com/gogs
RUN git clone https://github.com/gogs/gogs.git && \
cd gogs && \
git checkout $GOGS_VERSION
WORKDIR /go/src/github.com/gogs/gogs
RUN go build -tags "sqlite" -o /out/gogs
FROM alpine:$ALPINE_VERSION AS download-base
WORKDIR /downloads
RUN echo "$(apk --print-arch)" > /arch.txt
RUN ARCH2= && alpineArch="$(apk --print-arch)" \
&& case "${alpineArch##*-}" in \
x86_64) ARCH2='amd64' ;; \
aarch64) ARCH2='arm64' ;; \
*) echo "unsupported architecture"; exit 1 ;; \
esac && \
echo $ARCH2 > /arch2.txt
# Gogs - adapted from project Dockerfile at github.com/gogs/gogs
FROM download-base AS gogs
# Install system utils & Gogs runtime dependencies
RUN wget -O /usr/sbin/gosu "https://github.com/tianon/gosu/releases/download/1.14/gosu-$(cat /arch2.txt)" && \
chmod +x /usr/sbin/gosu \
&& echo http://dl-2.alpinelinux.org/alpine/edge/community/ >> /etc/apk/repositories \
&& apk --no-cache --no-progress add \
bash \
ca-certificates \
curl \
git \
linux-pam \
openssh \
s6 \
shadow \
socat \
tzdata \
rsync
ENV GOGS_CUSTOM /data/gogs
COPY --from=builder /go/src/github.com/gogs/gogs/docker/nsswitch.conf /etc/nsswitch.conf
WORKDIR /app/gogs
COPY --from=builder /go/src/github.com/gogs/gogs/docker ./docker
COPY --from=builder /go/src/github.com/gogs/gogs/templates ./templates
COPY --from=builder /go/src/github.com/gogs/gogs/public ./public
COPY --from=builder /out/gogs .
RUN ./docker/finalize.sh
VOLUME ["/data"]
EXPOSE 3000
ENTRYPOINT ["/app/gogs/docker/start.sh"]
CMD ["/bin/s6-svscan", "/app/gogs/docker/s6/"]
# Customized Gogs build
FROM gogs
RUN apk add --no-cache jq
ENV GOGS_CUSTOM=""
COPY app.ini ./custom/conf/app.ini
COPY gogs-install.txt .
COPY init.sh .
# this uses the original start script to prep the data folders:
RUN chmod o+w ./custom/conf/app.ini && \
chmod +x init.sh && ./init.sh
# replace with custom start script:
COPY start.sh ./docker/start.sh
RUN chmod +x ./docker/start.sh

View File

@@ -0,0 +1,17 @@
[server]
DISABLE_SSH = true
APP_DATA_PATH = /data
[repository]
ROOT = /data/repositories
[database]
DB_TYPE = sqlite3
PATH = /data/gogs.db
[service]
ENABLE_CAPTCHA = false
[log]
ROOT_PATH = /data/logs
MODE = console, file

View File

@@ -0,0 +1 @@
db_type=SQLite3&db_host=127.0.0.1%3A3306&db_user=root&db_passwd=&db_name=gogs&ssl_mode=disable&db_path=%2Fdata%2Fgogs.db&app_name=Gogs&repo_root_path=%2Fdata%2Frepositories&run_user=git&domain=localhost&ssh_port=22&http_port=3000&app_url=http%3A%2F%2Flocalhost%3A3000%2F&log_root_path=%2Fdata%2Flogs&smtp_host=&smtp_from=&smtp_user=&smtp_passwd=&admin_name=kiamol&admin_passwd=kiamol&admin_confirm_passwd=kiamol&admin_email=reader%40kiamol.net

View File

@@ -0,0 +1,22 @@
# /bin/sh
# start Gogs and give it time to spin up
/app/gogs/docker/start.sh & sleep 5
# finsh installation
curl -d @gogs-install.txt http://localhost:3000/install
# create user auth token
curl -q -X POST -H 'Content-Type: application/json' -d '{"name": "api"}' --user kiamol:kiamol http://localhost:3000/api/v1/users/kiamol/tokens > response.json
token=$(cat response.json | jq '.sha1' -r)
rm -f token.json
# create repo
curl -q -X POST -H 'Content-Type: application/json' -d '{
"name": "kiamol",
"description": "kiamol source code",
"private": false
}' "http://localhost:3000/api/v1/user/repos?token=$token"
# move the data from the volume to a directory in the image
cp -r /data /init-data

View File

@@ -0,0 +1,86 @@
#!/bin/sh
create_socat_links() {
# Bind linked docker container to localhost socket using socat
USED_PORT="3000:22"
while read -r NAME ADDR PORT; do
if test -z "$NAME$ADDR$PORT"; then
continue
elif echo $USED_PORT | grep -E "(^|:)$PORT($|:)" > /dev/null; then
echo "init:socat | Can't bind linked container ${NAME} to localhost, port ${PORT} already in use" 1>&2
else
SERV_FOLDER=/app/gogs/docker/s6/SOCAT_${NAME}_${PORT}
mkdir -p "${SERV_FOLDER}"
CMD="socat -ls TCP4-LISTEN:${PORT},fork,reuseaddr TCP4:${ADDR}:${PORT}"
# shellcheck disable=SC2039,SC3037
echo -e "#!/bin/sh\nexec $CMD" > "${SERV_FOLDER}"/run
chmod +x "${SERV_FOLDER}"/run
USED_PORT="${USED_PORT}:${PORT}"
echo "init:socat | Linked container ${NAME} will be binded to localhost on port ${PORT}" 1>&2
fi
done << EOT
$(env | sed -En 's|(.*)_PORT_([0-9]+)_TCP=tcp://(.*):([0-9]+)|\1 \3 \4|p')
EOT
}
cleanup() {
# Cleanup SOCAT services and s6 event folder
# On start and on shutdown in case container has been killed
rm -rf "$(find /app/gogs/docker/s6/ -name 'event')"
rm -rf /app/gogs/docker/s6/SOCAT_*
}
create_volume_subfolder() {
# Modify the owner of /data dir, make $USER(git) user have permission to create sub-dir in /data.
chown -R "$USER:$USER" /data
# COURSELABS - copy from init folder if no data:
if ! test -d /data/gogs.db; then
if test -d /init-data; then
gosu $USER cp -r /init-data/* /data/
fi
fi
# Create VOLUME subfolder
for f in /data/gogs/data /data/gogs/conf /data/gogs/log /data/git /data/ssh; do
if ! test -d $f; then
gosu "$USER" mkdir -p $f
fi
done
}
setids() {
export USER=git
PUID=${PUID:-1000}
PGID=${PGID:-1000}
groupmod -o -g "$PGID" $USER
usermod -o -u "$PUID" $USER
}
setids
cleanup
create_volume_subfolder
LINK=$(echo "$SOCAT_LINK" | tr '[:upper:]' '[:lower:]')
if [ "$LINK" = "false" ] || [ "$LINK" = "0" ]; then
echo "init:socat | Will not try to create socat links as requested" 1>&2
else
create_socat_links
fi
CROND=$(echo "$RUN_CROND" | tr '[:upper:]' '[:lower:]')
if [ "$CROND" = "true" ] || [ "$CROND" = "1" ]; then
echo "init:crond | Cron Daemon (crond) will be run as requested by s6" 1>&2
rm -f /app/gogs/docker/s6/crond/down
/bin/sh /app/gogs/docker/runtime/backup-init.sh "${PUID}"
else
# Tell s6 not to run the crond service
touch /app/gogs/docker/s6/crond/down
fi
# Exec CMD or S6 by default if nothing present
if [ $# -gt 0 ];then
exec "$@"
else
exec /bin/s6-svscan /app/gogs/docker/s6/
fi