77 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			Docker
		
	
	
	
			
		
		
	
	
			77 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			Docker
		
	
	
	
# Copyright Broadcom, Inc. All Rights Reserved.
 | 
						|
# SPDX-License-Identifier: APACHE-2.0
 | 
						|
 | 
						|
FROM docker.io/bitnami/minideb:bookworm
 | 
						|
 | 
						|
ARG DOWNLOADS_URL="downloads.bitnami.com/files/stacksmith"
 | 
						|
ARG TARGETARCH
 | 
						|
 | 
						|
LABEL org.opencontainers.image.base.name="docker.io/bitnami/minideb:bookworm" \
 | 
						|
      org.opencontainers.image.created="2025-10-14T05:19:53Z" \
 | 
						|
      org.opencontainers.image.description="Application packaged by Broadcom, Inc." \
 | 
						|
      org.opencontainers.image.documentation="https://github.com/bitnami/containers/tree/main/bitnami/nginx-ingress-controller/README.md" \
 | 
						|
      org.opencontainers.image.source="https://github.com/bitnami/containers/tree/main/bitnami/nginx-ingress-controller" \
 | 
						|
      org.opencontainers.image.title="nginx-ingress-controller" \
 | 
						|
      org.opencontainers.image.vendor="Broadcom, Inc." \
 | 
						|
      org.opencontainers.image.version="1.13.3"
 | 
						|
 | 
						|
ENV HOME="/" \
 | 
						|
    OS_ARCH="${TARGETARCH:-amd64}" \
 | 
						|
    OS_FLAVOUR="debian-12" \
 | 
						|
    OS_NAME="linux"
 | 
						|
 | 
						|
COPY prebuildfs /
 | 
						|
SHELL ["/bin/bash", "-o", "errexit", "-o", "nounset", "-o", "pipefail", "-c"]
 | 
						|
# Install required system packages and dependencies
 | 
						|
RUN install_packages ca-certificates curl libabsl20220623 libbrotli1 libc-ares2 libcap2-bin libcom-err2 libcrypt1 libcurl4 libffi8 libgcc-s1 libgmp10 libgnutls30 libgrpc++1.51 libgrpc29 libgssapi-krb5-2 libhogweed6 libicu72 libidn2-0 libk5crypto3 libkeyutils1 libkrb5-3 libkrb5support0 libldap-2.5-0 liblzma5 libnettle8 libnghttp2-14 libp11-kit0 libpcre3 libprotobuf32 libpsl5 libre2-9 librtmp1 libsasl2-2 libssh2-1 libssl3 libstdc++6 libtasn1-6 libunistring2 libxml2 libyajl2 libzstd1 procps zlib1g
 | 
						|
RUN --mount=type=secret,id=downloads_url,env=SECRET_DOWNLOADS_URL \
 | 
						|
    DOWNLOADS_URL=${SECRET_DOWNLOADS_URL:-${DOWNLOADS_URL}} ; \
 | 
						|
    mkdir -p /tmp/bitnami/pkg/cache/ ; cd /tmp/bitnami/pkg/cache/ || exit 1 ; \
 | 
						|
    COMPONENTS=( \
 | 
						|
      "nginx-ingress-controller-1.13.3-2-linux-${OS_ARCH}-debian-12" \
 | 
						|
    ) ; \
 | 
						|
    for COMPONENT in "${COMPONENTS[@]}"; do \
 | 
						|
      if [ ! -f "${COMPONENT}.tar.gz" ]; then \
 | 
						|
        curl -SsLf "https://${DOWNLOADS_URL}/${COMPONENT}.tar.gz" -O ; \
 | 
						|
        curl -SsLf "https://${DOWNLOADS_URL}/${COMPONENT}.tar.gz.sha256" -O ; \
 | 
						|
      fi ; \
 | 
						|
      sha256sum -c "${COMPONENT}.tar.gz.sha256" ; \
 | 
						|
      tar -zxf "${COMPONENT}.tar.gz" -C /opt/bitnami --strip-components=2 --no-same-owner ; \
 | 
						|
      rm -rf "${COMPONENT}".tar.gz{,.sha256} ; \
 | 
						|
    done
 | 
						|
RUN apt-get update && apt-get upgrade -y && \
 | 
						|
    apt-get clean && rm -rf /var/lib/apt/lists /var/cache/apt/archives
 | 
						|
RUN chmod g+rwX /opt/bitnami
 | 
						|
RUN find / -perm /6000 -type f -exec chmod a-s {} \; || true
 | 
						|
 | 
						|
RUN ln -s /usr/local/nginx/sbin/nginx /usr/bin/nginx && \
 | 
						|
    ln -s /nginx-ingress-controller /usr/bin/nginx-ingress-controller
 | 
						|
RUN cd /opt/bitnami/nginx-ingress-controller && \
 | 
						|
    mkdir -p rootfs/etc/ingress-controller/ssl rootfs/etc/ingress-controller/auth rootfs/var/log/nginx rootfs/tmp/nginx && \
 | 
						|
    if grep -q www-data /etc/passwd; then chown -R www-data rootfs/etc rootfs/var rootfs/tmp; fi && \
 | 
						|
    chgrp -R root rootfs/etc rootfs/var rootfs/tmp && \
 | 
						|
    chmod -R g+rwX rootfs/etc rootfs/var rootfs/tmp && \
 | 
						|
    cp -rp rootfs/. / && \
 | 
						|
    rm -rf rootfs && \
 | 
						|
    ldconfig /usr/local/lib
 | 
						|
RUN setcap    cap_net_bind_service=+ep /usr/local/nginx/sbin/nginx && \
 | 
						|
    setcap -v cap_net_bind_service=+ep /usr/local/nginx/sbin/nginx
 | 
						|
RUN setcap    cap_net_bind_service=+ep /nginx-ingress-controller && \
 | 
						|
    setcap -v cap_net_bind_service=+ep /nginx-ingress-controller
 | 
						|
RUN mkdir -p /etc/ingress-controller/auth /etc/ingress-controller/ssl
 | 
						|
RUN ln -sf /dev/stdout /var/log/nginx/access.log && \
 | 
						|
    ln -sf /dev/stderr /var/log/nginx/error.log
 | 
						|
ENV APP_VERSION="1.13.3" \
 | 
						|
    BITNAMI_APP_NAME="nginx-ingress-controller" \
 | 
						|
    IMAGE_REVISION="3" \
 | 
						|
    LD_LIBRARY_PATH="/lib:/usr/lib:/usr/local/lib:/modules_mount/etc/nginx/modules/otel:$LD_LIBRARY_PATH" \
 | 
						|
    LUA_CPATH="/usr/local/lib/lua/?/?.so;/usr/local/lib/lua/?.so;;" \
 | 
						|
    LUA_PATH="/usr/local/share/luajit-2.1.0-beta3/?.lua;/usr/local/share/lua/5.1/?.lua;/usr/local/lib/lua/?.lua;;" \
 | 
						|
    PATH="/usr/local/luajit/bin:/usr/local/nginx/sbin:/usr/local/nginx/bin:/opt/bitnami/nginx-ingress-controller/bin:/opt/bitnami/nginx/sbin:$PATH"
 | 
						|
 | 
						|
EXPOSE 80 443
 | 
						|
 | 
						|
WORKDIR /etc/nginx
 | 
						|
USER 1001
 | 
						|
ENTRYPOINT [ "/nginx-ingress-controller" ]
 |