2021-08-26 13:21:30 +00:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
set -Eeuo pipefail
|
2018-02-12 23:51:50 +00:00
|
|
|
|
2016-08-16 12:14:03 +00:00
|
|
|
self="$(basename "$BASH_SOURCE")"
|
2015-07-25 18:42:58 +00:00
|
|
|
cd "$(dirname "$(readlink -f "$BASH_SOURCE")")"
|
|
|
|
|
2021-08-26 13:21:30 +00:00
|
|
|
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
|
2018-02-12 23:51:50 +00:00
|
|
|
|
2016-08-16 12:14:03 +00:00
|
|
|
# get the most recent commit which modified any of "$@"
|
|
|
|
fileCommit() {
|
2021-08-26 13:21:30 +00:00
|
|
|
git log -1 --format='format:%H' HEAD -- "$@"
|
2016-08-16 12:14:03 +00:00
|
|
|
}
|
2015-07-25 18:42:58 +00:00
|
|
|
|
2016-08-16 12:14:03 +00:00
|
|
|
# get the most recent commit which modified "$1/Dockerfile" or any file COPY'd from "$1/Dockerfile"
|
|
|
|
dirCommit() {
|
2021-08-26 13:21:30 +00:00
|
|
|
local dir="$1"
|
|
|
|
shift
|
|
|
|
(
|
|
|
|
cd "$dir"
|
|
|
|
fileCommit \
|
|
|
|
Dockerfile \
|
|
|
|
$(git show HEAD:./Dockerfile | awk '
|
2016-08-16 12:14:03 +00:00
|
|
|
toupper($1) == "COPY" {
|
|
|
|
for (i = 2; i < NF; i++) {
|
2021-08-26 13:21:30 +00:00
|
|
|
if ($i ~ /^--from=/) {
|
|
|
|
next
|
|
|
|
}
|
2016-08-16 12:14:03 +00:00
|
|
|
print $i
|
|
|
|
}
|
|
|
|
}
|
|
|
|
')
|
2021-08-26 13:21:30 +00:00
|
|
|
)
|
2016-08-16 12:14:03 +00:00
|
|
|
}
|
2015-07-25 18:42:58 +00:00
|
|
|
|
2021-08-26 13:21:30 +00:00
|
|
|
gawkParents='
|
|
|
|
{ cmd = toupper($1) }
|
|
|
|
cmd == "FROM" {
|
|
|
|
print $2
|
|
|
|
next
|
|
|
|
}
|
|
|
|
cmd == "COPY" {
|
|
|
|
for (i = 2; i < NF; i++) {
|
|
|
|
if ($i ~ /^--from=/) {
|
|
|
|
gsub(/^--from=/, "", $i)
|
|
|
|
print $i
|
|
|
|
next
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
'
|
2018-02-14 01:48:51 +00:00
|
|
|
|
2021-08-26 13:21:30 +00:00
|
|
|
getArches() {
|
|
|
|
local repo="$1"
|
|
|
|
shift
|
|
|
|
|
|
|
|
local parentRepoToArchesStr
|
|
|
|
parentRepoToArchesStr="$(
|
|
|
|
find -name 'Dockerfile' -exec gawk "$gawkParents" '{}' + |
|
|
|
|
sort -u |
|
|
|
|
gawk -v officialImagesUrl='https://github.com/docker-library/official-images/raw/master/library/' '
|
|
|
|
$1 !~ /^('"$repo"'|scratch|.*\/.*)(:|$)/ {
|
|
|
|
printf "%s%s\n", officialImagesUrl, $1
|
2018-02-14 01:48:51 +00:00
|
|
|
}
|
2021-08-26 13:21:30 +00:00
|
|
|
' |
|
|
|
|
xargs -r bashbrew cat --format '["{{ .RepoName }}:{{ .TagName }}"]="{{ join " " .TagEntry.Architectures }}"'
|
|
|
|
)"
|
|
|
|
eval "declare -g -A parentRepoToArches=( $parentRepoToArchesStr )"
|
2018-02-14 01:48:51 +00:00
|
|
|
}
|
|
|
|
getArches 'joomla'
|
|
|
|
|
2021-08-26 13:21:30 +00:00
|
|
|
# get the Joomla maintainers of these docker images
|
|
|
|
joomlaMaintainers="$(jq -cr '. | map(.firstname + " " + .lastname + " <" + .email + "> (@" + .github + ")") | join(",\n ")' maintainers.json)"
|
|
|
|
|
2016-08-16 12:14:03 +00:00
|
|
|
cat <<-EOH
|
2020-08-26 19:47:39 +00:00
|
|
|
# this file is generated via https://github.com/joomla-docker/docker-joomla/blob/$(fileCommit "$self")/$self
|
2016-08-16 12:14:03 +00:00
|
|
|
|
2021-08-26 13:21:30 +00:00
|
|
|
Maintainers: $joomlaMaintainers
|
2020-08-26 19:47:39 +00:00
|
|
|
GitRepo: https://github.com/joomla-docker/docker-joomla.git
|
2016-08-16 12:14:03 +00:00
|
|
|
EOH
|
|
|
|
|
|
|
|
# prints "$2$1$3$1...$N"
|
|
|
|
join() {
|
2021-08-26 13:21:30 +00:00
|
|
|
local sep="$1"
|
|
|
|
shift
|
|
|
|
local out
|
|
|
|
printf -v out "${sep//%/%%}%s" "$@"
|
|
|
|
echo "${out#$sep}"
|
2016-08-16 12:14:03 +00:00
|
|
|
}
|
2015-07-25 18:42:58 +00:00
|
|
|
|
2021-08-26 13:21:30 +00:00
|
|
|
for version; do
|
|
|
|
export version
|
|
|
|
# get this Joomla versions PHP versions
|
|
|
|
phpVersions="$(jq -r '.[env.version].phpVersions | map(@sh) | join(" ")' versions.json)"
|
|
|
|
eval "phpVersions=( $phpVersions )"
|
|
|
|
# get this Joomla versions default PHP version
|
|
|
|
defaultPhpVersion="$(jq -r '.[env.version].php' versions.json)"
|
|
|
|
# get this Joomla versions variants
|
|
|
|
variants="$(jq -r '.[env.version].variants | map(@sh) | join(" ")' versions.json)"
|
|
|
|
eval "variants=( $variants )"
|
|
|
|
# get this Joomla versions default variant
|
|
|
|
defaultVariant="$(jq -r '.[env.version].variant' versions.json)"
|
|
|
|
# get the Joomla versions full version eg: 4.0.0
|
|
|
|
fullVersion="$(jq -r '.[env.version].version' versions.json)"
|
|
|
|
# check if this Joomla version is a Release Candidate
|
|
|
|
rcVersion="${version%-rc}"
|
|
|
|
versionAliases=()
|
|
|
|
while [ "$fullVersion" != "$rcVersion" -a "${fullVersion%[.]*}" != "$fullVersion" ]; do
|
|
|
|
versionAliases+=($fullVersion)
|
|
|
|
fullVersion="${fullVersion%[.]*}"
|
|
|
|
done
|
|
|
|
# get all that aliases of this Joomla version
|
|
|
|
aliases="$(jq -r '.[env.version].aliases | map(@sh) | join(" ")' versions.json)"
|
|
|
|
eval "aliases=( $aliases )"
|
|
|
|
# add the short version an all aliases found
|
|
|
|
versionAliases+=(
|
|
|
|
$version
|
|
|
|
${aliases[@]:-}
|
|
|
|
)
|
|
|
|
|
|
|
|
for phpVersion in "${phpVersions[@]}"; do
|
|
|
|
phpVersion="php$phpVersion"
|
|
|
|
for variant in "${variants[@]}"; do
|
|
|
|
dir="$version/$phpVersion/$variant"
|
|
|
|
# check if the docker file exist, else skip
|
|
|
|
[ -f "$dir/Dockerfile" ] || continue
|
|
|
|
# get the commit hash from this docker file
|
|
|
|
commit="$(dirCommit "$dir")"
|
|
|
|
|
|
|
|
phpVersionAliases=("${versionAliases[@]/%/-$phpVersion}")
|
|
|
|
phpVersionAliases=("${phpVersionAliases[@]//latest-/}")
|
|
|
|
|
|
|
|
variantSuffixes=("$variant")
|
|
|
|
|
|
|
|
variantAliases=()
|
|
|
|
phpVersionVariantAliases=()
|
|
|
|
for variantSuffix in "${variantSuffixes[@]}"; do
|
|
|
|
variantAliases+=("${versionAliases[@]/%/-$variantSuffix}")
|
|
|
|
phpVersionVariantAliases+=("${phpVersionAliases[@]/%/-$variantSuffix}")
|
|
|
|
done
|
|
|
|
variantAliases=("${variantAliases[@]//latest-/}")
|
|
|
|
phpVersionVariantAliases=("${phpVersionVariantAliases[@]//latest-/}")
|
|
|
|
|
|
|
|
fullAliases=()
|
|
|
|
if [ "$phpVersion" = "php$defaultPhpVersion" ] && [ "$variant" = "$defaultVariant" ]; then
|
|
|
|
fullAliases+=("${versionAliases[@]}")
|
|
|
|
fullAliases+=("${variantAliases[@]}")
|
|
|
|
fullAliases+=("${phpVersionAliases[@]}")
|
|
|
|
fi
|
|
|
|
fullAliases+=("${phpVersionVariantAliases[@]}")
|
|
|
|
|
|
|
|
variantParents="$(gawk "$gawkParents" "$dir/Dockerfile")"
|
|
|
|
variantArches=
|
|
|
|
for variantParent in $variantParents; do
|
|
|
|
parentArches="${parentRepoToArches[$variantParent]:-}"
|
|
|
|
if [ -z "$parentArches" ]; then
|
|
|
|
continue
|
|
|
|
elif [ -z "$variantArches" ]; then
|
|
|
|
variantArches="$parentArches"
|
|
|
|
else
|
|
|
|
variantArches="$(
|
|
|
|
comm -12 \
|
|
|
|
<(xargs -n1 <<<"$variantArches" | sort -u) \
|
|
|
|
<(xargs -n1 <<<"$parentArches" | sort -u)
|
|
|
|
)"
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
echo
|
|
|
|
cat <<-EOE
|
|
|
|
Tags: $(join ', ' "${fullAliases[@]}")
|
|
|
|
Architectures: $(join ', ' $variantArches)
|
|
|
|
GitCommit: $commit
|
|
|
|
Directory: $dir
|
|
|
|
EOE
|
|
|
|
done
|
|
|
|
done
|
2015-07-25 18:42:58 +00:00
|
|
|
done
|