php/generate-stackbrew-library.sh

157 lines
4.0 KiB
Bash
Raw Normal View History

#!/usr/bin/env bash
set -Eeuo pipefail
2016-06-09 10:34:11 -07:00
declare -A aliases=(
2020-11-26 08:55:18 -08:00
[7.4]='7'
2021-11-29 15:09:01 -05:00
[8.1]='8 latest'
2014-08-20 17:50:02 -06:00
)
self="$(basename "$BASH_SOURCE")"
2014-08-20 17:50:02 -06:00
cd "$(dirname "$(readlink -f "$BASH_SOURCE")")"
2020-08-17 22:12:07 -07:00
if [ "$#" -eq 0 ]; then
versions="$(jq -r 'to_entries | map(if .value then .key | @sh else empty end) | join(" ")' versions.json)"
2020-08-17 22:12:07 -07:00
eval "set -- $versions"
fi
2014-08-20 17:50:02 -06:00
# sort version numbers with highest first
2020-08-17 22:12:07 -07:00
IFS=$'\n'; set -- $(sort -rV <<<"$*"); unset IFS
# 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
}
}
')
)
}
getArches() {
local repo="$1"; shift
local officialImagesUrl='https://github.com/docker-library/official-images/raw/master/library/'
eval "declare -g -A parentRepoToArches=( $(
find -name 'Dockerfile' -exec awk '
toupper($1) == "FROM" && $2 !~ /^('"$repo"'|scratch|.*\/.*)(:|$)/ {
print "'"$officialImagesUrl"'" $2
}
' '{}' + \
| sort -u \
| xargs bashbrew cat --format '[{{ .RepoName }}:{{ .TagName }}]="{{ join " " .TagEntry.Architectures }}"'
) )"
}
getArches 'php'
cat <<-EOH
# this file is generated via https://github.com/docker-library/php/blob/$(fileCommit "$self")/$self
Maintainers: Tianon Gravi <admwiggin@gmail.com> (@tianon),
Joseph Ferguson <yosifkit@gmail.com> (@yosifkit)
GitRepo: https://github.com/docker-library/php.git
EOH
# prints "$2$1$3$1...$N"
join() {
local sep="$1"; shift
local out; printf -v out "${sep//%/%%}%s" "$@"
echo "${out#$sep}"
}
2014-08-20 17:50:02 -06:00
2020-08-17 22:12:07 -07:00
for version; do
rcVersion="${version%-rc}"
export version rcVersion
if ! fullVersion="$(jq -er '.[env.version] | if . then .version else empty end' versions.json)"; then
continue
fi
if [ "$rcVersion" != "$version" ] && rcFullVersion="$(jq -er '.[env.rcVersion] | if . then .version else empty end' versions.json)"; then
# if this is a "-rc" release, let's make sure the release it contains isn't already GA (and thus something we should not publish anymore)
latestVersion="$({ echo "$fullVersion"; echo "$rcFullVersion"; } | sort -V | tail -1)"
if [[ "$fullVersion" == "$rcFullVersion"* ]] || [ "$latestVersion" = "$rcFullVersion" ]; then
# "x.y.z-rc1" == x.y.z*
continue
fi
fi
2020-08-17 22:12:07 -07:00
variants="$(jq -r '.[env.version].variants | map(@sh) | join(" ")' versions.json)"
eval "variants=( $variants )"
versionAliases=(
$fullVersion
$version
${aliases[$version]:-}
)
defaultDebianVariant="$(jq -r '
.[env.version].variants
| map(
split("/")[0]
| select(
startswith("alpine")
| not
)
)
| .[0]
' versions.json)"
defaultAlpineVariant="$(jq -r '
.[env.version].variants
| map(
split("/")[0]
| select(
startswith("alpine")
)
)
| .[0]
' versions.json)"
2020-08-17 22:12:07 -07:00
for dir in "${variants[@]}"; do
suite="$(dirname "$dir")" # "buster", etc
variant="$(basename "$dir")" # "cli", etc
dir="$version/$dir"
[ -f "$dir/Dockerfile" ] || continue
variantAliases=( "${versionAliases[@]/%/-$variant}" )
2020-08-17 22:12:07 -07:00
variantAliases=( "${variantAliases[@]//latest-/}" )
if [ "$variant" = 'cli' ]; then
variantAliases+=( "${versionAliases[@]}" )
2020-08-17 22:12:07 -07:00
fi
suiteVariantAliases=( "${variantAliases[@]/%/-$suite}" )
if [ "$suite" = "$defaultAlpineVariant" ] ; then
2020-08-17 22:12:07 -07:00
variantAliases=( "${variantAliases[@]/%/-alpine}" )
elif [ "$suite" != "$defaultDebianVariant" ]; then
2020-08-17 22:12:07 -07:00
variantAliases=()
fi
variantAliases=( "${suiteVariantAliases[@]}" ${variantAliases[@]+"${variantAliases[@]}"} )
variantAliases=( "${variantAliases[@]//latest-/}" )
variantParent="$(awk 'toupper($1) == "FROM" { print $2 }' "$dir/Dockerfile")"
variantArches="${parentRepoToArches[$variantParent]}"
commit="$(dirCommit "$dir")"
echo
cat <<-EOE
Tags: $(join ', ' "${variantAliases[@]}")
Architectures: $(join ', ' $variantArches)
GitCommit: $commit
Directory: $dir
EOE
2014-08-20 17:50:02 -06:00
done
done