diff --git a/scripts/getFirefox b/scripts/getFirefox index b0dd95f..414ab73 100755 --- a/scripts/getFirefox +++ b/scripts/getFirefox @@ -1,7 +1,7 @@ #!/bin/bash -version=3.8.2 -date="24/09/2017" +version=3.9.0 +date="08/10/2017" projet="simpledeb" contact="IRC freenode ##sdeb ou https://framagit.org/kyodev/kyopages/issues/" script="getFirefox" @@ -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' \__, |\___|\__|_| |_|_| \___|_| \___/_/\_\ |___/ Tor Browser 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' ---------------------------------------------------------------------- @@ -241,13 +278,13 @@ cat << 'EOF' getFirefox -u, --upgrade, upgrade : mise à jour du script getFirefox -v, --version : versions du script EOF - printf "$COLOR" + printf "$STD" cat << 'EOF' ---------------------------------------------------------------------- Si présent, le *paquet Debian* firefox-esr ou firefox devrait être désinstallé ---------------------------------------------------------------------- EOF -echo -e " plus d'infos: $GREEN$urlNotice$COLOR\n" + echo -e " plus d'infos: $GREEN$urlNotice\n" } # assigne $verTorOnline @@ -265,8 +302,8 @@ f_tor_get_version(){ # 06/09/2017 verTorInstall="$(sed -n '1p' $dirInstallTB/Browser/TorBrowser/Docs/ChangeLog.txt | sed -En 's/^Tor Browser (.*)$/\1/p')" fi [ "$verTorInstall" ] || verTorInstall="$RED""Non Installé" - f__info "raw" "version Tor Browser installé: $GREEN$verTorInstall$COLORS" - f__info "version Tor Browser en ligne: $YELLOW$verTorOnline$COLORS" + f__info "raw" "version Tor Browser installé: $GREEN$verTorInstall" + f__info "version Tor Browser en ligne: $YELLOW$verTorOnline" } # installation TorBrowser, [$1 manuel, $2 archive] @@ -350,7 +387,7 @@ f_tor_lanceur_desktop(){ # 22/09/2017 } # version personnalisation Tor Browser en ligne, assigne $persTbATraiter -f_tor_pers_get_version(){ # 06/09/2017 +f_tor_pers_get_version(){ # 08/10/2017 local urlPersTb versPersTbOnline verPersTbInstall if [ -e "$profilTor/personnalisation.$script" ]; then urlPersTb="$(sed -n '1p' $profilTor/personnalisation.$script)" @@ -363,7 +400,7 @@ f_tor_pers_get_version(){ # 06/09/2017 verPersTbInstall="$(sed -n '2p' $profilTor/personnalisation.$script)" if [ "$verPersTbInstall" != "$versPersTbOnline" ]; then persTbATraiter="true"; fi fi - [ "$verPersTbInstall" ] && f__info "raw" "$GREEN""personnalisation Tor Browser installée $verPersTbInstall$COLOR" + [ "$verPersTbInstall" ] && f__info "raw" "personnalisation Tor Browser installée $GREEN$verPersTbInstall" if [ "$persTbATraiter" ]; then f__info "version personnalisation Tor Browser en ligne: $versPersTbOnline, mise à jour possible" else @@ -373,7 +410,7 @@ f_tor_pers_get_version(){ # 06/09/2017 } # recup userTor.js et chrome/userChrome.css pour Tor Browser -f_tor_pers_install(){ # 06/09/2017 +f_tor_pers_install(){ # 08/10/2017 local urlPersTb verPersTbDL dirTemp if [ ! -d "$profilTor/" ]; then f__info "Tor Browser inexistant" @@ -395,20 +432,20 @@ f_tor_pers_install(){ # 06/09/2017 # installation if [ -d "$profilTor/chrome/" ] && [ "$(stat -c %U $profilTor/chrome/)" == "root" ] && [ "$EUID" -ne 0 ]; then f__error "root propriétaire sur $profilTor/chrome/" "bug version de développement" \ - "$GREEN""réinstaller la personnalisation avec les privilèges root pour corriger$COLOR" + "$GREEN""réinstaller la personnalisation avec les privilèges root pour corriger" fi mkdir -p "$profilTor/chrome" # répertoire pour userChrome.css chown "$user_:" "$profilTor/chrome/" if [ -e "$profilTor/user.js" ] && [ "$(stat -c %U $profilTor/user.js)" == "root" ] && [ "$EUID" -ne 0 ]; then f__error "root propriétaire de $profilTor/user.js" "bug version de développement" \ - "$GREEN""réinstaller la personnalisation avec les privilèges root pour corriger$COLOR" + "$GREEN""réinstaller la personnalisation avec les privilèges root pour corriger" fi cp "$dirTemp/user.js" "$profilTor" chown "$user_:" "$profilTor/user.js" if [ -e "$profilTor/chrome/userChrome.css" ] && \ [ "$(stat -c %U $profilTor/chrome/userChrome.css)" == "root" ] && [ "$EUID" -ne 0 ]; then f__error "root propriétaire de $profilTor/chrome/userChrome.css" "bug version de développement" \ - "$GREEN""réinstaller la personnalisation avec les privilèges root pour corriger$COLOR" + "$GREEN""réinstaller la personnalisation avec les privilèges root pour corriger" fi if [ -e "$dirTemp/userChrome.css" ]; then cp "$dirTemp/userChrome.css" "$profilTor/chrome/" @@ -484,7 +521,7 @@ ffx_get_canalBas(){ # 22/09/2017 } # version Firefox en ligne -ffx_get_version(){ # 22/09/2017 +ffx_get_version(){ # 08/10/2017 local fileTmp recup_url verLatest verEsr verBeta verNightly verFFxInstall tabEspaces=" " printf " ." fileTmp="/tmp/getFirefox-wgetVer-$RANDOM" @@ -520,13 +557,13 @@ ffx_get_version(){ # 22/09/2017 [ "$verNightly" ] || verNightly="$RED""NA" [ "$verEsr" ] || verEsr="$RED""NA" [ "$verFFxInstall" ] || verFFxInstall="$RED""aucune(s)" - f__info "raw" "version(s) Firefox installé(s): $GREEN$verFFxInstall$COLOR" - f__info "versions Firefox en ligne: $YELLOW""latest: $verLatest$tabEspaces""beta/dev: $verBeta$tabEspaces""nightly: $verNightly$tabEspaces""esr: $verEsr$COLORS" + f__info "raw" "version(s) Firefox installé(s): $GREEN$verFFxInstall" + f__info "versions Firefox en ligne: $YELLOW""latest: $verLatest$tabEspaces""beta/dev: $verBeta$tabEspaces""nightly: $verNightly$tabEspaces""esr: $verEsr" } # ascii art godzilla; ligne vide finale ffx_godzilla(){ # 06/2017 -printf "$RED" + printf "$RED" cat << 'EOF' _.-~-. 7'' Q..\ @@ -542,7 +579,7 @@ cat << 'EOF' /..\ /..\__/ ' '::: | | | | | | (_) / /| | | | (_| | ::' vVVv vVVv ': |_| |_| |_|\___/___|_|_|_|\__,_| '' EOF -echo "$COLOR" + echo "$STD" } # installation Firefox, $1 produit, $2 manuel, $3 archive @@ -636,7 +673,7 @@ ffx_lanceur_desktop(){ # 22/09/2017 } # version personnalisation en ligne, assigne $prodATraiter -ffx_pers_get_version(){ # 22/09/2017 +ffx_pers_get_version(){ # 08/10/2017 local urlPers verPersOnline verPersInstall persEnPlace for ii in latest esr beta dev nightly; do if [ -e "$dirProfil/$ii/personnalisation.$script" ]; then @@ -654,7 +691,7 @@ ffx_pers_get_version(){ # 22/09/2017 else f__info "version personnalisation en ligne non accessible"; fi done unset ii - [ "$persEnPlace" ] && f__info "raw" "$GREEN""personnalisation(s) installée(s) pour $persEnPlace$COLOR" + [ "$persEnPlace" ] && f__info "raw" "$GREEN""personnalisation(s) installée(s) pour $persEnPlace" if [ "$prodATraiter" ]; then f__info "version personnalisation en ligne: $verPersOnline, mise à jour possible pour $prodATraiter" else @@ -663,7 +700,7 @@ ffx_pers_get_version(){ # 22/09/2017 } # recup user.js et chrome/userChrome.css, $1=canal à personnaliser ou mettre à jour -ffx_pers_install(){ # 06/09/2017 +ffx_pers_install(){ # 08/10/2017 local canal="$1" urlPers verPersDL dirTemp if [ ! -d "$dirProfil/$canal" ]; then f__info "firefox $canal inexistant" @@ -685,20 +722,20 @@ ffx_pers_install(){ # 06/09/2017 # installation if [ -d "$dirProfil/$canal/chrome/" ] && [ "$(stat -c %U $dirProfil/$canal/chrome/)" == "root" ] && [ "$EUID" -ne 0 ]; then f__error "root propriétaire sur $dirProfil/$canal/chrome/" "bug version de développement" \ - "$GREEN""réinstaller la personnalisation avec les privilèges root pour corriger$COLOR" + "$GREEN""réinstaller la personnalisation avec les privilèges root pour corriger" fi mkdir -p "$dirProfil/$canal/chrome" # répertoire pour userChrome.css chown "$user_:" "$dirProfil/$canal/chrome" if [ -e "$dirProfil/$canal/user.js" ] && [ "$(stat -c %U "$dirProfil/$canal/user.js")" == "root" ] && [ "$EUID" -ne 0 ]; then f__error "root propriétaire de $dirProfil/$canal/user.js" "bug version de développement" \ - "$GREEN""réinstaller la personnalisation avec les privilèges root pour corriger$COLOR" + "$GREEN""réinstaller la personnalisation avec les privilèges root pour corriger" fi cp "$dirTemp/user.js" "$dirProfil/$canal/" chown "$user_:" "$dirProfil/$canal/user.js" if [ -e "$dirProfil/$canal/chrome/userChrome.css" ] && \ [ "$(stat -c %U "$dirProfil/$canal/chrome/userChrome.css")" == "root" ] && [ "$EUID" -ne 0 ]; then f__error "root propriétaire de $dirProfil/$canal/chrome/userChrome.css" "bug version de développement" \ - "$GREEN""réinstaller la personnalisation avec les privilèges root pour corriger$COLOR" + "$GREEN""réinstaller la personnalisation avec les privilèges root pour corriger" fi [ -e "$dirTemp/userChrome.css" ] && cp "$dirTemp/userChrome.css" "$dirProfil/$canal/chrome" chown "$user_:" "$dirProfil/$canal/chrome/userChrome.css" @@ -789,7 +826,7 @@ ffx_recup_url(){ # 06/2017 } # désinstallation de Firefox, on laisse le profil user -ffx_remove(){ # 08/09/2017 +ffx_remove(){ # 08/10/2017 local canal="$1" [ "$EUID" -eq 0 ] || f__error "vous devez être ROOT pour désinstaller firefox" killall "/opt/usr/share/firefox-$canal/firefox" &>/dev/null @@ -813,7 +850,7 @@ ffx_remove(){ # 08/09/2017 f__info "log" "Firefox-$canal désinstallé, mais le profil est toujours en place" \ "\tle supprimer manuellement si nécessaire, pour cela:" \ "fermer toutes les instances ouvertes de firefox" \ - "et lancer en console, en user:$GREEN firefox -P$COLOR" + "et lancer en console, en user:$GREEN firefox -P" ffx_godzilla } @@ -838,6 +875,22 @@ ffx_usr_bin(){ # 08/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 + [ -e "/var/log/sdeb_getFF.log" ] && mv "/var/log/sdeb_getFF.log" "$fileLogs" # changement ancien logs + if f__requis "firefox-esr firefox" "debOnly" && [ "$debOnlyPresents" ]; then + f__info "paquet(s) installé(s) $debOnlyPresents" \ + "à moins d'être certain, vous devriez peut-être le désinstaller:$GREEN apt remove firefox*" \ + "\n Sur Gnome, attention, consulter:$GREEN https://kyodev.frama.io/kyopages/scripts/getFirefox/#gnome" + fi +} + # inscription dans tache upgrade en anacron hebdomadaire, via cron horaire, $1=upgrade|install|remove fscript_cronAnacron(){ # 06/09/2017 local dirAnacron dirSpool fileAnacron @@ -873,14 +926,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 @@ -895,14 +942,15 @@ fscript_get_version(){ # 07/09/2017 } # installation du script dans le système -fscript_install(){ # 06/09/2017 +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" @@ -910,41 +958,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(){ # 25/08/2017 - [ -e "/var/log/sdeb_getFF.log" ] && mv "/var/log/sdeb_getFF.log" "$fileLogs" # changement ancien logs - if f__requis "firefox-esr firefox" "debOnly" && [ "$debOnlyPresents" ]; then - f__info "paquet(s) installé(s) $debOnlyPresents" \ - "à moins d'être certain, vous devriez peut-être le désinstaller:$RED apt remove firefox* $COLOR" \ - "\n Sur Gnome, attention, consulter:$GREEN https://kyodev.frama.io/kyopages/scripts/getFirefox/#gnome $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 @@ -954,11 +994,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" @@ -968,7 +1009,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/" @@ -979,9 +1020,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 Firefox" -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/getFirefox_changelog.md b/scripts/getFirefox_changelog.md index 5871a62..ff7ce9d 100644 --- a/scripts/getFirefox_changelog.md +++ b/scripts/getFirefox_changelog.md @@ -4,6 +4,16 @@ * placé ln dans /usr/local/bin au lieu de /usr/bin ? +## 3.9.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 + ## 3.8.2 24/09/2017 * fix mineur détection pb 3, raccourci /usr/bin