Script updater added
This commit is contained in:
parent
fe0546542f
commit
f56c1ac3ea
3 changed files with 134 additions and 72 deletions
139
helium_helper.sh
139
helium_helper.sh
|
|
@ -19,7 +19,7 @@ APP_NAME_LONG="Helium Web Browser"
|
||||||
SOURCE="GitHub"
|
SOURCE="GitHub"
|
||||||
SCRIPT_NAME="$APP_NAME Helper Script"
|
SCRIPT_NAME="$APP_NAME Helper Script"
|
||||||
SCRIPT_FILE_NAME="helium_helper.sh"
|
SCRIPT_FILE_NAME="helium_helper.sh"
|
||||||
SCRIPT_VERSION="0.5.1"
|
SCRIPT_VERSION="0.1"
|
||||||
DATE=$(date)
|
DATE=$(date)
|
||||||
|
|
||||||
## LOCATIONS
|
## LOCATIONS
|
||||||
|
|
@ -58,7 +58,6 @@ dependency_check () {
|
||||||
MISSING=$(cat $TMP/missingDeps)
|
MISSING=$(cat $TMP/missingDeps)
|
||||||
echo -e "\n ${RED}Following dependencies are missing :\n\n${CRS}$MISSING\n\n ${CYN}Please install and re-run script !${CRS}"
|
echo -e "\n ${RED}Following dependencies are missing :\n\n${CRS}$MISSING\n\n ${CYN}Please install and re-run script !${CRS}"
|
||||||
exit_clean
|
exit_clean
|
||||||
exit
|
|
||||||
|
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
@ -98,13 +97,13 @@ install_helium() {
|
||||||
chmod +x $TMP/$GIT_FILENAME
|
chmod +x $TMP/$GIT_FILENAME
|
||||||
mkdir -p $INSTALL_PATH
|
mkdir -p $INSTALL_PATH
|
||||||
mv $TMP/$GIT_FILENAME $INSTALL_PATH/$APP_NAME.AppImage
|
mv $TMP/$GIT_FILENAME $INSTALL_PATH/$APP_NAME.AppImage
|
||||||
echo -e "\n ${GRN}$APP_NAME_LONG is installed!${CRS}\n"
|
|
||||||
add_launcher
|
add_launcher
|
||||||
exit_clean
|
echo -e "\n ${GRN}$APP_NAME_LONG is installed!${CRS}\n"
|
||||||
|
break
|
||||||
|
|
||||||
elif [[ "$CONFIRM_INSTALL" == "n" || "$CONFIRM_INSTALL" == "N" ]] ; then
|
elif [[ "$CONFIRM_INSTALL" == "n" || "$CONFIRM_INSTALL" == "N" ]] ; then
|
||||||
echo -e " ${RED}Cancelled!${CRS}\n"
|
echo -e " ${RED}Cancelled!${CRS}"
|
||||||
exit
|
break
|
||||||
|
|
||||||
else
|
else
|
||||||
echo -e " ${YEL}Invalid response!${CRS}\n"
|
echo -e " ${YEL}Invalid response!${CRS}\n"
|
||||||
|
|
@ -114,14 +113,14 @@ install_helium() {
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
### LAUNCHER --> TO DO
|
### LAUNCHER
|
||||||
add_launcher() {
|
add_launcher() {
|
||||||
if [ -f "$LAUNCHER_PATH/$APP_NAME.desktop" ] ; then
|
if [ -f "$LAUNCHER_PATH/$APP_NAME.desktop" ] ; then
|
||||||
echo -e "\n ${RED}${APP_NAME}.desktop already exists!${CRS}"
|
echo -e "\n ${YEL}${APP_NAME}.desktop already exists!${CRS}"
|
||||||
exit
|
|
||||||
|
|
||||||
elif [ -f "$INSTALL_PATH/$APP_NAME.AppImage" ] ; then
|
elif [ -f "$INSTALL_PATH/$APP_NAME.AppImage" ] ; then
|
||||||
while true ; do
|
while true ; do
|
||||||
|
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
|
echo
|
||||||
|
|
||||||
|
|
@ -137,12 +136,12 @@ add_launcher() {
|
||||||
mkdir -p $LAUNCHER_PATH $BACKUP_PATH $CONFIG_PATH/icon
|
mkdir -p $LAUNCHER_PATH $BACKUP_PATH $CONFIG_PATH/icon
|
||||||
mv $TMP/helium.desktop.template $LAUNCHER_PATH/$APP_NAME.desktop
|
mv $TMP/helium.desktop.template $LAUNCHER_PATH/$APP_NAME.desktop
|
||||||
mv $TMP/helium.png $CONFIG_PATH/icon
|
mv $TMP/helium.png $CONFIG_PATH/icon
|
||||||
echo -e "\n ${GRN}$APP_NAME_LONG launcher is set up!${CRS}\n"
|
echo -e "\n ${GRN}$APP_NAME_LONG launcher is set up!${CRS}"
|
||||||
exit_clean
|
break
|
||||||
|
|
||||||
elif [[ "$CONFIRM_LAUNCHER" == "n" || "$CONFIRM_LAUNCHER" == "N" ]] ; then
|
elif [[ "$CONFIRM_LAUNCHER" == "n" || "$CONFIRM_LAUNCHER" == "N" ]] ; then
|
||||||
echo -e " ${RED}Cancelled!${CRS}\n"
|
echo -e " ${RED}Launcher not added!${CRS}"
|
||||||
exit
|
break
|
||||||
|
|
||||||
else
|
else
|
||||||
echo -e " ${YEL}Invalid response!${CRS}\n"
|
echo -e " ${YEL}Invalid response!${CRS}\n"
|
||||||
|
|
@ -208,7 +207,7 @@ update_helium() {
|
||||||
break
|
break
|
||||||
|
|
||||||
elif [[ "$CONFIRM" == "n" || "$CONFIRM" == "N" ]] ; then
|
elif [[ "$CONFIRM" == "n" || "$CONFIRM" == "N" ]] ; then
|
||||||
echo -e " ${RED}Cancelled!${CRS}\n"
|
echo -e " ${RED}Cancelled!${CRS}"
|
||||||
exit
|
exit
|
||||||
|
|
||||||
else
|
else
|
||||||
|
|
@ -237,7 +236,6 @@ auto_update() {
|
||||||
|
|
||||||
else
|
else
|
||||||
echo -e "\n ${RED}Not implemented yet...${CRS}"
|
echo -e "\n ${RED}Not implemented yet...${CRS}"
|
||||||
exit
|
|
||||||
|
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
@ -247,16 +245,18 @@ remove_helium() {
|
||||||
if [ -d "$INSTALL_PATH" ] ; then
|
if [ -d "$INSTALL_PATH" ] ; then
|
||||||
|
|
||||||
while true ; do
|
while true ; do
|
||||||
read -p " Remove $APP_NAME_LONG folder $INSTALL_PATH? (Y/n) : " CONFIRM_REMOVE
|
read -p " Remove $APP_NAME_LONG incl. backups 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
|
||||||
rm -rf $INSTALL_PATH
|
rm -rf $INSTALL_PATH
|
||||||
|
if [ -f "$LAUNCHER_PATH/$APP_NAME.desktop" ] ; then
|
||||||
rm $LAUNCHER_PATH/$APP_NAME.desktop
|
rm $LAUNCHER_PATH/$APP_NAME.desktop
|
||||||
echo -e "\n ${RED}$APP_NAME_LONG removed!${CRS}\n"
|
fi
|
||||||
|
echo -e "\n ${RED}$APP_NAME_LONG removed!${CRS}"
|
||||||
exit
|
exit
|
||||||
|
|
||||||
elif [[ "$CONFIRM_REMOVE" == "n" || "$CONFIRM_REMOVE" == "N" ]] ; then
|
elif [[ "$CONFIRM_REMOVE" == "n" || "$CONFIRM_REMOVE" == "N" ]] ; then
|
||||||
echo -e " ${RED}Cancelled!${CRS}\n"
|
echo -e " ${RED}Cancelled!${CRS}"
|
||||||
exit
|
exit
|
||||||
|
|
||||||
else
|
else
|
||||||
|
|
@ -267,7 +267,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}\n"
|
echo -e "\n ${RED}Can't remove $APP_NAME_LONG! ${YEL}$INSTALL_PATH ${RED}directory not found...${CRS}"
|
||||||
exit
|
exit
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
@ -275,21 +275,82 @@ remove_helium() {
|
||||||
|
|
||||||
### SCRIPT VERSION
|
### SCRIPT VERSION
|
||||||
script_version() {
|
script_version() {
|
||||||
echo -e "\n ${CYN}$APP_NAME_LONG Helper Script Version : ${GRN}${SCRIPT_VERSION}${CRS}\n"
|
echo -e "\n ${CYN}$APP_NAME_LONG Helper Script Version :${CRS} $SCRIPT_VERSION\n"
|
||||||
exit
|
exit
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
### UPDATE SCRIPT --> TO DO
|
### UPDATE SCRIPT --> TO DO
|
||||||
|
remote_script_check() {
|
||||||
|
REMOTE_SCRIPT_URL=https://lab.c95.org/fr4nz/helium-helper/raw/branch/main/helium_helper.sh
|
||||||
|
mkdir -p $TMP
|
||||||
|
wget -P $TMP $REMOTE_SCRIPT_URL -q
|
||||||
|
chmod +x $TMP/$SCRIPT_FILE_NAME
|
||||||
|
}
|
||||||
update_script() {
|
update_script() {
|
||||||
if ! [ -f "$INSTALL_PATH/$APP_NAME.AppImage" ] ; then
|
remote_script_check
|
||||||
echo -e "\n ${RED}$APP_NAME_LONG AppImage not found! Can't update script...${CRS}"
|
|
||||||
|
### CHECK FOR LOCAL SCRIPT
|
||||||
|
if ! [ -f "$SCRIPT_PATH/$SCRIPT_FILE_NAME" ] ; then
|
||||||
|
echo -e "\n ${RED}$SCRIPT_FILE_NAME not found! Can't update script...${CRS}"
|
||||||
exit
|
exit
|
||||||
|
|
||||||
else
|
fi
|
||||||
echo -e "\n ${RED}Not implemented yet...${CRS}"
|
|
||||||
|
REMOTE_SCRIPT_VERSION=$($TMP/$SCRIPT_FILE_NAME -s | awk '{print $8}' | tr -d '\n' )
|
||||||
|
|
||||||
|
### CHECK FOR EMPTY VERSION TAGS
|
||||||
|
if [ -z "$SCRIPT_VERSION" ] ; then
|
||||||
|
echo -e "\n ${RED}Empty version tag from ${CYN}local script${RED}! Can't compare, exiting...${CRS}"
|
||||||
exit
|
exit
|
||||||
|
|
||||||
|
elif [ -z "$REMOTE_SCRIPT_VERSION" ] ; then
|
||||||
|
echo -e "\n ${RED}Empty version tag from ${CYN}remote script${RED}! Can't compare, exiting...${CRS}"
|
||||||
|
exit
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
|
### COMPARE LOCAL & REMOTE VERSION
|
||||||
|
SCRIPT_VERSION_NUM=$(echo $SCRIPT_VERSION | tr -d .)
|
||||||
|
REMOTE_SCRIPT_VERSION_NUM=$(echo $REMOTE_SCRIPT_VERSION | tr -d .)
|
||||||
|
|
||||||
|
if [ "$REMOTE_SCRIPT_VERSION" == "$SCRIPT_VERSION" ] ; then
|
||||||
|
echo -e "\n ${GRN}$SCRIPT_FILE_NAME is already up-to-date!${CRS}\n"
|
||||||
|
echo -e " ${CYN}Local Version :\t${CRS}${SCRIPT_VERSION}"
|
||||||
|
echo -e " ${CYN}Remote Version :\t${CRS}${REMOTE_SCRIPT_VERSION}\n"
|
||||||
|
|
||||||
|
elif [ "$REMOTE_SCRIPT_VERSION_NUM" -gt "$SCRIPT_VERSION_NUM" ] ; then
|
||||||
|
echo -e "\n ${YEL}$SCIPT_FILE_NAME is updatable!${CRS}\n"
|
||||||
|
echo -e " ${CYN}Local Version :\t${CRS}${SCRIPT_VERSION}"
|
||||||
|
echo -e " ${CYN}Remote Version :\t${CRS}${REMOTE_SCRIPT_VERSION}\n"
|
||||||
|
|
||||||
|
while true ; do
|
||||||
|
read -p " Update $SCRIPT_FILE_NAME? (Y/n) : " CONFIRM_SCRIPT_UPDATE
|
||||||
|
echo
|
||||||
|
|
||||||
|
if [[ "$CONFIRM_SCRIPT_UPDATE" == "" || "$CONFIRM_SCRIPT_UPDATE" == "y" || "$CONFIRM_SCRIPT_UPDATE" == "Y" ]] ; then
|
||||||
|
mv $SCRIPT_PATH/$SCRIPT_FILE_NAME $BACKUP_PATH/$SCRIPT_FILE_NAME.old
|
||||||
|
mv $TMP/$SCRIPT_FILE_NAME $SCRIPT_PATH
|
||||||
|
echo -e "\n ${GRN}$SCRIPT_FILE_NAME is up-to-date!${CRS}"
|
||||||
|
break
|
||||||
|
|
||||||
|
elif [[ "$CONFIRM_SCRIPT_UPDATE" == "n" || "$CONFIRM_SCRIPT_UPDATE" == "N" ]] ; then
|
||||||
|
echo -e " ${RED}Cancelled!${CRS}"
|
||||||
|
break
|
||||||
|
|
||||||
|
else
|
||||||
|
echo -e " ${YEL}Invalid response!${CRS}\n"
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
|
done
|
||||||
|
|
||||||
|
else
|
||||||
|
echo -e "\n ${RED}Version tags malformed or you are using a Beta version!${CRS}\n"
|
||||||
|
echo -e " ${CYN}Local Version :\t${CRS}${SCRIPT_VERSION}"
|
||||||
|
echo -e " ${CYN}Remote Version :\t${CRS}${REMOTE_SCRIPT_VERSION}\n"
|
||||||
|
echo -e " ${RED}Updating script failed...${CRS}\n"
|
||||||
|
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -339,16 +400,17 @@ compare_version() {
|
||||||
help() {
|
help() {
|
||||||
echo -e "\n${LCY}${SCRIPT_NAME}${CRS}\n"
|
echo -e "\n${LCY}${SCRIPT_NAME}${CRS}\n"
|
||||||
echo -e "$APP_NAME_LONG installer & updater script\n"
|
echo -e "$APP_NAME_LONG installer & updater script\n"
|
||||||
echo -e "Syntax: $SCRIPT_FILE_NAME [ -i | -L | -u | -r | -c | -s | -h ]\n" # | -U | -S
|
echo -e "Syntax: $SCRIPT_FILE_NAME [ -i | -l | -u | -r | -c | -s | -h ]\n" # | -U | -S | -a |
|
||||||
echo -e "Options:\n"
|
echo -e "Options:\n"
|
||||||
echo -e "\t-i\tDownload & install $APP_NAME_LONG from $SOURCE"
|
echo -e "\t-i\tDownload & install $APP_NAME_LONG from $SOURCE"
|
||||||
echo -e "\t-L\tCreate desktop launcher"
|
echo -e "\t-l\tCreate desktop launcher"
|
||||||
|
echo -e "\t-a\tCreate alias for $SCRIPT_FILE_NAME ${RED}--> Not yet working${CRS}"
|
||||||
echo -e "\t-u\tDownload & update $APP_NAME_LONG from $SOURCE"
|
echo -e "\t-u\tDownload & update $APP_NAME_LONG from $SOURCE"
|
||||||
echo -e "\t-U\tEnable automatic updates on login ${RED}--> Not yet working${CRS}"
|
echo -e "\t-U\tEnable automatic updates on login ${RED}--> Not yet working${CRS}"
|
||||||
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"
|
||||||
echo -e "\t-S\tUpdate script ${RED}--> Not yet working${CRS}"
|
echo -e "\t-S\tUpdate $SCRIPT_FILE_NAME ${RED}--> Not yet working${CRS}"
|
||||||
echo -e "\t-h\tPrint this help page.\n"
|
echo -e "\t-h\tPrint this help page.\n"
|
||||||
echo -e "Configured locations:\n"
|
echo -e "Configured locations:\n"
|
||||||
echo -e "\t${CYN}${INSTALL_PATH}${CRS}\t\tInstall location"
|
echo -e "\t${CYN}${INSTALL_PATH}${CRS}\t\tInstall location"
|
||||||
|
|
@ -369,38 +431,34 @@ exit_clean() {
|
||||||
########## MAIN ##########
|
########## MAIN ##########
|
||||||
|
|
||||||
## GET OPTIONS
|
## GET OPTIONS
|
||||||
while getopts ":i,:L,:u,:U,:r,:c,:s,:S,:h" OPTION ; do
|
while getopts ":i,:l,:a,:u,:U,:r,:c,:s,:S,:h" OPTION ; do
|
||||||
case $OPTION in
|
case $OPTION in
|
||||||
i)
|
i)
|
||||||
echo -e "\n ${YEL}Installing $APP_NAME_LONG...${CRS}"
|
echo -e "\n ${YEL}Installing $APP_NAME_LONG...${CRS}"
|
||||||
dependency_check
|
dependency_check
|
||||||
install_helium
|
install_helium
|
||||||
exit_clean
|
exit_clean ;;
|
||||||
exit ;;
|
|
||||||
|
|
||||||
L)
|
l)
|
||||||
echo -e "\n ${YEL}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 ;;
|
||||||
exit ;;
|
|
||||||
|
|
||||||
u)
|
u)
|
||||||
echo -e "\n ${YEL}Updating $APP_NAME_LONG...${CRS}"
|
echo -e "\n ${YEL}Updating $APP_NAME_LONG...${CRS}"
|
||||||
dependency_check
|
dependency_check
|
||||||
local_check
|
local_check
|
||||||
update_helium
|
update_helium
|
||||||
exit_clean
|
exit_clean ;;
|
||||||
exit ;;
|
|
||||||
|
|
||||||
U)
|
U)
|
||||||
echo -e "\n ${YEL}Enabling automatic updates...${CRS}"
|
echo -e "\n ${YEL}Enabling automatic updates...${CRS}"
|
||||||
dependency_check
|
dependency_check
|
||||||
local_check
|
local_check
|
||||||
auto_update
|
auto_update
|
||||||
exit_clean
|
exit_clean ;;
|
||||||
exit ;;
|
|
||||||
|
|
||||||
r)
|
r)
|
||||||
echo -e "\n ${YEL}Removing $APP_NAME_LONG...${CRS}"
|
echo -e "\n ${YEL}Removing $APP_NAME_LONG...${CRS}"
|
||||||
|
|
@ -412,8 +470,7 @@ while getopts ":i,:L,:u,:U,:r,:c,:s,:S,:h" OPTION ; do
|
||||||
dependency_check
|
dependency_check
|
||||||
local_check
|
local_check
|
||||||
compare_version
|
compare_version
|
||||||
exit_clean
|
exit_clean ;;
|
||||||
exit ;;
|
|
||||||
|
|
||||||
s)
|
s)
|
||||||
script_version
|
script_version
|
||||||
|
|
@ -422,10 +479,8 @@ while getopts ":i,:L,:u,:U,:r,:c,:s,:S,:h" OPTION ; do
|
||||||
S)
|
S)
|
||||||
echo -e "\n ${YEL}Updating script...${CRS}"
|
echo -e "\n ${YEL}Updating script...${CRS}"
|
||||||
dependency_check
|
dependency_check
|
||||||
local_check
|
|
||||||
update_script
|
update_script
|
||||||
exit_clean
|
exit_clean ;;
|
||||||
exit ;;
|
|
||||||
|
|
||||||
h)
|
h)
|
||||||
help
|
help
|
||||||
|
|
|
||||||
1
test.sh
Normal file
1
test.sh
Normal file
|
|
@ -0,0 +1 @@
|
||||||
|
#!/bin/bash
|
||||||
10
todo.md
10
todo.md
|
|
@ -4,6 +4,8 @@
|
||||||
- Readme updated
|
- Readme updated
|
||||||
- Desktop Entry updater
|
- Desktop Entry updater
|
||||||
- Launcher has an update option now
|
- Launcher has an update option now
|
||||||
|
- Launcher installer refined
|
||||||
|
- Clean Up
|
||||||
|
|
||||||
## Add
|
## Add
|
||||||
- Internet connectivity check in [Auto Update Script](https://lab.c95.org/fr4nz/helium-helper/src/branch/main/helium_auto_update.sh)
|
- Internet connectivity check in [Auto Update Script](https://lab.c95.org/fr4nz/helium-helper/src/branch/main/helium_auto_update.sh)
|
||||||
|
|
@ -25,8 +27,8 @@
|
||||||
|
|
||||||
## Notes
|
## Notes
|
||||||
|
|
||||||
|
- Auto Update
|
||||||
```sh
|
```sh
|
||||||
############# TO DO
|
|
||||||
while true ; do
|
while true ; do
|
||||||
read -p " Enable automatic update check on login? (y/N) : " AUTO_UPDATE
|
read -p " Enable automatic update check on login? (y/N) : " AUTO_UPDATE
|
||||||
|
|
||||||
|
|
@ -57,5 +59,9 @@
|
||||||
fi
|
fi
|
||||||
|
|
||||||
done
|
done
|
||||||
#############
|
```
|
||||||
|
|
||||||
|
- Script update
|
||||||
|
```sh
|
||||||
|
$SCRIPT_PATH/$SCRIPT_FILE_NAME -s | awk {'print $8'}
|
||||||
```
|
```
|
||||||
Loading…
Add table
Add a link
Reference in a new issue