Restore select function added; Decompress function added; Configure restore function added

This commit is contained in:
Fr4nz D13trich 2026-01-16 14:33:51 +01:00
parent 53307fa77a
commit 60136a75fe

View file

@ -24,13 +24,14 @@ 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.9.1" SCRIPT_VERSION="0.5.9.1"
ALIAS="update-helium" ALIAS="helium-helper"
DATE=$(date +"%d%m%y") DATE=$(date +"%d%m%y")
## LOCATIONS ## LOCATIONS
TMP=/tmp/$APP_NAME TMP=/tmp/$APP_NAME
INSTALL_PATH=$HOME/.apps/$APP_NAME INSTALL_PATH=$HOME/.apps/$APP_NAME\1
APP_CONFIG_PATH=$HOME/.config/net.imput.helium APP_CONFIG_FOLDER="net.imput.helium"
APP_CONFIG_PATH=$HOME/.config/$APP_CONFIG_FOLDER
ASSET_PATH=$INSTALL_PATH/assets ASSET_PATH=$INSTALL_PATH/assets
BACKUP_PATH=$ASSET_PATH/backup BACKUP_PATH=$ASSET_PATH/backup
LOG_PATH=$ASSET_PATH/logs LOG_PATH=$ASSET_PATH/logs
@ -377,40 +378,50 @@ backup_logger() {
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 " - Shell : $ACTIVE_SHELL" >> $TMP/backup/conf_log echo " # Shell : $ACTIVE_SHELL" >> $TMP/backup/conf_log
echo " - Alias : TRUE" >> $TMP/backup/conf_log echo " # Alias : TRUE" >> $TMP/backup/conf_log
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
echo " - Shell : $ACTIVE_SHELL" >> $TMP/backup/conf_log echo " # Shell : $ACTIVE_SHELL" >> $TMP/backup/conf_log
echo " - Alias : TRUE" >> $TMP/backup/conf_log echo " # Alias : TRUE" >> $TMP/backup/conf_log
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
echo " - Shell : $ACTIVE_SHELL" >> $TMP/backup/conf_log echo " # Shell : $ACTIVE_SHELL" >> $TMP/backup/conf_log
echo " - Alias : TRUE" >> $TMP/backup/conf_log echo " # Alias : TRUE" >> $TMP/backup/conf_log
fi fi
else else
echo " - Shell : $ACTIVE_SHELL" >> $TMP/backup/conf_log echo " # Shell : $ACTIVE_SHELL" >> $TMP/backup/conf_log
echo " - Alias : FALSE" >> $TMP/backup/conf_log echo " # Alias : FALSE" >> $TMP/backup/conf_log
fi fi
LOGGABLE=("$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") LOGGABLE=("$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")
for LOG_ITEM in ${LOGGABLE[@]} ; do for LOG_ITEM in ${LOGGABLE[@]} ; do
if [ -d "$LOG_ITEM" ] ; then if [ -d "$LOG_ITEM" ] ; then
echo " - Directory : $LOG_ITEM" >> $TMP/backup/conf_log echo " # Folder : $LOG_ITEM" >> $TMP/backup/conf_log
elif [ -f "$LOG_ITEM" ] ; then elif [ -f "$LOG_ITEM" ] ; then
echo " - File : $LOG_ITEM" >> $TMP/backup/conf_log echo " # File : $LOG_ITEM" >> $TMP/backup/conf_log
else else
echo " - N/A : $LOG_ITEM" >> $TMP/backup/conf_log echo " # N/A : $LOG_ITEM" >> $TMP/backup/conf_log
fi fi
done done
echo >> $TMP/backup/conf_log
echo >> $TMP/backup/conf_log
echo "### $SCRIPT_FILE_NAME VARIABLES ###" >> $TMP/backup/conf_log
echo >> $TMP/backup/conf_log
echo "INSTALL_PATH=$INSTALL_PATH" >> $TMP/backup/conf_log
echo "SCRIPT_PATH=$SCRIPT_PATH" >> $TMP/backup/conf_log
echo "LAUNCHER_PATH=$LAUNCHER_PATH" >> $TMP/backup/conf_log
echo "APP_CONFIG_PATH=$APP_CONFIG_PATH" >> $TMP/backup/conf_log
echo >> $TMP/backup/conf_log
} }
backup_file_collector() { backup_file_collector() {
@ -564,7 +575,7 @@ select_backup() {
done done
cd $CWD cd $CWD
echo -e " ${CYN}Choose one of the $BACKUP_COUNT options below${CRS}\n" echo -e "\n ${CYN}Choose one of the $BACKUP_COUNT options below${CRS}\n"
echo -e "$(cat $TMP/backup_restore/options)\n" echo -e "$(cat $TMP/backup_restore/options)\n"
while true ; do while true ; do
@ -572,8 +583,8 @@ select_backup() {
if [[ "$RESTORE_SELECT" -le "$BACKUP_COUNT" && "$RESTORE_SELECT" -gt "0" ]] ; then if [[ "$RESTORE_SELECT" -le "$BACKUP_COUNT" && "$RESTORE_SELECT" -gt "0" ]] ; then
RESTORE_FILE=$(sed -n $RESTORE_SELECT\p $TMP/backup_restore/options | awk '{print $3}') RESTORE_FILE=$(sed -n $RESTORE_SELECT\p $TMP/backup_restore/options | awk '{print $3}')
BACKUP_TYPE=$(echo $RESTORE_FILE | awk -F'.' '{print $2}')
RESTORE_SOURCE=$BACKUP_PATH/$RESTORE_FILE RESTORE_SOURCE=$BACKUP_PATH/$RESTORE_FILE
echo $RESTORE_SOURCE
break break
elif [[ "$RESTORE_SELECT" == "exit" || "$RESTORE_SELECT" == "EXIT" ]] ; then elif [[ "$RESTORE_SELECT" == "exit" || "$RESTORE_SELECT" == "EXIT" ]] ; then
@ -586,12 +597,128 @@ select_backup() {
done done
elif [ "$BACKUP_COUNT" -lt "1" ] ; then elif [ "$BACKUP_COUNT" -lt "1" ] ; then
echo -e " ${RED}No backup archive found in ${CYN}$BACKUP_PATH${RED}!${CRS}" echo -e " ${RED}No backup archive found in ${CYN}$BACKUP_PATH${RED}!${CRS}\n"
exit_clean exit_clean
else else
RESTORE_SOURCE=$(ls $BACKUP_PATH/$APP_NAME.$BACKUP_TYPE.backup_*) RESTORE_SOURCE=$(ls $BACKUP_PATH/$APP_NAME.$BACKUP_TYPE.backup_*)
echo $RESTORE_SOURCE RESTORE_FILE=$(echo $RESTORE_SOURCE | rev | awk -F'/' '{print $1}' | rev)
if [ "$BACKUP_TYPE" == "*" ] ; then
BACKUP_TYPE=$(file $RESTORE_SOURCE | awk '{print $1}' | awk -F'.' '{print $2}')
fi
fi
BACKUP_COMPRESSION=$(file $RESTORE_SOURCE | awk '{print $2}')
decompress_backup
configure_restore
restore_backup
}
decompress_backup() {
CWD=$(pwd)
mkdir -p $TMP/backup_restore
cd $TMP/backup_restore
echo -e "\n - ${CRS}Decompressing backup archive ${CYN}$RESTORE_FILE${CRS}...${CRS}\n"
cp $RESTORE_SOURCE .
if [ "$BACKUP_COMPRESSION" == "bzip2" ] ; then
tar -xjf $APP_NAME.*.backup_*.tar.bz2
rm $APP_NAME.*.backup_*.tar.bz2
elif [ "$BACKUP_COMPRESSION" == "gzip" ] ; then
tar -xzf $APP_NAME.*.backup_*.tar.gz
rm $APP_NAME.*.backup_*.tar.gz
elif [ "$BACKUP_COMPRESSION" == "zip" ] ; then
unzip $APP_NAME.*.backup_*.tar.zip
tar -xf $APP_NAME.*.backup_*.tar
rm $APP_NAME.*.backup_*.tar.zip $APP_NAME.*.backup_*.tar.zip
else
echo -e " ${YEL}TBA...${CRS}\n" #######################################################################
fi
}
configure_restore() {
echo -e " - ${CRS}Analysing ${CYN}$BACKUP_TYPE${CRS} backup content...${CRS}\n"
RESTORABLE=("$APP_NAME.$FILE_EXTENSION" "$SCRIPT_FILE_NAME" "$AUTO_SCRIPT_FILE_NAME" "$APP_NAME.desktop" "$APP_CONFIG_FOLDER")
for RESTORE_ITEM in ${RESTORABLE[@]} ; do
if [ -d "$RESTORE_ITEM" ] ; then
if [ -d "$APP_CONFIG_PATH" ] ; then
echo " - Folder : $RESTORE_ITEM | already present" >> $TMP/restore_conf
echo $RESTORE_ITEM >> $TMP/restore_check
else
echo " - Folder : $RESTORE_ITEM | not present" >> $TMP/restore_conf
fi
elif [ -f "$RESTORE_ITEM" ] ; then
if [[ -f "$INSTALL_PATH/$RESTORE_ITEM" || -f "$SCRIPT_PATH/$RESTORE_ITEM" || -f "$LAUNCHER_PATH/$RESTORE_ITEM" ]] ; then
echo " - File : $RESTORE_ITEM | already present" >> $TMP/restore_conf
echo "\"$RESTORE_ITEM\"" >> $TMP/restore_check
else
echo " - File : $RESTORE_ITEM | not present" >> $TMP/restore_conf
fi
fi
done
RESTORE_PATH=("INSTALL_PATH" "SCRIPT_PATH" "LAUNCHER_PATH" "APP_CONFIG_PATH")
#################################################################################################
for CHANGED in ${RESTORE_PATH[@]} ; do
LOCAL_PATH=$(echo \$$CHANGED)
echo $LOCAL_PATH
if [ "$(cat conf_log | grep $RESTORE_PATH | awk -F '=' '{print $2}')" == "$LOCAL_PATH" ] ; then
echo $(cat conf_log | grep "${CHANGED}_PATH") >> $TMP/restore_path_change
echo "${CHANGED}_PATH"
else
echo "BAD"
echo $(cat conf_log | grep "${CHANGED}_PATH")
fi
done
}
restore_backup() {
echo -e " ${LCY}Backup Content Summary${CRS}\n"
echo -e "$(cat $TMP/restore_conf)\n"
if [ -f "$TMP/restore_check" ] ; then
echo -e " ${RED}WARNING: Some items are existing on your system!${CRS}\n"
while true ; do
read -p " Overwrite existing? (y/N) : " RESTORE_OVERWRITE
if [[ "$RESTORE_OVERWRITE" == "" || "$RESTORE_OVERWRITE" == "n" || "$RESTORE_OVERWRITE" == "N" ]] ; then
echo -e "\n ${RED}Cancelled!${CRS}\n"
break
elif [[ "$RESTORE_OVERWRITE" == "y" || "$RESTORE_OVERWRITE" == "Y" ]] ; then
EXISTING=$(cat $TMP/restore_check)
for REPLACE in ${EXISTING[@]} ; do
rm -rf $REPLACE
done
fi
done
else
echo -e " ${CYN}The content above is about to be restored...${CRS}\n"
while true ; do
read -p " Proceed with changes? (Y/n) : " RESTORE_CONFIRM
if [[ "$RESTORE_CONFIRM" == "" || "$RESTORE_CONFIRM" == "y" || "$RESTORE_CONFIRM" == "Y" ]] ; then
echo -e " - ${CRS}Copying ${CYN}$BACKUP_TYPE${CRS} backup files...${CRS}\n"
elif [[ "$RESTORE_CONFIRM" == "n" || "$RESTORE_CONFIRM" == "N" ]] ; then
echo -e "\n ${RED}Cancelled!${CRS}\n"
break
fi
done
fi fi
} }
@ -675,8 +802,7 @@ update_script() {
read -p " Copy script to $SCRIPT_PATH? (Y/n) : " CONFIRM_SCRIPT_INSTALL read -p " Copy script to $SCRIPT_PATH? (Y/n) : " CONFIRM_SCRIPT_INSTALL
if [[ "$CONFIRM_SCRIPT_INSTALL" == "" || "$CONFIRM_SCRIPT_INSTALL" == "y" || "$CONFIRM_SCRIPT_INSTALL" == "Y" ]] ; then if [[ "$CONFIRM_SCRIPT_INSTALL" == "" || "$CONFIRM_SCRIPT_INSTALL" == "y" || "$CONFIRM_SCRIPT_INSTALL" == "Y" ]] ; then
mkdir -p $SCRIPT_PATH mkdir -p $SCRIPT_PATH $TMP
mkdir -p $TMP
wget -P $TMP $REMOTE_SCRIPT_URL -q wget -P $TMP $REMOTE_SCRIPT_URL -q
wget -P $TMP $REMOTE_REPO_URL/$AUTO_SCRIPT_FILE_NAME -q wget -P $TMP $REMOTE_REPO_URL/$AUTO_SCRIPT_FILE_NAME -q
chmod +x $TMP/$SCRIPT_FILE_NAME $TMP/$AUTO_SCRIPT_FILE_NAME chmod +x $TMP/$SCRIPT_FILE_NAME $TMP/$AUTO_SCRIPT_FILE_NAME
@ -719,7 +845,6 @@ update_script() {
while true ; do while true ; do
read -p " Update $SCRIPT_FILE_NAME? (Y/n) : " CONFIRM_SCRIPT_UPDATE 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 if [[ "$CONFIRM_SCRIPT_UPDATE" == "" || "$CONFIRM_SCRIPT_UPDATE" == "y" || "$CONFIRM_SCRIPT_UPDATE" == "Y" ]] ; then
if ! [ -d "$BACKUP_PATH" ] ; then if ! [ -d "$BACKUP_PATH" ] ; then
@ -735,11 +860,11 @@ update_script() {
break break
elif [[ "$CONFIRM_SCRIPT_UPDATE" == "n" || "$CONFIRM_SCRIPT_UPDATE" == "N" ]] ; then elif [[ "$CONFIRM_SCRIPT_UPDATE" == "n" || "$CONFIRM_SCRIPT_UPDATE" == "N" ]] ; then
echo -e " ${RED}Cancelled!${CRS}\n" 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
@ -897,11 +1022,11 @@ while getopts ":i,:l,:a,:u,:b,:B,:r,:c,:s,:S,:h" OPTION ; do
fi fi
path_correction path_correction
call_backup call_backup
exit ;; exit_clean ;;
B) B)
TARGET="BACKUP" TARGET="BACKUP"
echo -e "\n ${YEL}Restoring $APP_NAME_LONG from backup...${CRS}\n" echo -e "\n ${YEL}Restoring $APP_NAME_LONG from backup...${CRS}"
if [ "$#" -gt "1" ] ; then if [ "$#" -gt "1" ] ; then
ALL_PARAMETER=$@ ALL_PARAMETER=$@