1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- # not using python:3.*-alpine cause glib-dev package depends on python3
- # https://pkgs.alpinelinux.org/package/v3.11/main/aarch64/glib-dev
- ARG BASE_IMAGE=alpine:3.11
- ARG SOURCE_DIR_PATH=/systemctl-mqtt
- # hadolint ignore=DL3006
- FROM $BASE_IMAGE as build
- RUN apk add --no-cache \
- cairo-dev `# PyGObject > pycairo` \
- dbus-dev \
- gcc \
- git `# setuptools_scm` \
- glib-dev `# dbus-python` \
- gobject-introspection-dev `# PyGObject` \
- make `# dbus-python` \
- musl-dev `# dbus-python` \
- py3-certifi `# pipenv` \
- py3-virtualenv `# pipenv` \
- python3-dev `# dbus-python` \
- && adduser -S build
- USER build
- RUN pip3 install --user --no-cache-dir pipenv==2020.6.2
- ARG SOURCE_DIR_PATH
- COPY --chown=build:1234 . $SOURCE_DIR_PATH
- WORKDIR $SOURCE_DIR_PATH
- ENV PIPENV_CACHE_DIR=/tmp/pipenv-cache \
- PIPENV_VENV_IN_PROJECT=yes-please \
- PATH=/home/build/.local/bin:$PATH
- RUN pipenv install --deploy --verbose \
- && pipenv graph \
- && pipenv run pip freeze \
- && rm -r .git/ $PIPENV_CACHE_DIR
- # workaround for broken multi-stage copy
- # > failed to copy files: failed to copy directory: Error processing tar file(exit status 1): Container ID ... cannot be mapped to a host ID
- USER 0
- RUN chown -R 0:0 $SOURCE_DIR_PATH
- USER build
- # hadolint ignore=DL3006
- FROM $BASE_IMAGE
- RUN apk add --no-cache \
- ca-certificates \
- dbus-libs \
- glib `# PyGObject` \
- gobject-introspection `# PyGObject` \
- python3 \
- tini \
- && find / -xdev -type f -perm /u+s -exec chmod -c u-s {} \; \
- && find / -xdev -type f -perm /g+s -exec chmod -c g-s {} \;
- USER nobody
- ARG SOURCE_DIR_PATH
- COPY --from=build $SOURCE_DIR_PATH $SOURCE_DIR_PATH
- ARG VIRTUALENV_PATH=$SOURCE_DIR_PATH/.venv
- ENV PATH=$VIRTUALENV_PATH/bin:$PATH
- ENTRYPOINT ["tini", "--"]
- CMD ["systemctl-mqtt", "--help"]
|