2016-09-02 15:11:38 +02:00
|
|
|
#!/bin/bash
|
2017-04-26 22:14:40 +02:00
|
|
|
set -Eeuo pipefail
|
2016-09-02 15:11:38 +02:00
|
|
|
|
2018-03-21 14:01:49 +01:00
|
|
|
declare -A release_channel=(
|
2020-08-27 23:29:00 +02:00
|
|
|
[stable]='19.0.2'
|
|
|
|
[production]='18.0.8'
|
2018-03-21 14:01:49 +01:00
|
|
|
)
|
|
|
|
|
2017-01-13 10:31:57 +01:00
|
|
|
self="$(basename "$BASH_SOURCE")"
|
2016-09-02 15:11:38 +02:00
|
|
|
cd "$(dirname "$(readlink -f "$BASH_SOURCE")")"
|
|
|
|
|
2017-01-13 10:31:57 +01:00
|
|
|
# Get the most recent commit which modified any of "$@".
|
|
|
|
fileCommit() {
|
2018-10-01 17:29:15 +02:00
|
|
|
commit="$(git log -1 --format='format:%H' HEAD -- "$@")"
|
|
|
|
if [ -z "$commit" ]; then
|
|
|
|
# return some valid sha1 hash to make bashbrew happy
|
|
|
|
echo '0000000000000000000000000000000000000000'
|
|
|
|
else
|
|
|
|
echo "$commit"
|
|
|
|
fi
|
2017-01-13 10:31:57 +01:00
|
|
|
}
|
2016-09-02 15:11:38 +02:00
|
|
|
|
2017-01-13 10:31:57 +01:00
|
|
|
# Get the most recent commit which modified "$1/Dockerfile" or any file that
|
|
|
|
# the Dockerfile copies into the rootfs (with COPY).
|
|
|
|
dockerfileCommit() {
|
|
|
|
local dir="$1"; shift
|
|
|
|
(
|
|
|
|
cd "$dir";
|
|
|
|
fileCommit Dockerfile \
|
2018-03-13 10:58:19 +01:00
|
|
|
$(awk '
|
2017-01-13 10:31:57 +01:00
|
|
|
toupper($1) == "COPY" {
|
|
|
|
for (i = 2; i < NF; i++)
|
|
|
|
print $i;
|
|
|
|
}
|
2018-03-13 10:58:19 +01:00
|
|
|
' Dockerfile)
|
2017-01-13 10:31:57 +01:00
|
|
|
)
|
|
|
|
}
|
2016-09-02 15:11:38 +02:00
|
|
|
|
2018-02-14 01:19:07 +01:00
|
|
|
getArches() {
|
|
|
|
local repo="$1"; shift
|
|
|
|
local officialImagesUrl='https://github.com/docker-library/official-images/raw/master/library/'
|
|
|
|
|
|
|
|
eval "declare -g -A parentRepoToArches=( $(
|
2018-02-14 02:44:38 +01:00
|
|
|
find -maxdepth 3 -name 'Dockerfile' -exec awk '
|
2018-02-14 01:19:07 +01:00
|
|
|
toupper($1) == "FROM" && $2 !~ /^('"$repo"'|scratch|microsoft\/[^:]+)(:|$)/ {
|
2020-03-09 15:03:05 +01:00
|
|
|
print "'"$officialImagesUrl"'" $2
|
2018-02-14 01:19:07 +01:00
|
|
|
}
|
|
|
|
' '{}' + \
|
|
|
|
| sort -u \
|
|
|
|
| xargs bashbrew cat --format '[{{ .RepoName }}:{{ .TagName }}]="{{ join " " .TagEntry.Architectures }}"'
|
|
|
|
) )"
|
|
|
|
}
|
|
|
|
getArches 'nextcloud'
|
|
|
|
|
2017-01-13 10:31:57 +01:00
|
|
|
# Header.
|
|
|
|
cat <<-EOH
|
|
|
|
# This file is generated via https://github.com/nextcloud/docker/blob/$(fileCommit "$self")/$self
|
|
|
|
|
2017-01-21 16:31:10 +01:00
|
|
|
Maintainers: Nextcloud <docker@nextcloud.com> (@nextcloud)
|
2017-01-13 10:31:57 +01:00
|
|
|
GitRepo: https://github.com/nextcloud/docker.git
|
|
|
|
EOH
|
|
|
|
|
|
|
|
# prints "$2$1$3$1...$N"
|
|
|
|
join() {
|
|
|
|
local sep="$1"; shift
|
|
|
|
local out; printf -v out "${sep//%/%%}%s" "$@"
|
|
|
|
echo "${out#$sep}"
|
|
|
|
}
|
|
|
|
|
2020-03-12 00:53:13 +01:00
|
|
|
latest=$( cat latest.txt )
|
2018-03-13 10:58:19 +01:00
|
|
|
|
2017-01-13 10:31:57 +01:00
|
|
|
# Generate each of the tags.
|
|
|
|
versions=( */ )
|
|
|
|
versions=( "${versions[@]%/}" )
|
|
|
|
for version in "${versions[@]}"; do
|
|
|
|
variants=( $version/*/ )
|
|
|
|
variants=( $(for variant in "${variants[@]%/}"; do
|
|
|
|
echo "$(basename "$variant")"
|
|
|
|
done) )
|
|
|
|
for variant in "${variants[@]}"; do
|
|
|
|
commit="$(dockerfileCommit "$version/$variant")"
|
2018-03-13 10:58:19 +01:00
|
|
|
fullversion_with_extension="$( awk '$1 == "ENV" && $2 == "NEXTCLOUD_VERSION" { print $3; exit }' "$version/$variant/Dockerfile" )"
|
|
|
|
fullversion="$( echo "$fullversion_with_extension" | grep -oE '[[:digit:]]+(\.[[:digit:]]+){2}')"
|
|
|
|
|
|
|
|
versionAliases=( )
|
|
|
|
versionPostfix=""
|
|
|
|
if [ "$fullversion_with_extension" != "$fullversion" ]; then
|
|
|
|
versionAliases=( "$fullversion_with_extension" )
|
2019-03-12 13:47:17 +01:00
|
|
|
versionPostfix="-$( echo "$fullversion_with_extension" | tr '[:upper:]' '[:lower:]' | grep -oE '(beta|rc|alpha)')"
|
2018-03-13 10:58:19 +01:00
|
|
|
fi
|
2017-01-13 10:31:57 +01:00
|
|
|
|
2018-03-13 10:58:19 +01:00
|
|
|
versionAliases+=( "$fullversion$versionPostfix" "${fullversion%.*}$versionPostfix" "${fullversion%.*.*}$versionPostfix" )
|
|
|
|
if [ "$fullversion_with_extension" = "$latest" ]; then
|
2017-01-13 10:31:57 +01:00
|
|
|
versionAliases+=( "latest" )
|
|
|
|
fi
|
|
|
|
|
2018-03-21 14:01:49 +01:00
|
|
|
for channel in "${!release_channel[@]}"; do
|
|
|
|
if [ "$fullversion_with_extension" = "${release_channel[$channel]}" ]; then
|
|
|
|
versionAliases+=( "$channel" )
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
2017-01-13 10:31:57 +01:00
|
|
|
variantAliases=( "${versionAliases[@]/%/-$variant}" )
|
|
|
|
variantAliases=( "${variantAliases[@]//latest-}" )
|
|
|
|
|
|
|
|
if [ "$variant" = "apache" ]; then
|
|
|
|
variantAliases+=( "${versionAliases[@]}" )
|
|
|
|
fi
|
|
|
|
|
2018-02-14 01:19:07 +01:00
|
|
|
variantParent="$(awk 'toupper($1) == "FROM" { print $2 }' "$version/$variant/Dockerfile")"
|
|
|
|
variantArches="${parentRepoToArches[$variantParent]}"
|
|
|
|
|
2017-01-13 10:31:57 +01:00
|
|
|
cat <<-EOE
|
|
|
|
|
|
|
|
Tags: $(join ', ' "${variantAliases[@]}")
|
2018-02-14 01:19:07 +01:00
|
|
|
Architectures: $(join ', ' $variantArches)
|
2017-01-13 10:31:57 +01:00
|
|
|
GitCommit: $commit
|
|
|
|
Directory: $version/$variant
|
|
|
|
EOE
|
|
|
|
done
|
|
|
|
done
|