From a3cacf29f717585bc2970289b4504c8bf986be98 Mon Sep 17 00:00:00 2001 From: Dev Mukherjee Date: Tue, 30 Jul 2024 10:52:29 +1000 Subject: [PATCH] feat: adds basic container for running cli initial thoughts on how i can run the cli and tui in a container this goes in line with publishing brew packages refs #33 --- Dockerfile | 41 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 41 insertions(+) diff --git a/Dockerfile b/Dockerfile index e69de29b..03f8bf9e 100644 --- a/Dockerfile +++ b/Dockerfile @@ -0,0 +1,41 @@ +# Use an official Python runtime based on Debian 12 "bookworm" as a parent image. +FROM python:3.12-slim-bookworm + +# Install system packages required by Wagtail and Django. +RUN apt-get update --yes --quiet && apt-get install --yes --quiet --no-install-recommends \ + build-essential \ + libpq-dev \ + postgresql-client \ + curl \ + libjpeg62-turbo-dev \ + zlib1g-dev \ + libwebp-dev \ + libpango-1.0-0 \ + libpangoft2-1.0-0 \ + && rm -rf /var/lib/apt/lists/* + + +# Install task from their servers, not this requires curl +# so you must only have this tkas post the apt updates +RUN sh -c "$(curl --location https://taskfile.dev/install.sh)" \ + -- -d -b /usr/local/bin + +WORKDIR /opt +COPY Taskfile.yml Taskfile.yml +COPY poetry.lock poetry.lock +COPY pyproject.toml pyproject.toml + +# Ask poetry to install all packages including the app +# not in virtual machine as we are in a container +# In prodduction add --no-dev to poetry installation +RUN pip3 install --upgrade pip +RUN pip3 install poetry +RUN poetry config virtualenvs.create false +RUN poetry install --no-root + +# Copy the files in the src directory which is the app package +# and the dependency matrix dedescribed by pyproject.toml +WORKDIR /opt/${PROJ_NAME} + +# Run the CLI +ENTRYPOINT [ "gala" ] \ No newline at end of file