Backup function added ;
Script output refined ; Custom alias through $2 added; Arch detection added ; Removal Process adatptions ;
This commit is contained in:
parent
434f8b0b70
commit
f2335fd148
1 changed files with 187 additions and 91 deletions
262
helium_helper.sh
262
helium_helper.sh
|
|
@ -9,19 +9,22 @@ YEL="\e[0;33m"
|
||||||
RED="\e[0;31m"
|
RED="\e[0;31m"
|
||||||
GRN="\e[0;32m"
|
GRN="\e[0;32m"
|
||||||
LCY="\e[1;36m"
|
LCY="\e[1;36m"
|
||||||
|
WHT="\e[1;37m"
|
||||||
CRS="\e[0m"
|
CRS="\e[0m"
|
||||||
|
|
||||||
## GLOBAL VARIABLES
|
## GLOBAL VARIABLES
|
||||||
APP_NAME="Helium"
|
APP_NAME="Helium"
|
||||||
APP_NAME_LONG="Helium Web Browser"
|
APP_NAME_LONG="Helium Web Browser"
|
||||||
ARCH="x86_64"
|
|
||||||
FILE_EXTENSION="AppImage"
|
FILE_EXTENSION="AppImage"
|
||||||
APP_SOURCE="GitHub"
|
APP_SOURCE="GitHub"
|
||||||
|
ARCH_OVERRIDE=""
|
||||||
|
BACKUP_COMPRESSION_OVERRIDE=""
|
||||||
SCRIPT_NAME="$APP_NAME Helper Script"
|
SCRIPT_NAME="$APP_NAME Helper Script"
|
||||||
SCRIPT_FILE_NAME="helium_helper.sh"
|
SCRIPT_FILE_NAME="helium_helper.sh"
|
||||||
AUTO_SCRIPT_FILE_NAME="helium_launcher_update.sh"
|
AUTO_SCRIPT_FILE_NAME="helium_launcher_update.sh"
|
||||||
SCRIPT_VERSION="0.5.8"
|
SCRIPT_VERSION="0.5.8"
|
||||||
ALIAS="update-helium"
|
ALIAS="update-helium"
|
||||||
|
DATE=$(date +"%d%m%y")
|
||||||
|
|
||||||
## LOCATIONS
|
## LOCATIONS
|
||||||
TMP=/tmp/$APP_NAME
|
TMP=/tmp/$APP_NAME
|
||||||
|
|
@ -52,7 +55,7 @@ cmd_query() {
|
||||||
}
|
}
|
||||||
|
|
||||||
dependency_check () {
|
dependency_check () {
|
||||||
DEPENDENCIES=("curl" "wget")
|
DEPENDENCIES=("curl" "wget" "tar")
|
||||||
mkdir -p $TMP
|
mkdir -p $TMP
|
||||||
|
|
||||||
for PACKAGE in "${DEPENDENCIES[@]}" ; do
|
for PACKAGE in "${DEPENDENCIES[@]}" ; do
|
||||||
|
|
@ -78,22 +81,39 @@ shell_query() {
|
||||||
}
|
}
|
||||||
|
|
||||||
shell_check() {
|
shell_check() {
|
||||||
SHELLS=("bash" "fish" "ksh" "zsh")
|
SHELLS=("bash" "fish" "zsh")
|
||||||
|
|
||||||
for SHELL_OPTION in "${SHELLS[@]}" ; do
|
for SHELL_OPTION in "${SHELLS[@]}" ; do
|
||||||
shell_query "$SHELL_OPTION"
|
shell_query "$SHELL_OPTION"
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
|
### ARCH CHECK
|
||||||
|
|
||||||
|
arch_check() {
|
||||||
|
if [ "$ARCH_OVERRIDE" ] ; then
|
||||||
|
ARCH=$ARCH_OVERRIDE
|
||||||
|
|
||||||
|
else
|
||||||
|
ARCH=$(uname -m)
|
||||||
|
if [ "$ARCH" == "aarch64" ] ; then
|
||||||
|
ARCH="arm64"
|
||||||
|
|
||||||
|
elif [ "$ARCH" == "amd64" ] ; then
|
||||||
|
ARCH="x86_64"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
### CHECK LOCAL INSTALL
|
### CHECK LOCAL INSTALL
|
||||||
local_check() {
|
local_check() {
|
||||||
if ! [ -d "$INSTALL_PATH" ] ; then
|
if ! [ -d "$INSTALL_PATH" ] ; then
|
||||||
echo -e "\n ${RED}$APP_NAME_LONG directory not found!${CRS}"
|
echo -e "\n ${YEL}$APP_NAME_LONG directory not found!${CRS}\n"
|
||||||
install_helium
|
install_helium
|
||||||
exit
|
exit
|
||||||
|
|
||||||
elif ! [ -f "$INSTALL_PATH/$APP_NAME.$FILE_EXTENSION" ] ; then
|
elif ! [ -f "$INSTALL_PATH/$APP_NAME.$FILE_EXTENSION" ] ; then
|
||||||
echo -e "\n ${RED}$APP_NAME_LONG directory found but no executable named ${CYN}$APP_NAME.$FILE_EXTENSION${RED}!${CRS}"
|
echo -e "\n ${YEL}$APP_NAME_LONG directory found but no executable named ${CYN}$APP_NAME.$FILE_EXTENSION${YEL}!${CRS}\n"
|
||||||
install_helium
|
install_helium
|
||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
|
|
@ -109,12 +129,12 @@ install_helium() {
|
||||||
|
|
||||||
while true ; do
|
while true ; do
|
||||||
read -p " Download and install $APP_NAME_LONG from $APP_SOURCE? (Y/n) : " CONFIRM_INSTALL
|
read -p " Download and install $APP_NAME_LONG from $APP_SOURCE? (Y/n) : " CONFIRM_INSTALL
|
||||||
echo
|
|
||||||
|
|
||||||
if [[ "$CONFIRM_INSTALL" == "" || "$CONFIRM_INSTALL" == "y" || "$CONFIRM_INSTALL" == "Y" ]] ; then
|
if [[ "$CONFIRM_INSTALL" == "" || "$CONFIRM_INSTALL" == "y" || "$CONFIRM_INSTALL" == "Y" ]] ; then
|
||||||
DOWNLOAD_URL=$(curl -s $APP_SOURCE_URL | grep "browser_download_url" | grep "$ARCH.$FILE_EXTENSION" | grep -v "zsync" | tr -d \" | awk '{print $2}')
|
DOWNLOAD_URL=$(curl -s $APP_SOURCE_URL | grep "browser_download_url" | grep "$ARCH.$FILE_EXTENSION" | grep -v "zsync" | tr -d \" | awk '{print $2}')
|
||||||
APP_SOURCE_FILENAME=$(curl -s $APP_SOURCE_URL | grep "browser_download_url" | grep "$ARCH.$FILE_EXTENSION" | grep -v "zsync" | tr -d \" | awk '{print $2}' | awk -F'/' '{print $9}')
|
APP_SOURCE_FILENAME=$(curl -s $APP_SOURCE_URL | grep "browser_download_url" | grep "$ARCH.$FILE_EXTENSION" | grep -v "zsync" | tr -d \" | awk '{print $2}' | awk -F'/' '{print $9}')
|
||||||
wget -P $TMP $DOWNLOAD_URL -q --show-progress
|
echo -e "\n - Downloading ${CYN}$APP_SOURCE_FILENAME${CRS}..."
|
||||||
|
wget -P $TMP $DOWNLOAD_URL -q
|
||||||
chmod +x $TMP/$APP_SOURCE_FILENAME
|
chmod +x $TMP/$APP_SOURCE_FILENAME
|
||||||
mkdir -p $INSTALL_PATH
|
mkdir -p $INSTALL_PATH
|
||||||
mv $TMP/$APP_SOURCE_FILENAME $INSTALL_PATH/$APP_NAME.$FILE_EXTENSION
|
mv $TMP/$APP_SOURCE_FILENAME $INSTALL_PATH/$APP_NAME.$FILE_EXTENSION
|
||||||
|
|
@ -123,11 +143,11 @@ install_helium() {
|
||||||
break
|
break
|
||||||
|
|
||||||
elif [[ "$CONFIRM_INSTALL" == "n" || "$CONFIRM_INSTALL" == "N" ]] ; then
|
elif [[ "$CONFIRM_INSTALL" == "n" || "$CONFIRM_INSTALL" == "N" ]] ; then
|
||||||
echo -e " ${RED}Cancelled!${CRS}"
|
echo -e "\n ${RED}Cancelled!${CRS}\n"
|
||||||
break
|
break
|
||||||
|
|
||||||
else
|
else
|
||||||
echo -e " ${YEL}Invalid response!${CRS}\n"
|
echo -e "\n ${YEL}Invalid response!${CRS}\n"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
done
|
done
|
||||||
|
|
@ -142,7 +162,6 @@ add_launcher() {
|
||||||
while true ; do
|
while true ; do
|
||||||
echo
|
echo
|
||||||
read -p " Add $APP_NAME_LONG launcher to $LAUNCHER_PATH? (Y/n) : " CONFIRM_LAUNCHER
|
read -p " Add $APP_NAME_LONG launcher to $LAUNCHER_PATH? (Y/n) : " CONFIRM_LAUNCHER
|
||||||
echo
|
|
||||||
|
|
||||||
if [[ "$CONFIRM_LAUNCHER" == "" || "$CONFIRM_LAUNCHER" == "y" || "$CONFIRM_LAUNCHER" == "Y" ]] ; then
|
if [[ "$CONFIRM_LAUNCHER" == "" || "$CONFIRM_LAUNCHER" == "y" || "$CONFIRM_LAUNCHER" == "Y" ]] ; then
|
||||||
LAUNCHER_URL=$REMOTE_REPO_URL/assets/launcher/helium.desktop.template
|
LAUNCHER_URL=$REMOTE_REPO_URL/assets/launcher/helium.desktop.template
|
||||||
|
|
@ -151,13 +170,15 @@ add_launcher() {
|
||||||
LOCAL_VERSION=$($INSTALL_PATH/$APP_NAME.$FILE_EXTENSION --version | awk '{print $2}')
|
LOCAL_VERSION=$($INSTALL_PATH/$APP_NAME.$FILE_EXTENSION --version | awk '{print $2}')
|
||||||
mkdir -p $LAUNCHER_PATH $SCRIPT_PATH $BACKUP_PATH $ASSET_PATH/icon
|
mkdir -p $LAUNCHER_PATH $SCRIPT_PATH $BACKUP_PATH $ASSET_PATH/icon
|
||||||
if ! [ -f "$SCRIPT_PATH/$AUTO_SCRIPT_FILE_NAME" ] ; then
|
if ! [ -f "$SCRIPT_PATH/$AUTO_SCRIPT_FILE_NAME" ] ; then
|
||||||
wget -P $TMP $AUTO_SCRIPT_URL -q --show-progress
|
echo -e "\n - Downloading ${CYN}$AUTO_SCRIPT_FILE_NAME${CRS}..."
|
||||||
|
wget -P $TMP $AUTO_SCRIPT_URL -q
|
||||||
chmod +x $TMP/$AUTO_SCRIPT_FILE_NAME
|
chmod +x $TMP/$AUTO_SCRIPT_FILE_NAME
|
||||||
mv $TMP/$AUTO_SCRIPT_FILE_NAME $SCRIPT_PATH
|
mv $TMP/$AUTO_SCRIPT_FILE_NAME $SCRIPT_PATH
|
||||||
fi
|
fi
|
||||||
|
|
||||||
wget -P $TMP $LAUNCHER_URL -q --show-progress
|
echo -e "\n - Downloading ${CYN}launcher files${CRS}..."
|
||||||
wget -P $TMP $ICON_URL -q --show-progress
|
wget -P $TMP $LAUNCHER_URL -q
|
||||||
|
wget -P $TMP $ICON_URL -q
|
||||||
sed -i "s|%APP_LOCATION%|$INSTALL_PATH/$APP_NAME.$FILE_EXTENSION|" $TMP/helium.desktop.template
|
sed -i "s|%APP_LOCATION%|$INSTALL_PATH/$APP_NAME.$FILE_EXTENSION|" $TMP/helium.desktop.template
|
||||||
sed -i "s|%ICON_LOCATION%|$ASSET_PATH/icon/helium.png|" $TMP/helium.desktop.template
|
sed -i "s|%ICON_LOCATION%|$ASSET_PATH/icon/helium.png|" $TMP/helium.desktop.template
|
||||||
sed -i "s|%APP_VERSION%|$LOCAL_VERSION|" $TMP/helium.desktop.template
|
sed -i "s|%APP_VERSION%|$LOCAL_VERSION|" $TMP/helium.desktop.template
|
||||||
|
|
@ -197,36 +218,44 @@ add_alias() {
|
||||||
|
|
||||||
if [ "$ACTIVE_SHELL" == "zsh" ] ; then
|
if [ "$ACTIVE_SHELL" == "zsh" ] ; then
|
||||||
if [ "$(cat $HOME/.zshrc | grep "$ALIAS")" ] ; then
|
if [ "$(cat $HOME/.zshrc | grep "$ALIAS")" ] ; then
|
||||||
echo -e "\n ${LCY}$ALIAS ${GRN}already present in${CRS} $HOME/.zshrc\n"
|
echo -e "\n ${LCY}$ALIAS${CRS} already present in ${CYN}$HOME/.zshrc${CRS}\n"
|
||||||
exit
|
|
||||||
fi
|
else
|
||||||
|
echo "### $APP_NAME_LONG Alias zsh ###" >> $HOME/.zshrc
|
||||||
echo "alias $ALIAS=\"$SCRIPT_PATH/$SCRIPT_FILE_NAME\"" >> $HOME/.zshrc
|
echo "alias $ALIAS=\"$SCRIPT_PATH/$SCRIPT_FILE_NAME\"" >> $HOME/.zshrc
|
||||||
echo -e "\n ${LCY}$ALIAS ${GRN}added to${CRS} $HOME/.zshrc\n"
|
echo >> $HOME/.zshrc
|
||||||
|
echo -e "\n ${LCY}$ALIAS${CRS} added to ${CYN}$HOME/.zshrc${CRS}\n"
|
||||||
|
fi
|
||||||
|
|
||||||
elif [ "$ACTIVE_SHELL" == "bash" ] ; then
|
elif [ "$ACTIVE_SHELL" == "bash" ] ; then
|
||||||
if [ "$(cat $HOME/.bashrc | grep "$ALIAS")" ] ; then
|
if [ "$(cat $HOME/.bashrc | grep "$ALIAS")" ] ; then
|
||||||
echo -e "\n ${LCY}$ALIAS ${GRN}already present in${CRS} $HOME/.bashrc\n"
|
echo -e "\n ${LCY}$ALIAS${CRS} already present in ${CYN}$HOME/.bashrc${CRS}\n"
|
||||||
exit
|
|
||||||
|
else
|
||||||
|
echo "### $APP_NAME_LONG Alias bash ###" >> $HOME/.bashrc
|
||||||
|
echo "alias $ALIAS=\"$SCRIPT_PATH/$SCRIPT_FILE_NAME\"" >> $HOME/.bashrc
|
||||||
|
echo >> $HOME/.bashrc
|
||||||
|
echo -e "\n ${LCY}$ALIAS${CRS} added to ${CYN}$HOME/.bashrc${CRS}\n"
|
||||||
fi
|
fi
|
||||||
echo "alias $ALIAS=\"$SCRIPT_PATH/$SCRIPT_FILE_NAME\"" >> $HOME/.zshrc
|
|
||||||
echo -e "\n ${LCY}$ALIAS ${GRN}added to${CRS} $HOME/.bashrc\n"
|
|
||||||
|
|
||||||
elif [ "$ACTIVE_SHELL" == "fish" ] ; then
|
elif [ "$ACTIVE_SHELL" == "fish" ] ; then
|
||||||
if [ "$(cat $HOME/.config/fish/config.fish | grep "source $HOME/.config/fish/$ALIAS.fish")" ] ; then
|
if [ "$(cat $HOME/.config/fish/config.fish | grep "source $HOME/.config/fish/$ALIAS.fish")" ] ; then
|
||||||
echo -e "\n ${LCY}$ALIAS ${GRN}already present in${CRS} $HOME/.config/fish/config.fish\n"
|
echo -e "\n ${LCY}$ALIAS${CRS} already present in ${CYN}$HOME/.config/fish/config.fish${CRS}\n"
|
||||||
exit
|
|
||||||
fi
|
else
|
||||||
echo "### Helium Helper Alias FISH ###" > $HOME/.config/fish/$ALIAS.fish
|
echo "### $APP_NAME_LONG Alias FISH ###" > $HOME/.config/fish/$ALIAS.fish
|
||||||
echo >> $HOME/.config/fish/$ALIAS.fish
|
echo >> $HOME/.config/fish/$ALIAS.fish
|
||||||
echo "function $ALIAS" >> $HOME/.config/fish/$ALIAS.fish
|
echo "function $ALIAS" >> $HOME/.config/fish/$ALIAS.fish
|
||||||
echo " $SCRIPT_PATH/$SCRIPT_FILE_NAME \$argv" >> $HOME/.config/fish/$ALIAS.fish
|
echo " $SCRIPT_PATH/$SCRIPT_FILE_NAME \$argv" >> $HOME/.config/fish/$ALIAS.fish
|
||||||
echo "end" >> $HOME/.config/fish/$ALIAS.fish
|
echo "end" >> $HOME/.config/fish/$ALIAS.fish
|
||||||
|
echo >> $HOME/.config/fish/$ALIAS.fish
|
||||||
echo "source $HOME/.config/fish/$ALIAS.fish" >> $HOME/.config/fish/config.fish
|
echo "source $HOME/.config/fish/$ALIAS.fish" >> $HOME/.config/fish/config.fish
|
||||||
echo -e "\n ${LCY}$ALIAS ${GRN}added to${CRS} $HOME/.config/fish/config.fish\n"
|
echo -e "\n ${LCY}$ALIAS ${CRS}added to ${CYN}$HOME/.config/fish/config.fish${CRS}\n"
|
||||||
|
fi
|
||||||
|
|
||||||
else
|
else
|
||||||
echo -e "\n ${LCY}$ACTIVE_SHELL ${RED}not yet supported!${CRS}\n"
|
echo -e "\n ${LCY}$ACTIVE_SHELL${RED}shell is not yet supported!${CRS}\n"
|
||||||
echo -e " ${LCY}Working implementation are available for bash, zsh & fish!${CRS}\n"
|
echo -e " ${CRS}Working implementation are available for bash, zsh & fish!${CRS}\n"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -259,37 +288,26 @@ update_helium() {
|
||||||
|
|
||||||
while true ; do
|
while true ; do
|
||||||
read -p " Download and update $APP_NAME_LONG from $APP_SOURCE? (Y/n) : " CONFIRM
|
read -p " Download and update $APP_NAME_LONG from $APP_SOURCE? (Y/n) : " CONFIRM
|
||||||
echo
|
|
||||||
|
|
||||||
if [[ "$CONFIRM" == "" || "$CONFIRM" == "y" || "$CONFIRM" == "Y" ]] ; then
|
if [[ "$CONFIRM" == "" || "$CONFIRM" == "y" || "$CONFIRM" == "Y" ]] ; then
|
||||||
DOWNLOAD_URL=$(curl -s $APP_SOURCE_URL | grep "browser_download_url" | grep "$ARCH.$FILE_EXTENSION" | grep -v "zsync" | tr -d \" | awk '{print $2}')
|
DOWNLOAD_URL=$(curl -s $APP_SOURCE_URL | grep "browser_download_url" | grep "$ARCH.$FILE_EXTENSION" | grep -v "zsync" | tr -d \" | awk '{print $2}')
|
||||||
APP_SOURCE_FILENAME=$(curl -s $APP_SOURCE_URL | grep "browser_download_url" | grep "$ARCH.$FILE_EXTENSION" | grep -v "zsync" | tr -d \" | awk '{print $2}' | awk -F'/' '{print $9}')
|
APP_SOURCE_FILENAME=$(curl -s $APP_SOURCE_URL | grep "browser_download_url" | grep "$ARCH.$FILE_EXTENSION" | grep -v "zsync" | tr -d \" | awk '{print $2}' | awk -F'/' '{print $9}')
|
||||||
mkdir -p $TMP $BACKUP_PATH
|
mkdir -p $TMP
|
||||||
wget -P $TMP $DOWNLOAD_URL -q --show-progress
|
echo -e "\n - Downloading ${CYN}$APP_SOURCE_FILENAME${CRS}..."
|
||||||
|
wget -P $TMP $DOWNLOAD_URL -q
|
||||||
|
backup_helium
|
||||||
chmod +x $TMP/$APP_SOURCE_FILENAME
|
chmod +x $TMP/$APP_SOURCE_FILENAME
|
||||||
if [ -f "$BACKUP_PATH/$APP_NAME.old" ] ; then
|
|
||||||
rm $BACKUP_PATH/$APP_NAME.old
|
|
||||||
fi
|
|
||||||
if [ -d "$APP_CONFIG_PATH" ] ; then
|
|
||||||
if [ -f "$BACKUP_PATH/$APP_NAME.config.tar" ] ; then
|
|
||||||
rm $BACKUP_PATH/$APP_NAME.config.tar
|
|
||||||
fi
|
|
||||||
tar -cf $BACKUP_PATH/$APP_NAME.config.tar $APP_CONFIG_PATH > /dev/null 2>&1
|
|
||||||
fi
|
|
||||||
mv $INSTALL_PATH/$APP_NAME.$FILE_EXTENSION $BACKUP_PATH/$APP_NAME.old
|
|
||||||
mv $TMP/$APP_SOURCE_FILENAME $INSTALL_PATH/$APP_NAME.$FILE_EXTENSION
|
mv $TMP/$APP_SOURCE_FILENAME $INSTALL_PATH/$APP_NAME.$FILE_EXTENSION
|
||||||
cp $LAUNCHER_PATH/$APP_NAME.desktop $BACKUP_PATH/$APP_NAME.desktop.old
|
|
||||||
chmod -x $BACKUP_PATH/*.sh.old $BACKUP_PATH/$APP_NAME.old
|
|
||||||
sed -i "s|X-AppImage-Version=.*|X-AppImage-Version=$($INSTALL_PATH/$APP_NAME.$FILE_EXTENSION --version | awk '{print $2}')|" $LAUNCHER_PATH/$APP_NAME.desktop
|
sed -i "s|X-AppImage-Version=.*|X-AppImage-Version=$($INSTALL_PATH/$APP_NAME.$FILE_EXTENSION --version | awk '{print $2}')|" $LAUNCHER_PATH/$APP_NAME.desktop
|
||||||
echo -e "\n ${GRN}$APP_NAME_LONG is up-to-date !${CRS}\n"
|
echo -e " ${GRN}$APP_NAME_LONG is up-to-date!${CRS}\n"
|
||||||
break
|
break
|
||||||
|
|
||||||
elif [[ "$CONFIRM" == "n" || "$CONFIRM" == "N" ]] ; then
|
elif [[ "$CONFIRM" == "n" || "$CONFIRM" == "N" ]] ; then
|
||||||
echo -e " ${RED}Cancelled!${CRS}\n"
|
echo -e "\n ${RED}Cancelled!${CRS}\n"
|
||||||
exit
|
exit
|
||||||
|
|
||||||
else
|
else
|
||||||
echo -e " ${YEL}Invalid response!${CRS}\n"
|
echo -e "\n ${YEL}Invalid response!${CRS}\n"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
|
|
@ -303,14 +321,88 @@ update_helium() {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
### AUTOMATIC UPDATE --> TO DO?
|
### BACKUP
|
||||||
auto_update() {
|
backup_helium() {
|
||||||
if ! [ -f "$INSTALL_PATH/$APP_NAME.$FILE_EXTENSION" ] ; then
|
if [[ -d "$INSTALL_PATH" || -d "$SCRIPT_PATH" || -d $APP_CONFIG_PATH ]] ; then
|
||||||
echo -e "\n ${RED}$APP_NAME AppImage not found! Can't add auto update script...${CRS}"
|
BACKUPABLE=("$INSTALL_PATH/$APP_NAME.$FILE_EXTENSION" "$SCRIPT_PATH/$SCRIPT_FILE_NAME" "$SCRIPT_PATH/$AUTO_SCRIPT_FILE_NAME" "$LAUNCHER_PATH/$APP_NAME.desktop" "$APP_CONFIG_PATH")
|
||||||
exit
|
echo -e "\n - ${CRS}Collectig files for ${CYN}backup${CRS}...${CRS}"
|
||||||
|
|
||||||
|
for BACKUP_ITEM in ${BACKUPABLE[@]} ; do
|
||||||
|
if [ -d "$BACKUP_ITEM" ] ; then
|
||||||
|
mkdir -p $TMP/backup
|
||||||
|
cp -r $BACKUP_ITEM $TMP/backup
|
||||||
|
|
||||||
|
elif [ -f "$BACKUP_ITEM" ] ; then
|
||||||
|
mkdir -p $TMP/backup
|
||||||
|
cp $BACKUP_ITEM $TMP/backup
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
if [ -d "$TMP/backup" ] ; then
|
||||||
|
CWD=$(pwd)
|
||||||
|
cd $TMP/backup
|
||||||
|
chmod -x *.sh *.$FILE_EXTENSION > /dev/null 2>&1
|
||||||
|
|
||||||
|
if [ "$BACKUP_COMPRESSION_OVERRIDE" ] ; then
|
||||||
|
BACKUP_COMPRESSION=$BACKUP_COMPRESSION_OVERRIDE
|
||||||
|
|
||||||
|
elif ! [ "$BACKUP_COMPRESSION_OVERRIDE" ] ; then
|
||||||
|
COMPRESSION_METHOD=("pbzip2" "gzip" "bzip2" "zip")
|
||||||
|
|
||||||
|
until [ "$BACKUP_COMPRESSION" ] ; do
|
||||||
|
for COMPRESSION_TYPE in ${COMPRESSION_METHOD[@]} ; do
|
||||||
|
|
||||||
|
if [ "$(command -v $COMPRESSION_TYPE) > /dev/null 2>&1" ] ; then
|
||||||
|
BACKUP_COMPRESSION=$COMPRESSION_TYPE
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo -e "\n - ${CRS}Compressing backup archive with ${CYN}$BACKUP_COMPRESSION${CRS}...${CRS}\n"
|
||||||
|
|
||||||
|
if [ "$BACKUP_COMPRESSION" == "pbzip2" ] ; then
|
||||||
|
tar -cf $APP_NAME.backup_$DATE.tar * > /dev/null 2>&1
|
||||||
|
pbzip2 $APP_NAME.backup_$DATE.tar
|
||||||
|
mkdir -p $BACKUP_PATH
|
||||||
|
mv $APP_NAME.backup_$DATE.tar.bz2 $BACKUP_PATH
|
||||||
|
cd $TMP && rm -rf backup
|
||||||
|
|
||||||
|
elif [ "$BACKUP_COMPRESSION" == "gzip" ] ; then
|
||||||
|
tar -cf $APP_NAME.backup_$DATE.tar * > /dev/null 2>&1
|
||||||
|
gzip $APP_NAME.backup_$DATE.tar
|
||||||
|
mkdir -p $BACKUP_PATH
|
||||||
|
mv $APP_NAME.backup_$DATE.tar.gz $BACKUP_PATH
|
||||||
|
cd $TMP && rm -rf backup
|
||||||
|
|
||||||
|
elif [ "$BACKUP_COMPRESSION" == "bzip2" ] ; then
|
||||||
|
tar -cf $APP_NAME.backup_$DATE.tar * > /dev/null 2>&1
|
||||||
|
bzip2 $APP_NAME.backup_$DATE.tar
|
||||||
|
mkdir -p $BACKUP_PATH
|
||||||
|
mv $APP_NAME.backup_$DATE.tar.bz2 $BACKUP_PATH
|
||||||
|
cd $TMP && rm -rf backup
|
||||||
|
|
||||||
|
elif [ "$BACKUP_COMPRESSION" == "zip" ] ; then
|
||||||
|
tar -cf $APP_NAME.backup_$DATE.tar * > /dev/null 2>&1
|
||||||
|
zip -r $APP_NAME.backup_$DATE.tar.zip $APP_NAME.backup_$DATE.tar > /dev/null 2>&1
|
||||||
|
mkdir -p $BACKUP_PATH
|
||||||
|
mv $APP_NAME.backup_$DATE.tar.zip $BACKUP_PATH
|
||||||
|
cd $TMP && rm -rf backup
|
||||||
|
|
||||||
else
|
else
|
||||||
echo -e "\n ${RED}Not implemented yet...${CRS}"
|
echo -e " ${YEL}No supported compression method detected! Copying backup uncompressed...${CRS}\n"
|
||||||
|
mkdir -p $BACKUP_PATH
|
||||||
|
mv $TMP/backup $BACKUP_PATH/$APP_NAME.backup_$DATE
|
||||||
|
cd $TMP && rm -rf backup
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo -e " - ${CRS}Backup stored in ${CYN}$BACKUP_PATH${CRS}...${CRS}\n"
|
||||||
|
cd $CWD
|
||||||
|
fi
|
||||||
|
|
||||||
|
else
|
||||||
|
echo -e " ${YEL}Nothing to back up...${CRS}"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -319,15 +411,14 @@ remove_helium() {
|
||||||
if [ -d "$INSTALL_PATH" ] ; then
|
if [ -d "$INSTALL_PATH" ] ; then
|
||||||
|
|
||||||
while true ; do
|
while true ; do
|
||||||
read -p " Remove $APP_NAME_LONG incl. backups and launcher? (Y/n) : " CONFIRM_REMOVE
|
read -p " Remove $APP_NAME_LONG incl. backups, configuration and launcher? (Y/n) : " CONFIRM_REMOVE
|
||||||
|
|
||||||
if [[ "$CONFIRM_REMOVE" == "" || "$CONFIRM_REMOVE" == "y" || "$CONFIRM_REMOVE" == "Y" ]] ; then
|
if [[ "$CONFIRM_REMOVE" == "" || "$CONFIRM_REMOVE" == "y" || "$CONFIRM_REMOVE" == "Y" ]] ; then
|
||||||
REMOVABLE=("$INSTALL_PATH" "$LAUNCHER_PATH/$APP_NAME.desktop" "$SCRIPT_PATH/$SCRIPT_FILE_NAME" "$SCRIPT_PATH/$AUTO_SCRIPT_FILE_NAME")
|
REMOVABLE=("$INSTALL_PATH" "$LAUNCHER_PATH/$APP_NAME.desktop" "$SCRIPT_PATH/$SCRIPT_FILE_NAME" "$SCRIPT_PATH/$AUTO_SCRIPT_FILE_NAME" "$APP_CONFIG_PATH")
|
||||||
echo
|
echo -e "\n - ${CRS}Removing ${CYN}$APP_NAME${CRS} directory and configuration...${CRS}"
|
||||||
|
|
||||||
for RM_PATH in "${REMOVABLE[@]}" ; do
|
for RM_PATH in "${REMOVABLE[@]}" ; do
|
||||||
if [[ -f "$RM_PATH" || -d "$RM_PATH" ]] ; then
|
if [[ -f "$RM_PATH" || -d "$RM_PATH" ]] ; then
|
||||||
echo -e " ${YEL}Removing ${CYN}$RM_PATH ${YEL}...${CRS}"
|
|
||||||
rm -rf "$RM_PATH"
|
rm -rf "$RM_PATH"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
@ -336,26 +427,28 @@ remove_helium() {
|
||||||
|
|
||||||
if [ "$ACTIVE_SHELL" == "zsh" ] ; then
|
if [ "$ACTIVE_SHELL" == "zsh" ] ; then
|
||||||
if [ "$(cat $HOME/.zshrc | grep "$ALIAS")" ] ; then
|
if [ "$(cat $HOME/.zshrc | grep "$ALIAS")" ] ; then
|
||||||
|
sed -i "/$APP_NAME_LONG/d" $HOME/.zshrc
|
||||||
sed -i "/$ALIAS/d" $HOME/.zshrc
|
sed -i "/$ALIAS/d" $HOME/.zshrc
|
||||||
echo -e "\n ${CYN}$ACTIVE_SHELL ${YEL}alias removed ... ${CRS}"
|
echo -e "\n - Alias removed from ${CYN}$ACTIVE_SHELL${CRS}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
elif [ "$ACTIVE_SHELL" == "bash" ] ; then
|
elif [ "$ACTIVE_SHELL" == "bash" ] ; then
|
||||||
if [ "$(cat $HOME/.bashrc | grep "$ALIAS")" ] ; then
|
if [ "$(cat $HOME/.bashrc | grep "$ALIAS")" ] ; then
|
||||||
|
sed -i "/$APP_NAME_LONG/d" $HOME/.bashrc
|
||||||
sed -i "/$ALIAS/d" $HOME/.bashrc
|
sed -i "/$ALIAS/d" $HOME/.bashrc
|
||||||
echo -e "\n ${CYN}$ACTIVE_SHELL ${YEL}alias removed ... ${CRS}"
|
echo -e "\n - Alias removed from ${CYN}$ACTIVE_SHELL${CRS}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
elif [ "$ACTIVE_SHELL" == "fish" ] ; then
|
elif [ "$ACTIVE_SHELL" == "fish" ] ; then
|
||||||
if [ "$(cat $HOME/.config/fish/config.fish | grep "source $HOME/.config/fish/$ALIAS.fish")" ] ; then
|
if [ "$(cat $HOME/.config/fish/config.fish | grep "source $HOME/.config/fish/$ALIAS.fish")" ] ; then
|
||||||
sed -i "/$ALIAS/d" $HOME/.config/fish/config.fish
|
sed -i "/$ALIAS/d" $HOME/.config/fish/config.fish
|
||||||
rm $HOME/.config/fish/$ALIAS.fish
|
rm $HOME/.config/fish/$ALIAS.fish
|
||||||
echo -e "\n ${CYN}$ACTIVE_SHELL ${YEL}alias removed ... ${CRS}"
|
echo -e "\n - Alias removed from ${CYN}$ACTIVE_SHELL${CRS}"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo -e "\n ${RED}$APP_NAME_LONG removed!${CRS}\n"
|
echo -e "\n ${YEL}$APP_NAME_LONG removed!${CRS}\n"
|
||||||
exit
|
break
|
||||||
|
|
||||||
elif [[ "$CONFIRM_REMOVE" == "n" || "$CONFIRM_REMOVE" == "N" ]] ; then
|
elif [[ "$CONFIRM_REMOVE" == "n" || "$CONFIRM_REMOVE" == "N" ]] ; then
|
||||||
echo -e " ${RED}Cancelled!${CRS}"
|
echo -e " ${RED}Cancelled!${CRS}"
|
||||||
|
|
@ -367,7 +460,7 @@ remove_helium() {
|
||||||
done
|
done
|
||||||
|
|
||||||
else
|
else
|
||||||
echo -e "\n ${RED}Can't remove $APP_NAME_LONG! ${YEL}$INSTALL_PATH ${RED}directory not found...${CRS}"
|
echo -e " ${RED}Can't remove $APP_NAME_LONG! ${CYN}$INSTALL_PATH ${RED}directory not found...${CRS}\n"
|
||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
@ -375,8 +468,6 @@ remove_helium() {
|
||||||
### SCRIPT VERSION
|
### SCRIPT VERSION
|
||||||
script_version() {
|
script_version() {
|
||||||
echo -e "\n ${CYN}$APP_NAME_LONG Helper Script Version : ${CRS}$SCRIPT_VERSION\n"
|
echo -e "\n ${CYN}$APP_NAME_LONG Helper Script Version : ${CRS}$SCRIPT_VERSION\n"
|
||||||
exit
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
### UPDATE SCRIPT
|
### UPDATE SCRIPT
|
||||||
|
|
@ -397,7 +488,7 @@ update_script() {
|
||||||
chmod +x $TMP/$SCRIPT_FILE_NAME $TMP/$AUTO_SCRIPT_FILE_NAME
|
chmod +x $TMP/$SCRIPT_FILE_NAME $TMP/$AUTO_SCRIPT_FILE_NAME
|
||||||
mv $TMP/$SCRIPT_FILE_NAME $TMP/$AUTO_SCRIPT_FILE_NAME $SCRIPT_PATH
|
mv $TMP/$SCRIPT_FILE_NAME $TMP/$AUTO_SCRIPT_FILE_NAME $SCRIPT_PATH
|
||||||
echo -e "\n ${GRN}$SCRIPT_FILE_NAME is up-to-date!${CRS}"
|
echo -e "\n ${GRN}$SCRIPT_FILE_NAME is up-to-date!${CRS}"
|
||||||
exit_clean
|
break
|
||||||
|
|
||||||
elif [[ "$CONFIRM_SCRIPT_INSTALL" == "n" || "$CONFIRM_SCRIPT_INSTALL" == "N" ]] ; then
|
elif [[ "$CONFIRM_SCRIPT_INSTALL" == "n" || "$CONFIRM_SCRIPT_INSTALL" == "N" ]] ; then
|
||||||
echo -e " ${RED}Cancelled!${CRS}\n"
|
echo -e " ${RED}Cancelled!${CRS}\n"
|
||||||
|
|
@ -467,7 +558,7 @@ update_script() {
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
### COMPARE APPIMAGE VERSION
|
### COMPARE APPIMAGE VERSIONarch_check
|
||||||
compare_version() {
|
compare_version() {
|
||||||
LOCAL_VERSION=$($INSTALL_PATH/$APP_NAME.$FILE_EXTENSION --version | awk '{print $2}')
|
LOCAL_VERSION=$($INSTALL_PATH/$APP_NAME.$FILE_EXTENSION --version | awk '{print $2}')
|
||||||
APP_SOURCE_VERSION=$(curl -s $APP_SOURCE_URL | grep "tag_name" | tr -d \", | awk '{print $2}')
|
APP_SOURCE_VERSION=$(curl -s $APP_SOURCE_URL | grep "tag_name" | tr -d \", | awk '{print $2}')
|
||||||
|
|
@ -490,13 +581,11 @@ compare_version() {
|
||||||
echo -e "\n ${GRN}$APP_NAME_LONG is up-to-date!${CRS}\n"
|
echo -e "\n ${GRN}$APP_NAME_LONG is up-to-date!${CRS}\n"
|
||||||
echo -e " ${CYN}Local Version :\t${CRS}${LOCAL_VERSION}"
|
echo -e " ${CYN}Local Version :\t${CRS}${LOCAL_VERSION}"
|
||||||
echo -e " ${CYN}$APP_SOURCE Version :\t${CRS}${APP_SOURCE_VERSION}\n"
|
echo -e " ${CYN}$APP_SOURCE Version :\t${CRS}${APP_SOURCE_VERSION}\n"
|
||||||
exit
|
|
||||||
|
|
||||||
elif [ "$APP_SOURCE_VERSION_NUM" -gt "$LOCAL_VERSION_NUM" ] ; then
|
elif [ "$APP_SOURCE_VERSION_NUM" -gt "$LOCAL_VERSION_NUM" ] ; then
|
||||||
echo -e "\n ${YEL}$APP_NAME_LONG is updatable!${CRS}\n"
|
echo -e "\n ${YEL}$APP_NAME_LONG is updatable!${CRS}\n"
|
||||||
echo -e " ${CYN}Local Version :\t${CRS}${LOCAL_VERSION}"
|
echo -e " ${CYN}Local Version :\t${CRS}${LOCAL_VERSION}"
|
||||||
echo -e " ${CYN}$APP_SOURCE Version :\t${CRS}${APP_SOURCE_VERSION}\n"
|
echo -e " ${CYN}$APP_SOURCE Version :\t${CRS}${APP_SOURCE_VERSION}\n"
|
||||||
exit
|
|
||||||
|
|
||||||
else
|
else
|
||||||
echo -e "\n ${RED}Version tags malformed or you are using a Beta version!${CRS}\n"
|
echo -e "\n ${RED}Version tags malformed or you are using a Beta version!${CRS}\n"
|
||||||
|
|
@ -517,7 +606,7 @@ help() {
|
||||||
echo -e "\t-l\tCreate desktop launcher"
|
echo -e "\t-l\tCreate desktop launcher"
|
||||||
echo -e "\t-a\tCreate alias for $SCRIPT_FILE_NAME"
|
echo -e "\t-a\tCreate alias for $SCRIPT_FILE_NAME"
|
||||||
echo -e "\t-u\tDownload & update $APP_NAME_LONG from $APP_SOURCE"
|
echo -e "\t-u\tDownload & update $APP_NAME_LONG from $APP_SOURCE"
|
||||||
#echo -e "\t-U\tEnable automatic updates on login ${RED}--> Not yet working${CRS}"
|
echo -e "\t-b\tBackup $APP_NAME_LONG & configuration"
|
||||||
echo -e "\t-r\tRemove $APP_NAME_LONG"
|
echo -e "\t-r\tRemove $APP_NAME_LONG"
|
||||||
echo -e "\t-c\tCompare local to remote version"
|
echo -e "\t-c\tCompare local to remote version"
|
||||||
echo -e "\t-s\tShow script version"
|
echo -e "\t-s\tShow script version"
|
||||||
|
|
@ -541,48 +630,54 @@ exit_clean() {
|
||||||
########## MAIN ##########
|
########## MAIN ##########
|
||||||
|
|
||||||
## GET OPTIONS
|
## GET OPTIONS
|
||||||
while getopts ":i,:l,:a,:u,:U,:r,:c,:s,:S,:h" OPTION ; do
|
while getopts ":i,:l,:a,:u,:b,:r,:c,:s,:S,:h" OPTION ; do
|
||||||
case $OPTION in
|
case $OPTION in
|
||||||
i)
|
i)
|
||||||
echo -e "\n ${CYN}Installing $APP_NAME_LONG...${CRS}"
|
echo -e "\n ${YEL}Installing $APP_NAME_LONG...${CRS}\n"
|
||||||
dependency_check
|
dependency_check
|
||||||
|
arch_check
|
||||||
install_helium
|
install_helium
|
||||||
exit_clean ;;
|
exit_clean ;;
|
||||||
|
|
||||||
l)
|
l)
|
||||||
echo -e "\n ${CYN}Adding $APP_NAME_LONG launcher...${CRS}"
|
echo -e "\n ${YEL}Adding $APP_NAME_LONG launcher...${CRS}"
|
||||||
dependency_check
|
dependency_check
|
||||||
local_check
|
local_check
|
||||||
add_launcher
|
add_launcher
|
||||||
exit_clean ;;
|
exit_clean ;;
|
||||||
|
|
||||||
a)
|
a)
|
||||||
echo -e "\n ${CYN}Adding alias...${CRS}"
|
echo -e "\n ${YEL}Adding alias...${CRS}"
|
||||||
|
if [ "$2" ] ; then
|
||||||
|
ALIAS=$2
|
||||||
|
fi
|
||||||
shell_check
|
shell_check
|
||||||
add_alias
|
add_alias
|
||||||
exit ;;
|
exit ;;
|
||||||
|
|
||||||
u)
|
u)
|
||||||
echo -e "\n ${CYN}Updating $APP_NAME_LONG...${CRS}"
|
echo -e "\n ${YEL}Updating $APP_NAME_LONG...${CRS}"
|
||||||
dependency_check
|
dependency_check
|
||||||
|
arch_check
|
||||||
local_check
|
local_check
|
||||||
update_helium
|
update_helium
|
||||||
exit_clean ;;
|
exit_clean ;;
|
||||||
|
|
||||||
U)
|
b)
|
||||||
echo -e "\n ${CYN}Enabling automatic updates...${CRS}"
|
echo -e "\n ${YEL}Backing up $APP_NAME_LONG incl. configuration and script...${CRS}"
|
||||||
dependency_check
|
if [ "$2" ] ; then
|
||||||
local_check
|
BACKUP_PATH=$2
|
||||||
auto_update
|
fi
|
||||||
exit_clean ;;
|
backup_helium
|
||||||
|
exit ;;
|
||||||
|
|
||||||
r)
|
r)
|
||||||
echo -e "\n ${CYN}Removing $APP_NAME_LONG...${CRS}"
|
echo -e "\n ${YEL}Removing $APP_NAME_LONG...${CRS}\n"
|
||||||
remove_helium
|
remove_helium
|
||||||
exit ;;
|
exit ;;
|
||||||
|
|
||||||
c)
|
c)
|
||||||
echo -e "\n ${CYN}Comparing remote to local version...${CRS}"
|
echo -e "\n ${YEL}Comparing remote to local version...${CRS}"
|
||||||
dependency_check
|
dependency_check
|
||||||
local_check
|
local_check
|
||||||
compare_version
|
compare_version
|
||||||
|
|
@ -593,7 +688,7 @@ while getopts ":i,:l,:a,:u,:U,:r,:c,:s,:S,:h" OPTION ; do
|
||||||
exit ;;
|
exit ;;
|
||||||
|
|
||||||
S)
|
S)
|
||||||
echo -e "\n ${CYN}Updating script...${CRS}"
|
echo -e "\n ${YEL}Updating script...${CRS}"
|
||||||
dependency_check
|
dependency_check
|
||||||
update_script
|
update_script
|
||||||
exit_clean ;;
|
exit_clean ;;
|
||||||
|
|
@ -611,6 +706,7 @@ done
|
||||||
|
|
||||||
## DEPENDENCY CHECK
|
## DEPENDENCY CHECK
|
||||||
dependency_check
|
dependency_check
|
||||||
|
arch_check
|
||||||
|
|
||||||
## CHECK FOR LOCAL INSTALL
|
## CHECK FOR LOCAL INSTALL
|
||||||
local_check
|
local_check
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue