diff --git a/install.sh b/install.sh index b46c098..cf91fd7 100644 --- a/install.sh +++ b/install.sh @@ -4,20 +4,25 @@ # Can be launched with the following command: # sh <(curl -sSL https://raw.githubusercontent.com/Katenary/katenary/master/install.sh) -set -e - # Detect the OS and architecture OS=$(uname) ARCH=$(uname -m) +for c in curl grep cut tr; do + if ! command -v $c >/dev/null 2>&1; then + echo "Error: $c is not installed" + exit 1 + fi +done + # Detect the home directory "bin" directory, it is commonly: # - $HOME/.local/bin # - $HOME/.bin # - $HOME/bin -COMON_INSTALL_PATHS="$HOME/.local/bin $HOME/.bin $HOME/bin" +COMMON_INSTALL_PATHS="$HOME/.local/bin $HOME/.bin $HOME/bin" INSTALL_PATH="" -for p in $COMON_INSTALL_PATHS; do +for p in $COMMON_INSTALL_PATHS; do if [ -d $p ]; then INSTALL_PATH=$p break @@ -43,20 +48,20 @@ if ! echo "$PATH" | grep -q "$INSTALL_PATH"; then fi # Where to download the binary -BASE="https://github.com/Katenary/katenary/releases/latest/download/" +TAG=$(curl -sLf https://repo.katenary.io/api/v1/repos/katenary/katenary/releases/latest 2>/dev/null | grep -Po '"tag_name":\s*"[^"]*"' | cut -d ":" -f2 | tr -d '"') -# for compatibility with older ARM versions +# use the right names for the OS and architecture if [ $ARCH = "x86_64" ]; then ARCH="amd64" fi -BIN_URL="$BASE/katenary-$OS-$ARCH" +BIN_URL="https://repo.katenary.io/api/packages/Katenary/generic/katenary/$TAG/katenary-$OS-$ARCH" echo echo "Downloading $BIN_URL" T=$(mktemp -u) -curl -SL -# $BIN_URL -o $T || (echo "Failed to download katenary" && rm -f $T && exit 1) +curl -sLf -# $BIN_URL -o $T 2>/dev/null || (echo -e "Failed to download katenary version $TAG.\n\nPlease open an issue and explain the problem, following the link:\nhttps://repo.katenary.io/Katenary/katenary/issues/new?title=[install.sh]%20Install%20$TAG%20failed" && rm -f $T && exit 1) mv "$T" "${INSTALL_PATH}/katenary" chmod +x "${INSTALL_PATH}/katenary"