-
Notifications
You must be signed in to change notification settings - Fork 577
/
Copy pathgenerate-stackbrew-library.sh
executable file
·133 lines (112 loc) · 3.28 KB
/
generate-stackbrew-library.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
#!/usr/bin/env bash
set -Eeuo pipefail
declare -A aliases=(
[7.4]='7 latest'
[6.2]='6'
)
self="$(basename "$BASH_SOURCE")"
cd "$(dirname "$(readlink -f "$BASH_SOURCE")")"
if [ "$#" -eq 0 ]; then
versions="$(jq -r 'keys | map(@sh) | join(" ")' versions.json)"
eval "set -- $versions"
fi
# sort version numbers with highest first
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 'redis'
cat <<-EOH
# This file was generated via https://github.com/redis/docker-library-redis/blob/$(fileCommit "$self")/$self
Maintainers: David Maier <[email protected]> (@dmaier-redislabs),
Yossi Gottlieb <[email protected]> (@yossigo)
GitRepo: https://github.com/redis/docker-library-redis.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; do
export version
fullVersion="$(jq -r '.[env.version].version' versions.json)"
versionAliases=()
while [ "$fullVersion" != "$version" ] && [ "${fullVersion%.*}" != "$fullVersion" ]; do
versionAliases+=( $fullVersion )
fullVersion="${fullVersion%.*}"
done
versionAliases+=(
$version
${aliases[$version]:-}
)
for variant in debian alpine; do
export variant
dir="$version/$variant"
commit="$(dirCommit "$dir")"
if [ "$variant" = 'debian' ]; then
variantAliases=( "${versionAliases[@]}" )
else
variantAliases=( "${versionAliases[@]/%/-$variant}" )
variantAliases=( "${variantAliases[@]//latest-/}" )
fi
parent="$(awk 'toupper($1) == "FROM" { print $2 }' "$dir/Dockerfile")"
arches="${parentRepoToArches[$parent]}"
suite="${parent#*:}" # "bookworm-slim", "bookworm"
suite="${suite%-slim}" # "bookworm"
if [ "$variant" = 'alpine' ]; then
suite="alpine$suite" # "alpine3.18"
fi
suiteAliases=( "${versionAliases[@]/%/-$suite}" )
suiteAliases=( "${suiteAliases[@]//latest-/}" )
variantAliases+=( "${suiteAliases[@]}" )
# calculate the intersection of parent image arches and gosu arches
arches="$(jq -r --arg arches "$arches" '
(
$arches
| gsub("^[[:space:]]+|[[:space:]]+$"; "")
| split("[[:space:]]+"; "")
) as $parentArches
| .[env.version]
| $parentArches - ($parentArches - (.gosu.arches | keys))
| join(", ")
' versions.json)"
echo
cat <<-EOE
Tags: $(join ', ' "${variantAliases[@]}")
Architectures: $arches
GitCommit: $commit
Directory: $dir
EOE
done
done