FROM ghcr.io/astral-sh/uv:python3.14-bookworm-slim AS builder ENV UV_LINK_MODE=copy \ UV_COMPILE_BYTECODE=1 \ PYTHONUNBUFFERED=1 WORKDIR /home/timetracker/app RUN --mount=type=cache,target=/root/.cache/uv \ --mount=type=bind,source=uv.lock,target=uv.lock \ --mount=type=bind,source=pyproject.toml,target=pyproject.toml \ uv sync --frozen --no-install-project --no-dev COPY . . RUN --mount=type=cache,target=/root/.cache/uv \ uv sync --frozen --no-dev FROM python:3.14-slim-bookworm ENV PROD=1 \ PYTHONUNBUFFERED=1 \ PATH="/home/timetracker/app/.venv/bin:$PATH" RUN apt-get update && apt-get install -y --no-install-recommends \ curl \ ca-certificates \ libcap2-bin \ supervisor \ && rm -rf /var/lib/apt/lists/* \ && useradd -m --uid 1000 timetracker \ && mkdir -p /var/log/supervisor /etc/supervisor/conf.d /home/timetracker/data \ && chown timetracker:timetracker /var/log/supervisor /home/timetracker/data RUN curl -sL "https://caddyserver.com/api/download?os=linux&arch=amd64" \ -o /usr/local/bin/caddy && chmod +x /usr/local/bin/caddy WORKDIR /home/timetracker/app COPY --from=builder --chown=timetracker:timetracker /home/timetracker/app /home/timetracker/app COPY --chown=timetracker:timetracker Caddyfile /etc/caddy/Caddyfile COPY --chown=timetracker:timetracker supervisor.conf /etc/supervisor/conf.d/supervisor.conf COPY --chown=timetracker:timetracker entrypoint.sh / RUN chmod +x /entrypoint.sh ENV VERSION_NUMBER=1.6.1 EXPOSE 8000 ENTRYPOINT ["/entrypoint.sh"]