ADD alpine-minirootfs-3.21.0-x86_64.tar.gz / # buildkit |
CMD ["/bin/sh"] |
ENV PATH=/usr/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin |
ENV LANG=C.UTF-8 |
RUN /bin/sh -c set -eux; apk add --no-cache ca-certificates tzdata ; # buildkit |
ENV GPG_KEY=7169605F62C751356D054A26A821E680E5FA6305 |
ENV PYTHON_VERSION=3.12.8 |
ENV PYTHON_SHA256=c909157bb25ec114e5869124cc2a9c4a4d4c1e957ca4ff553f1edc692101154e |
RUN /bin/sh -c set -eux; apk add --no-cache --virtual .build-deps gnupg tar xz bluez-dev bzip2-dev dpkg-dev dpkg findutils gcc gdbm-dev libc-dev libffi-dev libnsl-dev libtirpc-dev linux-headers make ncurses-dev openssl-dev pax-utils readline-dev sqlite-dev tcl-dev tk tk-dev util-linux-dev xz-dev zlib-dev ; wget -O python.tar.xz "https://www.python.org/ftp/python/${PYTHON_VERSION%%[a-z]*}/Python-$PYTHON_VERSION.tar.xz"; echo "$PYTHON_SHA256 *python.tar.xz" | sha256sum -c -; wget -O python.tar.xz.asc "https://www.python.org/ftp/python/${PYTHON_VERSION%%[a-z]*}/Python-$PYTHON_VERSION.tar.xz.asc"; GNUPGHOME="$(mktemp -d)"; export GNUPGHOME; gpg --batch --keyserver hkps://keys.openpgp.org --recv-keys "$GPG_KEY"; gpg --batch --verify python.tar.xz.asc python.tar.xz; gpgconf --kill all; rm -rf "$GNUPGHOME" python.tar.xz.asc; mkdir -p /usr/src/python; tar --extract --directory /usr/src/python --strip-components=1 --file python.tar.xz; rm python.tar.xz; cd /usr/src/python; gnuArch="$(dpkg-architecture --query DEB_BUILD_GNU_TYPE)"; ./configure --build="$gnuArch" --enable-loadable-sqlite-extensions --enable-option-checking=fatal --enable-shared --with-lto --with-ensurepip ; nproc="$(nproc)"; EXTRA_CFLAGS="-DTHREAD_STACK_SIZE=0x100000"; LDFLAGS="${LDFLAGS:--Wl},--strip-all"; make -j "$nproc" "EXTRA_CFLAGS=${EXTRA_CFLAGS:-}" "LDFLAGS=${LDFLAGS:-}" ; rm python; make -j "$nproc" "EXTRA_CFLAGS=${EXTRA_CFLAGS:-}" "LDFLAGS=${LDFLAGS:--Wl},-rpath='\$\$ORIGIN/../lib'" python ; make install; cd /; rm -rf /usr/src/python; find /usr/local -depth \( \( -type d -a \( -name test -o -name tests -o -name idle_test \) \) -o \( -type f -a \( -name '*.pyc' -o -name '*.pyo' -o -name 'libpython*.a' \) \) \) -exec rm -rf '{}' + ; find /usr/local -type f -executable -not \( -name '*tkinter*' \) -exec scanelf --needed --nobanner --format '%n#p' '{}' ';' | tr ',' '\n' | sort -u | awk 'system("[ -e /usr/local/lib/" $1 " ]") == 0 { next } { print "so:" $1 }' | xargs -rt apk add --no-network --virtual .python-rundeps ; apk del --no-network .build-deps; export PYTHONDONTWRITEBYTECODE=1; python3 --version; pip3 --version # buildkit |
RUN /bin/sh -c set -eux; for src in idle3 pip3 pydoc3 python3 python3-config; do dst="$(echo "$src" | tr -d 3)"; [ -s "/usr/local/bin/$src" ]; [ ! -e "/usr/local/bin/$dst" ]; ln -svT "$src" "/usr/local/bin/$dst"; done # buildkit |
CMD ["python3"] |
WORKDIR /runner/ |
ARG USER |
ARG GROUP USER |
ARG GROUP UID USER |
ARG GID GROUP UID USER |
|4 GID=1000 GROUP=ansible UID=1000 USER=ansible /bin/sh -c addgroup ${GROUP} --gid ${GID} && adduser ${USER} --uid ${UID} --ingroup "${GROUP}" --disabled-password && chown ${USER}:${GROUP} /runner/ |
|4 GID=1000 GROUP=ansible UID=1000 USER=ansible /bin/sh -c chmod 777 /runner/ /home/ansible/ |
COPY multi:ae5f0daf5acaa5a702d306adb56edc3b4610307191e02c48728b23f2b85ff4d9 in /requirements/ |
|4 GID=1000 GROUP=ansible UID=1000 USER=ansible /bin/sh -c apk add --update --no-cache $(cat /requirements/apk.list) |
ENV PATH=/opt/ansible_venv/bin:${PATH} ANSIBLE_ROLES_PATH=roles:/runner/roles:/usr/share/ansible/roles ANSIBLE_COLLECTIONS_PATH=collections:/runner/collections:/usr/share/ansible/collections ANSIBLE_LOCAL_TEMP=/tmp ANSIBLE_INVENTORY_PLUGINS=/runner/project/plugins ANSIBLE_SSH_ARGS="-o ControlMaster=auto -o ControlPersist=60s" ANSIBLE_SSH_HOST_KEY_CHECKING=False ANSIBLE_SSH_PIPELINING=True ANSIBLE_HASH_BEHAVIOUR=merge |
COPY dir:c643b343d40869d09791b80f1ca3e7736363d168adb484b1d519a86ce7dd5235 in /opt/ansible_venv/ |
ARG ANSIBLE_GALAXY_CLI_ROLE_OPTS GID GROUP UID USER |
ARG ANSIBLE_GALAXY_CLI_COLLECTION_OPTS ANSIBLE_GALAXY_CLI_ROLE_OPTS GID GROUP UID USER |
|6 ANSIBLE_GALAXY_CLI_COLLECTION_OPTS= ANSIBLE_GALAXY_CLI_ROLE_OPTS= GID=1000 GROUP=ansible UID=1000 USER=ansible /bin/sh -c ansible-galaxy role install ${ANSIBLE_GALAXY_CLI_ROLE_OPTS} --role-file /requirements/requirements.yml --roles-path "/usr/share/ansible/roles" && ANSIBLE_GALAXY_DISABLE_GPG_VERIFY=1 ansible-galaxy collection install ${ANSIBLE_GALAXY_CLI_COLLECTION_OPTS} --requirements-file /requirements/requirements.yml --collections-path "/usr/share/ansible/collections" && chmod -R a=rX /usr/share/ansible |
ENV HOME=/home/ansible |
USER ${UID}:${GID} |