53 lines
2.0 KiB
Docker
53 lines
2.0 KiB
Docker
|
|
# Firegex Dockerfile UUID signature
|
|
# cf1795af-3284-4183-a888-81ad3590ad84
|
|
# Needed for start.py to detect the Dockerfile
|
|
|
|
|
|
FROM --platform=$BUILDPLATFORM oven/bun AS frontend
|
|
WORKDIR /app
|
|
ADD ./frontend/package.json .
|
|
ADD ./frontend/bun.lock .
|
|
RUN bun i
|
|
COPY ./frontend/ .
|
|
RUN bun run build
|
|
|
|
# Base fedora container
|
|
FROM --platform=$TARGETARCH registry.fedoraproject.org/fedora:latest AS base
|
|
RUN dnf -y update && dnf install -y python3.13 libnetfilter_queue \
|
|
libnfnetlink libmnl libcap-ng-utils nftables git \
|
|
vectorscan libtins python3-nftables libpcap uv
|
|
|
|
RUN mkdir -p /execute/modules
|
|
WORKDIR /execute
|
|
|
|
FROM --platform=$TARGETARCH base AS compiler
|
|
|
|
RUN dnf -y update && dnf install -y python3.13-devel @development-tools gcc-c++ \
|
|
libnetfilter_queue-devel libnfnetlink-devel libmnl-devel libcap-ng-utils nftables \
|
|
vectorscan-devel libtins-devel python3-nftables libpcap-devel boost-devel uv git
|
|
|
|
COPY ./backend/binsrc /execute/binsrc
|
|
RUN g++ binsrc/nfregex.cpp -o cppregex -std=c++23 -O3 -lnetfilter_queue -pthread -lnfnetlink $(pkg-config --cflags --libs libtins libhs libmnl)
|
|
RUN g++ binsrc/nfproxy.cpp -o cpproxy -std=c++23 -O3 -lnetfilter_queue -lpython3.13 -pthread -lnfnetlink $(pkg-config --cflags --libs libtins libmnl python3)
|
|
|
|
#Building main conteiner
|
|
FROM --platform=$TARGETARCH base AS final
|
|
|
|
ADD ./backend/requirements.txt /execute/requirements.txt
|
|
COPY ./fgex-lib /execute/fgex-lib
|
|
|
|
RUN dnf install -y gcc-c++ python3.13-devel &&\
|
|
git clone https://github.com/domysh/brotli &&\
|
|
cd brotli && uv pip install --no-cache --system . &&\
|
|
cd .. && rm -rf brotli &&\
|
|
uv pip install --no-cache --system -r /execute/requirements.txt &&\
|
|
uv pip install --no-cache --system ./fgex-lib &&\
|
|
dnf remove -y gcc-c++ python3.13-devel
|
|
|
|
COPY ./backend/ /execute/
|
|
COPY --from=compiler /execute/cppregex /execute/cpproxy /execute/modules/
|
|
COPY --from=frontend /app/dist/ ./frontend/
|
|
|
|
CMD ["/bin/sh", "/execute/docker-entrypoint.sh"]
|