Skip to content
Snippets Groups Projects
Select Git revision
  • a8ed1e25b4f53453ad6f5c99573b6a48c0e27a8c
  • master default protected
  • spilo-wale-removal
  • dependabot/go_modules/golang.org/x/oauth2-0.27.0
  • dependabot/go_modules/golang.org/x/net-0.38.0
  • dependabot/pip/ui/requests-2.32.4
  • bug-upgrade
  • gh-pages
  • patroni-4-integration
  • remove-zappr
  • ignore-auto-upgrade
  • arm-pooler
  • update-go-and-deps
  • pluralsh-liveness-probe
  • silenium-dev-master
  • bump-v1.9.1
  • enable-query-logging
  • bump-v1.7.1
  • resize-mixed-mode
  • instance-annotation
  • bump-v1.8.2
  • v1.14.0
  • v1.13.0
  • v1.12.2
  • v1.12.1
  • v1.12.0
  • v1.11.0
  • v1.10.1
  • v1.10.0
  • v1.9.0
  • v1.8.2
  • v1.8.1
  • v1.8.0
  • v1.7.1
  • v1.7.0
  • v1.6.3
  • v1.6.2
  • v1.6.1
  • v1.6.0
  • v1.5.0
  • v1.4.0
41 results

pod.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