Merge branch 'add-deb-and-rpm-repos' into 'main'

Publish generic deb and rpm repos.

See merge request nvidia/container-toolkit/container-toolkit!460
This commit is contained in:
Evan Lezar 2023-08-10 13:35:12 +00:00
commit 37ac294a11
2 changed files with 98 additions and 81 deletions

View File

@ -8,56 +8,60 @@
set -x -e set -x -e
function deb-sign { function deb-sign {
local last_found local last_found
for r in "$@"; do for r in "$@"; do
if [ -f "./${r}" ]; then if [ -f "./${r}" ]; then
last_found=${r} last_found=${r}
fi fi
done done
if [[ -z ${last_found} ]]; then if [[ -z ${last_found} ]]; then
echo "WARNING: No expected package found in $(pwd); skipping signing of repo;" echo "WARNING: No expected package found in $(pwd); skipping signing of repo;"
return return
fi fi
apt-ftparchive packages . \ apt-ftparchive packages . \
| tee Packages \ | tee Packages \
| xz > Packages.xz | xz > Packages.xz
apt-ftparchive -c repo.conf release . \ apt-ftparchive -c repo.conf release . \
| gpg --batch --yes --expert --clearsign \ | gpg --batch --yes --expert --clearsign \
--armor \ --armor \
--no-emit-version \ --no-emit-version \
--no-comments \ --no-comments \
--personal-digest-preferences sha512 \ --personal-digest-preferences sha512 \
--local-user "${GPG_LOCAL_USER}" \ --local-user "${GPG_LOCAL_USER}" \
> InRelease > InRelease
} }
function rpm-sign { function rpm-sign {
for r in "$@"; do for r in "$@"; do
if [ -f "./${r}" ]; then if [ -f "./${r}" ]; then
rpmsign --addsign --key-id A04EA552 --digest-algo=sha512 "${r}" rpmsign --addsign --key-id A04EA552 --digest-algo=sha512 "${r}"
fi fi
done done
createrepo -v --no-database -s sha512 --compress-type xz --revision "1.0" . createrepo -v --no-database -s sha512 --compress-type xz --revision "1.0" .
gpg2 --batch --yes --expert --sign --detach-sign \ gpg2 --batch --yes --expert --sign --detach-sign \
--armor \ --armor \
--no-emit-version \ --no-emit-version \
--no-comments --personal-digest-preferences sha512 \ --no-comments --personal-digest-preferences sha512 \
--local-user "${GPG_LOCAL_USER}" \ --local-user "${GPG_LOCAL_USER}" \
repodata/repomd.xml repodata/repomd.xml
} }
function sign() { function sign() {
local target=$1 local target=$1
local dst_root=$2 local dst_root=$2
local by_package_type=$3
local src_dist=${target%-*} local src_dist=${target%-*}
local dist=${src_dist/amazonlinux/amzn} local dst_dist=${src_dist/amazonlinux/amzn}
local pkg_type=unknown
local arch=${target##*-}
local dst_arch=${arch}
local pkg_type
case ${src_dist} in case ${src_dist} in
amazonlinux*) pkg_type=rpm amazonlinux*) pkg_type=rpm
;; ;;
centos*) pkg_type=rpm centos* | rpm) pkg_type=rpm
;; ;;
debian*) pkg_type=deb debian*) pkg_type=deb
;; ;;
@ -65,33 +69,47 @@ function sign() {
;; ;;
opensuse-leap*) pkg_type=rpm opensuse-leap*) pkg_type=rpm
;; ;;
ubuntu*) pkg_type=deb ubuntu* | deb) pkg_type=deb
arch=${arch//ppc64le/ppc64el}
;; ;;
*) echo "ERROR: unexpected distribution ${src_dist}" *) echo "ERROR: unexpected distribution ${src_dist}"
;; ;;
esac esac
local arch=${target##*-} if [[ x"${by_package_type}" == x"true" ]]; then
case ${src_dist} in dst_dist=${pkg_type}
ubuntu*) arch=${arch//ppc64le/ppc64el} fi
esac
local dst=${dst_root}/${dist}/${arch} local dst=${dst_root}/${dst_dist}/${arch}
if [[ ! -d ${dst} ]]; then if [[ ! -d ${dst} ]]; then
echo "Directory ${dst} not found. Skipping" echo "Directory ${dst} not found. Skipping"
return return
fi fi
cd "${dst}" cd "${dst}"
if [[ -f "/etc/debian_version" ]]; then if [[ -f "/etc/debian_version" ]]; then
[[ "${pkg_type}" == "deb" ]] && deb-sign ${ALL_DEBS} [[ "${pkg_type}" == "deb" ]] && deb-sign ${ALL_DEBS}
else else
[[ "${pkg_type}" == "rpm" ]] && rpm-sign ${ALL_RPMS} [[ "${pkg_type}" == "rpm" ]] && rpm-sign ${ALL_RPMS}
fi fi
cd - cd -
} }
for target in ${TARGETS[@]}; do for target in ${TARGETS[@]}; do
sign "${target}" "$(pwd)" echo "checking target=${target}"
by_package_type=
case ${target} in
ubuntu18.04-* | centos7-*)
by_package_type="true"
;;
centos8-ppc64le)
by_package_type="false"
;;
*)
echo "Skipping target ${target}"
continue
;;
esac
sign "${target}" "$(pwd)" ${by_package_type}
done done

View File

