From b801312f1ff6769627c256e5e5cf21a239dff986 Mon Sep 17 00:00:00 2001 From: casjay Date: Sun, 2 Jul 2023 16:26:03 -0400 Subject: [PATCH] =?UTF-8?q?=F0=9F=97=83=EF=B8=8F=20Committing=20everything?= =?UTF-8?q?=20that=20changed=20=F0=9F=97=83=EF=B8=8F?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Dockerfile --- Dockerfile | 232 +++++++++++++++++++++++++++++++++++------------------ 1 file changed, 156 insertions(+), 76 deletions(-) diff --git a/Dockerfile b/Dockerfile index c66ef95..9d07d1b 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,110 +1,190 @@ +# Docker image for ifconfig using the alpine template +ARG LICENSE="MIT" +ARG IMAGE_NAME="ifconfig" +ARG PHP_SERVER="ifconfig" +ARG BUILD_DATE="Sun Jul 2 04:21:03 PM EDT 2023" +ARG LANGUAGE="en_US.UTF-8" +ARG TIMEZONE="America/New_York" +ARG WWW_ROOT_DIR="/data/htdocs" +ARG DEFAULT_FILE_DIR="/usr/local/share/template-files" +ARG DEFAULT_DATA_DIR="/usr/local/share/template-files/data" +ARG DEFAULT_CONF_DIR="/usr/local/share/template-files/config" +ARG DEFAULT_TEMPLATE_DIR="/usr/local/share/template-files/defaults" + +ARG IMAGE_REPO="casjaysdevdocker/alpine" +ARG IMAGE_VERSION="latest" +ARG CONTAINER_VERSION="${IMAGE_VERSION}" + +ARG SERVICE_PORT="8080" +ARG EXPOSE_PORTS="8080" +ARG PHP_VERSION="php81" + +ARG USER="root" +ARG DISTRO_VERSION="${IMAGE_VERSION}" +ARG BUILD_VERSION="${DISTRO_VERSION}" + FROM golang:1.15-buster AS src -RUN apt update && apt install -yy git && \ - git clone -q https://github.com/mpolden/echoip /go/src/github.com/mpolden/echoip && \ - cd /go/src/github.com/mpolden/echoip - -WORKDIR /go/src/github.com/mpolden/echoip ENV GO111MODULE=on CGO_ENABLED=0 -RUN make +WORKDIR /go/src/github.com/mpolden/echoip +RUN apt update && apt install -yy git +RUN git clone -q https://github.com/mpolden/echoip /go/src/github.com/mpolden/echoip +RUN cd /go/src/github.com/mpolden/echoip && make -FROM casjaysdevdocker/alpine:latest AS build +FROM tianon/gosu:latest AS gosu +FROM ${IMAGE_REPO}:${DISTRO_VERSION} AS build +ARG USER +ARG LICENSE +ARG TIMEZONE +ARG LANGUAGE +ARG IMAGE_NAME +ARG PHP_SERVER +ARG BUILD_DATE +ARG SERVICE_PORT +ARG EXPOSE_PORTS +ARG BUILD_VERSION +ARG WWW_ROOT_DIR +ARG DEFAULT_FILE_DIR +ARG DEFAULT_DATA_DIR +ARG DEFAULT_CONF_DIR +ARG DEFAULT_TEMPLATE_DIR +ARG DISTRO_VERSION +ARG PHP_VERSION -ARG ALPINE_VERSION="v3.16" +ARG PACK_LIST="bash bash-completion git curl wget sudo unzip iproute2 ssmtp openssl jq ca-certificates tzdata mailcap ncurses util-linux pciutils usbutils coreutils binutils findutils grep rsync zip certbot tini certbot py3-pip procps net-tools coreutils sed gawk grep attr findutils readline lsof less curl shadow \ + " -ARG DEFAULT_DATA_DIR="/usr/local/share/template-files/data" \ - DEFAULT_CONF_DIR="/usr/local/share/template-files/config" \ - DEFAULT_TEMPLATE_DIR="/usr/local/share/template-files/defaults" +ENV ENV=~/.bashrc +ENV SHELL="/bin/sh" +ENV TZ="${TIMEZONE}" +ENV TIMEZONE="${TZ}" +ENV LANG="${LANGUAGE}" +ENV TERM="xterm-256color" +ENV HOSTNAME="casjaysdev-ifconfig" -ARG PACK_LIST="bash" +USER ${USER} +WORKDIR /root -ENV LANG=en_US.UTF-8 \ - ENV=ENV=~/.bashrc \ - TZ="America/New_York" \ - SHELL="/bin/sh" \ - TERM="xterm-256color" \ - TIMEZONE="${TZ:-$TIMEZONE}" \ - HOSTNAME="casjaysdev-ifconfig" +RUN set -ex ; \ + echo "" COPY --from=src /go/bin/echoip /opt/echoip/ +COPY --from=gosu /usr/local/bin/gosu /usr/local/bin/gosu COPY ./rootfs/. / +COPY ./Dockerfile /root/Dockerfile -RUN set -ex; \ +RUN set -ex ; \ + echo "" + +RUN set -ex ; \ rm -Rf "/etc/apk/repositories"; \ + [ "$DISTRO_VERSION" = "latest" ] && DISTRO_VERSION="edge"; \ + [ "$DISTRO_VERSION" = "edge" ] || DISTRO_VERSION="v${DISTRO_VERSION}" ; \ mkdir -p "${DEFAULT_DATA_DIR}" "${DEFAULT_CONF_DIR}" "${DEFAULT_TEMPLATE_DIR}"; \ - echo "http://dl-cdn.alpinelinux.org/alpine/${ALPINE_VERSION}/main" >>"/etc/apk/repositories"; \ - echo "http://dl-cdn.alpinelinux.org/alpine/${ALPINE_VERSION}/community" >>"/etc/apk/repositories"; \ - if [ "${ALPINE_VERSION}" = "edge" ]; then echo "http://dl-cdn.alpinelinux.org/alpine/${ALPINE_VERSION}/testing" >>"/etc/apk/repositories" ; fi ; \ - apk update --update-cache && apk add --no-cache ${PACK_LIST} + echo "http://dl-cdn.alpinelinux.org/alpine/${DISTRO_VERSION}/main" >>"/etc/apk/repositories"; \ + echo "http://dl-cdn.alpinelinux.org/alpine/${DISTRO_VERSION}/community" >>"/etc/apk/repositories"; \ + if [ "${DISTRO_VERSION}" = "edge" ]; then echo "http://dl-cdn.alpinelinux.org/alpine/${DISTRO_VERSION}/testing" >>"/etc/apk/repositories" ; fi ; \ + apk -U upgrade --no-cache && apk add --no-cache ${PACK_LIST} -RUN ln -sf /opt/echoip/echoip /usr/local/bin/echoip ; \ +RUN set -ex ; \ + echo "$TIMEZONE" >"/etc/timezone" ; \ + echo 'hosts: files dns' >"/etc/nsswitch.conf" ; \ + [ -f "/usr/share/zoneinfo/${TZ}" ] && ln -sf "/usr/share/zoneinfo/${TZ}" "/etc/localtime" ; \ + PHP_FPM="$(ls /usr/*bin/php*fpm* 2>/dev/null || echo '')" ; \ + [ -n "$PHP_FPM" ] && [ -z "$(type -P php-fpm)" ] && ln -sf "$PHP_FPM" "/usr/bin/php-fpm" || true ; \ + if [ -f "/etc/profile.d/color_prompt.sh.disabled" ]; then mv -f "/etc/profile.d/color_prompt.sh.disabled" "/etc/profile.d/color_prompt.sh"; fi + +RUN set -ex ; \ + touch "/etc/profile" "/root/.profile" ; \ + { [ -f "/etc/bash/bashrc" ] && cp -Rf "/etc/bash/bashrc" "/root/.bashrc" ; } || { [ -f "/etc/bashrc" ] && cp -Rf "/etc/bashrc" "/root/.bashrc" ; } || { [ -f "/etc/bash.bashrc" ] && cp -Rf "/etc/bash.bashrc" "/root/.bashrc" ; }; \ + sed -i 's|root:x:.*|root:x:0:0:root:/root:/bin/bash|g' "/etc/passwd" ; \ + grep -s -q 'alias quit' "/root/.bashrc" || printf '# Profile\n\n%s\n%s\n%s\n' '. /etc/profile' '. /root/.profile' "alias quit='exit 0 2>/dev/null'" >>"/root/.bashrc" ; \ + [ -f "/usr/local/etc/docker/env/default.sample" ] && [ -d "/etc/profile.d" ] && \ + cp -Rf "/usr/local/etc/docker/env/default.sample" "/etc/profile.d/container.env.sh" && chmod 755 "/etc/profile.d/container.env.sh" ; \ + BASH_CMD="$(type -P bash)" ; [ -f "$BASH_CMD" ] && rm -rf "/bin/sh" && ln -sf "$BASH_CMD" "/bin/sh" ; \ + pip install certbot-dns-rfc2136 + +RUN set -ex ; \ + ln -sf /opt/echoip/echoip /usr/local/bin/echoip ; \ ln -sf /opt/echoip/echoip /usr/local/bin/ifconfig ; \ sed -i "s|REPLACE_MODIFIED|$(date +'%Y-%m-%d at %H:%M')|g" /opt/echoip/html/index.html -RUN echo 'Running cleanup' ; \ - rm -Rf /usr/share/doc/* /usr/share/info/* /tmp/* /var/tmp/* ; \ - rm -Rf /usr/local/bin/.gitkeep /usr/local/bin/.gitkeep /config /data /var/cache/apk/* ; \ - rm -rf /lib/systemd/system/multi-user.target.wants/* ; \ +RUN set -ex ; \ + echo 'Running cleanup' ; \ + echo "" + +RUN set -ex ; \ + rm -Rf "/config" "/data" ; \ rm -rf /etc/systemd/system/*.wants/* ; \ + rm -rf /lib/systemd/system/systemd-update-utmp* ; \ + rm -rf /lib/systemd/system/anaconda.target.wants/*; \ rm -rf /lib/systemd/system/local-fs.target.wants/* ; \ + rm -rf /lib/systemd/system/multi-user.target.wants/* ; \ rm -rf /lib/systemd/system/sockets.target.wants/*udev* ; \ rm -rf /lib/systemd/system/sockets.target.wants/*initctl* ; \ - rm -rf /lib/systemd/system/sysinit.target.wants/systemd-tmpfiles-setup* ; \ - rm -rf /lib/systemd/system/systemd-update-utmp* ; \ - if [ -d "/lib/systemd/system/sysinit.target.wants" ]; then cd "/lib/systemd/system/sysinit.target.wants" && rm $(ls | grep -v systemd-tmpfiles-setup) ; fi + rm -Rf /usr/share/doc/* /usr/share/info/* /tmp/* /var/tmp/* /var/cache/*/* ; \ + if [ -d "/lib/systemd/system/sysinit.target.wants" ]; then cd "/lib/systemd/system/sysinit.target.wants" && rm -f $(ls | grep -v systemd-tmpfiles-setup) ; fi + +RUN echo "Init done" FROM scratch +ARG USER +ARG LICENSE +ARG LANGUAGE +ARG TIMEZONE +ARG IMAGE_NAME +ARG PHP_SERVER +ARG BUILD_DATE +ARG SERVICE_PORT +ARG EXPOSE_PORTS +ARG BUILD_VERSION +ARG DEFAULT_DATA_DIR +ARG DEFAULT_CONF_DIR +ARG DEFAULT_TEMPLATE_DIR +ARG DISTRO_VERSION +ARG PHP_VERSION -ARG \ - SERVICE_PORT="8080" \ - EXPOSE_PORTS="8080" \ - PHP_SERVER="ifconfig" \ - NODE_VERSION="system" \ - NODE_MANAGER="system" \ - BUILD_VERSION="latest" \ - LICENSE="MIT" \ - IMAGE_NAME="ifconfig" \ - BUILD_DATE="Mon Nov 14 12:26:35 PM EST 2022" \ - TIMEZONE="America/New_York" +USER ${USER} +WORKDIR /root -LABEL maintainer="CasjaysDev " \ - org.opencontainers.image.vendor="CasjaysDev" \ - org.opencontainers.image.authors="CasjaysDev" \ - org.opencontainers.image.vcs-type="Git" \ - org.opencontainers.image.name="${IMAGE_NAME}" \ - org.opencontainers.image.base.name="${IMAGE_NAME}" \ - org.opencontainers.image.license="${LICENSE}" \ - org.opencontainers.image.vcs-ref="${BUILD_VERSION}" \ - org.opencontainers.image.build-date="${BUILD_DATE}" \ - org.opencontainers.image.version="${BUILD_VERSION}" \ - org.opencontainers.image.schema-version="${BUILD_VERSION}" \ - org.opencontainers.image.url="https://hub.docker.com/r/casjaysdevdocker/${IMAGE_NAME}" \ - org.opencontainers.image.vcs-url="https://github.com/casjaysdevdocker/${IMAGE_NAME}" \ - org.opencontainers.image.url.source="https://github.com/casjaysdevdocker/${IMAGE_NAME}" \ - org.opencontainers.image.documentation="https://hub.docker.com/r/casjaysdevdocker/${IMAGE_NAME}" \ - org.opencontainers.image.description="Containerized version of ${IMAGE_NAME}" \ - com.github.containers.toolbox="false" +LABEL maintainer="CasjaysDev " +LABEL org.opencontainers.image.vendor="CasjaysDev" +LABEL org.opencontainers.image.authors="CasjaysDev" +LABEL org.opencontainers.image.vcs-type="Git" +LABEL org.opencontainers.image.name="${IMAGE_NAME}" +LABEL org.opencontainers.image.base.name="${IMAGE_NAME}" +LABEL org.opencontainers.image.license="${LICENSE}" +LABEL org.opencontainers.image.vcs-ref="${BUILD_VERSION}" +LABEL org.opencontainers.image.build-date="${BUILD_DATE}" +LABEL org.opencontainers.image.version="${BUILD_VERSION}" +LABEL org.opencontainers.image.schema-version="${BUILD_VERSION}" +LABEL org.opencontainers.image.url="https://hub.docker.com/r/casjaysdevdocker/${IMAGE_NAME}" +LABEL org.opencontainers.image.vcs-url="https://github.com/casjaysdevdocker/${IMAGE_NAME}" +LABEL org.opencontainers.image.url.source="https://github.com/casjaysdevdocker/${IMAGE_NAME}" +LABEL org.opencontainers.image.documentation="https://hub.docker.com/r/casjaysdevdocker/${IMAGE_NAME}" +LABEL org.opencontainers.image.description="Containerized version of ${IMAGE_NAME}" +LABEL com.github.containers.toolbox="false" -ENV LANG=en_US.UTF-8 \ - ENV=~/.bashrc \ - SHELL="/bin/bash" \ - PORT="${SERVICE_PORT}" \ - TERM="xterm-256color" \ - PHP_SERVER="${PHP_SERVER}" \ - CONTAINER_NAME="${IMAGE_NAME}" \ - TZ="${TZ:-America/New_York}" \ - TIMEZONE="${TZ:-$TIMEZONE}" \ - HOSTNAME="casjaysdev-${IMAGE_NAME}" +ENV ENV=~/.bashrc +ENV SHELL="/bin/bash" +ENV TZ="${TIMEZONE}" +ENV TIMEZONE="${TZ}" +ENV LANG="${LANGUAGE}" +ENV TERM="xterm-256color" +ENV PORT="${SERVICE_PORT}" +ENV ENV_PORTS="${EXPOSE_PORTS}" +ENV PHP_SERVER="${PHP_SERVER}" +ENV PHP_VERSION="${PHP_VERSION}" +ENV CONTAINER_NAME="${IMAGE_NAME}" +ENV HOSTNAME="casjaysdev-${IMAGE_NAME}" +ENV USER="${USER}" COPY --from=build /. / -USER root -WORKDIR /root - VOLUME [ "/config","/data" ] -EXPOSE $EXPOSE_PORTS +EXPOSE ${ENV_PORTS} -#CMD [ "" ] -ENTRYPOINT [ "tini", "-p", "SIGTERM", "--", "/usr/local/bin/entrypoint.sh" ] +CMD [ "start", "all" ] +ENTRYPOINT [ "tini", "--", "/usr/local/bin/entrypoint.sh" ] HEALTHCHECK --start-period=1m --interval=2m --timeout=3s CMD [ "/usr/local/bin/entrypoint.sh", "healthcheck" ]