diff --git a/scripts/getFirefox b/scripts/getFirefox index ccc8775..f1d6dff 100755 --- a/scripts/getFirefox +++ b/scripts/getFirefox @@ -1,6 +1,6 @@ #!/bin/bash -version=2.8.0 +version=2.9.0 date="30/08/2017" projet="simpledeb" contact="IRC freenode ##sdeb ou https://framagit.org/kyodev/kyopages/issues/" @@ -53,9 +53,15 @@ f__architecture(){ # v07/2017 esac } - # test validité archive, $1 fichier (bzip2), return 1 si invalide -f__archive_test(){ # v07/2017 - file -b "$1" | grep -q 'bzip2 compressed data' || return 1 + # test validité archive, $1 archive, assigne $archive_detect (gzip|xz|deb|zip), return 1 si inconnue +f__archive_test(){ # v30/08/2017 + local filetest="$(file -b $1)" + grep -q 'gzip compressed data' <<< "$filetest" && archive_detect="gzip" + grep -q 'bzip2 compressed data' <<< "$filetest" && archive_detect="bzip2" + grep -q 'Debian binary package' <<< "$filetest" && archive_detect="deb" + grep -q 'Zip archive data' <<< "$filetest" && archive_detect="zip" + grep -q 'XZ compressed data' <<< "$filetest" && archive_detect="xz" + if [ ! "$archive_detect" ] || [ "$archive_detect" == "empty" ]; then return 1; fi } # affichage $1 en rouge, $1++ optionnels en bleu, sortie script sur erreur, log $1 si $opType=upgrade @@ -94,12 +100,12 @@ f__log(){ # v08/2017 # si $2=debOnly et si paquets manquants: return 1 et $debOnlyPackages ( $1=liste paquets ) # si $2=debOnly et si paquets présent: return 0 et $debOnlyPresents ( $1=liste paquets ) # attention priorité $debOnlyPackages sur $debOnlyPresents -f__requis(){ # v17/08/2017-3 - local dependsMissing packagesMissing +f__requis(){ # v30/08/2017-3 + local dependsMissing packagesMissing command package unset debOnlyPackages debOnlyPresents for i in $1; do - local command="$(cut -d '>' -f 1 <<< $i)" - local package="$(cut -d '>' -f 2 <<< $i)" + command="$(cut -d '>' -f 1 <<< $i)" + package="$(cut -d '>' -f 2 <<< $i)" if [ "$2" == "debOnly" ]; then if [ "$(which dpkg)" ]; then # package only et debian LC_ALL=C dpkg --get-selections | grep -qE "^$package[[:space:]]+install" \ @@ -124,13 +130,13 @@ f__requis(){ # v17/08/2017-3 # 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(){ # v21/08/2017-4 +f__user(){ # v30/08/2017-4 if [ "$USER_INSTALL" ]; then # user_ via variable environnement, moyen d'injecter root user_="$USER_INSTALL"; return 0 fi - local user_id test - local root_login="$(grep ':0:' /etc/passwd | cut -d':' -f1)" || local root_login="root" + 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 @@ -157,9 +163,10 @@ f__user(){ # v21/08/2017-4 # test wget, $1 url à tester, sortie script, sur erreur ou retour à la normale # si $2=print affiche url testée & entêtes http & location (si présente) et sortie normale fonction -f__wget_test(){ #v28/08/2017 - local file_test_wget="/tmp/testWget-$RANDOM" - wget -Sq --tries=1 --timeout=10 --user-agent="$user_agent" --spider --save-headers "$1" &>"$file_test_wget" || local retourWget="$?" +f__wget_test(){ # v30/08/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="$?" [ "$retourWget" == 1 ] && retourWget="code erreur générique" [ "$retourWget" == 2 ] && retourWget="parse erreur (ligne de commande?)" [ "$retourWget" == 3 ] && retourWget="erreur Entrée/sortie fichier" @@ -168,8 +175,8 @@ f__wget_test(){ #v28/08/2017 [ "$retourWget" == 6 ] && retourWget="défaut authentification" [ "$retourWget" == 7 ] && retourWget="erreur de protocole" [ "$retourWget" == 8 ] && retourWget="réponse serveur en erreur" - local retourHttp="$(grep -i 'HTTP/' "$file_test_wget" | tr -d '\n' | xargs)" - local location="$(grep -i 'location' $file_test_wget | xargs)" + retourHttp="$(grep -i 'HTTP/' "$file_test_wget" | tr -d '\n' | xargs)" + location="$(grep -i 'location' $file_test_wget | xargs)" if [ "$2" == "print" ] && [ -z "$retourWget" ]; then echo -e "\n$1" echo "$GREEN$retourHttp$COLOR" @@ -188,7 +195,7 @@ f__wget_test(){ #v28/08/2017 } # affichage help -f_help(){ #v25/08/2017 +f_help(){ # v25/08/2017 printf $BLUE cat << 'EOF' ---------------------------------------------------------------------- @@ -233,32 +240,42 @@ ffx_get_canalBas(){ } # version Firefox en ligne -ffx_get_versionsFF(){ #v28/08/2017 +ffx_get_versionsFF(){ # v30/08/2017 + local fileTmp recup_url verLatest verEsr verBeta verNightly versionInstall printf "." - local fileTmp="/tmp/getFirefox-wgetVer-$RANDOM" - local recup_url="https://www.mozilla.org/en-US/firefox/notes/" - wget -q --tries=2 --timeout=15 --user-agent=$user_agent -O - "$recup_url" &>"$fileTmp" - local verLatest="$(grep -Eo 'data-latest-firefox="[0-9\.]+"' $fileTmp | grep -Eo '[0-9\.]+')" - local verEsr="$(grep -Eo 'data-esr-versions="[0-9\.]+"' $fileTmp | grep -Eo '[0-9\.]+')" + fileTmp="/tmp/getFirefox-wgetVer-$RANDOM" + # version latest & esr + recup_url="https://www.mozilla.org/en-US/firefox/notes/" + wget -q --tries=2 --timeout=15 --user-agent="$user_agent" -O - "$recup_url" &>"$fileTmp" + verLatest="$(grep -Eo 'data-latest-firefox="[0-9\.]+"' $fileTmp | grep -Eo '[0-9\.]+')" printf "." - local recup_url="https://download.mozilla.org/?product=firefox-beta-latest&os=linux64&lang=fr" + verEsr="$(grep -Eo 'data-esr-versions="[0-9\.]+"' $fileTmp | grep -Eo '[0-9\.]+')" + printf "." + # version beta + recup_url="https://download.mozilla.org/?product=firefox-beta-latest&os=linux64&lang=fr" wget -Sq --tries=1 --timeout=10 --user-agent="$user_agent" --spider --save-headers "$recup_url" &>"$fileTmp" - local verBeta="$(grep -i 'location' $fileTmp | sed -E 's/.*firefox-(.*)\.tar.bz2/\1/')" + verBeta="$(grep -i 'location' $fileTmp | sed -E 's/.*firefox-(.*)\.tar.bz2/\1/')" printf "." - local recup_url="https://download.mozilla.org/?product=firefox-nightly-latest-l10n-ssl&os=linux64&lang=fr" + # version nightly + recup_url="https://download.mozilla.org/?product=firefox-nightly-latest-l10n-ssl&os=linux64&lang=fr" wget -Sq --tries=1 --timeout=10 --user-agent="$user_agent" --spider --save-headers "$recup_url" &>"$fileTmp" - local verNightly="$(grep -i 'location' $fileTmp | sed -E 's/.*firefox-(.*)\.fr.linux.*/\1/')" + verNightly="$(grep -i 'location' $fileTmp | sed -E 's/.*firefox-(.*)\.fr.linux.*/\1/')" printf "." rm "$fileTmp" + # versions installées for prod in latest esr beta dev nightly; do if [ -x "$dirInstall$prod/firefox" ]; then printf "." - versionInstall+="\n $prod: $($dirInstall$prod/firefox -v | grep -Eo '[0-9].*')" + versionInstall+="$prod: $($dirInstall$prod/firefox -v | grep -Eo '[0-9].*')\t" fi done printf ".\n" - f__info "raw" "$GREEN""Firefox installé(s): $versionInstall$COLOR" - f__info "version Firefox en ligne:\n Release : $verLatest\n Beta/dev: $verBeta\n Nightly : $verNightly\n ESR : $verEsr" + [ "$verLatest" ] || verLatest="$RED""NA" + [ "$verBeta" ] || verBeta="$RED""NA" + [ "$verNightly" ] || verNightly="$RED""NA" + [ "$verEsr" ] || verEsr="$RED""NA" + f__info "raw" "version Firefox installé(s): $GREEN$versionInstall$COLOR" + f__info "version Firefox en ligne: $YELLOW""Release: $verLatest\tBeta/dev: $verBeta\tNightly: $verNightly\tESR: $verEsr$COLORS" } # ascii art godzilla; ligne vide finale @@ -283,19 +300,20 @@ echo "$COLOR" } # installation Firefox, $1 produit, $2 manuel, $3 archive -ffx_install(){ #v27/08/2017 +ffx_install(){ # v30/08/2017 [ $EUID -eq 0 ] || f__error "vous devez être ROOT pour installer Firefox" + local versionArchive dirTemp fileTemp produit if [ "$2" == "manuel" ]; then - local versionArchive="$(sed -E 's/firefox-(.*)\.linux.*/\1/' <<< $(stat -c %n $3))" + versionArchive="$(sed -E 's/firefox-(.*)\.linux.*/\1/' <<< $(basename $3))" f__info "installation manuelle de firefox version $versionArchive ($3)" - local dirTemp="$(dirname $3)/$script-$RANDOM/" - local fileTemp="$(basename $3)" + dirTemp="$(dirname $3)/$script-$RANDOM/" + fileTemp="$(basename $3)" mkdir -p "$dirTemp" else - local produit="$1" + produit="$1" f__info "installation Firefox-$produit" - local dirTemp="/tmp/$script-$RANDOM/" - local fileTemp="$dirTemp""firefox-$produit.$architecture.tar.bz2" + dirTemp="/tmp/$script-$RANDOM/" + fileTemp="$dirTemp""firefox-$produit.$architecture.tar.bz2" mkdir -p "$dirTemp" # téléchargement & test archive f__info " - téléchargement..." @@ -328,13 +346,17 @@ ffx_install(){ #v27/08/2017 ffx_usr_bin # traitement user ffx_profil_user - f__info "log" "Firefox-$produit installé $versionArchive" + if [ "$1" == "manuel" ]; then + f__info "log" "archive Firefox-$produit $versionArchive installée" + else + f__info "log" "Firefox-$produit installé" + fi ffx_godzilla } # installation d'un FF chargé manuellement, $1 produit, $2 fichier archive -ffx_install_manuel(){ #v27/08/2017 - [ -e "$2" ] || f__error "fichier $1 introuvable" +ffx_install_manuel(){ # v30/08/2017 + [ -e "$2" ] || f__error "fichier $2 introuvable" f__archive_test "$2" || f__error "Le fichier $2 n'est pas une archive valide" ffx_install "$1" "manuel" "$2" [ -e "$fileDev" ] || rm "$2" &>/dev/null ## on efface pas si fileDev (dev) @@ -365,20 +387,20 @@ ffx_lanceur_desktop(){ } # version personnalisation en ligne, assigne $prodATraiter -ffx_pers_get_version(){ #v28/08/2017 +ffx_pers_get_version(){ # v30/08/2017 + local urlPers versionPersOnline versionPersInstall persEnPlace f__requis "wget" if [ -e "$dirProfil/$produit/personnalisation.$script" ]; then - local urlPers="$(sed -n '1p' "$dirProfil/$produit/personnalisation.$script")" + urlPers="$(sed -n '1p' "$dirProfil/$produit/personnalisation.$script")" else - local urlPers="https://framagit.org/kyodev/kyopages/raw/master/scripts/" + urlPers="https://framagit.org/kyodev/kyopages/raw/master/scripts/" fi - local versionPersOnline="$(wget -q --tries=2 --timeout=15 -O - "$urlPers"user.js | sed -En 's/\/\*v(.*)\*\//\1/p')" + versionPersOnline="$(wget -q --tries=2 --timeout=15 -O - "$urlPers"user.js | sed -En 's/\/\*v(.*)\*\//\1/p')" if [ "$versionPersOnline" ]; then - local versionPers persEnPlace for prod in latest esr beta dev nightly; do if [ -e "$dirProfil/$prod/personnalisation.$script" ]; then - versionPers="$(sed -n '2p' $dirProfil/$prod/personnalisation.$script)" - if [ "$versionPers" != "$versionPersOnline" ]; then prodATraiter+="$prod "; fi + versionPersInstall="$(sed -n '2p' $dirProfil/$prod/personnalisation.$script)" + if [ "$versionPersInstall" != "$versionPersOnline" ]; then prodATraiter+="$prod "; fi persEnPlace+="$prod " fi done @@ -392,22 +414,22 @@ ffx_pers_get_version(){ #v28/08/2017 } # recup user.js et chrome/userChrome.css, $1=produit à personnaliser ou mettre à jour -ffx_pers_install(){ #25/08/2017 - local produit="$1" - [ ! -d "$dirProfil/$produit" ] && f__error "firefox <$produit> n'est pas installé" "personnalisation abandonnée" +ffx_pers_install(){ # v30/08/2017 + local produit="$1" urlPers versionPersOnline dirTemp + [ ! -d "$dirProfil/$produit" ] && return f__requis "wget" # détermination url chargement fichiers personnalisation, std ou spécifique dans personnalisation.getFirefox if [ -e "$dirProfil/$produit/personnalisation.$script" ]; then - local urlPers="$(head -n1 "$dirProfil/$produit/personnalisation.$script")" + urlPers="$(head -n1 "$dirProfil/$produit/personnalisation.$script")" else - local urlPers="https://framagit.org/kyodev/kyopages/raw/master/scripts/" + urlPers="https://framagit.org/kyodev/kyopages/raw/master/scripts/" fi # chargement fichiers personnalisation - local dirTemp="/tmp/$script-$RANDOM/" + dirTemp="/tmp/$script-$RANDOM/" mkdir -p "$dirTemp" wget -q --tries=2 --timeout=15 -O "$dirTemp"user.js "$urlPers"user.js if [ "$?" != "0" ]; then f__wget_test "$urlPers"user.js; fi - local versionPers="$(sed -En 's/\/\*v(.*)\*\//\1/p' "$dirTemp"user.js)" # uniquement sur user.js + versionPersOnline="$(sed -En 's/\/\*v(.*)\*\//\1/p' "$dirTemp"user.js)" # uniquement sur user.js wget -q --tries=1 --timeout=15 -O "$dirTemp"userChrome.css "$urlPers"userChrome.css chown -R "$user_": "$dirTemp" # installation @@ -416,14 +438,14 @@ ffx_pers_install(){ #25/08/2017 cp "$dirTemp"user.js "$dirProfil/$produit/" [ -e "$dirTemp"userChrome.css ] && cp "$dirTemp"userChrome.css "$dirProfil/$produit/chrome" echo "$urlPers" > "$dirProfil/$produit/personnalisation.$script" - echo "$versionPers" >> "$dirProfil/$produit/personnalisation.$script" + echo "$versionPersOnline" >> "$dirProfil/$produit/personnalisation.$script" chown -R "$user_": "$dirProfil/$produit/personnalisation.$script" rm -rf "$dirTemp" - f__info "log" "personnalisation $versionPers mise en place pour $produit" + f__info "log" "personnalisation $versionPersOnline mise en place pour $produit" } # maj user.js et chrome/userChrome.css -ffx_pers_upgrade(){ #25/08/2017 +ffx_pers_upgrade(){ # v25/08/2017 ffx_pers_get_version if [ "$prodATraiter" ]; then for i in $prodATraiter; do ffx_pers_install "$i"; done @@ -450,7 +472,7 @@ ffx_profilIni_inscription(){ } # traitement utilisateur, $1=user si appel indépendant pour reconfiguration -ffx_profil_user(){ #22/08/2017 +ffx_profil_user(){ # v22/08/2017 if [ "$1" == "user" ] && [ ! -x "/usr/bin/firefox-$produit" ]; then f__error "firefox <$produit> n'est pas installé" " il faut donc utiliser l'installation et pas l'ajout d'un nouveau profil" fi @@ -481,7 +503,7 @@ ffx_profil_user(){ #22/08/2017 [ "$1" == "user" ] && f__info "log" "profil <$produit> configuré pour $user_" } - # calcul url téléchargement, assigne $recup_url. fixer url pour beta et nightly dans ffx_get_versionsFF + # calcul url téléchargement, assigne $recup_url ffx_recup_url(){ if [ "$produit" == "latest" ]; then recup_url="https://download.mozilla.org/?product=firefox-$produit&os=$architecture&lang=fr" @@ -541,11 +563,12 @@ ffx_usr_bin(){ } # inscription dans tache upgrade en anacron hebdomadaire, via cron horaire, $1=upgrade|install|remove -fscript_cronAnacron(){ # v27/08/2017 +fscript_cronAnacron(){ # v30/08/2017 + local dirAnacron dirSpool fileAnacron [ "$(type -t fscript_cronAnacron_special)" ] && fscript_cronAnacron_special # test, si fonction spécifique, appel - local dirAnacron="/home/$user_/.config/anacron" - local dirSpool="$dirAnacron/spool" - local fileAnacron="$dirAnacron/$script.anacrontab" + dirAnacron="/home/$user_/.config/anacron" + dirSpool="$dirAnacron/spool" + fileAnacron="$dirAnacron/$script.anacrontab" [ $EUID -eq 0 ] && sed -i "/$script.anacrontab/d" /etc/crontab case "$1" in install | upgrade ) @@ -692,6 +715,7 @@ dirInstall="/opt/usr/share/firefox-" dirProfil="/home/$user_/.mozilla/firefox" fileProfileIni="$dirProfil/profiles.ini" produitAll="latest beta nightly" +dirInstallTB="/opt/usr/share/tor-browser/" ls -d /opt/firefox-* &>/dev/null && problemOldInstall="detected" # ancienne localisation install firefox [ "$problemOldInstall" ] && f__info "raw" "$RED""Ancien(s) répertoire(s) d'installation détecté(s)" \ @@ -741,6 +765,7 @@ for i in $options; do ffx_get_versionsFF fscript_get_version ffx_pers_get_version + f_tb_get_version ffx_godzilla exit ;; # affiche versions Firefox en ligne & installées, script et personnalisation -i ) diff --git a/scripts/getFirefox_changelog.md b/scripts/getFirefox_changelog.md index 5244e5d..fa9f79b 100644 --- a/scripts/getFirefox_changelog.md +++ b/scripts/getFirefox_changelog.md @@ -4,6 +4,14 @@ ## todo * install: copie du profil du canal inférieur? +## 2.9.0 30/08/2017 + +* révision f__requis, f__user, f__wget_test, fscript_cronAnacron +* révision déclaration local +* révision f__archive_test, ffx_install_manuel +* révision affichage ffx_get_versionsFF, ffx_pers_get_version, ffx_pers_install +* si produit all, installation personnalisation uniquement pour les produits installés au lieu de f__error + ## 2.8.0 30/08/2017 * révision conditions d'utilisations, fscript_install, fscript_remove(), fscript_update