FROM node:18.20.4-alpine3.20 as builder WORKDIR /app COPY ./frontend . RUN npm install -g pnpm RUN pnpm install --prefer-offline=true --frozen-lockfile=true RUN pnpm build ############################################### # Base Image - Python ############################################### FROM python:3.10-slim as python-base ENV FUWARE_HOME="/app" ENV PYTHONUNBUFFERED=1 \ PYTHONDONTWRITEBYTECODE=1 \ PIP_NO_CACHE_DIR=off \ PIP_DISABLE_PIP_VERSION_CHECK=on \ PIP_DEFAULT_TIMEOUT=100 \ POETRY_HOME="/opt/poetry" \ POETRY_VIRTUALENVS_IN_PROJECT=true \ POETRY_NO_INTERACTION=1 \ PYSETUP_PATH="/opt/pysetup" \ VENV_PATH="/opt/pysetup/.venv" # prepend poetry and venv to path ENV PATH="$POETRY_HOME/bin:$VENV_PATH/bin:$PATH" # create user account RUN useradd -u 911 -U -d $FUWARE_HOME -s /bin/bash abc \ && usermod -G users abc \ && mkdir $FUWARE_HOME ############################################### # Builder Image ############################################### FROM python-base as builder-base RUN apt-get update \ && apt-get install --no-install-recommends -y \ curl \ build-essential \ libpq-dev \ libwebp-dev \ # LDAP Dependencies libsasl2-dev libldap2-dev libssl-dev \ gnupg gnupg2 gnupg1 \ && rm -rf /var/lib/apt/lists/* \ && pip install -U --no-cache-dir pip # install poetry - respects $POETRY_VERSION & $POETRY_HOME ENV POETRY_VERSION=1.3.1 RUN curl -sSL https://install.python-poetry.org | python3 - # copy project requirement files here to ensure they will be cached. WORKDIR $PYSETUP_PATH COPY ./poetry.lock ./pyproject.toml ./ # install runtime deps - uses $POETRY_VIRTUALENVS_IN_PROJECT internally RUN poetry install --only main ############################################### # Production Image ############################################### FROM python-base as production ENV PRODUCTION=true ENV TESTING=false ARG COMMIT ENV GIT_COMMIT_HASH=$COMMIT RUN apt-get update \ && apt-get install --no-install-recommends -y \ gosu \ iproute2 \ libldap-common \ libldap-2.5 \ && rm -rf /var/lib/apt/lists/* # create directory used for Docker Secrets RUN mkdir -p /run/secrets # copying poetry and venv into image COPY --from=builder-base $POETRY_HOME $POETRY_HOME COPY --from=builder-base $PYSETUP_PATH $PYSETUP_PATH # copy backend COPY ./backend $FUWARE_HOME/backend COPY ./poetry.lock ./pyproject.toml $FUWARE_HOME/ # Alembic COPY ./alembic $FUWARE_HOME/alembic COPY ./alembic.ini $FUWARE_HOME/ # venv already has runtime deps installed we get a quicker install WORKDIR $FUWARE_HOME RUN . $VENV_PATH/bin/activate && poetry install --only main WORKDIR / VOLUME [ "$FUWARE_HOME/data/" ] ENV APP_PORT=9000 EXPOSE ${APP_PORT} HEALTHCHECK CMD python $FUWARE_HOME/backend/scripts/healthcheck.py || exit 1 # ---------------------------------- # Copy Frontend # copying caddy into image ENV STATIC_FILES=/spa/static COPY --from=builder /app/dist ${STATIC_FILES} ENV HOST 0.0.0.0 EXPOSE ${APP_PORT} COPY ./docker/entry.sh $FUWARE_HOME/run.sh RUN chmod +x $FUWARE_HOME/run.sh ENTRYPOINT ["/app/run.sh"]