FROM ubuntu:18.04 ARG TARGETPLATFORM ARG RUNNER_VERSION=2.278.0 ARG DOCKER_VERSION=19.03.12 RUN test -n "$TARGETPLATFORM" || (echo "TARGETPLATFORM must be set" && false) ENV DEBIAN_FRONTEND=noninteractive RUN apt update -y \ && apt install -y software-properties-common \ && add-apt-repository -y ppa:git-core/ppa \ && apt update -y \ && apt install -y --no-install-recommends \ build-essential \ curl \ ca-certificates \ dnsutils \ ftp \ git \ iproute2 \ iputils-ping \ jq \ libunwind8 \ locales \ netcat \ openssh-client \ parallel \ python3-pip \ rsync \ shellcheck \ sudo \ telnet \ time \ tzdata \ unzip \ upx \ wget \ zip \ zstd \ && ln -sf /usr/bin/python3 /usr/bin/python \ && ln -sf /usr/bin/pip3 /usr/bin/pip \ && rm -rf /var/lib/apt/lists/* # arch command on OS X reports "i386" for Intel CPUs regardless of bitness RUN export ARCH=$(echo ${TARGETPLATFORM} | cut -d / -f2) \ && if [ "$ARCH" = "arm64" ]; then export ARCH=aarch64 ; fi \ && if [ "$ARCH" = "i386" ]; then export ARCH=x86_64 ; fi \ && curl -L -o /usr/local/bin/dumb-init https://github.com/Yelp/dumb-init/releases/download/v1.2.2/dumb-init_1.2.2_${ARCH} \ && chmod +x /usr/local/bin/dumb-init # Docker download supports arm64 as aarch64 & amd64 / i386 as x86_64 RUN set -vx; \ export ARCH=$(echo ${TARGETPLATFORM} | cut -d / -f2) \ && if [ "$ARCH" = "arm64" ]; then export ARCH=aarch64 ; fi \ && if [ "$ARCH" = "amd64" ] || [ "$ARCH" = "i386" ]; then export ARCH=x86_64 ; fi \ && curl -L -o docker.tgz https://download.docker.com/linux/static/stable/${ARCH}/docker-${DOCKER_VERSION}.tgz \ && tar zxvf docker.tgz \ && install -o root -g root -m 755 docker/docker /usr/local/bin/docker \ && rm -rf docker docker.tgz \ && adduser --disabled-password --gecos "" --uid 1000 runner \ && groupadd docker \ && usermod -aG sudo runner \ && usermod -aG docker runner \ && echo "%sudo ALL=(ALL:ALL) NOPASSWD:ALL" > /etc/sudoers ENV RUNNER_ASSETS_DIR=/runnertmp ENV HOME=/home/runner # Runner download supports amd64 as x64. Externalstmp is needed for making mount points work inside DinD. # # libyaml-dev is required for ruby/setup-ruby action. # It is installed after installdependencies.sh and before removing /var/lib/apt/lists # to avoid rerunning apt-update on its own. RUN export ARCH=$(echo ${TARGETPLATFORM} | cut -d / -f2) \ && if [ "$ARCH" = "amd64" ] || [ "$ARCH" = "x86_64" ] || [ "$ARCH" = "i386" ]; then export ARCH=x64 ; fi \ && mkdir -p "$RUNNER_ASSETS_DIR" \ && cd "$RUNNER_ASSETS_DIR" \ && curl -L -o runner.tar.gz https://github.com/actions/runner/releases/download/v${RUNNER_VERSION}/actions-runner-linux-${ARCH}-${RUNNER_VERSION}.tar.gz \ && tar xzf ./runner.tar.gz \ && rm runner.tar.gz \ && ./bin/installdependencies.sh \ && mv ./externals ./externalstmp \ && apt-get install -y libyaml-dev \ && rm -rf /var/lib/apt/lists/* RUN echo AGENT_TOOLSDIRECTORY=/opt/hostedtoolcache > .env \ && mkdir /opt/hostedtoolcache \ && chgrp docker /opt/hostedtoolcache \ && chmod g+rwx /opt/hostedtoolcache COPY entrypoint.sh / COPY --chown=runner:docker patched $RUNNER_ASSETS_DIR/patched # Add the Python "User Script Directory" to the PATH ENV PATH="${PATH}:${HOME}/.local/bin" USER runner ENTRYPOINT ["/usr/local/bin/dumb-init", "--"] CMD ["/entrypoint.sh"]