#syntax=docker/dockerfile:1.4 # see https://github.com/moby/buildkit/blob/master/frontend/dockerfile/docs/syntax.md#user-content-syntax # see https://docs.docker.com/build/dockerfile/frontend/ # see https://docs.docker.com/engine/reference/builder/#syntax # # SPDX-FileCopyrightText: © Vegard IT GmbH (https://vegardit.com) # SPDX-FileContributor: Sebastian Thomschke # SPDX-License-Identifier: Apache-2.0 # SPDX-ArtifactOfProjectHomePage: https://github.com/vegardit/docker-gitea-act-runner # # https://hub.docker.com/_/debian?tab=tags&name=stable-slim FROM debian:stable-slim LABEL maintainer="Vegard IT GmbH (vegardit.com)" USER root SHELL ["/bin/bash", "-euo", "pipefail", "-c"] ARG DEBIAN_FRONTEND=noninteractive ARG LC_ALL=C ARG INSTALL_SUPPORT_TOOLS=0 ARG UPX_COMPRESS=true ARG BASE_LAYER_CACHE_KEY # dood|dind|dind-rootless ARG FLAVOR ARG GITEA_ACT_RUNNER_VERSION RUN --mount=type=bind,source=.shared,target=/mnt/shared <> /etc/sudoers if [[ $FLAVOR == dind* ]]; then echo "#################################################" echo "Installing docker engine..." echo "#################################################" # https://docs.docker.com/engine/install/debian/#install-using-the-repository apt-get install --no-install-recommends -y gnupg install -m 0755 -d /etc/apt/keyrings curl "https://download.docker.com/linux/debian/gpg" | gpg --dearmor -o /etc/apt/keyrings/docker.gpg chmod a+r /etc/apt/keyrings/docker.gpg echo \ "deb [arch="$(dpkg --print-architecture)" signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/debian \ "$(source /etc/os-release && echo "$VERSION_CODENAME")" stable" > /etc/apt/sources.list.d/docker.list apt-get update apt-get install --no-install-recommends -y docker-ce containerd.io fuse-overlayfs apt-get remove -y gnupg minimize /usr/bin/containerd* /usr/bin/ctr /usr/bin/docker* /usr/bin/runc docker --version runc --version # https://github.com/docker/for-linux/issues/1437#issuecomment-1293818806 update-alternatives --set iptables /usr/sbin/iptables-legacy update-alternatives --set ip6tables /usr/sbin/ip6tables-legacy # set up subuid/subgid so that "--userns-remap=default" works out-of-the-box addgroup --system dockremap adduser --system --ingroup dockremap dockremap echo 'dockremap:165536:65536' | tee -a /etc/subuid echo 'dockremap:165536:65536' | tee -a /etc/subgid curl "https://raw.githubusercontent.com/moby/moby/v24.0.2/hack/dind" -o /usr/local/bin/dind-hack chmod +x /usr/local/bin/dind-hack if [[ $FLAVOR == dind-rootless ]]; then # https://docs.docker.com/engine/security/rootless/ apt-get install --no-install-recommends -y \ dbus-user-session \ docker-ce-rootless-extras \ kmod \ iproute2 \ slirp4netns \ uidmap runuser -u act -g act -- /usr/bin/dockerd-rootless-setuptool.sh install --skip-iptables # workaround "failed to load plugin io.containerd.internal.v1.opt error="mkdir /opt/containerd: permission denied" mkdir /opt/containerd chown act:act /opt/containerd else usermod -aG docker act fi fi echo "#################################################" echo "Cleanup..." echo "#################################################" apt-get remove -y binutils curl rm -rf /opt/upx /mnt/shared/cmd/debian-cleanup.sh EOF ARG BUILD_DATE ARG GIT_BRANCH ARG GIT_COMMIT_HASH ARG GIT_COMMIT_DATE ARG GIT_REPO_URL LABEL \ org.label-schema.schema-version="1.0" \ org.label-schema.build-date=$BUILD_DATE \ org.label-schema.vcs-ref=$GIT_COMMIT_HASH \ org.label-schema.vcs-url=$GIT_REPO_URL # Default configuration: can be overridden at the docker command line ENV \ INIT_SH_FILE='' \ # GITEA_RUNNER_CONFIG_TEMPLATE_FILE='/opt/config.template.yaml' \ # GITEA_RUNNER_NAME='' \ GITEA_RUNNER_LABELS='' \ GITEA_RUNNER_LABELS_DEFAULT='\ ubuntu-latest:docker://catthehacker/ubuntu:runner-22.04,\ ubuntu-22.04:docker://catthehacker/ubuntu:runner-22.04,\ ubuntu-20.04:docker://catthehacker/ubuntu:runner-20.04' \ GITEA_RUNNER_UID=1000 \ GITEA_RUNNER_GID=1000 \ # GITEA_RUNNER_REGISTRATION_FILE='/data/.runner' \ GITEA_RUNNER_REGISTRATION_TIMEOUT=30\ GITEA_RUNNER_REGISTRATION_RETRY_INTERVAL=5s \ # GITEA_RUNNER_LOG_LEVEL='info' \ GITEA_RUNNER_MAX_PARALLEL_JOBS=1 \ GITEA_RUNNER_JOB_TIMEOUT='3h' \ GITEA_RUNNER_ENV_FILE='/data/.env' \ GITEA_RUNNER_FETCH_TIMEOUT='5s' \ GITEA_RUNNER_FETCH_INTERVAL='2s' \ # GITEA_INSTANCE_INSECURE='false' \ # GITEA_RUNNER_JOB_CONTAINER_DOCKER_HOST="" \ GITEA_RUNNER_JOB_CONTAINER_NETWORK='bridge' \ GITEA_RUNNER_JOB_CONTAINER_OPTIONS='' \ GITEA_RUNNER_JOB_CONTAINER_PRIVILEGED='false' \ GITEA_RUNNER_JOB_CONTAINER_WORKDIR_PARENT='/workspace' \ GITEA_RUNNER_ACTION_CACHE_DIR='/data/cache/actions' \ # ACT_CACHE_SERVER_ENABLED='true' \ ACT_CACHE_SERVER_DIR='/data/cache/server' \ ACT_CACHE_SERVER_HOST='' \ ACT_CACHE_SERVER_PORT=0 RUN </opt/build_info cat /opt/build_info EOF COPY image/*.sh /opt/ COPY image/config.template.yaml /opt/ COPY .shared/lib/bash-init.sh /opt/bash-init.sh USER act VOLUME /data # only for dind relevant VOLUME /var/lib/docker ENTRYPOINT ["/usr/bin/tini", "--"] CMD ["/bin/bash", "/opt/run.sh"]