Compare commits
18 commits
1ea3c4c1a3
...
8e1e61b4c1
| Author | SHA1 | Date | |
|---|---|---|---|
| 8e1e61b4c1 | |||
| 5910d664d4 | |||
| b67067fccf | |||
| 587dad376a | |||
| 8f864c0a2b | |||
| 904765ada3 | |||
| f6765bb49f | |||
| 95960ccb1c | |||
| a181243c00 | |||
| f909883f57 | |||
| f633a04f98 | |||
| 7b2693a0df | |||
| 3ad37ea244 | |||
| 55587dfe4b | |||
| dc690e80b7 | |||
| 73d66859d6 | |||
| 46d2c3e91a | |||
| 375ff9a2b7 |
8 changed files with 474 additions and 94 deletions
11
README.md
11
README.md
|
|
@ -2,14 +2,15 @@
|
||||||
## Overview
|
## Overview
|
||||||
### Helium_Helper.sh
|
### Helium_Helper.sh
|
||||||
- Interactive installer and updater script
|
- Interactive installer and updater script
|
||||||
- Installs to `/home/<USER>/.apps/Helium` | changeable in line 15 `INSTALL_PATH`
|
- Installs to `/home/<USER>/.apps/Helium` | changeable in line 27 `INSTALL_PATH`
|
||||||
- Assumes:
|
- Assumes:
|
||||||
- Presence of `/home/<USER>/.apps/Helium` when updating | changeable in line 15 `INSTALL_PATH`
|
- Presence of `/home/<USER>/.apps/Helium` when updating | changeable in line 27 `INSTALL_PATH`
|
||||||
- Executable named `helium-browser.AppImage` | for convenience so launchers don't have to be edited at each update
|
- Executable named `Helium.AppImage` | for convenience so launchers don't have to be edited at each update
|
||||||
- Keeps prior AppImage as `helium-browser.OldAppImage` which will be replaced at every update
|
- Keeps prior AppImage as `Helium.old` which will be replaced at every update
|
||||||
|
- Adds desktop launcher to `/home/<USER>/.local/share/applications`
|
||||||
|
|
||||||
### Helium_Auto_Update.sh
|
### Helium_Auto_Update.sh
|
||||||
- Automatic updater script for e.g. `cron`
|
- Automatic updater script
|
||||||
- Installs to `/home/<USER>/.apps/Helium` | changeable in line 8 `INSTALL_PATH`
|
- Installs to `/home/<USER>/.apps/Helium` | changeable in line 8 `INSTALL_PATH`
|
||||||
- Assumes:
|
- Assumes:
|
||||||
- Presence of `/home/<USER>/.apps/Helium` when updating | changeable in line 8 `INSTALL_PATH`
|
- Presence of `/home/<USER>/.apps/Helium` when updating | changeable in line 8 `INSTALL_PATH`
|
||||||
|
|
|
||||||
BIN
assets/icon/helium.png
Normal file
BIN
assets/icon/helium.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 40 KiB |
24
assets/launcher/helium.desktop.template
Normal file
24
assets/launcher/helium.desktop.template
Normal file
|
|
@ -0,0 +1,24 @@
|
||||||
|
[Desktop Entry]
|
||||||
|
Version=1.0
|
||||||
|
Name=Helium Web Browser
|
||||||
|
GenericName=Web Browser
|
||||||
|
Comment=Access the Internet
|
||||||
|
Exec=%APP_LOCATION% %U
|
||||||
|
StartupNotify=true
|
||||||
|
StartupWMClass=helium
|
||||||
|
Terminal=false
|
||||||
|
Icon=%ICON_LOCATION%
|
||||||
|
Type=Application
|
||||||
|
Categories=Network;WebBrowser;
|
||||||
|
MimeType=application/pdf;application/rdf+xml;application/rss+xml;application/xhtml+xml;application/xhtml_xml;application/xml;image/gif;image/jpeg;image/png;image/webp;text/html;text/xml;x-scheme-handler/http;x-scheme-handler/https;
|
||||||
|
Actions=new-window;new-private-window;
|
||||||
|
X-AppImage-Version=%APP_VERSION%
|
||||||
|
|
||||||
|
[Desktop Action new-window]
|
||||||
|
Name=New Window
|
||||||
|
Exec=%APP_LOCATION%
|
||||||
|
|
||||||
|
[Desktop Action new-private-window]
|
||||||
|
Name=New Incognito Window
|
||||||
|
Exec=%APP_LOCATION% --incognito
|
||||||
|
|
||||||
24
assets/launcher/helium.desktop.txt
Normal file
24
assets/launcher/helium.desktop.txt
Normal file
|
|
@ -0,0 +1,24 @@
|
||||||
|
[Desktop Entry]
|
||||||
|
Version=1.0
|
||||||
|
Name=Helium Web Browser
|
||||||
|
GenericName=Web Browser
|
||||||
|
Comment=Access the Internet
|
||||||
|
Exec=%APP_LOCATION% %U
|
||||||
|
StartupNotify=true
|
||||||
|
StartupWMClass=helium
|
||||||
|
Terminal=false
|
||||||
|
Icon=%ICON_LOCATION%
|
||||||
|
Type=Application
|
||||||
|
Categories=Network;WebBrowser;
|
||||||
|
MimeType=application/pdf;application/rdf+xml;application/rss+xml;application/xhtml+xml;application/xhtml_xml;application/xml;image/gif;image/jpeg;image/png;image/webp;text/html;text/xml;x-scheme-handler/http;x-scheme-handler/https;
|
||||||
|
Actions=new-window;new-private-window;
|
||||||
|
X-AppImage-Version=%APP_VERSION%
|
||||||
|
|
||||||
|
[Desktop Action new-window]
|
||||||
|
Name=New Window
|
||||||
|
Exec=%APP_LOCATION%
|
||||||
|
|
||||||
|
[Desktop Action new-private-window]
|
||||||
|
Name=New Incognito Window
|
||||||
|
Exec=%APP_LOCATION% --incognito
|
||||||
|
|
||||||
469
helium_helper.sh
469
helium_helper.sh
|
|
@ -1,57 +1,95 @@
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# HELIUM BOWSER INSTALL & UPDATE SCRIPT ---> INTERACTIVE
|
# Helium BOWSER INSTALL & UPDATE SCRIPT ---> INTERACTIVE
|
||||||
|
|
||||||
|
########## PREREQUISITES ###########
|
||||||
|
set -e
|
||||||
|
|
||||||
## SOME COLOR
|
## SOME COLOR
|
||||||
CYN="\e[0;36m"
|
CYN="\e[0;36m"
|
||||||
YEL="\e[0;33m"
|
YEL="\e[0;33m"
|
||||||
RED="\e[0;31m"
|
RED="\e[0;31m"
|
||||||
GRN="\e[0;32m"
|
GRN="\e[0;32m"
|
||||||
|
LCY="\e[1;36m"
|
||||||
CRS="\e[0m"
|
CRS="\e[0m"
|
||||||
|
|
||||||
## FOLDER & GLOBAL VARIABLES
|
## GLOBAL VARIABLES
|
||||||
SCRIPT_VERSION="0.4"
|
APP_NAME="Helium"
|
||||||
mkdir -p /tmp/Helium
|
APP_NAME_LONG="Helium Web Browser"
|
||||||
TMP=/tmp/Helium
|
SOURCE="GitHub"
|
||||||
INSTALL_PATH=$HOME/.apps/Helium
|
SCRIPT_NAME="$APP_NAME Helper Script"
|
||||||
PROFILE=$HOME/.profile
|
SCRIPT_FILE_NAME="helium_helper.sh"
|
||||||
MISSING=$(cat $TMP/missingDeps 2>/dev/null)
|
SCRIPT_VERSION="0.5.1"
|
||||||
DEPENDENCIES=("curl" "wget")
|
DATE=$(date)
|
||||||
GIT_VERSION=$(curl -s https://api.github.com/repos/imputnet/helium-linux/releases/latest | grep "tag_name" | tr -d \", | awk '{print $2}')
|
|
||||||
|
|
||||||
### SCRIPT DEPENDENCIES
|
## LOCATIONS
|
||||||
dependency_check() {
|
TMP=/tmp/$APP_NAME
|
||||||
|
INSTALL_PATH=$HOME/.apps/$APP_NAME
|
||||||
|
CONFIG_PATH=$INSTALL_PATH/assets
|
||||||
|
BACKUP_PATH=$INSTALL_PATH/assets/backup
|
||||||
|
LOG_PATH=$INSTALL_PATH/assets/logs
|
||||||
|
LOG=$LOG_PATH/log
|
||||||
|
LAUNCHER_PATH=$HOME/.local/share/applications
|
||||||
|
SCRIPT_PATH=$HOME/.local/bin
|
||||||
|
#PROFILE=$HOME/.profile ### for AUTO UPDATE
|
||||||
|
|
||||||
|
########## FUNCTIONS ###########
|
||||||
|
|
||||||
|
### DEPENDENCIES
|
||||||
|
cmd_query() {
|
||||||
local PACKAGE="$1"
|
local PACKAGE="$1"
|
||||||
|
|
||||||
if command -v "$PACKAGE" >/dev/null 2>&1 ; then
|
if ! command -v "$PACKAGE" >/dev/null 2>&1 ; then
|
||||||
:
|
echo " - $PACKAGE" >> $TMP/missingDeps
|
||||||
|
|
||||||
else
|
|
||||||
echo "$PACKAGE" >> $TMP/missingDeps
|
|
||||||
|
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
for PACKAGE in "${DEPENDENCIES[@]}" ; do
|
dependency_check () {
|
||||||
dependency_check "$PACKAGE"
|
DEPENDENCIES=("curl" "wget")
|
||||||
|
mkdir -p $TMP
|
||||||
|
|
||||||
|
for PACKAGE in "${DEPENDENCIES[@]}" ; do
|
||||||
|
cmd_query "$PACKAGE"
|
||||||
|
|
||||||
done
|
done
|
||||||
|
|
||||||
if ! [ "$MISSING" ] ; then
|
if [ -f "$TMP/missingDeps" ] ; then
|
||||||
:
|
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}"
|
||||||
|
exit_clean
|
||||||
|
exit
|
||||||
|
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
else
|
### CHECK LOCAL INSTALL
|
||||||
echo -e "\n ${RED}Following dependencies are missing :\n\n${YEL}$MISSING\n\n ${CYN}Please install and re-run script !${CRS}"
|
local_check() {
|
||||||
rm $TMP/missingDeps
|
if ! [ -d "$INSTALL_PATH" ] ; then
|
||||||
exit 1
|
echo -e "\n ${RED}$APP_NAME_LONG directory not found!${CRS}"
|
||||||
|
install_helium
|
||||||
|
exit
|
||||||
|
|
||||||
|
elif ! [ -f "$INSTALL_PATH/$APP_NAME.AppImage" ] ; then
|
||||||
|
echo -e "\n ${RED}$APP_NAME_LONG directory found but no executable named ${CYN}$APP_NAME.AppImage${RED}!${CRS}"
|
||||||
|
install_helium
|
||||||
|
exit
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
## CHECK LOCAL INSTALL
|
### INSTALL
|
||||||
install_helium() {
|
install_helium() {
|
||||||
|
if [ -f "$INSTALL_PATH/$APP_NAME.AppImage" ] ; then
|
||||||
|
echo -e "\n ${CYN}$APP_NAME_LONG AppImage found! Trying to update...${CRS}"
|
||||||
|
update_helium
|
||||||
|
exit
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
while true ; do
|
while true ; do
|
||||||
read -p " Download and install Helium from GitHub? (Y/n) : " CONFIRM_INSTALL
|
read -p " Download and install $APP_NAME_LONG from $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
|
||||||
GIT_URL=$(curl -s https://api.github.com/repos/imputnet/helium-linux/releases/latest | grep "browser_download_url" | grep "x86_64.AppImage" | grep -v "zsync" | tr -d \" | awk '{print $2}')
|
GIT_URL=$(curl -s https://api.github.com/repos/imputnet/helium-linux/releases/latest | grep "browser_download_url" | grep "x86_64.AppImage" | grep -v "zsync" | tr -d \" | awk '{print $2}')
|
||||||
|
|
@ -59,92 +97,357 @@ install_helium() {
|
||||||
wget -P $TMP $GIT_URL -q --show-progress
|
wget -P $TMP $GIT_URL -q --show-progress
|
||||||
chmod +x $TMP/$GIT_FILENAME
|
chmod +x $TMP/$GIT_FILENAME
|
||||||
mkdir -p $INSTALL_PATH
|
mkdir -p $INSTALL_PATH
|
||||||
mv $TMP/$GIT_FILENAME $INSTALL_PATH/helium-browser.AppImage
|
mv $TMP/$GIT_FILENAME $INSTALL_PATH/$APP_NAME.AppImage
|
||||||
echo -e "\n ${GRN}Helium is installed !${CRS}\n"
|
echo -e "\n ${GRN}$APP_NAME_LONG is installed!${CRS}\n"
|
||||||
rm -rf $TMP
|
add_launcher
|
||||||
exit 0
|
exit_clean
|
||||||
|
|
||||||
elif [[ "$CONFIRM_INSTALL" == "n" || "$CONFIRM_INSTALL" == "N" ]] ; then
|
elif [[ "$CONFIRM_INSTALL" == "n" || "$CONFIRM_INSTALL" == "N" ]] ; then
|
||||||
echo -e "\n ${RED}Installation cancelled !${CRS}\n"
|
echo -e "\n ${RED}Installation cancelled!${CRS}\n"
|
||||||
exit 1
|
exit
|
||||||
|
|
||||||
else
|
else
|
||||||
echo -e " ${YEL}Invalid response !${CRS}\n"
|
echo -e " ${YEL}Invalid response!${CRS}\n"
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
if ! [ -d "$INSTALL_PATH" ] ; then
|
### LAUNCHER --> TO DO
|
||||||
echo -e "\n ${RED}Helium directory not found !${CRS}"
|
add_launcher() {
|
||||||
install_helium
|
if [ -f "$LAUNCHER_PATH/$APP_NAME.desktop" ] ; then
|
||||||
|
echo -e "\n ${RED}${APP_NAME}.desktop already exists!${CRS}"
|
||||||
|
exit
|
||||||
|
|
||||||
|
elif [ -f "$INSTALL_PATH/$APP_NAME.AppImage" ] ; then
|
||||||
|
while true ; do
|
||||||
|
read -p " Add $APP_NAME_LONG launcher to $LAUNCHER_PATH? (Y/n) : " CONFIRM_LAUNCHER
|
||||||
|
echo
|
||||||
|
|
||||||
elif ! [ -f "$INSTALL_PATH/helium-browser.AppImage" ] ; then
|
if [[ "$CONFIRM_LAUNCHER" == "" || "$CONFIRM_LAUNCHER" == "y" || "$CONFIRM_LAUNCHER" == "Y" ]] ; then
|
||||||
echo -e "\n ${RED}Helium directory found but no executable named ${CYN}helium-browser.AppImage ${RED}!${CRS}"
|
LAUNCHER_URL=https://lab.c95.org/fr4nz/helium-helper/raw/branch/main/assets/launcher/helium.desktop.template
|
||||||
install_helium
|
ICON_URL=https://lab.c95.org/fr4nz/helium-helper/raw/branch/main/assets/icon/helium.png
|
||||||
|
LOCAL_VERSION=$($INSTALL_PATH/$APP_NAME.AppImage --version | awk '{print $2}')
|
||||||
|
wget -P $TMP $LAUNCHER_URL -q --show-progress
|
||||||
|
wget -P $TMP $ICON_URL -q --show-progress
|
||||||
|
sed -i "s|%APP_LOCATION%|$INSTALL_PATH/$APP_NAME.AppImage|" $TMP/helium.desktop.template
|
||||||
|
sed -i "s|%ICON_LOCATION%|$CONFIG_PATH/icon/helium.png|" $TMP/helium.desktop.template
|
||||||
|
sed -i "s|%APP_VERSION%|$LOCAL_VERSION|" $TMP/helium.desktop.template
|
||||||
|
mkdir -p $LAUNCHER_PATH $BACKUP_PATH $CONFIG_PATH/icon
|
||||||
|
cp $TMP/helium.desktop.template $LAUNCHER_PATH/$APP_NAME.desktop
|
||||||
|
mv $TMP/helium.desktop.template $BACKUP_PATH/$APP_NAME.desktop.backup
|
||||||
|
mv $TMP/helium.png $CONFIG_PATH/icon
|
||||||
|
echo -e "\n ${GRN}$APP_NAME_LONG launcher is set up!${CRS}\n"
|
||||||
|
exit_clean
|
||||||
|
|
||||||
else
|
elif [[ "$CONFIRM_LAUNCHER" == "n" || "$CONFIRM_LAUNCHER" == "N" ]] ; then
|
||||||
:
|
echo -e "\n ${RED}Launcher creation cancelled!${CRS}\n"
|
||||||
|
exit
|
||||||
|
|
||||||
fi
|
else
|
||||||
|
echo -e " ${YEL}Invalid response!${CRS}\n"
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
## COMPARE
|
done
|
||||||
|
|
||||||
|
else
|
||||||
|
echo -e "\n ${RED}$APP_NAME_LONG AppImage not found! Can't add launcher...${CRS}"
|
||||||
|
install_helium
|
||||||
|
exit
|
||||||
|
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
### UPDATE
|
||||||
update_helium() {
|
update_helium() {
|
||||||
|
LOCAL_VERSION=$($INSTALL_PATH/$APP_NAME.AppImage --version | awk '{print $2}')
|
||||||
|
GIT_VERSION=$(curl -s https://api.github.com/repos/imputnet/helium-linux/releases/latest | grep "tag_name" | tr -d \", | awk '{print $2}')
|
||||||
|
|
||||||
while true ; do
|
### CHECK FOR EMPTY VERSION TAGS
|
||||||
read -p " Download and update Helium from GitHub? (Y/n) : " CONFIRM
|
if [ -z "$GIT_VERSION" ] ; then
|
||||||
|
echo -e "\n ${RED}Empty version tag from ${CYN}$SOURCE${RED}! Can't compare, exiting...${CRS}"
|
||||||
|
exit
|
||||||
|
|
||||||
if [[ "$CONFIRM" == "" || "$CONFIRM" == "y" || "$CONFIRM" == "Y" ]] ; then
|
elif [ -z "$LOCAL_VERSION" ] ; then
|
||||||
GIT_URL=$(curl -s https://api.github.com/repos/imputnet/helium-linux/releases/latest | grep "browser_download_url" | grep "x86_64.AppImage" | grep -v "zsync" | tr -d \" | awk '{print $2}')
|
echo -e "\n ${RED}Empty version tag from ${CYN}local AppImage${RED}! Can't compare, exiting...${CRS}"
|
||||||
GIT_FILENAME=$(curl -s https://api.github.com/repos/imputnet/helium-linux/releases/latest | grep "browser_download_url" | grep "x86_64.AppImage" | grep -v "zsync" | tr -d \" | awk '{print $2}' | awk -F'/' '{print $9}')
|
exit
|
||||||
wget -P $TMP $GIT_URL -q --show-progress
|
|
||||||
chmod +x $TMP/$GIT_FILENAME
|
|
||||||
rm $INSTALL_PATH/helium-browser.OldAppImage >/dev/null 2>&1
|
|
||||||
mv $INSTALL_PATH/helium-browser.AppImage $INSTALL_PATH/helium-browser.OldAppImage >/dev/null 2>&1
|
|
||||||
mv $TMP/$GIT_FILENAME $INSTALL_PATH/helium-browser.AppImage
|
|
||||||
echo -e "\n ${GRN}Helium is up-to-date !${CRS}\n"
|
|
||||||
break
|
|
||||||
|
|
||||||
elif [[ "$CONFIRM" == "n" || "$CONFIRM" == "N" ]] ; then
|
fi
|
||||||
echo -e "\n ${RED}Update cancelled !${CRS}\n"
|
|
||||||
exit 1
|
### COMPARE LOCAL & REMOTE VERSION
|
||||||
|
LOCAL_VERSION_NUM=$(echo $LOCAL_VERSION | tr -d .)
|
||||||
|
GIT_VERSION_NUM=$(echo $GIT_VERSION | tr -d .)
|
||||||
|
|
||||||
|
if [ "$GIT_VERSION" == "$LOCAL_VERSION" ] ; then
|
||||||
|
echo -e "\n ${GRN}$APP_NAME_LONG is already up-to-date!${CRS}\n"
|
||||||
|
|
||||||
|
elif [ "$GIT_VERSION_NUM" -gt "$LOCAL_VERSION_NUM" ] ; then
|
||||||
|
echo -e "\n ${RED}$APP_NAME_LONG is updatable!${CRS}\n"
|
||||||
|
echo -e " ${CYN}Local Version :\t${CRS}${LOCAL_VERSION}"
|
||||||
|
echo -e " ${CYN}$SOURCE Version :\t${CRS}${GIT_VERSION}\n"
|
||||||
|
|
||||||
|
while true ; do
|
||||||
|
read -p " Download and update $APP_NAME_LONG from $SOURCE? (Y/n) : " CONFIRM
|
||||||
|
echo
|
||||||
|
|
||||||
|
if [[ "$CONFIRM" == "" || "$CONFIRM" == "y" || "$CONFIRM" == "Y" ]] ; then
|
||||||
|
GIT_URL=$(curl -s https://api.github.com/repos/imputnet/helium-linux/releases/latest | grep "browser_download_url" | grep "x86_64.AppImage" | grep -v "zsync" | tr -d \" | awk '{print $2}')
|
||||||
|
GIT_FILENAME=$(curl -s https://api.github.com/repos/imputnet/helium-linux/releases/latest | grep "browser_download_url" | grep "x86_64.AppImage" | grep -v "zsync" | tr -d \" | awk '{print $2}' | awk -F'/' '{print $9}')
|
||||||
|
mkdir -p $TMP
|
||||||
|
wget -P $TMP $GIT_URL -q --show-progress
|
||||||
|
chmod +x $TMP/$GIT_FILENAME
|
||||||
|
if [ -f "$INSTALL_PATH/$APP_NAME.old" ] ; then
|
||||||
|
rm $INSTALL_PATH/$APP_NAME.old
|
||||||
|
fi
|
||||||
|
mv $INSTALL_PATH/$APP_NAME.AppImage $INSTALL_PATH/$APP_NAME.old
|
||||||
|
mv $TMP/$GIT_FILENAME $INSTALL_PATH/$APP_NAME.AppImage
|
||||||
|
echo -e "\n ${GRN}$APP_NAME_LONG is up-to-date !${CRS}\n"
|
||||||
|
break
|
||||||
|
|
||||||
|
elif [[ "$CONFIRM" == "n" || "$CONFIRM" == "N" ]] ; then
|
||||||
|
echo -e "\n ${RED}Update cancelled!${CRS}\n"
|
||||||
|
exit
|
||||||
|
|
||||||
|
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}${LOCAL_VERSION}"
|
||||||
|
echo -e " ${CYN}$SOURCE Version :\t${CRS}${GIT_VERSION}\n"
|
||||||
|
echo -e " ${RED}Update failed... Exiting...${CRS}\n"
|
||||||
|
exit
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
### AUTOMATIC UPDATE --> TO DO
|
||||||
|
auto_update() {
|
||||||
|
if ! [ -f "$INSTALL_PATH/$APP_NAME.AppImage" ] ; then
|
||||||
|
echo -e "\n ${RED}$APP_NAME AppImage not found! Can't add auto update script...${CRS}"
|
||||||
|
exit
|
||||||
|
|
||||||
|
else
|
||||||
|
echo -e "\n ${RED}Not implemented yet...${CRS}"
|
||||||
|
exit
|
||||||
|
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
### REMOVE
|
||||||
|
remove_helium() {
|
||||||
|
if [ -d "$INSTALL_PATH" ] ; then
|
||||||
|
|
||||||
|
while true ; do
|
||||||
|
read -p " Remove $APP_NAME_LONG folder $INSTALL_PATH? (Y/n) : " CONFIRM_REMOVE
|
||||||
|
|
||||||
|
if [[ "$CONFIRM_REMOVE" == "" || "$CONFIRM_REMOVE" == "y" || "$CONFIRM_REMOVE" == "Y" ]] ; then
|
||||||
|
rm -rf $INSTALL_PATH
|
||||||
|
rm $LAUNCHER_PATH/$APP_NAME.desktop
|
||||||
|
echo -e "\n ${RED}$APP_NAME_LONG removed!${CRS}\n"
|
||||||
|
exit
|
||||||
|
|
||||||
|
elif [[ "$CONFIRM_REMOVE" == "n" || "$CONFIRM_REMOVE" == "N" ]] ; then
|
||||||
|
echo -e "\n ${RED}Removal cancelled!${CRS}\n"
|
||||||
|
exit
|
||||||
|
|
||||||
else
|
else
|
||||||
echo -e " ${YEL}Invalid response !${CRS}\n"
|
echo -e " ${YEL}Invalid response!${CRS}\n"
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
done
|
done
|
||||||
|
|
||||||
|
else
|
||||||
|
echo -e "\n ${RED}Can't remove $APP_NAME_LONG! ${YEL}$INSTALL_PATH ${RED}directory not found...${CRS}\n"
|
||||||
|
exit
|
||||||
|
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
LOCAL_VERSION=$($INSTALL_PATH/helium-browser.AppImage --version | awk '{print $2}')
|
### SCRIPT VERSION
|
||||||
|
script_version() {
|
||||||
|
echo -e "\n ${CYN}$APP_NAME_LONG Helper Script Version : ${GRN}${SCRIPT_VERSION}${CRS}\n"
|
||||||
|
exit
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
### CHECK FROM EMPTY VERSION TAGS
|
### UPDATE SCRIPT --> TO DO
|
||||||
if [ -z "$GIT_VERSION" ] ; then
|
update_script() {
|
||||||
echo -e "\n ${RED}Empty version tag from ${CYN}GitHub ${RED}! Can't compare, exiting ...${CRS}"
|
if ! [ -f "$INSTALL_PATH/$APP_NAME.AppImage" ] ; then
|
||||||
exit 1
|
echo -e "\n ${RED}$APP_NAME_LONG AppImage not found! Can't update script...${CRS}"
|
||||||
|
exit
|
||||||
|
|
||||||
|
else
|
||||||
|
echo -e "\n ${RED}Not implemented yet...${CRS}"
|
||||||
|
exit
|
||||||
|
|
||||||
elif [ -z "$LOCAL_VERSION" ] ; then
|
fi
|
||||||
echo -e "\n ${RED}Empty version tag from ${CYN}local AppImage ${RED}! Can't compare, exiting ...${CRS}"
|
}
|
||||||
exit 1
|
|
||||||
|
|
||||||
else
|
### COMPARE APPIMAGE VERSION
|
||||||
:
|
compare_version() {
|
||||||
|
LOCAL_VERSION=$($INSTALL_PATH/$APP_NAME.AppImage --version | awk '{print $2}')
|
||||||
|
GIT_VERSION=$(curl -s https://api.github.com/repos/imputnet/helium-linux/releases/latest | grep "tag_name" | tr -d \", | awk '{print $2}')
|
||||||
|
|
||||||
fi
|
### CHECK FOR EMPTY VERSION TAGS
|
||||||
|
if [ -z "$GIT_VERSION" ] ; then
|
||||||
|
echo -e "\n ${RED}Empty version tag from ${CYN}$SOURCE${RED}! Can't compare, exiting...${CRS}"
|
||||||
|
exit
|
||||||
|
|
||||||
if [ "$GIT_VERSION" == "$LOCAL_VERSION" ] ; then
|
elif [ -z "$LOCAL_VERSION" ] ; then
|
||||||
echo -e "\n ${GRN}Helium is up-to-date !${CRS}\n"
|
echo -e "\n ${RED}Empty version tag from ${CYN}local AppImage${RED}! Can't compare, exiting...${CRS}"
|
||||||
|
exit
|
||||||
|
|
||||||
else
|
fi
|
||||||
echo -e "\n ${RED}Helium is updatable !${CRS}\n"
|
|
||||||
echo -e " ${CYN}Local Version : ${CRS}${LOCAL_VERSION}"
|
|
||||||
echo -e " ${CYN}GitHub Version : ${CRS}${GIT_VERSION}\n"
|
|
||||||
update_helium
|
|
||||||
|
|
||||||
fi
|
### COMPARE LOCAL & REMOTE VERSION
|
||||||
|
LOCAL_VERSION_NUM=$(echo $LOCAL_VERSION | tr -d .)
|
||||||
|
GIT_VERSION_NUM=$(echo $GIT_VERSION | tr -d .)
|
||||||
|
|
||||||
rm -rf $TMP
|
if [ "$GIT_VERSION" == "$LOCAL_VERSION" ] ; then
|
||||||
|
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}$SOURCE Version :\t${CRS}${GIT_VERSION}\n"
|
||||||
|
exit
|
||||||
|
|
||||||
|
elif [ "$GIT_VERSION_NUM" -gt "$LOCAL_VERSION_NUM" ] ; then
|
||||||
|
echo -e "\n ${YEL}$APP_NAME_LONG is updatable!${CRS}\n"
|
||||||
|
echo -e " ${CYN}Local Version :\t${CRS}${LOCAL_VERSION}"
|
||||||
|
echo -e " ${CYN}$SOURCE Version :\t${CRS}${GIT_VERSION}\n"
|
||||||
|
exit
|
||||||
|
|
||||||
|
else
|
||||||
|
echo -e "\n ${RED}Version tags malformed or you are using a Beta version!${CRS}\n"
|
||||||
|
echo -e " ${CYN}Local Version :\t${CRS}${LOCAL_VERSION}"
|
||||||
|
echo -e " ${CYN}$SOURCE Version :\t${CRS}${GIT_VERSION}\n"
|
||||||
|
echo -e " ${RED}Update failed ... Exiting ...${CRS}\n"
|
||||||
|
exit
|
||||||
|
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
exit 0
|
### HELP
|
||||||
|
help() {
|
||||||
|
echo -e "\n${LCY}${SCRIPT_NAME}${CRS}\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 "Options:\n"
|
||||||
|
echo -e "\t-i\tDownload & install $APP_NAME_LONG from $SOURCE"
|
||||||
|
echo -e "\t-L\tCreate desktop launcher"
|
||||||
|
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-r\tRemove $APP_NAME_LONG"
|
||||||
|
echo -e "\t-c\tCompare local to remote version"
|
||||||
|
echo -e "\t-s\tShow script version"
|
||||||
|
#echo -e "\t-S\tUpdate script ${RED}--> Not yet working${CRS}"
|
||||||
|
echo -e "\t-h\tPrint this help page.\n"
|
||||||
|
echo -e "Configured locations:\n"
|
||||||
|
echo -e "\t${CYN}${INSTALL_PATH}${CRS}\t\tInstall location"
|
||||||
|
echo -e "\t${CYN}${LAUNCHER_PATH}${CRS}\tLauncher location"
|
||||||
|
echo -e "\t${CYN}${SCRIPT_PATH}${CRS}\t\t\tScript location\n"
|
||||||
|
}
|
||||||
|
|
||||||
|
### EXIT CLEAN
|
||||||
|
exit_clean() {
|
||||||
|
if [ -d "$TMP" ] ; then
|
||||||
|
rm -rf $TMP
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
|
exit
|
||||||
|
}
|
||||||
|
|
||||||
|
########## MAIN ##########
|
||||||
|
|
||||||
|
## GET OPTIONS
|
||||||
|
while getopts ":i,:L,:u,:U,:r,:c,:s,:S,:h" OPTION ; do
|
||||||
|
case $OPTION in
|
||||||
|
i)
|
||||||
|
echo -e "\n ${YEL}Installing $APP_NAME_LONG...${CRS}"
|
||||||
|
dependency_check
|
||||||
|
local_check
|
||||||
|
install_helium
|
||||||
|
exit_clean
|
||||||
|
exit ;;
|
||||||
|
|
||||||
|
L)
|
||||||
|
echo -e "\n ${YEL}Adding $APP_NAME_LONG launcher...${CRS}"
|
||||||
|
dependency_check
|
||||||
|
local_check
|
||||||
|
add_launcher
|
||||||
|
exit_clean
|
||||||
|
exit ;;
|
||||||
|
|
||||||
|
u)
|
||||||
|
echo -e "\n ${YEL}Updating $APP_NAME_LONG...${CRS}"
|
||||||
|
dependency_check
|
||||||
|
local_check
|
||||||
|
update_helium
|
||||||
|
exit_clean
|
||||||
|
exit ;;
|
||||||
|
|
||||||
|
U)
|
||||||
|
echo -e "\n ${YEL}Enabling automatic updates...${CRS}"
|
||||||
|
dependency_check
|
||||||
|
local_check
|
||||||
|
auto_update
|
||||||
|
exit_clean
|
||||||
|
exit ;;
|
||||||
|
|
||||||
|
r)
|
||||||
|
echo -e "\n ${YEL}Removing $APP_NAME_LONG...${CRS}"
|
||||||
|
remove_helium
|
||||||
|
exit ;;
|
||||||
|
|
||||||
|
c)
|
||||||
|
echo -e "\n ${YEL}Comparing remote to local version...${CRS}"
|
||||||
|
dependency_check
|
||||||
|
local_check
|
||||||
|
compare_version
|
||||||
|
exit_clean
|
||||||
|
exit ;;
|
||||||
|
|
||||||
|
s)
|
||||||
|
script_version
|
||||||
|
exit ;;
|
||||||
|
|
||||||
|
S)
|
||||||
|
echo -e "\n ${YEL}Updating script...${CRS}"
|
||||||
|
dependency_check
|
||||||
|
local_check
|
||||||
|
update_script
|
||||||
|
exit_clean
|
||||||
|
exit ;;
|
||||||
|
|
||||||
|
h)
|
||||||
|
help
|
||||||
|
exit;;
|
||||||
|
|
||||||
|
*)
|
||||||
|
echo -e "\n${YEL}Option ${RED}-t${YEL} not recognized... Refer to help below!${CRS}"
|
||||||
|
help
|
||||||
|
exit;;
|
||||||
|
|
||||||
|
esac
|
||||||
|
|
||||||
|
done
|
||||||
|
|
||||||
|
## DEPENDENCY CHECK
|
||||||
|
dependency_check
|
||||||
|
|
||||||
|
## CHECK FOR LOCAL INSTALL
|
||||||
|
local_check
|
||||||
|
|
||||||
|
## UPDATE
|
||||||
|
update_helium
|
||||||
|
|
||||||
|
## CLEAN
|
||||||
|
exit_clean
|
||||||
|
|
|
||||||
Binary file not shown.
|
Before Width: | Height: | Size: 371 KiB |
12
test.sh
Executable file
12
test.sh
Executable file
|
|
@ -0,0 +1,12 @@
|
||||||
|
#!/bin/bash
|
||||||
|
TMP=/tmp/Helium
|
||||||
|
add_launcher() {
|
||||||
|
if [ -f "$INSTALL_PATH/helium-browser.AppImage" ] ; then
|
||||||
|
|
||||||
|
|
||||||
|
else
|
||||||
|
echo -e "\n ${RED}Helium AppImage not found! Can't add launcher...${CRS}"
|
||||||
|
exit
|
||||||
|
|
||||||
|
fi
|
||||||
|
}
|
||||||
28
todo.md
28
todo.md
|
|
@ -1,13 +1,27 @@
|
||||||
# To Do List Helium installer
|
# To Do List Helium installer
|
||||||
|
|
||||||
## Fix
|
## Last Jobs
|
||||||
- Auto Update implementation
|
- Improved Version comparasing
|
||||||
|
- Clean up function added
|
||||||
|
- Remover function added
|
||||||
|
- Dummy functions added for:
|
||||||
|
- Auto Update
|
||||||
|
- Script update
|
||||||
|
- Dependency check fixed
|
||||||
|
- Launcher function works
|
||||||
|
- Remover extended
|
||||||
|
- Readme updated
|
||||||
|
|
||||||
|
|
||||||
## Add
|
## Add
|
||||||
- Internet connectivity check in [Auto Update Script](https://lab.c95.org/fr4nz/shell-scripts/src/branch/main/helium-browser/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)
|
||||||
- Desktop entry [Helper Script](https://lab.c95.org/fr4nz/shell-scripts/src/branch/main/helium-browser/helium_helper.sh)
|
- Desktop entry updater [Helper Script](https://lab.c95.org/fr4nz/helium-helper/src/branch/main/helium_helper.sh) & [Auto Update Script](https://lab.c95.org/fr4nz/helium-helper/src/branch/main/helium_auto_update.sh)
|
||||||
- Desktop entry updater [Helper Script](https://lab.c95.org/fr4nz/shell-scripts/src/branch/main/helium-browser/helium_helper.sh)
|
- Auto update setup
|
||||||
- create help function
|
- shell recognition
|
||||||
|
- Script updater
|
||||||
|
- Architecture detection
|
||||||
|
- Uninstaller --> Partially done
|
||||||
|
- Set alias
|
||||||
|
|
||||||
## Repo
|
## Repo
|
||||||
- Merge workflow
|
- Merge workflow
|
||||||
|
|
@ -15,6 +29,8 @@
|
||||||
- Remove to do list
|
- Remove to do list
|
||||||
- Remove comment from script
|
- Remove comment from script
|
||||||
|
|
||||||
|
## Fix
|
||||||
|
|
||||||
## Notes
|
## Notes
|
||||||
|
|
||||||
```sh
|
```sh
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue