|
@@ -0,0 +1,58 @@
|
|
|
+
|
|
|
+
|
|
|
+ARG BASE_IMAGE=alpine:3.11
|
|
|
+ARG SOURCE_DIR_PATH=/systemctl-mqtt
|
|
|
+ARG VIRTUALENV_PATH=$SOURCE_DIR_PATH/.venv
|
|
|
+
|
|
|
+
|
|
|
+FROM $BASE_IMAGE as build
|
|
|
+
|
|
|
+RUN apk add --no-cache \
|
|
|
+ dbus-dev \
|
|
|
+ gcc \
|
|
|
+ git `
|
|
|
+ glib-dev `
|
|
|
+ make `
|
|
|
+ musl-dev `
|
|
|
+ py3-virtualenv \
|
|
|
+ python3-dev `
|
|
|
+
|
|
|
+ARG SOURCE_DIR_PATH
|
|
|
+RUN mkdir $SOURCE_DIR_PATH \
|
|
|
+ && chown nobody $SOURCE_DIR_PATH
|
|
|
+USER nobody
|
|
|
+
|
|
|
+ARG VIRTUALENV_PATH
|
|
|
+RUN virtualenv --no-site-packages $VIRTUALENV_PATH
|
|
|
+ENV PATH=$VIRTUALENV_PATH/bin:$PATH
|
|
|
+WORKDIR $SOURCE_DIR_PATH
|
|
|
+RUN pip install --no-cache-dir pipenv==2020.6.2
|
|
|
+COPY --chown=nobody . $SOURCE_DIR_PATH
|
|
|
+ENV PIPENV_CACHE_DIR=/tmp/pipenv-cache
|
|
|
+RUN pipenv install --deploy --verbose \
|
|
|
+ && rm -r .git/ $PIPENV_CACHE_DIR
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+USER 0
|
|
|
+RUN chown -R 0:0 $SOURCE_DIR_PATH
|
|
|
+
|
|
|
+
|
|
|
+FROM $BASE_IMAGE
|
|
|
+
|
|
|
+RUN apk add --no-cache \
|
|
|
+ ca-certificates \
|
|
|
+ dbus-libs \
|
|
|
+ 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
|
|
|
+ENV PATH=$VIRTUALENV_PATH/bin:$PATH
|
|
|
+ENTRYPOINT ["tini", "--"]
|
|
|
+CMD ["systemctl-mqtt", "--help"]
|