From a41c4174b98c95381e717e9f9230484d19e35c2c Mon Sep 17 00:00:00 2001 From: kyodev Date: Mon, 9 Oct 2017 20:21:47 +0200 Subject: [PATCH] 1.3.0 --- scripts/getThunderbird | 217 +++++++++++++++++----------- scripts/getThunderbird_changelog.md | 9 ++ 2 files changed, 142 insertions(+), 84 deletions(-) diff --git a/scripts/getThunderbird b/scripts/getThunderbird index ddd576d..72e6ced 100755 --- a/scripts/getThunderbird +++ b/scripts/getThunderbird @@ -1,7 +1,7 @@ #!/bin/bash -version=1.2.0 -date="24/09/2017" +version=1.3.0 +date="08/10/2017" projet="simpledeb" contact="IRC freenode ##sdeb ou https://framagit.org/kyodev/kyopages/issues/" script="getThunderbird" @@ -14,13 +14,8 @@ user_agent="Mozilla/5.0 Firefox" # contributeurs: kyodev ##### -f__affichage(){ # 06/2017 définition couleurs - YELLOW="$(printf "\033[0;33m")" # ? - GREEN="$(printf "\033[0;32m")" # ok - BLUE="$(printf "\033[0;34m")" # info - RED="$(printf "\033[0;31m")" # alerte - COLOR="$(printf "\033[0m")" # standard - +f__affichage(){ # 08/10/2017 + f__color clear printf "$BLUE" cat << 'EOF' @@ -31,7 +26,7 @@ cat << 'EOF' \__, |\___|\__||_| |_| |_|\__,_|_| |_|\__,_|\___|_| |_.__/|_|_| \__,_| |___/ EOF - echo -e "$YELLOW version $version - $date$COLOR\n" + echo -e "$YELLOW version $version - $date$STD\n" } # détection architecture, assigne $architecture : linux|linux64, return 1 si architecture inconnue @@ -64,28 +59,45 @@ f__archive_test(){ # 30/08/2017 if [ ! "$archive_detect" ] || [ "$archive_detect" == "empty" ]; then return 1; fi } +f__color(){ # 08/10/2017 + YELLOW=$(tput setaf 3) # question + GREEN=$(tput setaf 2) # ok + BLUE=$(tput setaf 4) # info + RED=$(tput setaf 1) # alerte + STD=$(tput sgr0) # retour normal + MAGENTA=$(tput setaf 5) + CYAN=$(tput setaf 6) + BOLD=$(tput bold) + ITAL=$(tput sitm) + SOUL=$(tput smul) +} + # affichage $1 en rouge, $1++ optionnels en bleu, sortie script sur erreur, log $1 si $opType=upgrade -f__error() { # 22/09/2017 - echo -e "\n$RED $script $version, erreur critique: $1 $COLOR" - for (( i=2 ; i<=$# ; i++ )); do echo -e " $BLUE${!i}"; done +f__error(){ # 08/10/2017 + echo -e "\n$RED $script $version, erreur critique: $1 $STD" + for (( i=2 ; i<=$# ; i++ )); do + echo -e " $BLUE${!i}$STD" + done unset i - echo "$COLOR" + echo if [ "$opType" == "upgrade" ]; then f__log "$script $version: $1"; fi exit 1 } - # affichage des paramètres en bleu, si $1=raw pas de ligne vide à la fin, si $1=log uniquement $2 logué -f__info() { # 22/09/2017 + # affichage des paramètres en bleu, si $1=raw pas de ligne vide à la fin, si $1=log alors uniquement $2 logué +f__info(){ # 08/10/2017 local depart=1 if [ "$1" == "raw" ] || [ "$1" == "log" ]; then depart=2; fi [ "$1" == "log" ] && f__log "$(sed -E 's/\\t//;s/\\n// ' <<< $2 | xargs )" - for (( i=$depart ; i<=$# ; i++ )); do echo -e " $BLUE${!i}"; done + for (( i=$depart ; i<=$# ; i++ )); do + echo -e " $BLUE${!i}$STD" + done unset i - [ "$1" == raw ] && printf "$COLOR" || echo "$COLOR" + [ "$1" == raw ] || echo } # log spécifique, fichier log limité à 10000octets, $1 message à loguer -f__log(){ # 08/O9/2017 +f__log(){ # 08/09/2017 if [ -w "$fileLogs" ]; then if [ "$(stat -c %s $fileLogs)" -ge "10000" ]; then echo "$(date +%Y%m%d\ %H%M%S) $1" &>/dev/null > "$fileLogs" @@ -131,16 +143,40 @@ f__requis(){ # 22/09/2017 fi } + # $1=cmd si $2: nb de tentatives pour s'identifier, sinon 1 tentative par défaut +f__sudo(){ # 08/10/2017 + local nb=1 sudo isudo + # sudo --shell bash équivalent su ? + if sudo -v &>/dev/null && [ $EUID -ne 0 ] ; then + sudo="sudo --shell $(which bash) " + else + sudo="su --shell $(which bash) --preserve-environment -c " + fi + [ "$2" ] && nb="$2" + for (( isudo=1 ; isudo<="$nb" ; isudo++ )); do + $sudo " $1" + [ "$?" == 0 ] && break + [ "$isudo" == "$nb" ] && return 1 + done +} + # user ayant initié la session graphique, assigne $user_ # return 1 sur échec identification user, return 2 sur absence home/ # gestion variable environnement user avec: USER_INSTALL=user script -f__user(){ # 30/08/2017-4 +f__user(){ # 06/10/2017 + local user_id test root_login + root_login="$(grep ':0:' /etc/passwd | cut -d':' -f1)" || root_login="root" if [ "$USER_INSTALL" ]; then # user_ via variable environnement, moyen d'injecter root user_="$USER_INSTALL"; return 0 + elif [[ "$TERM" =~ linux ]]; then #debian 9 recovery ou nomodeset TERM=linux + if [ "$USER" ]; then + user_="$USER" + elif [ "$EUID" -eq 0 ]; then + user_="$root_login" + return 0 + fi fi - local user_id test root_login - root_login="$(grep ':0:' /etc/passwd | cut -d':' -f1)" || root_login="root" if [ "$SUDO_UID" ]; then user_id="$SUDO_UID"; elif grep -qEo '[0-9]+' <<< "$XDG_RUNTIME_DIR" ; then @@ -155,9 +191,9 @@ f__user(){ # 30/08/2017-4 if [ "$SUDO_USER" ] && [ "$SUDO_USER" != "$root_login" ]; then user_="$SUDO_USER"; elif grep -qv 'root' <<< "$(who)"; then - user_="$(grep -v 'root' <<< $(who) | head -n1 | cut -d ' ' -f1)"; + user_="$(grep -v 'root' <<< $(who) | head -n1 | cut -d ' ' -f1)"; # grep -v 'root' <<< $(who) | awk 'FNR==1{print $1}' elif grep -q 'hourly.*get[A-Z].*\.anacrontab.*\.config/anacron/spool' /etc/crontab; then - user_="$(grep 'hourly.*get[A-Z].*\.anacrontab.*\.config/anacron/spool' /etc/crontab | head -n1 | cut -d' ' -f2)"; + user_="$(grep 'hourly.*get[A-Z].*\.anacrontab.*\.config/anacron/spool' /etc/crontab | head -n1 | cut -d' ' -f2)"; # grep 'hourly.*get[A-Z].*\.anacrontab.*\.config/anacron/spool' /etc/crontab | awk 'FNR==1{print $2} fi fi if [ -z "$user_" ]; then return 1; fi @@ -165,13 +201,17 @@ f__user(){ # 30/08/2017-4 return 0 } - # test wget, $1 url à tester, sortie script, sur erreur ou retour à la normale + # test wget, $1 url à tester, sortie du script si $1 seul (même si url testée ok) # si $2=print affiche url testée & entêtes http & location (si présente) et sortie normale fonction - # si $2=loc affiche seulement location -f__wget_test(){ # 07/09/2017 + # si $2=loc affiche seulement location et sortie normale fonction + # si $2=test return 0 si ok, return 1 si ko +f__wget_test(){ # 08/10/2017 local file_test_wget retourWget retourHttp location - file_test_wget="/tmp/testWget-$RANDOM" - wget -Sq --tries=1 --timeout=10 --user-agent="$user_agent" --spider --save-headers "$1" &>"$file_test_wget" || retourWget="$?" + file_test_wget="/tmp/testWget-$$-$RANDOM" + wget -Sq --tries=1 --timeout=10 --user-agent="$user_agent" --spider --save-headers "$1" &>"$file_test_wget" + retourWget="$?" + [ "$2" == "test" ] && rm "$file_test_wget" + [ "$2" == "test" ] && [ "$retourWget" == "0" ] && return 0 || return 1 [ "$retourWget" == 1 ] && retourWget="code erreur générique" [ "$retourWget" == 2 ] && retourWget="parse erreur (ligne de commande?)" [ "$retourWget" == 3 ] && retourWget="erreur Entrée/sortie fichier" @@ -184,34 +224,31 @@ f__wget_test(){ # 07/09/2017 location="$(grep -i 'location' $file_test_wget | xargs)" if [ "$2" == "print" ]; then if [ "$retourWget" ]; then - echo "erreur wget: $RED$retourWget$COLOR" - echo -e "$BLUE $1$COLOR\t$RED $retourHttp$COLOR" - [ "$location" ] && echo "$YELLOW $location" || echo "$YELLOW no location" - echo "$COLOR" - return + echo "erreur wget: $RED$retourWget" + echo -e "$BLUE $1$STD\t$RED $retourHttp" else - echo -e "$BLUE $1$COLOR\t$GREEN $retourHttp$YELLOW" - [ "$location" ] && echo "$YELLOW $location" || echo "$YELLOW no location" - echo "$COLOR" - return + echo -e "$BLUE $1$STD\t$GREEN $retourHttp" fi fi - if [ "$2" == "loc" ]; then - [ "$location" ] && echo "$location" || echo "no location" - return + if [ "$2" == "print" ] || [ "$2" == "loc" ]; then + [ "$location" ] && echo "$YELLOW $location" || echo "$YELLOW no location" + echo "$STD" + return 0 fi if [ "$retourWget" ]; then rm "$file_test_wget" f__error "erreur wget, $retourWget" "$1" "$YELLOW$retourHttp" \ "si persistance, contacter $projet $contact en indiquant les messages précédents" fi - if [ "$(grep -c '200' <<< $retourHttp)" -ne 0 ]; then echo -e "$GREEN\ntout est ok, réessayer\n$COLOR"; fi + if [ "$(grep -c '200' <<< $retourHttp)" -ne 0 ]; then + echo -e "$GREEN\ntout est ok, réessayer\n$STD" + fi rm "$file_test_wget" exit 0 } # affichage help -f_help(){ # 09/09/2017 +f_help(){ # 08/10/2017 printf $BLUE cat << 'EOF' ---------------------------------------------------------------------- @@ -237,13 +274,13 @@ cat << 'EOF' getThunderbird -u, --upgrade : mise à jour du script getThunderbird -v, --version : versions du script EOF - printf "$COLOR" + printf "$STD" cat << 'EOF' ---------------------------------------------------------------------- Si présent, le *paquet Debian* thunderbird devrait être désinstallé ---------------------------------------------------------------------- EOF -echo -e " plus d'infos: $GREEN$urlNotice$COLOR\n" +echo -e " plus d'infos: $GREEN$urlNotice\n" } # demande confirmation pour continuer, $1=simple -> avertissement simple @@ -292,7 +329,7 @@ f_tb_get_canalBas(){ # 23/09/2017 } # assigne $verLatest, $verBeta -f_tb_get_versions(){ # 23/09/2017 +f_tb_get_versions(){ # 08/10/2017 local recup_url prefixe verOnline verTbInstall canal tabEspaces="$(printf " %.s" $(seq 6))" verPaquet architecture="linux64" for canal in latest beta; do @@ -320,8 +357,8 @@ f_tb_get_versions(){ # 23/09/2017 [ "$verLatest" ] || verLatest="$RED""NA" [ "$verBeta" ] || verBeta="$RED""NA" [ "$verTbInstall" ] || verTbInstall="$RED""aucune(s)" - f__info "raw" "version(s) Thunderbird installé(s): $GREEN$verTbInstall$COLOR" - [ "$verPaquet" ] && f__info "raw" "$RED""version paquet debian Thunderbird: $verPaquet$COLOR" + f__info "raw" "version(s) Thunderbird installé(s): $GREEN$verTbInstall" + [ "$verPaquet" ] && f__info "raw" "$RED""version paquet debian Thunderbird: $verPaquet" f__info "versions Thunderbird en ligne: $YELLOW""latest: $verLatest$tabEspaces""beta: $verBeta$tabEspaces" } @@ -464,7 +501,7 @@ f_tb_profil_user(){ # 09/09/2017 } # désinstallation de Thunderbird, on laisse le profil user, $1=canal -f_tb_remove(){ # 08/09/2017 +f_tb_remove(){ # 08/10/2017 local canal="$1" [ "$EUID" -eq 0 ] || f__error "vous devez être ROOT pour désinstaller Thunderbird" killall "/opt/usr/share/thunderbird-$canal/thunderbird" &>/dev/null @@ -485,7 +522,7 @@ f_tb_remove(){ # 08/09/2017 f__info "log" "thunderbird-$canal désinstallé, mais le profil est toujours en place" \ "\tle supprimer manuellement si nécessaire, pour cela:" \ "fermer toutes les instances ouvertes de thunderbird" \ - "et lancer en console, en user:$GREEN thunderbird -P$COLOR" + "et lancer en console, en user:$GREEN thunderbird -P" } # lien /usr/bin/thunderbird pour le plus bas canal thunderbird installé @@ -496,6 +533,21 @@ f_tb_usr_bin(){ # 07/09/2017 fi } + # spécifique script +fscript_cronAnacron_special(){ # 19/08/2017 + rm "/home/$user_/.mozilla/$script.anacrontab" &>/dev/null # ancienne localisation éventuelle + rm "/home/$user_/.config/anacron/spool/getFF"* &>/dev/null # ancien job +} + + # spécifique script +fscript_install_special(){ # 08/10/2017 + f_tb_alertIcedove "simple" + if f__requis "thunderbird icedove" "debOnly" && [ "$debOnlyPresents" ]; then + f__info "paquet(s) installé(s) $debOnlyPresents" \ + "vous devriez peut-être le désinstaller:$GREEN apt remove thunderbird* $BLUE?" + fi +} + # inscription dans tache upgrade en anacron hebdomadaire, via cron horaire, $1=upgrade|install|remove fscript_cronAnacron(){ # 06/09/2017 local dirAnacron dirSpool fileAnacron @@ -531,14 +583,8 @@ fscript_cronAnacron(){ # 06/09/2017 esac } - # spécifique script -fscript_cronAnacron_special(){ # 19/08/2017 - rm "/home/$user_/.mozilla/$script.anacrontab" &>/dev/null # ancienne localisation éventuelle - rm "/home/$user_/.config/anacron/spool/getFF"* &>/dev/null # ancien job -} - # version script en ligne, assigne $versionScript, $script_aJour=ok|ko -fscript_get_version(){ # 07/09/2017 +fscript_get_version(){ # 08/10/2017 f__info "raw" "$GREEN""version script en cours: $version" versionScript="$(wget -q --tries=2 --timeout=15 -O - "$urlScript" | grep '^version=' | cut -d '=' -f 2)" if [ "$versionScript" ]; then @@ -553,14 +599,16 @@ fscript_get_version(){ # 07/09/2017 } # installation du script dans le système -fscript_install(){ # 06/09/2017 + # installation du script dans le système +fscript_install(){ # 08/10/2017 if grep -q 'bin' <<< "$(dirname $0)" ; then - f__info "$RED""l'installation dans le système doit se faire depuis un script local $GREEN(./$script -i )$COLOR" - return + f__info "$RED""l'installation dans le système doit se faire depuis un script local $GREEN(./$script -i )" + return 1 fi if [ "$EUID" -ne 0 ]; then - f__info "$RED""vous devez être ROOT pour installer ce script dans le système$COLOR" - return 3 + f__info "vous devez être$RED ROOT$BLUE pour installer ce script dans le système" + f__sudo "exec $0 -i" + return $? fi [ "$(type -t fscript_install_special)" ] && fscript_install_special # test, si fonction spécifique, appel f__requis "wget anacron cron" @@ -568,40 +616,33 @@ fscript_install(){ # 06/09/2017 mkdir -p /opt/bin/ cp -d "$(basename $0)" "/opt/bin/$script" ln -s "/opt/bin/$script" "/usr/bin/$script" &>/dev/null - chmod 755 "/opt/bin/$script" + chmod 775 "/opt/bin/$script" # rwx rwx r-x, proprio user_ # cron/anacron install fscript_cronAnacron "install" # création fichier log touch "$fileLogs" - chmod 644 "$fileLogs" + chmod 664 "$fileLogs" # rw- rw- r--, proprio user_ chown "$user_:" "$fileLogs" "/opt/bin/$script" [ -e "$fileDev" ] || rm "$(basename $0)" &>/dev/null ## on efface pas si fileDev (dev) - f__info "log" "$script $version installé dans le système." "maintenant, appel du script par:$GREEN $script$BLUE (sans ./)" -} - - # spécifique script -fscript_install_special(){ # 08/09/2017 - f_tb_alertIcedove "simple" - if f__requis "thunderbird icedove" "debOnly" && [ "$debOnlyPresents" ]; then - f__info "paquet(s) installé(s) $debOnlyPresents" \ - "à moins d'être certain, vous devriez peut-être le désinstaller:$RED apt remove thunderbird* $COLOR" - fi + f__info "log" "$script $version installé dans le système." "maintenant, appel du script par: $GREEN$script$BLUE (sans ./)" } # suppression du script dans le système -fscript_remove(){ # 06/09/2017 +fscript_remove(){ # 08/10/2017 if ! grep -q 'bin' <<< "$(dirname $0)" ; then - f__info "$RED""cette fonction doit être appelée depuis le script installé dans le système $GREEN($script -r)$COLOR" + f__info "$RED""cette fonction doit être appelée depuis le script installé dans le système $GREEN($script -r)" return 1 fi if [ ! -x "/opt/bin/$script" ];then - f__info "$RED$script n'est pas installé$COLOR" - return 2 + f__info "$RED$script n'est pas installé" + return 1 fi if [ "$EUID" -ne 0 ]; then - f__info "$RED""vous devez être ROOT pour supprimer ce script dans le système$COLOR" - return 3 + f__info "vous devez être$RED ROOT$BLUE pour supprimer ce script dans le système" + f__sudo "exec $0 -r" + return $? fi + [ "$(type -t fscript_remove_special)" ] && fscript_remove_special # test, si fonction spécifique, appel # suppression de /opt rm "/opt/bin/$script" &>/dev/null unlink "/usr/bin/$script" &>/dev/null @@ -611,11 +652,12 @@ fscript_remove(){ # 06/09/2017 } # mise à jour script si dispo -fscript_update(){ # 06/09/2017 +fscript_update(){ # 08/10/2017 if ! grep -q 'bin' <<< "$(dirname $0)" ; then - f__info "$RED""cette fonction doit être appelée depuis le script installé dans le système $GREEN($script -u)$COLOR" + f__info "$RED""cette fonction doit être appelée depuis le script installé dans le système $GREEN($script -u)" return fi + [ "$(type -t fscript_update_special)" ] && fscript_update_special # test, si fonction spécifique, appel fscript_get_version if [ "$script_aJour" == "ok" ]; then f__info "log" "pas de mise à jour disponible pour $script $version" @@ -625,7 +667,7 @@ fscript_update(){ # 06/09/2017 mkdir -p "$dirTemp" wget -q --tries=2 --timeout=15 -O "$dirTemp/$script" "$urlScript" if [ "$?" != "0" ]; then f__wget_test "$urlScript"; fi - chmod 755 "$dirTemp/$script" + chmod 775 "/opt/bin/$script" # rwx rwx r-x, proprio user_ chown "$user_:" "$dirTemp/$script" cp -d "$dirTemp/$script" "/opt/bin/$script" rm -rf "$dirTemp/" @@ -636,9 +678,16 @@ fscript_update(){ # 06/09/2017 # initialisation PATH='/usr/sbin:/usr/bin:/sbin:/bin'; TERM=xterm; IFS=$' \t\n' export PATH TERM IFS + f__affichage f__architecture || f__error "Seules les architecture 32 et 64 bits sont supportée (i686 & amd64) par Thunderbird" -f__user || f__error "échec détection user" + +f__user +retourFUser="$?" +[ "$retourFUser" -eq 1 ] && f__error "user indéterminé" +[ "$retourFUser" -eq 2 ] && f__error "user détecté, mais pas de home: /home/$user_" + +[ "$(grep -o 'version 4' <<< $(bash --version) | sed 's/version //')" -ge "4" ] || f__error "bash version 4" f__requis "wget file tar killall>psmisc" # requis pour fonctionnement programme fileLogs="/var/log/sdeb_$script.log" diff --git a/scripts/getThunderbird_changelog.md b/scripts/getThunderbird_changelog.md index d2ff17b..b6c8790 100644 --- a/scripts/getThunderbird_changelog.md +++ b/scripts/getThunderbird_changelog.md @@ -5,6 +5,15 @@ * placé ln dans /usr/local/bin au lieu de /usr/bin ? +## 1.3.0 08/10/2017 + +* f__wget_test(): nouvelle option test, nouveau nommage fichier temp +* f__user, premier essai root only, fonctionnement en root only en console +* test bash4 au démarrage +* révision f__color: utilisation terminfo pour retour au std (et non noir), donc modifs: + * f__color f__error f__info f__wget_test f__dialog_oui_non + * fscript_get_version fscript_install fscript_remove fscript_update +* intégration f__sudo dans install & remove script ## 1.2.0 24/09/2017