Namespace
shlinkio
Image / Tag
shlink-web-client:4.5.1
Content Digest
sha256:0e695130f19307dd89c5a2b9b3486106b2445319da88b3af489af162a8f05ee4
Details
Created

2025-08-13 08:17:11 UTC

Size

21.9 MB

Content Digest
Labels
  • maintainer
    Alejandro Celaya <alejandro@alejandrocelaya.com>
  • org.opencontainers.image.created
    2025-08-13T08:16:39.788Z
  • org.opencontainers.image.description
    A React-based client application for Shlink
  • org.opencontainers.image.licenses
    MIT
  • org.opencontainers.image.revision
    aab26e3736ac240c5ee5b0ab82ebadb96e79a13b
  • org.opencontainers.image.source
    https://github.com/shlinkio/shlink-web-client
  • org.opencontainers.image.title
    shlink-web-client
  • org.opencontainers.image.url
    https://github.com/shlinkio/shlink-web-client
  • org.opencontainers.image.version
    4.5.1

Environment
DYNPKG_RELEASE

1

NGINX_VERSION

1.29.0

NJS_RELEASE

1

NJS_VERSION

0.9.0

PATH

/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin

PKG_RELEASE

1


Layers

[#000] sha256:9824c27679d3b27c5e1cb00a73adb6f4f8d556994111c12db3c5d61a0c843df8 - 16.57% (3.62 MB)

[#001] sha256:660f644e1524f828c7df8f5dae78f6559177e68eb950118c565efa8e110341fc - 7.89% (1.73 MB)

[#002] sha256:7145cf1e19b67e2345589db0561fbf2602345ddb0b34e639d5a52ff59f00d3b8 - 0.01% (2.73 KB)

[#003] sha256:34076946a30e5b189c38f58c59059e4f83e6fdaa59272ff44396d7b461a2357f - 0.0% (629 Bytes)

[#004] sha256:14ae65510bd29a0dfe07da19c732bb3905104503cfff3dfeeb69cccab8130a32 - 0.0% (956 Bytes)

[#005] sha256:147b4231c09287f4d919917b6fc878524bb4f8af84c0bf07fea7e5bb0e0e0fab - 0.0% (405 Bytes)

[#006] sha256:ed3215b396a078a524c839d612f3f4b287e26647216294108651f691912bfcf1 - 0.01% (1.18 KB)

[#007] sha256:d3dfad8d90ce4d6a8f5ddc1feab31e608a609ed1adcf085129cc44f0b85a31cd - 0.01% (1.37 KB)

[#008] sha256:738e72a4c99c47b7fb4d1471af6bc3c5713f47514180ed9bad4902ddd0781a3a - 73.16% (16 MB)

[#009] sha256:bea1d8353d485670aef57934d7f45fcc5b2a1553b39a036f175ca91e9d37dc45 - 0.0% (263 Bytes)

[#010] sha256:c692eb6433dbc94acbf0f5b47352231614ec1d0c54cb5eecc6321a6e933e2c07 - 0.0% (875 Bytes)

[#011] sha256:b6c7e35bc73acb54f8ce513bea805b58229656f3fd11ba85e0ca4a08270b5eb2 - 0.0% (542 Bytes)

[#012] sha256:25ff0dbad8ef6b4db396e81c6519d161c0a9ae390bc74420928f1c4e35b76b20 - 2.34% (525 KB)

[#013] sha256:ee3b3f9ffb008975acdba5da5ab6419d752f175ec9541dca78bc1b28f87dc992 - 0.0% (212 Bytes)


History
2025-07-15 11:01:16 UTC (buildkit.dockerfile.v0)

ADD alpine-minirootfs-3.22.1-x86_64.tar.gz / # buildkit

2025-07-15 11:01:16 UTC (buildkit.dockerfile.v0)

CMD ["/bin/sh"]

2025-08-11 00:28:46 UTC (buildkit.dockerfile.v0)

LABEL maintainer=NGINX Docker Maintainers <docker-maint@nginx.com>

2025-08-11 00:28:46 UTC (buildkit.dockerfile.v0)

ENV NGINX_VERSION=1.29.0

2025-08-11 00:28:46 UTC (buildkit.dockerfile.v0)

ENV PKG_RELEASE=1

2025-08-11 00:28:46 UTC (buildkit.dockerfile.v0)

ENV DYNPKG_RELEASE=1

2025-08-11 00:28:46 UTC (buildkit.dockerfile.v0)

ARG UID=101

2025-08-11 00:28:46 UTC (buildkit.dockerfile.v0)

ARG GID=101

2025-08-11 00:28:46 UTC (buildkit.dockerfile.v0)

RUN |2 UID=101 GID=101 /bin/sh -c set -x && addgroup -g $GID -S nginx || true && adduser -S -D -H -u $UID -h /var/cache/nginx -s /sbin/nologin -G nginx -g nginx nginx || true && apkArch="$(cat /etc/apk/arch)" && nginxPackages=" nginx=${NGINX_VERSION}-r${PKG_RELEASE} " && apk add --no-cache --virtual .checksum-deps openssl && case "$apkArch" in x86_64|aarch64) set -x && KEY_SHA512="e09fa32f0a0eab2b879ccbbc4d0e4fb9751486eedda75e35fac65802cc9faa266425edf83e261137a2f4d16281ce2c1a5f4502930fe75154723da014214f0655" && wget -O /tmp/nginx_signing.rsa.pub https://nginx.org/keys/nginx_signing.rsa.pub && if echo "$KEY_SHA512 */tmp/nginx_signing.rsa.pub" | sha512sum -c -; then echo "key verification succeeded!"; mv /tmp/nginx_signing.rsa.pub /etc/apk/keys/; else echo "key verification failed!"; exit 1; fi && apk add -X "https://nginx.org/packages/mainline/alpine/v$(egrep -o '^[0-9]+\.[0-9]+' /etc/alpine-release)/main" --no-cache $nginxPackages ;; *) set -x && tempDir="$(mktemp -d)" && chown nobody:nobody $tempDir && apk add --no-cache --virtual .build-deps gcc libc-dev make openssl-dev pcre2-dev zlib-dev linux-headers bash alpine-sdk findutils curl && su nobody -s /bin/sh -c " export HOME=${tempDir} && cd ${tempDir} && curl -f -L -O https://github.com/nginx/pkg-oss/archive/${NGINX_VERSION}-${PKG_RELEASE}.tar.gz && PKGOSSCHECKSUM=\"400593da45fc0195a01138c0c23a06059da1c6a2e26959f2c4c95fbaf63436ff211665ef01392d2b775a0133d5b57680dabe51b840a55f82e89621e84cf651d1 *${NGINX_VERSION}-${PKG_RELEASE}.tar.gz\" && if [ \"\$(openssl sha512 -r ${NGINX_VERSION}-${PKG_RELEASE}.tar.gz)\" = \"\$PKGOSSCHECKSUM\" ]; then echo \"pkg-oss tarball checksum verification succeeded!\"; else echo \"pkg-oss tarball checksum verification failed!\"; exit 1; fi && tar xzvf ${NGINX_VERSION}-${PKG_RELEASE}.tar.gz && cd pkg-oss-${NGINX_VERSION}-${PKG_RELEASE} && cd alpine && make base && apk index --allow-untrusted -o ${tempDir}/packages/alpine/${apkArch}/APKINDEX.tar.gz ${tempDir}/packages/alpine/${apkArch}/*.apk && abuild-sign -k ${tempDir}/.abuild/abuild-key.rsa ${tempDir}/packages/alpine/${apkArch}/APKINDEX.tar.gz " && cp ${tempDir}/.abuild/abuild-key.rsa.pub /etc/apk/keys/ && apk del --no-network .build-deps && apk add -X ${tempDir}/packages/alpine/ --no-cache $nginxPackages ;; esac && apk del --no-network .checksum-deps && if [ -n "$tempDir" ]; then rm -rf "$tempDir"; fi && if [ -f "/etc/apk/keys/abuild-key.rsa.pub" ]; then rm -f /etc/apk/keys/abuild-key.rsa.pub; fi && apk add --no-cache gettext-envsubst && apk add --no-cache tzdata && ln -sf /dev/stdout /var/log/nginx/access.log && ln -sf /dev/stderr /var/log/nginx/error.log && mkdir /docker-entrypoint.d # buildkit

2025-08-11 00:28:46 UTC (buildkit.dockerfile.v0)

RUN |2 UID=101 GID=101 /bin/sh -c sed -i 's,listen 80;,listen 8080;,' /etc/nginx/conf.d/default.conf && sed -i '/user nginx;/d' /etc/nginx/nginx.conf && sed -i 's,\(/var\)\{0\,1\}/run/nginx.pid,/tmp/nginx.pid,' /etc/nginx/nginx.conf && sed -i "/^http {/a \ proxy_temp_path /tmp/proxy_temp;\n client_body_temp_path /tmp/client_temp;\n fastcgi_temp_path /tmp/fastcgi_temp;\n uwsgi_temp_path /tmp/uwsgi_temp;\n scgi_temp_path /tmp/scgi_temp;\n" /etc/nginx/nginx.conf && chown -R $UID:0 /var/cache/nginx && chmod -R g+w /var/cache/nginx && chown -R $UID:0 /etc/nginx && chmod -R g+w /etc/nginx # buildkit

2025-08-11 00:28:46 UTC (buildkit.dockerfile.v0)

COPY docker-entrypoint.sh / # buildkit

2025-08-11 00:28:46 UTC (buildkit.dockerfile.v0)

COPY 10-listen-on-ipv6-by-default.sh /docker-entrypoint.d # buildkit

2025-08-11 00:28:46 UTC (buildkit.dockerfile.v0)

COPY 15-local-resolvers.envsh /docker-entrypoint.d # buildkit

2025-08-11 00:28:46 UTC (buildkit.dockerfile.v0)

COPY 20-envsubst-on-templates.sh /docker-entrypoint.d # buildkit

2025-08-11 00:28:46 UTC (buildkit.dockerfile.v0)

COPY 30-tune-worker-processes.sh /docker-entrypoint.d # buildkit

2025-08-11 00:28:46 UTC (buildkit.dockerfile.v0)

ENTRYPOINT ["/docker-entrypoint.sh"]

2025-08-11 00:28:46 UTC (buildkit.dockerfile.v0)

EXPOSE map[8080/tcp:{}]

2025-08-11 00:28:46 UTC (buildkit.dockerfile.v0)

STOPSIGNAL SIGQUIT

2025-08-11 00:28:46 UTC (buildkit.dockerfile.v0)

USER 101

2025-08-11 00:28:46 UTC (buildkit.dockerfile.v0)

CMD ["nginx" "-g" "daemon off;"]

2025-08-11 02:09:27 UTC (buildkit.dockerfile.v0)

ENV NJS_VERSION=0.9.0

2025-08-11 02:09:27 UTC (buildkit.dockerfile.v0)

ENV NJS_RELEASE=1

2025-08-11 02:09:27 UTC (buildkit.dockerfile.v0)

ARG UID=101

2025-08-11 02:09:27 UTC (buildkit.dockerfile.v0)

ARG GID=101

2025-08-11 02:09:27 UTC (buildkit.dockerfile.v0)

USER root

2025-08-11 02:09:27 UTC (buildkit.dockerfile.v0)

RUN |2 UID=101 GID=101 /bin/sh -c set -x && apkArch="$(cat /etc/apk/arch)" && nginxPackages=" nginx=${NGINX_VERSION}-r${PKG_RELEASE} nginx-module-xslt=${NGINX_VERSION}-r${DYNPKG_RELEASE} nginx-module-geoip=${NGINX_VERSION}-r${DYNPKG_RELEASE} nginx-module-image-filter=${NGINX_VERSION}-r${DYNPKG_RELEASE} nginx-module-njs=${NGINX_VERSION}.${NJS_VERSION}-r${NJS_RELEASE} " && apk add --no-cache --virtual .checksum-deps openssl && case "$apkArch" in x86_64|aarch64) apk add -X "https://nginx.org/packages/mainline/alpine/v$(egrep -o '^[0-9]+\.[0-9]+' /etc/alpine-release)/main" --no-cache $nginxPackages ;; *) set -x && tempDir="$(mktemp -d)" && chown nobody:nobody $tempDir && apk add --no-cache --virtual .build-deps gcc libc-dev make openssl-dev pcre2-dev zlib-dev linux-headers libxslt-dev gd-dev geoip-dev libedit-dev bash alpine-sdk findutils curl && su nobody -s /bin/sh -c " export HOME=${tempDir} && cd ${tempDir} && curl -f -L -O https://github.com/nginx/pkg-oss/archive/${NGINX_VERSION}-${PKG_RELEASE}.tar.gz && PKGOSSCHECKSUM=\"400593da45fc0195a01138c0c23a06059da1c6a2e26959f2c4c95fbaf63436ff211665ef01392d2b775a0133d5b57680dabe51b840a55f82e89621e84cf651d1 *${NGINX_VERSION}-${PKG_RELEASE}.tar.gz\" && if [ \"\$(openssl sha512 -r ${NGINX_VERSION}-${PKG_RELEASE}.tar.gz)\" = \"\$PKGOSSCHECKSUM\" ]; then echo \"pkg-oss tarball checksum verification succeeded!\"; else echo \"pkg-oss tarball checksum verification failed!\"; exit 1; fi && tar xzvf ${NGINX_VERSION}-${PKG_RELEASE}.tar.gz && cd pkg-oss-${NGINX_VERSION}-${PKG_RELEASE} && cd alpine && make module-geoip module-image-filter module-njs module-xslt && apk index --allow-untrusted -o ${tempDir}/packages/alpine/${apkArch}/APKINDEX.tar.gz ${tempDir}/packages/alpine/${apkArch}/*.apk && abuild-sign -k ${tempDir}/.abuild/abuild-key.rsa ${tempDir}/packages/alpine/${apkArch}/APKINDEX.tar.gz " && cp ${tempDir}/.abuild/abuild-key.rsa.pub /etc/apk/keys/ && apk del --no-network .build-deps && apk add -X ${tempDir}/packages/alpine/ --no-cache $nginxPackages ;; esac && apk del --no-network .checksum-deps && if [ -n "$tempDir" ]; then rm -rf "$tempDir"; fi && if [ -f "/etc/apk/keys/abuild-key.rsa.pub" ]; then rm -f /etc/apk/keys/abuild-key.rsa.pub; fi && apk add --no-cache curl ca-certificates # buildkit

2025-08-11 02:09:27 UTC (buildkit.dockerfile.v0)

USER 101

2025-08-13 08:16:42 UTC (buildkit.dockerfile.v0)

ARG UID=101

2025-08-13 08:16:42 UTC (buildkit.dockerfile.v0)

LABEL maintainer=Alejandro Celaya <alejandro@alejandrocelaya.com>

2025-08-13 08:16:42 UTC (buildkit.dockerfile.v0)

USER root

2025-08-13 08:16:42 UTC (buildkit.dockerfile.v0)

RUN |1 UID=101 /bin/sh -c rm -r /usr/share/nginx/html && rm /etc/nginx/conf.d/default.conf # buildkit

2025-08-13 08:16:42 UTC (buildkit.dockerfile.v0)

COPY config/docker/nginx.conf /etc/nginx/conf.d/default.conf # buildkit

2025-08-13 08:16:42 UTC (buildkit.dockerfile.v0)

COPY scripts/docker/servers_from_env.sh /docker-entrypoint.d/30-shlink-servers-json.sh # buildkit

2025-08-13 08:17:11 UTC (buildkit.dockerfile.v0)

COPY /shlink-web-client/build /usr/share/nginx/html # buildkit

2025-08-13 08:17:11 UTC (buildkit.dockerfile.v0)

RUN |1 UID=101 /bin/sh -c echo '[]' > /usr/share/nginx/html/servers.json && chown $UID:0 /usr/share/nginx/html/servers.json # buildkit

2025-08-13 08:17:11 UTC (buildkit.dockerfile.v0)

USER 101

Details
Created

2025-08-13 08:20:28 UTC

Size

22.3 MB

Content Digest
Labels
  • maintainer
    Alejandro Celaya <alejandro@alejandrocelaya.com>
  • org.opencontainers.image.created
    2025-08-13T08:16:39.788Z
  • org.opencontainers.image.description
    A React-based client application for Shlink
  • org.opencontainers.image.licenses
    MIT
  • org.opencontainers.image.revision
    aab26e3736ac240c5ee5b0ab82ebadb96e79a13b
  • org.opencontainers.image.source
    https://github.com/shlinkio/shlink-web-client
  • org.opencontainers.image.title
    shlink-web-client
  • org.opencontainers.image.url
    https://github.com/shlinkio/shlink-web-client
  • org.opencontainers.image.version
    4.5.1

Environment
DYNPKG_RELEASE

1

NGINX_VERSION

1.29.0

NJS_RELEASE

1

NJS_VERSION

0.9.0

PATH

/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin

PKG_RELEASE

1


Layers

[#000] sha256:6e174226ea690ced550e5641249a412cdbefd2d09871f3e64ab52137a54ba606 - 17.65% (3.94 MB)

[#001] sha256:891795c37aa1b89d2cafb50ef1f097f71aa609dac6e81d6f43bd58614f7713f3 - 7.7% (1.72 MB)

[#002] sha256:f81dc20ced487c9536622ef40befb60ae4635f02a9e5df7820f9a7d646f1d680 - 0.01% (2.73 KB)

[#003] sha256:34076946a30e5b189c38f58c59059e4f83e6fdaa59272ff44396d7b461a2357f - 0.0% (629 Bytes)

[#004] sha256:6e7d0992762fbef26b88af78bdc45ad414035de741990466e2db47c68eaa1816 - 0.0% (956 Bytes)

[#005] sha256:414c324963320bea224c5a2a348e7ec7a0bd7f156b07eb2ea40a82f44daa19ac - 0.0% (405 Bytes)

[#006] sha256:c2ef2fda4dee4ba64f772b4f834218e8e35397a7c34cc19ac6decf3e2f7c8ff2 - 0.01% (1.18 KB)

[#007] sha256:837b861cd4870845c37c3bffa6f996f9acfbc68b19eb527e9eee45f3873493e8 - 0.01% (1.37 KB)

[#008] sha256:72919a0be3d534d6fdbe6b9baeae8edfc13a9a7a3336b3230305ca6287cc0823 - 72.31% (16.1 MB)

[#009] sha256:1caab30037b36e7d2f28ed9373c6a024dc878a84f00edd246022a789d7113d5d - 0.0% (264 Bytes)

[#010] sha256:c50199c2a33e29d321937605089314a9b5c5adce7c1db63e7aa03f5f0772e7b5 - 0.0% (877 Bytes)

[#011] sha256:f18a0cf4286eff3a916f6158b1c1301d8c4f5122c68bb11f97a336d16c7c2367 - 0.0% (541 Bytes)

[#012] sha256:25f55f0b0806d8657083032fc054f4ef10e1b20193402d22bb7aeb72d6c85648 - 2.3% (525 KB)

[#013] sha256:900dd7cb907961a36545f0f74a9dcb72d2533d97106eee7a7e79314ece1f7506 - 0.0% (213 Bytes)


History
2025-07-15 11:01:16 UTC (buildkit.dockerfile.v0)

ADD alpine-minirootfs-3.22.1-aarch64.tar.gz / # buildkit

2025-07-15 11:01:16 UTC (buildkit.dockerfile.v0)

CMD ["/bin/sh"]

2025-08-11 00:29:13 UTC (buildkit.dockerfile.v0)

LABEL maintainer=NGINX Docker Maintainers <docker-maint@nginx.com>

2025-08-11 00:29:13 UTC (buildkit.dockerfile.v0)

ENV NGINX_VERSION=1.29.0

2025-08-11 00:29:13 UTC (buildkit.dockerfile.v0)

ENV PKG_RELEASE=1

2025-08-11 00:29:13 UTC (buildkit.dockerfile.v0)

ENV DYNPKG_RELEASE=1

2025-08-11 00:29:13 UTC (buildkit.dockerfile.v0)

ARG UID=101

2025-08-11 00:29:13 UTC (buildkit.dockerfile.v0)

ARG GID=101

2025-08-11 00:29:13 UTC (buildkit.dockerfile.v0)

RUN |2 UID=101 GID=101 /bin/sh -c set -x && addgroup -g $GID -S nginx || true && adduser -S -D -H -u $UID -h /var/cache/nginx -s /sbin/nologin -G nginx -g nginx nginx || true && apkArch="$(cat /etc/apk/arch)" && nginxPackages=" nginx=${NGINX_VERSION}-r${PKG_RELEASE} " && apk add --no-cache --virtual .checksum-deps openssl && case "$apkArch" in x86_64|aarch64) set -x && KEY_SHA512="e09fa32f0a0eab2b879ccbbc4d0e4fb9751486eedda75e35fac65802cc9faa266425edf83e261137a2f4d16281ce2c1a5f4502930fe75154723da014214f0655" && wget -O /tmp/nginx_signing.rsa.pub https://nginx.org/keys/nginx_signing.rsa.pub && if echo "$KEY_SHA512 */tmp/nginx_signing.rsa.pub" | sha512sum -c -; then echo "key verification succeeded!"; mv /tmp/nginx_signing.rsa.pub /etc/apk/keys/; else echo "key verification failed!"; exit 1; fi && apk add -X "https://nginx.org/packages/mainline/alpine/v$(egrep -o '^[0-9]+\.[0-9]+' /etc/alpine-release)/main" --no-cache $nginxPackages ;; *) set -x && tempDir="$(mktemp -d)" && chown nobody:nobody $tempDir && apk add --no-cache --virtual .build-deps gcc libc-dev make openssl-dev pcre2-dev zlib-dev linux-headers bash alpine-sdk findutils curl && su nobody -s /bin/sh -c " export HOME=${tempDir} && cd ${tempDir} && curl -f -L -O https://github.com/nginx/pkg-oss/archive/${NGINX_VERSION}-${PKG_RELEASE}.tar.gz && PKGOSSCHECKSUM=\"400593da45fc0195a01138c0c23a06059da1c6a2e26959f2c4c95fbaf63436ff211665ef01392d2b775a0133d5b57680dabe51b840a55f82e89621e84cf651d1 *${NGINX_VERSION}-${PKG_RELEASE}.tar.gz\" && if [ \"\$(openssl sha512 -r ${NGINX_VERSION}-${PKG_RELEASE}.tar.gz)\" = \"\$PKGOSSCHECKSUM\" ]; then echo \"pkg-oss tarball checksum verification succeeded!\"; else echo \"pkg-oss tarball checksum verification failed!\"; exit 1; fi && tar xzvf ${NGINX_VERSION}-${PKG_RELEASE}.tar.gz && cd pkg-oss-${NGINX_VERSION}-${PKG_RELEASE} && cd alpine && make base && apk index --allow-untrusted -o ${tempDir}/packages/alpine/${apkArch}/APKINDEX.tar.gz ${tempDir}/packages/alpine/${apkArch}/*.apk && abuild-sign -k ${tempDir}/.abuild/abuild-key.rsa ${tempDir}/packages/alpine/${apkArch}/APKINDEX.tar.gz " && cp ${tempDir}/.abuild/abuild-key.rsa.pub /etc/apk/keys/ && apk del --no-network .build-deps && apk add -X ${tempDir}/packages/alpine/ --no-cache $nginxPackages ;; esac && apk del --no-network .checksum-deps && if [ -n "$tempDir" ]; then rm -rf "$tempDir"; fi && if [ -f "/etc/apk/keys/abuild-key.rsa.pub" ]; then rm -f /etc/apk/keys/abuild-key.rsa.pub; fi && apk add --no-cache gettext-envsubst && apk add --no-cache tzdata && ln -sf /dev/stdout /var/log/nginx/access.log && ln -sf /dev/stderr /var/log/nginx/error.log && mkdir /docker-entrypoint.d # buildkit

2025-08-11 00:29:14 UTC (buildkit.dockerfile.v0)

RUN |2 UID=101 GID=101 /bin/sh -c sed -i 's,listen 80;,listen 8080;,' /etc/nginx/conf.d/default.conf && sed -i '/user nginx;/d' /etc/nginx/nginx.conf && sed -i 's,\(/var\)\{0\,1\}/run/nginx.pid,/tmp/nginx.pid,' /etc/nginx/nginx.conf && sed -i "/^http {/a \ proxy_temp_path /tmp/proxy_temp;\n client_body_temp_path /tmp/client_temp;\n fastcgi_temp_path /tmp/fastcgi_temp;\n uwsgi_temp_path /tmp/uwsgi_temp;\n scgi_temp_path /tmp/scgi_temp;\n" /etc/nginx/nginx.conf && chown -R $UID:0 /var/cache/nginx && chmod -R g+w /var/cache/nginx && chown -R $UID:0 /etc/nginx && chmod -R g+w /etc/nginx # buildkit

2025-08-11 00:29:14 UTC (buildkit.dockerfile.v0)

COPY docker-entrypoint.sh / # buildkit

2025-08-11 00:29:14 UTC (buildkit.dockerfile.v0)

COPY 10-listen-on-ipv6-by-default.sh /docker-entrypoint.d # buildkit

2025-08-11 00:29:14 UTC (buildkit.dockerfile.v0)

COPY 15-local-resolvers.envsh /docker-entrypoint.d # buildkit

2025-08-11 00:29:14 UTC (buildkit.dockerfile.v0)

COPY 20-envsubst-on-templates.sh /docker-entrypoint.d # buildkit

2025-08-11 00:29:14 UTC (buildkit.dockerfile.v0)

COPY 30-tune-worker-processes.sh /docker-entrypoint.d # buildkit

2025-08-11 00:29:14 UTC (buildkit.dockerfile.v0)

ENTRYPOINT ["/docker-entrypoint.sh"]

2025-08-11 00:29:14 UTC (buildkit.dockerfile.v0)

EXPOSE map[8080/tcp:{}]

2025-08-11 00:29:14 UTC (buildkit.dockerfile.v0)

STOPSIGNAL SIGQUIT

2025-08-11 00:29:14 UTC (buildkit.dockerfile.v0)

USER 101

2025-08-11 00:29:14 UTC (buildkit.dockerfile.v0)

CMD ["nginx" "-g" "daemon off;"]

2025-08-11 02:09:50 UTC (buildkit.dockerfile.v0)

ENV NJS_VERSION=0.9.0

2025-08-11 02:09:50 UTC (buildkit.dockerfile.v0)

ENV NJS_RELEASE=1

2025-08-11 02:09:50 UTC (buildkit.dockerfile.v0)

ARG UID=101

2025-08-11 02:09:50 UTC (buildkit.dockerfile.v0)

ARG GID=101

2025-08-11 02:09:50 UTC (buildkit.dockerfile.v0)

USER root

2025-08-11 02:09:50 UTC (buildkit.dockerfile.v0)

RUN |2 UID=101 GID=101 /bin/sh -c set -x && apkArch="$(cat /etc/apk/arch)" && nginxPackages=" nginx=${NGINX_VERSION}-r${PKG_RELEASE} nginx-module-xslt=${NGINX_VERSION}-r${DYNPKG_RELEASE} nginx-module-geoip=${NGINX_VERSION}-r${DYNPKG_RELEASE} nginx-module-image-filter=${NGINX_VERSION}-r${DYNPKG_RELEASE} nginx-module-njs=${NGINX_VERSION}.${NJS_VERSION}-r${NJS_RELEASE} " && apk add --no-cache --virtual .checksum-deps openssl && case "$apkArch" in x86_64|aarch64) apk add -X "https://nginx.org/packages/mainline/alpine/v$(egrep -o '^[0-9]+\.[0-9]+' /etc/alpine-release)/main" --no-cache $nginxPackages ;; *) set -x && tempDir="$(mktemp -d)" && chown nobody:nobody $tempDir && apk add --no-cache --virtual .build-deps gcc libc-dev make openssl-dev pcre2-dev zlib-dev linux-headers libxslt-dev gd-dev geoip-dev libedit-dev bash alpine-sdk findutils curl && su nobody -s /bin/sh -c " export HOME=${tempDir} && cd ${tempDir} && curl -f -L -O https://github.com/nginx/pkg-oss/archive/${NGINX_VERSION}-${PKG_RELEASE}.tar.gz && PKGOSSCHECKSUM=\"400593da45fc0195a01138c0c23a06059da1c6a2e26959f2c4c95fbaf63436ff211665ef01392d2b775a0133d5b57680dabe51b840a55f82e89621e84cf651d1 *${NGINX_VERSION}-${PKG_RELEASE}.tar.gz\" && if [ \"\$(openssl sha512 -r ${NGINX_VERSION}-${PKG_RELEASE}.tar.gz)\" = \"\$PKGOSSCHECKSUM\" ]; then echo \"pkg-oss tarball checksum verification succeeded!\"; else echo \"pkg-oss tarball checksum verification failed!\"; exit 1; fi && tar xzvf ${NGINX_VERSION}-${PKG_RELEASE}.tar.gz && cd pkg-oss-${NGINX_VERSION}-${PKG_RELEASE} && cd alpine && make module-geoip module-image-filter module-njs module-xslt && apk index --allow-untrusted -o ${tempDir}/packages/alpine/${apkArch}/APKINDEX.tar.gz ${tempDir}/packages/alpine/${apkArch}/*.apk && abuild-sign -k ${tempDir}/.abuild/abuild-key.rsa ${tempDir}/packages/alpine/${apkArch}/APKINDEX.tar.gz " && cp ${tempDir}/.abuild/abuild-key.rsa.pub /etc/apk/keys/ && apk del --no-network .build-deps && apk add -X ${tempDir}/packages/alpine/ --no-cache $nginxPackages ;; esac && apk del --no-network .checksum-deps && if [ -n "$tempDir" ]; then rm -rf "$tempDir"; fi && if [ -f "/etc/apk/keys/abuild-key.rsa.pub" ]; then rm -f /etc/apk/keys/abuild-key.rsa.pub; fi && apk add --no-cache curl ca-certificates # buildkit

2025-08-11 02:09:50 UTC (buildkit.dockerfile.v0)

USER 101

2025-08-13 08:16:43 UTC (buildkit.dockerfile.v0)

ARG UID=101

2025-08-13 08:16:43 UTC (buildkit.dockerfile.v0)

LABEL maintainer=Alejandro Celaya <alejandro@alejandrocelaya.com>

2025-08-13 08:16:43 UTC (buildkit.dockerfile.v0)

USER root

2025-08-13 08:16:43 UTC (buildkit.dockerfile.v0)

RUN |1 UID=101 /bin/sh -c rm -r /usr/share/nginx/html && rm /etc/nginx/conf.d/default.conf # buildkit

2025-08-13 08:16:43 UTC (buildkit.dockerfile.v0)

COPY config/docker/nginx.conf /etc/nginx/conf.d/default.conf # buildkit

2025-08-13 08:16:43 UTC (buildkit.dockerfile.v0)

COPY scripts/docker/servers_from_env.sh /docker-entrypoint.d/30-shlink-servers-json.sh # buildkit

2025-08-13 08:20:28 UTC (buildkit.dockerfile.v0)

COPY /shlink-web-client/build /usr/share/nginx/html # buildkit

2025-08-13 08:20:28 UTC (buildkit.dockerfile.v0)

RUN |1 UID=101 /bin/sh -c echo '[]' > /usr/share/nginx/html/servers.json && chown $UID:0 /usr/share/nginx/html/servers.json # buildkit

2025-08-13 08:20:28 UTC (buildkit.dockerfile.v0)

USER 101

Danger Zone
Delete Tag

Please be careful as this will not just delete the reference but also the actual content!

For example when you have latest and v1.2.3 both pointing to the same image
the deletion of latest will also permanently remove v1.2.3.

Delete