@ -48,7 +48,7 @@ SHA=$(git rev-parse --short=8 ${REFERENCE})
IMAGE_NAME="registry.gitlab.com/nvidia/container-toolkit/container-toolkit/staging/container-toolkit" IMAGE_NAME="registry.gitlab.com/nvidia/container-toolkit/container-toolkit/staging/container-toolkit"
IMAGE_TAG=${SHA}-packaging IMAGE_TAG=${SHA}-packaging
VERSION="$(get_version_from_image ${IMAGE_NAME}:${IMAGE_TAG} ${SHA})" : ${VERSION:="$(get_version_from_image ${IMAGE_NAME}:${IMAGE_TAG} ${SHA})"}
REPO="experimental" REPO="experimental"
if [[ ${VERSION/rc./} == ${VERSION} ]]; then if [[ ${VERSION/rc./} == ${VERSION} ]]; then
@ -83,11 +83,15 @@ function sync() {
local target=$1 local target=$1
local src_root=$2 local src_root=$2
local dst_root=$3 local dst_root=$3
local by_package_type=$4
local src_dist=${target%-*} local src_dist=${target%-*}
local dst_dist=${src_dist/amazonlinux/amzn} local dst_dist=${src_dist/amazonlinux/amzn}
local pkg_type local pkg_type=unknown
local arch=${target##*-}
local dst_arch=${arch}
case ${src_dist} in case ${src_dist} in
amazonlinux*) pkg_type=rpm amazonlinux*) pkg_type=rpm
;; ;;
@ -100,28 +104,17 @@ function sync() {
opensuse-leap*) pkg_type=rpm opensuse-leap*) pkg_type=rpm
;; ;;
ubuntu*) pkg_type=deb ubuntu*) pkg_type=deb
dst_arch=${arch//ppc64le/ppc64el}
;; ;;
*) echo "ERROR: unexpected distribution ${src_dist}" *) echo "ERROR: unexpected distribution ${src_dist}"
exit 1 exit 1
;; ;;
esac esac
if [[ $# -ge 4 && $4 == "package_type" ]] ; then if [[ x"${by_package_type}" == x"true" ]]; then
if [[ "${src_dist}" != "ubuntu18.04" && "${src_dist}" != "centos7" ]]; then dst_dist=${pkg_type}
echo "Package type repos require ubuntu18.04 or centos7 as the source"
echo "skipping"
return
fi
dst_dist=$pkg_type
fi fi
local arch=${target##*-}
local dst_arch=${arch}
case ${src_dist} in
ubuntu*) dst_arch=${arch//ppc64le/ppc64el}
esac
local src=${src_root}/${src_dist}/${arch} local src=${src_root}/${src_dist}/${arch}
local dst=${dst_root}/${dst_dist}/${dst_arch} local dst=${dst_root}/${dst_dist}/${dst_arch}
@ -173,20 +166,27 @@ if [[ x"${_current_branch}" != x"gh-pages" ]]; then
fi fi
: ${UPSTREAM_REMOTE:="origin"} : ${UPSTREAM_REMOTE:="origin"}
_remote_name=$( git remote -v | grep "git@gitlab.com:nvidia/container-toolkit/libnvidia-container.git (push)" | cut -d$'\t' -f1 )
if [[ x"${_remote_name}" != x"${UPSTREAM_REMOTE}" ]]; then
echo "Identified ${_remote_name} as git@gitlab.com:nvidia/container-toolkit/libnvidia-container.git remote."
echo "Set UPSTREAM_REMOTE=${_remote_name} instead of ${UPSTREAM_REMOTE}"
fi
: ${UPSTREAM_REFERENCE:="${UPSTREAM_REMOTE}/gh-pages"} : ${UPSTREAM_REFERENCE:="${UPSTREAM_REMOTE}/gh-pages"}
git -C ${PACKAGE_REPO_ROOT} reset --hard ${UPSTREAM_REFERENCE} git -C ${PACKAGE_REPO_ROOT} reset --hard ${UPSTREAM_REFERENCE}
git -C ${PACKAGE_REPO_ROOT} clean -fdx ${REPO} git -C ${PACKAGE_REPO_ROOT} clean -fdx ${REPO}
for target in ${targets[@]}; do for target in ${targets[@]}; do
sync ${target} ${PACKAGE_CACHE}/packages ${PACKAGE_REPO_ROOT}/${REPO} echo "checking target=${target}"
# We also create a `package_type` repo; internally we skip this for non-ubuntu18.04 or centos7 distributions by_package_type=
sync ${target} ${PACKAGE_CACHE}/packages ${PACKAGE_REPO_ROOT}/${REPO} "package_type" case ${target} in
ubuntu18.04-* | centos7-*)
by_package_type="true"
;;
centos8-ppc64le)
by_package_type="false"
;;
*)
echo "Skipping target ${target}"
continue
;;
esac
sync ${target} ${PACKAGE_CACHE}/packages ${PACKAGE_REPO_ROOT}/${REPO} ${by_package_type}
done done
git -C ${PACKAGE_REPO_ROOT} add ${REPO} git -C ${PACKAGE_REPO_ROOT} add ${REPO}
@ -237,7 +237,6 @@ function sign() {
gpg --import /keys/sub.key; gpg --import /keys/sub.key;
/helpers/packages-sign-all.sh; /helpers/packages-sign-all.sh;
" "
} }
sign deb sign deb