0
0
Fork 0
mirror of https://github.com/nextcloud/docker.git synced 2025-01-21 21:23:53 +01:00
nextcloud-docker/generate-stackbrew-library.sh

117 lines
3.3 KiB
Bash
Raw Normal View History

2016-09-02 15:11:38 +02:00
#!/bin/bash
set -Eeuo pipefail
2016-09-02 15:11:38 +02:00
2021-01-14 18:30:16 +01:00
stable_channel='20.0.5'
self="$(basename "$BASH_SOURCE")"
2016-09-02 15:11:38 +02:00
cd "$(dirname "$(readlink -f "$BASH_SOURCE")")"
# Get the most recent commit which modified any of "$@".
fileCommit() {
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
}
2016-09-02 15:11:38 +02: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 '
toupper($1) == "COPY" {
for (i = 2; i < NF; i++)
print $i;
}
2018-03-13 10:58:19 +01:00
' Dockerfile)
)
}
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'
# 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)
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}"
}
latest=$( cat latest.txt )
2018-03-13 10:58:19 +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" )
versionPostfix="-$( echo "$fullversion_with_extension" | tr '[:upper:]' '[:lower:]' | grep -oE '(beta|rc|alpha)')"
2018-03-13 10:58:19 +01:00
fi
2018-03-13 10:58:19 +01:00
versionAliases+=( "$fullversion$versionPostfix" "${fullversion%.*}$versionPostfix" "${fullversion%.*.*}$versionPostfix" )
if [ "$fullversion_with_extension" = "$latest" ]; then
versionAliases+=( "latest" )
fi
if [ "$fullversion_with_extension" = "$stable_channel" ]; then
versionAliases+=( "stable" "production" )
fi
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]}"
cat <<-EOE
Tags: $(join ', ' "${variantAliases[@]}")
2018-02-14 01:19:07 +01:00
Architectures: $(join ', ' $variantArches)
GitCommit: $commit
Directory: $version/$variant
EOE
done
done