unifios-utilities/cni-plugins/05-install-cni-plugins.sh
Adam Bolsover 87b9f7dac6
Introduced checksums to cni-plugins (#178)
* Update 05-install-cni-plugins.sh

Added checksum checks for cni-plugin. Also allowed for specific version selection. Finally added a fallback to the last installed version.

* Update 05-install-cni-plugins.sh

moved the net.d setup from dns to cni-plugin, so that all the function of cni are in one place.

* Update 10-dns.sh

moved conf files from dns to cni-plugin

* Update 05-install-cni-plugins.sh

Fixed some comments

* Update 05-install-cni-plugins.sh

Fix comments
2021-07-02 22:32:41 -07:00

137 lines
4.7 KiB
Bash

#!/bin/sh
## Set the version of cni plugin to use. It will revert to latest if an invalid version is given, and the installer will use the last installed version if that fails.
# Examples of valid version code would be "latest", "v0.9.1" and "v0.9.0".
CNI_PLUGIN_VER=latest
# location of the CNI Plugin cached tar files
CNI_CACHE="/mnt/data/.cache/cni-plugins"
# location of the conf files to go in the net.d folder of the cni-plugin directory
CNI_NETD="/mnt/data/podman/cni"
# The checksum to use. For CNI Plugin sha1, sha256 and sha512 are available.
CNI_CHECKSUM="sha256"
# Maximum number of loops to attempt to download the plugin if required - setting a 0 or negative value will reinstalled the currently installed version (if in cache)
MAX_TRIES=3
mkdir -p "${CNI_CACHE}" "${CNI_NETD}"
# The script will attempt to use the nominated version first, and falls back to latest version if that fails
if [ "$#" -eq 0 ]; then
set ${CNI_PLUGIN_VER}
fi
# Insert conf files for podman networks into the net.d folder
populate_netd()
{
for file in "${CNI_NETD}"/*.conflist
do
if [ -f "$file" ]; then
ln -fs "$file" "/etc/cni/net.d/$(basename "$file")"
fi
done
}
# This function checks a valid checksum has been selected. It requires the checksum is given as the first argument
checksum_check()
{
if [ "$#" -eq 0 ]; then
echo "no arguement given"
return 2
fi
case $1 in
"sha1" | "sha256" | "sha512")
return 0;
;;
*)
echo "Incorrect checksum selection"
return 1;
;;
esac
}
# Test a file against it's checksum - 1 is the checksum type, 2 is the file to test and 3 is the checksum file
checksum_test()
{
if [ ! -f ${2} ] || [ ! -f ${3} ]; then
echo "file does not exist"
return 2
fi
if ! checksum_check ${1}; then
echo "An incorrect checksum has been used"
return 3
fi
value1=$(${1}sum ${2} | awk '{print $1}')
value2=$(cat ${3} | awk '{print $1}')
if [ "${value1}" = "${value2}" ]; then
return 0
else
return 1
fi
}
# Install function - it requires the first argument to be the version to install
install()
{
if [ "$#" -eq 0 ]; then
set "installed"
fi
if [ -f "${CNI_CACHE}/cni-plugins-linux-arm64-$1.tgz" ]; then
echo "Pouring ${CNI_CACHE}/cni-plugins-linux-arm64-$1.tgz"
rm -rf /opt/cni/bin
mkdir -p /opt/cni/bin
tar -xzC /opt/cni/bin -f "${CNI_CACHE}/cni-plugins-linux-arm64-$1.tgz"
# Create a link to installed version as fallback option
if [ "$1" != "installed" ]; then
ln -sf "${CNI_CACHE}/${CNI_TAR}" "${CNI_CACHE}/cni-plugins-linux-arm64-installed.tgz"
ln -sf "${CNI_CACHE}/${CNI_TAR}.${CNI_CHECKSUM}" "${CNI_CACHE}/cni-plugins-linux-arm64-installed.tgz.${CNI_CHECKSUM}"
fi
return 0
fi
echo "No CNI Plugin available to install"
return 1
}
# Download function - the first argument is the version to download. It will default to latest if a invalid option is given.
download()
{
# To stop infinite recursion
if [ ${MAX_TRIES} -lt 1 ]; then
# install the last installed version if latest and specified version have both failed.
install
return 1
fi
# This defaults to latest, in case the specified download doesn't work.
if [ "$#" -eq 0 ]; then
set latest
fi
# Find the corect parameters
set "$(basename "$(curl -fsSLo /dev/null -w "%{url_effective}" https://github.com/containernetworking/plugins/releases/$1)")" "$@"
CNI_TAR="cni-plugins-linux-arm64-$1.tgz"
URL="https://github.com/containernetworking/plugins/releases/download/$1/${CNI_TAR}"
# Cache a checksum for the file
if [ ! -f "${CNI_CACHE}/${CNI_TAR}.${CNI_CHECKSUM}" ]; then
echo "Downloading ${URL}.${CNI_CHECKSUM}"
curl -fsSLo "/tmp/${CNI_TAR}.${CNI_CHECKSUM}" "${URL}.${CNI_CHECKSUM}"
mv "/tmp/${CNI_TAR}.${CNI_CHECKSUM}" "${CNI_CACHE}/${CNI_TAR}.${CNI_CHECKSUM}"
fi
# Cache the tar file
if [ ! -f "${CNI_CACHE}/${CNI_TAR}" ]; then
echo "Downloading ${URL}"
curl -fsSLo "/tmp/${CNI_TAR}" "${URL}"
mv "/tmp/${CNI_TAR}" "${CNI_CACHE}/${CNI_TAR}"
fi
# Symbolic link to latest
if [ "$1" != "$2" ]; then
ln -sf "${CNI_CACHE}/${CNI_TAR}" "${CNI_CACHE}/cni-plugins-linux-arm64-$2.tgz"
ln -sf "${CNI_CACHE}/${CNI_TAR}.${CNI_CHECKSUM}" "${CNI_CACHE}/cni-plugins-linux-arm64-$2.tgz.${CNI_CHECKSUM}"
fi
# Test integrity of the files
if ! checksum_test ${CNI_CHECKSUM} ${CNI_CACHE}/${CNI_TAR} ${CNI_CACHE}/${CNI_TAR}.${CNI_CHECKSUM}; then
echo "Corrupt tar file, deleting tar and checksum"
rm -f "${CNI_CACHE}/${CNI_TAR}" "${CNI_CACHE}/${CNI_TAR}.${CNI_CHECKSUM}"
MAX_TRIES=${(MAX_TRIES - 1)}
# try again on fallback of latest until retries are exhausted
download
else
install $1 $2
return 0
fi
}
download
populate_netd