mirror of
https://github.com/bunkerity/bunkerweb
synced 2026-05-24 09:28:37 +00:00
69 lines
3 KiB
Docker
69 lines
3 KiB
Docker
FROM python:3.12.2-alpine3.19@sha256:1a0501213b470de000d8432b3caab9d8de5489e9443c2cc7ccaa6b0aa5c3148e as builder
|
|
|
|
# Install python dependencies
|
|
RUN apk add --no-cache build-base postgresql-dev
|
|
|
|
# Copy python requirements
|
|
COPY src/deps/requirements.txt /tmp/requirements-deps.txt
|
|
COPY src/common/gen/requirements.txt /tmp/req/requirements-gen.txt
|
|
COPY src/common/db/requirements.txt /tmp/req/requirements-db.txt
|
|
|
|
WORKDIR /usr/share/bunkerweb
|
|
|
|
# Install python requirements
|
|
RUN export MAKEFLAGS="-j$(nproc)" && \
|
|
pip install --no-cache-dir --require-hashes --break-system-packages -r /tmp/requirements-deps.txt && \
|
|
pip install --no-cache-dir --require-hashes --target deps/python $(for file in $(ls /tmp/req/requirements*.txt) ; do echo "-r ${file}" ; done | xargs)
|
|
|
|
# Copy files
|
|
# can't exclude specific files/dir from . so we are copying everything by hand
|
|
COPY src/autoconf autoconf
|
|
COPY src/common/api api
|
|
COPY src/common/cli cli
|
|
COPY src/common/core core
|
|
COPY src/common/db db
|
|
COPY src/common/helpers helpers
|
|
COPY src/common/settings.json settings.json
|
|
COPY src/common/utils utils
|
|
|
|
FROM python:3.12.2-alpine3.19@sha256:1a0501213b470de000d8432b3caab9d8de5489e9443c2cc7ccaa6b0aa5c3148e
|
|
|
|
# Set default umask to prevent huge recursive chmod increasing the final image size
|
|
RUN umask 027
|
|
|
|
# Copy dependencies
|
|
COPY --from=builder --chown=0:101 /usr/share/bunkerweb /usr/share/bunkerweb
|
|
|
|
WORKDIR /usr/share/bunkerweb
|
|
|
|
# Add autoconf user, drop bwcli, install runtime dependencies, create data folders and set permissions
|
|
RUN apk add --no-cache bash && \
|
|
addgroup -g 101 autoconf && \
|
|
adduser -h /var/cache/autoconf -g autoconf -s /bin/sh -G autoconf -D -H -u 101 autoconf && \
|
|
cp helpers/bwcli /usr/bin/ && \
|
|
echo "Docker" > INTEGRATION && \
|
|
mkdir -p /etc/bunkerweb /var/tmp/bunkerweb /var/run/bunkerweb /var/log/bunkerweb /var/www && \
|
|
mkdir -p /data/cache && ln -s /data/cache /var/cache/bunkerweb && \
|
|
mkdir -p /data/lib && ln -s /data/lib /var/lib/bunkerweb && \
|
|
mkdir -p /data/www && ln -s /data/www /var/www/html && \
|
|
for dir in $(echo "configs plugins") ; do mkdir -p "/data/${dir}" && ln -s "/data/${dir}" "/etc/bunkerweb/${dir}" ; done && \
|
|
for dir in $(echo "configs/http configs/stream configs/server-http configs/server-stream configs/default-server-http configs/default-server-stream configs/modsec configs/modsec-crs") ; do mkdir "/data/${dir}" ; done && \
|
|
chown -R root:autoconf /data && \
|
|
chmod -R 770 /data && \
|
|
chown -R root:autoconf INTEGRATION /var/cache/bunkerweb /var/lib/bunkerweb /etc/bunkerweb /var/tmp/bunkerweb /usr/bin/bwcli && \
|
|
chmod -R 770 /var/cache/bunkerweb /var/lib/bunkerweb /etc/bunkerweb /var/tmp/bunkerweb && \
|
|
chmod 750 cli/main.py helpers/*.sh /usr/bin/bwcli autoconf/main.py deps/python/bin/* && \
|
|
chmod 660 INTEGRATION
|
|
|
|
# Fix CVEs
|
|
RUN apk add --no-cache "libexpat>=2.6.0-r0"
|
|
|
|
VOLUME /data
|
|
|
|
WORKDIR /usr/share/bunkerweb/autoconf
|
|
|
|
USER autoconf:autoconf
|
|
|
|
HEALTHCHECK --interval=10s --timeout=10s --start-period=30s --retries=6 CMD /usr/share/bunkerweb/helpers/healthcheck-autoconf.sh
|
|
|
|
CMD [ "python3", "main.py" ]
|