Script updater added

This commit is contained in:
Fr4nz D13trich 2025-12-23 17:47:06 +01:00
parent fe0546542f
commit f56c1ac3ea
3 changed files with 134 additions and 72 deletions

View file

@ -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
View file

@ -0,0 +1 @@
#!/bin/bash

10
todo.md
View file

@ -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'}
``` ```