add scripts to install cli tools
Signed-off-by: Poor12 <shentiecheng@huawei.com>
This commit is contained in:
parent
5c46c7caef
commit
1265b4e4b4
|
@ -0,0 +1,260 @@
|
||||||
|
#!/usr/bin/env bash
|
||||||
|
set -o errexit
|
||||||
|
set -o nounset
|
||||||
|
set -o pipefail
|
||||||
|
|
||||||
|
# This script installs karmada cli tools to the install location you want.
|
||||||
|
# Usage: ./install-cli.sh <install_cli_type>
|
||||||
|
# Example:
|
||||||
|
|
||||||
|
# ./install-cli.sh
|
||||||
|
# will install the latest karmadactl to /usr/local/bin
|
||||||
|
|
||||||
|
# ./install-cli.sh kubectl-karmada
|
||||||
|
# will install the latest kubectl-karmada to /usr/local/bin
|
||||||
|
|
||||||
|
# export INSTALL_CLI_VERSION=1.3.0
|
||||||
|
# ./install-cli.sh
|
||||||
|
# will install the 1.3.0 karmadactl to /usr/local/bin
|
||||||
|
|
||||||
|
# INSTALL_CLI_TYPE supports 'karmadactl' or 'kubectl-karmada'.
|
||||||
|
INSTALL_CLI_TYPE=${1:-"karmadactl"}
|
||||||
|
# INSTALL_CLI_VERSION represents which version should be installed.
|
||||||
|
# Defaults to 'latest' means latest release version.
|
||||||
|
INSTALL_CLI_VERSION=${INSTALL_CLI_VERSION:-"latest"}
|
||||||
|
# INSTALL_LOCATION represents where to put the CLI.
|
||||||
|
INSTALL_LOCATION=${INSTALL_LOCATION:-"/usr/local/bin"}
|
||||||
|
GITHUB_REPO="karmada-io/karmada"
|
||||||
|
|
||||||
|
# Helper functions for logs
|
||||||
|
info() {
|
||||||
|
echo '[INFO] ' "$@"
|
||||||
|
}
|
||||||
|
|
||||||
|
warn() {
|
||||||
|
echo '[WARN] ' "$@" >&2
|
||||||
|
}
|
||||||
|
|
||||||
|
fatal() {
|
||||||
|
echo '[ERROR] ' "$@" >&2
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
# Set os, fatal if operating system not supported
|
||||||
|
setup_verify_os() {
|
||||||
|
if [[ -z "${OS-}" ]]; then
|
||||||
|
OS=$(uname)
|
||||||
|
fi
|
||||||
|
case ${OS} in
|
||||||
|
Darwin)
|
||||||
|
OS=darwin
|
||||||
|
;;
|
||||||
|
Linux)
|
||||||
|
OS=linux
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
fatal "Unsupported operating system ${OS}"
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
# Set arch, fatal if architecture not supported
|
||||||
|
setup_verify_arch() {
|
||||||
|
if [[ -z "${ARCH-}" ]]; then
|
||||||
|
ARCH=$(uname -m)
|
||||||
|
fi
|
||||||
|
case ${ARCH} in
|
||||||
|
arm64|aarch64|armv8l)
|
||||||
|
ARCH=arm64
|
||||||
|
;;
|
||||||
|
amd64|x86_64)
|
||||||
|
ARCH=amd64
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
fatal "Unsupported architecture ${ARCH}"
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
# Set cli tools, install karmadactl by default, fatal if cli tool not supported
|
||||||
|
setup_install_cli() {
|
||||||
|
case ${INSTALL_CLI_TYPE} in
|
||||||
|
karmadactl|kubectl-karmada)
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
fatal "Unsupported cli tool ${INSTALL_CLI_TYPE}"
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
# Verify existence of downloader executable
|
||||||
|
verify_downloader() {
|
||||||
|
# Return failure if it doesn't exist or is no executable
|
||||||
|
[[ -x "$(which "$1")" ]] || return 1
|
||||||
|
|
||||||
|
# Set verified executable as our downloader program and return success
|
||||||
|
DOWNLOADER=$1
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
# Create tempory directory and cleanup when done
|
||||||
|
setup_tmp() {
|
||||||
|
TMP_DIR=$(mktemp -d -t "${INSTALL_CLI_TYPE}"-install.XXXXXXXXXX)
|
||||||
|
TMP_METADATA="${TMP_DIR}/${INSTALL_CLI_TYPE}.json"
|
||||||
|
TMP_HASH="${TMP_DIR}/${INSTALL_CLI_TYPE}.hash"
|
||||||
|
TMP_BIN="${TMP_DIR}/${INSTALL_CLI_TYPE}.tgz"
|
||||||
|
cleanup() {
|
||||||
|
local code=$?
|
||||||
|
rm -rf "${TMP_DIR}" || true
|
||||||
|
exit ${code}
|
||||||
|
}
|
||||||
|
trap cleanup INT EXIT
|
||||||
|
}
|
||||||
|
|
||||||
|
# Find version from Github metadata
|
||||||
|
get_release_version() {
|
||||||
|
if [[ "${INSTALL_CLI_VERSION-}" != "latest" ]]; then
|
||||||
|
SUFFIX_URL="tags/v${INSTALL_CLI_VERSION}"
|
||||||
|
else
|
||||||
|
SUFFIX_URL="latest"
|
||||||
|
fi
|
||||||
|
|
||||||
|
METADATA_URL="https://api.github.com/repos/${GITHUB_REPO}/releases/${SUFFIX_URL}"
|
||||||
|
|
||||||
|
info "Downloading metadata ${METADATA_URL}"
|
||||||
|
download "${TMP_METADATA}" "${METADATA_URL}"
|
||||||
|
|
||||||
|
VERSION_KARMADA=$(grep '"tag_name":' "${TMP_METADATA}" | sed -E 's/.*"([^"]+)".*/\1/' | cut -c 2-)
|
||||||
|
if [[ -n "${VERSION_KARMADA}" ]]; then
|
||||||
|
info "Using ${VERSION_KARMADA} as release"
|
||||||
|
else
|
||||||
|
fatal "Unable to determine release version"
|
||||||
|
fi
|
||||||
|
|
||||||
|
ret=0
|
||||||
|
vercomp ${VERSION_KARMADA} 1.2.0 || ret=$?
|
||||||
|
if [[ $ret -eq 2 ]]; then
|
||||||
|
fatal "Installation of cli tools before version 1.2.0 is not supported"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Download from file from URL
|
||||||
|
download() {
|
||||||
|
[[ $# -eq 2 ]] || fatal 'download needs exactly 2 arguments'
|
||||||
|
|
||||||
|
ret=0
|
||||||
|
case $DOWNLOADER in
|
||||||
|
curl)
|
||||||
|
curl -o "$1" -sfL "$2" || ret=$?
|
||||||
|
;;
|
||||||
|
wget)
|
||||||
|
wget -qO "$1" "$2" || ret=$?
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
fatal "Incorrect executable '${DOWNLOADER}'"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# Abort if download command failed
|
||||||
|
[[ $ret -eq 0 ]] || fatal 'Download failed'
|
||||||
|
}
|
||||||
|
|
||||||
|
# Version comparison
|
||||||
|
# Returns 0 on '=', 1 on '>', and 2 on '<'.
|
||||||
|
# Ref: https://stackoverflow.com/a/4025065
|
||||||
|
vercomp () {
|
||||||
|
if [[ $1 == $2 ]]
|
||||||
|
then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
local IFS=.
|
||||||
|
local i ver1=($1) ver2=($2)
|
||||||
|
# fill empty fields in ver1 with zeros
|
||||||
|
for ((i=${#ver1[@]}; i<${#ver2[@]}; i++))
|
||||||
|
do
|
||||||
|
ver1[i]=0
|
||||||
|
done
|
||||||
|
for ((i=0; i<${#ver1[@]}; i++))
|
||||||
|
do
|
||||||
|
if [[ -z ${ver2[i]} ]]
|
||||||
|
then
|
||||||
|
# fill empty fields in ver2 with zeros
|
||||||
|
ver2[i]=0
|
||||||
|
fi
|
||||||
|
if ((10#${ver1[i]} > 10#${ver2[i]}))
|
||||||
|
then
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
if ((10#${ver1[i]} < 10#${ver2[i]}))
|
||||||
|
then
|
||||||
|
return 2
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
# Download hash from Github URL
|
||||||
|
download_hash() {
|
||||||
|
HASH_URL="https://github.com/${GITHUB_REPO}/releases/download/v${VERSION_KARMADA}/${INSTALL_CLI_TYPE}-${OS}-${ARCH}.tgz.sha256"
|
||||||
|
|
||||||
|
info "Downloading hash ${HASH_URL}"
|
||||||
|
download "${TMP_HASH}" "${HASH_URL}"
|
||||||
|
HASH_EXPECTED=$(grep "${INSTALL_CLI_TYPE}-${OS}-${ARCH}.tgz" "${TMP_HASH}")
|
||||||
|
HASH_EXPECTED=${HASH_EXPECTED%%[[:blank:]]*}
|
||||||
|
}
|
||||||
|
|
||||||
|
# Download binary from Github URL
|
||||||
|
download_binary() {
|
||||||
|
BIN_URL="https://github.com/${GITHUB_REPO}/releases/download/v${VERSION_KARMADA}/${INSTALL_CLI_TYPE}-${OS}-${ARCH}.tgz"
|
||||||
|
info "Downloading binary ${BIN_URL}"
|
||||||
|
download "${TMP_BIN}" "${BIN_URL}"
|
||||||
|
}
|
||||||
|
|
||||||
|
compute_sha256sum() {
|
||||||
|
cmd=$(which sha256sum shasum | head -n 1)
|
||||||
|
case $(basename "$cmd") in
|
||||||
|
sha256sum)
|
||||||
|
sha256sum "$1" | cut -f 1 -d ' '
|
||||||
|
;;
|
||||||
|
shasum)
|
||||||
|
shasum -a 256 "$1" | cut -f 1 -d ' '
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
fatal "Can not find sha256sum or shasum to compute checksum"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
# Verify downloaded binary hash
|
||||||
|
verify_binary() {
|
||||||
|
info "Verifying binary download"
|
||||||
|
HASH_BIN=$(compute_sha256sum "${TMP_BIN}")
|
||||||
|
HASH_BIN=${HASH_BIN%%[[:blank:]]*}
|
||||||
|
if [[ "${HASH_EXPECTED}" != "${HASH_BIN}" ]]; then
|
||||||
|
fatal "Download sha256 does not match ${HASH_EXPECTED}, got ${HASH_BIN}"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Setup permissions and move binary
|
||||||
|
setup_binary() {
|
||||||
|
info "Installing ${INSTALL_CLI_TYPE} to ${INSTALL_LOCATION}/${INSTALL_CLI_TYPE}"
|
||||||
|
tar -xzof "${TMP_BIN}" -C "${TMP_DIR}" --no-same-owner
|
||||||
|
|
||||||
|
local CMD_MOVE="mv -i \"${TMP_DIR}/${INSTALL_CLI_TYPE}\" \"${INSTALL_LOCATION}\""
|
||||||
|
if [[ -w "${INSTALL_LOCATION}" ]]; then
|
||||||
|
eval "${CMD_MOVE}"
|
||||||
|
else
|
||||||
|
eval "sudo ${CMD_MOVE}"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Run the install process
|
||||||
|
{
|
||||||
|
setup_verify_os
|
||||||
|
setup_verify_arch
|
||||||
|
setup_install_cli
|
||||||
|
verify_downloader curl || verify_downloader wget || fatal 'Can not find curl or wget for downloading files'
|
||||||
|
setup_tmp
|
||||||
|
get_release_version
|
||||||
|
download_hash
|
||||||
|
download_binary
|
||||||
|
verify_binary
|
||||||
|
setup_binary
|
||||||
|
}
|
Loading…
Reference in New Issue