Dockerfile 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. ARG BASE_IMAGE=docker.io/python:3.8.7-slim-buster
  2. ARG SOURCE_DIR_PATH=/location-guessing-game-telegram-bot
  3. # hadolint ignore=DL3006
  4. FROM $BASE_IMAGE as build
  5. RUN apt-get update \
  6. && apt-get install --no-install-recommends --yes ca-certificates \
  7. && rm -rf /var/lib/apt/lists/* \
  8. && useradd --create-home build
  9. USER build
  10. RUN pip install --user --no-cache-dir pipenv==2020.11.15
  11. ARG SOURCE_DIR_PATH
  12. COPY --chown=build Pipfile Pipfile.lock $SOURCE_DIR_PATH/
  13. WORKDIR $SOURCE_DIR_PATH
  14. ENV PIPENV_CACHE_DIR=/tmp/pipenv-cache \
  15. PIPENV_VENV_IN_PROJECT=yes-please \
  16. PATH=/home/build/.local/bin:$PATH
  17. RUN pipenv install --deploy \
  18. && pipenv graph \
  19. && pipenv run pip freeze \
  20. && rm -rf $PIPENV_CACHE_DIR
  21. COPY --chown=build . $SOURCE_DIR_PATH
  22. RUN chmod -cR a+rX .
  23. # workaround for broken multi-stage copy
  24. # > failed to copy files: failed to copy directory: Error processing tar file(exit status 1): Container ID ... cannot be mapped to a host ID
  25. USER 0
  26. RUN chown -R 0:0 $SOURCE_DIR_PATH
  27. USER build
  28. # hadolint ignore=DL3006
  29. FROM $BASE_IMAGE
  30. RUN apt-get update \
  31. && apt-get install --no-install-recommends --yes ca-certificates \
  32. && rm -rf /var/lib/apt/lists/* \
  33. && find / -xdev -type f -perm /u+s -exec chmod -c u-s {} \; \
  34. && find / -xdev -type f -perm /g+s -exec chmod -c g-s {} \;
  35. USER nobody
  36. ARG SOURCE_DIR_PATH
  37. COPY --from=build $SOURCE_DIR_PATH $SOURCE_DIR_PATH
  38. ENV PATH=$SOURCE_DIR_PATH/.venv/bin:$PATH
  39. WORKDIR $SOURCE_DIR_PATH
  40. CMD ["python", "location_guessing_game_telegram_bot.py"]