Skip to content
Snippets Groups Projects
Select Git revision
  • v1.6.4
  • master default protected
  • mschwarzl/dockerignore
  • dependabot/github_actions/docker/build-push-action-6
  • dependabot/go_modules/golang.org/x/crypto-0.24.0
  • dependabot/github_actions/golangci/golangci-lint-action-6
  • dependabot/go_modules/github.com/jmoiron/sqlx-1.4.0
  • dependabot/go_modules/golang.org/x/net-0.23.0
  • dependabot/go_modules/github.com/zmap/zlint/v3-3.6.2
  • dependabot/go_modules/github.com/go-sql-driver/mysql-1.8.1
  • nicky/golang-cross-latest
  • nicky/docker-arch
  • nicky/postgres-in-test
  • nicky/goreleaser-action
  • watson/cert-exts
  • cbroglie/custom-csr-extensions
  • kyle/darwin-broken
  • v1.6.5
  • v1.6.3
  • v1.6.2
  • v1.6.1
  • v1.6.0
  • v1.5.0
  • v1.4.1
  • v1.4.0
  • v1.4.0-rc1
  • 1.3.4
  • 1.3.3
  • 1.3.2
  • 1.3.1
  • 1.3.0
  • 1.2.0
  • 1.1.0
  • 1.0.0
34 results

whitelist_net.go

Blame
  • generate-stackbrew-library.sh 3.87 KiB
    #!/bin/bash
    set -eu
    
    declare -A aliases
    aliases=(
    	[mainline]='1 1.27 latest'
    	[stable]='1.26'
    )
    
    self="$(basename "$BASH_SOURCE")"
    cd "$(dirname "$(readlink -f "$BASH_SOURCE")")"
    base=debian
    
    versions=( mainline stable )
    
    # get the most recent commit which modified any of "$@"
    fileCommit() {
    	git log -1 --format='format:%H' HEAD -- "$@"
    }
    
    # get the most recent commit which modified "$1/Dockerfile" or any file COPY'd from "$1/Dockerfile"
    dirCommit() {
    	local dir="$1"; shift
    	(
    		cd "$dir"
    		fileCommit \
    			Dockerfile \
    			$(git show HEAD:./Dockerfile | awk '
    				toupper($1) == "COPY" {
    					for (i = 2; i < NF; i++) {
    						print $i
    					}
    				}
    			')
    	)
    }
    
    cat <<-EOH
    # this file is generated via https://github.com/nginxinc/docker-nginx/blob/$(fileCommit "$self")/$self
    
    Maintainers: NGINX Docker Maintainers <docker-maint@nginx.com> (@nginxinc)
    GitRepo: https://github.com/nginxinc/docker-nginx.git
    EOH
    
    # prints "$2$1$3$1...$N"
    join() {
    	local sep="$1"; shift
    	local out; printf -v out "${sep//%/%%}%s" "$@"
    	echo "${out#$sep}"
    }
    
    for version in "${versions[@]}"; do
        debian_otel="debian-otel"
        alpine_otel="alpine-otel"
    	commit="$(dirCommit "$version/$base")"
    
    	fullVersion="$(git show "$commit":"$version/$base/Dockerfile" | awk '$1 == "ENV" && $2 == "NGINX_VERSION" { print $3; exit }')"
    
    	versionAliases=( $fullVersion )
    	if [ "$version" != "$fullVersion" ]; then
    		versionAliases+=( $version )
    	fi
    	versionAliases+=( ${aliases[$version]:-} )
    
    	debianVersion="$(git show "$commit":"$version/$base/Dockerfile" | awk -F"[-:]" '$1 == "FROM debian" { print $2; exit }')"
    	debianAliases=( ${versionAliases[@]/%/-$debianVersion} )
    	debianAliases=( "${debianAliases[@]//latest-/}" )
    
    	echo
    	cat <<-EOE
    		Tags: $(join ', ' "${versionAliases[@]}"), $(join ', ' "${debianAliases[@]}")
    		Architectures: amd64, arm32v5, arm32v7, arm64v8, i386, mips64le, ppc64le, s390x
    		GitCommit: $commit
    		Directory: $version/$base
    	EOE
    
    	for variant in debian-perl; do
    		commit="$(dirCommit "$version/$variant")"
    
    		variantAliases=( "${versionAliases[@]/%/-perl}" )
    		variantAliases+=( "${versionAliases[@]/%/-${variant/debian/$debianVersion}}" )
    		variantAliases=( "${variantAliases[@]//latest-/}" )
    
    		echo
    		cat <<-EOE
    			Tags: $(join ', ' "${variantAliases[@]}")
    			Architectures: amd64, arm32v5, arm32v7, arm64v8, i386, mips64le, ppc64le, s390x
    			GitCommit: $commit
    			Directory: $version/$variant
    		EOE
    	done
    
    	for variant in $debian_otel; do
    		commit="$(dirCommit "$version/$variant")"
    
    		variantAliases=( "${versionAliases[@]/%/-otel}" )
    		variantAliases+=( "${versionAliases[@]/%/-${variant/debian/$debianVersion}}" )
    		variantAliases=( "${variantAliases[@]//latest-/}" )
    
    		echo
    		cat <<-EOE
    			Tags: $(join ', ' "${variantAliases[@]}")
    			Architectures: amd64, arm64v8
    			GitCommit: $commit
    			Directory: $version/$variant
    		EOE
    	done
    
    
    	commit="$(dirCommit "$version/alpine-slim")"
    	alpineVersion="$(git show "$commit":"$version/alpine-slim/Dockerfile" | awk -F: '$1 == "FROM alpine" { print $2; exit }')"
    
    	for variant in alpine alpine-perl alpine-slim; do
    		commit="$(dirCommit "$version/$variant")"
    
    		variantAliases=( "${versionAliases[@]/%/-$variant}" )
    		variantAliases+=( "${versionAliases[@]/%/-${variant/alpine/alpine$alpineVersion}}" )
    		variantAliases=( "${variantAliases[@]//latest-/}" )
    
    		echo
    		cat <<-EOE
    			Tags: $(join ', ' "${variantAliases[@]}")
    			Architectures: arm64v8, arm32v6, arm32v7, ppc64le, s390x, i386, amd64
    			GitCommit: $commit
    			Directory: $version/$variant
    		EOE
    	done
    
    	for variant in $alpine_otel; do
    		commit="$(dirCommit "$version/$variant")"
    
    		variantAliases=( "${versionAliases[@]/%/-$variant}" )
    		variantAliases+=( "${versionAliases[@]/%/-${variant/alpine/alpine$alpineVersion}}" )
    		variantAliases=( "${variantAliases[@]//latest-/}" )
    
    		echo
    		cat <<-EOE
    			Tags: $(join ', ' "${variantAliases[@]}")
    			Architectures: amd64, arm64v8
    			GitCommit: $commit
    			Directory: $version/$variant
    		EOE
    	done
    
    done