diff --git a/scripts/getFirefox b/scripts/getFirefox index 06fb13e..3bf7437 100755 --- a/scripts/getFirefox +++ b/scripts/getFirefox @@ -1,7 +1,7 @@ #!/bin/bash -version=3.7.0 -date="09/09/2017" +version=3.8.0 +date="22/09/2017" projet="simpledeb" contact="IRC freenode ##sdeb ou https://framagit.org/kyodev/kyopages/issues/" script="getFirefox" @@ -14,7 +14,7 @@ user_agent="Mozilla/5.0 Firefox" # contributeurs: kyodev ##### -f__affichage(){ # v06/2017 définition couleurs +f__affichage(){ # 06/2017 définition couleurs YELLOW="$(printf "\033[0;33m")" # ? GREEN="$(printf "\033[0;32m")" # ok BLUE="$(printf "\033[0;34m")" # info @@ -35,7 +35,7 @@ EOF } # détection architecture, assigne $architecture : linux|linux64, return 1 si architecture inconnue -f__architecture(){ # v07/2017 +f__architecture(){ # 07/2017 case "$(uname -m)" in amd64 | x86_64 ) architecture="linux64";; @@ -54,7 +54,7 @@ f__architecture(){ # v07/2017 } # test validité archive, $1 archive, assigne $archive_detect (gzip|xz|deb|zip), return 1 si inconnue -f__archive_test(){ # v30/08/2017 +f__archive_test(){ # 30/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" @@ -65,25 +65,27 @@ f__archive_test(){ # v30/08/2017 } # affichage $1 en rouge, $1++ optionnels en bleu, sortie script sur erreur, log $1 si $opType=upgrade -f__error() { # v25/08/2017 +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 + for (( i=2 ; i<=$# ; i++ )); do echo -e " $BLUE${!i}"; done + unset i echo "$COLOR" 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() { # v25/08/2017 +f__info() { # 22/09/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 + unset i [ "$1" == raw ] && printf "$COLOR" || echo "$COLOR" } # log spécifique, fichier log limité à 10000octets, $1 message à loguer -f__log(){ # v08/O9/2017 +f__log(){ # 08/O9/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" @@ -101,7 +103,7 @@ f__log(){ # v08/O9/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(){ # v30/08/2017-3 +f__requis(){ # 22/09/2017 local dependsMissing packagesMissing command package unset debOnlyPackages debOnlyPresents for i in $1; do @@ -117,6 +119,7 @@ f__requis(){ # v30/08/2017-3 packagesMissing+="$package " fi done + unset i [ "$debOnlyPackages" ] && debOnlyPackages="$(xargs <<< $debOnlyPackages)" # trim début & fin [ "$debOnlyPresents" ] && debOnlyPresents="$(xargs <<< $debOnlyPresents)" # trim début & fin [ "$debOnlyPackages" ] && return 1 @@ -131,7 +134,7 @@ f__requis(){ # v30/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(){ # v30/08/2017-4 +f__user(){ # 30/08/2017-4 if [ "$USER_INSTALL" ]; then # user_ via variable environnement, moyen d'injecter root user_="$USER_INSTALL"; return 0 @@ -165,7 +168,7 @@ f__user(){ # v30/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 # si $2=loc affiche seulement location -f__wget_test(){ # v07/09/2017 +f__wget_test(){ # 07/09/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="$?" @@ -208,7 +211,7 @@ f__wget_test(){ # v07/09/2017 } # affichage help -f_help(){ # v09/09/2017 +f_help(){ # 09/09/2017 printf $BLUE cat << 'EOF' ---------------------------------------------------------------------- @@ -248,7 +251,7 @@ echo -e " plus d'infos: $GREEN$urlNotice$COLOR\n" } # assigne $verTorOnline -f_tb_get_version(){ # v06/09/2017 +f_tor_get_version(){ # 06/09/2017 local fileTmp recup_urlTb verTorInstall # version online fileTmp="/tmp/getFirefox-wgetVer-$RANDOM" @@ -267,9 +270,9 @@ f_tb_get_version(){ # v06/09/2017 } # installation TorBrowser, [$1 manuel, $2 archive] -f_tb_install(){ # v07/09/2017 +f_tor_install(){ # 07/09/2017 [ "$EUID" -eq 0 ] || f__error "vous devez être ROOT pour installer Tor Browser" - [ "$verTorOnline" ] || f_tb_get_version + [ "$verTorOnline" ] || f_tor_get_version local dirTemp archi fileTemp recup_urlTb verArchive fileDesktop if [ "$1" == "manuel" ]; then verArchive="$(sed -En 's/.*tor-browser-linux[0-9]{2}-(.*)\.tar\.xz.*$/\1/p' <<< $(basename $2))" @@ -302,7 +305,7 @@ f_tb_install(){ # v07/09/2017 chown -R "$user_:" "$dirInstallTB/" chmod -R g+wrs,a+r "$dirInstallTB/" rm -rf "$dirTemp/" - f_tb_lanceur_desktop + f_tor_lanceur_desktop fileDesktop="/usr/share/applications/tor-browser.desktop" # lien dans /usr/bin ln -sf "$fileDesktop" "/usr/bin/tor-browser" @@ -316,18 +319,16 @@ f_tb_install(){ # v07/09/2017 } # installation Tor Browser chargé manuellement, $1 fichier archive -f_tb_install_manuel(){ # v31/08/2017 +f_tor_install_manuel(){ # 31/08/2017 [ -e "$1" ] || f__error "fichier $1 introuvable" f__archive_test "$1" || f__error "Le fichier $1 n'est pas une archive valide" - f_tb_install "manuel" "$1" + f_tor_install "manuel" "$1" [ -e "$fileDev" ] || rm "$1" &>/dev/null ## on efface pas si fileDev (dev) } # création lanceur.desktop pour tor-browser -f_tb_lanceur_desktop(){ # v06/09/2017 +f_tor_lanceur_desktop(){ # 22/09/2017 local fileDesktop="/usr/share/applications/tor-browser.desktop" - echo "#!/usr/bin/env $dirInstallTB/Browser/execdesktop" > "$fileDesktop" - echo >> "$fileDesktop" echo "[Desktop Entry]" >> "$fileDesktop" echo "Name=Tor Browser" >> "$fileDesktop" echo "X-GNOME-FullName=Tor Browser" >> "$fileDesktop" @@ -349,7 +350,7 @@ f_tb_lanceur_desktop(){ # v06/09/2017 } # version personnalisation Tor Browser en ligne, assigne $persTbATraiter -f_tb_pers_get_version(){ # v06/09/2017 +f_tor_pers_get_version(){ # 06/09/2017 local urlPersTb versPersTbOnline verPersTbInstall if [ -e "$profilTor/personnalisation.$script" ]; then urlPersTb="$(sed -n '1p' $profilTor/personnalisation.$script)" @@ -372,7 +373,7 @@ f_tb_pers_get_version(){ # v06/09/2017 } # recup userTor.js et chrome/userChrome.css pour Tor Browser -f_tb_pers_install(){ # v06/09/2017 +f_tor_pers_install(){ # 06/09/2017 local urlPersTb verPersTbDL dirTemp if [ ! -d "$profilTor/" ]; then f__info "Tor Browser inexistant" @@ -421,7 +422,7 @@ f_tb_pers_install(){ # v06/09/2017 } # supprime personnalisation pour Tor Browser -f_tb_pers_remove(){ # v06/09/2017 +f_tor_pers_remove(){ # 06/09/2017 # "$profilTor/chrome/" volontairement laissé si autres fichiers ajoutés rm "$profilTor/user.js" "$profilTor/personnalisation.$script" rm "$profilTor/chrome/userChrome.css" @@ -429,15 +430,15 @@ f_tb_pers_remove(){ # v06/09/2017 } # maj userTor.js et chrome/userChrome.css pour Tor Browser -f_tb_pers_upgrade(){ # v06/09/2017 - f_tb_pers_get_version +f_tor_pers_upgrade(){ # 06/09/2017 + f_tor_pers_get_version if [ "$persTbATraiter" ]; then - f_tb_pers_install + f_tor_pers_install fi } # désinstallation de Tor Browser -f_tb_remove(){ # v08/09/2017 +f_tor_remove(){ # 08/09/2017 [ "$EUID" -eq 0 ] || f__error "vous devez être ROOT pour désinstaller Tor Browser" if [ ! -d "$dirInstallTB/" ]; then f__info "$GREEN""Tor Browser n'est pas installé." @@ -456,7 +457,7 @@ f_tb_remove(){ # v08/09/2017 } # copie du répertoire défault dans canal, $1=canal -ffx_default(){ # v09/09/2017 +ffx_default(){ # 09/09/2017 local canal="$1" profileDefault f__info "copie d'un profil default sur $canal" [ -d "$dirProfil/$canal" ] || mkdir -p "$dirProfil/$canal" # répertoire du profil @@ -474,17 +475,18 @@ ffx_default(){ # v09/09/2017 } # détermination canal bas Firefox installé, assigne $firefoxCanalBas -ffx_get_canalBas(){ +ffx_get_canalBas(){ # 22/09/2017 for ii in nightly dev beta esr latest; do if [ -d "$dirInstall$ii/" ]; then firefoxCanalBas="$ii"; fi done + unset ii [ "$firefoxCanalBas" ] || return 1 } # version Firefox en ligne -ffx_get_versionsFF(){ # v07/09/2017 +ffx_get_version(){ # 22/09/2017 local fileTmp recup_url verLatest verEsr verBeta verNightly verFFxInstall tabEspaces=" " - printf "." + printf " ." fileTmp="/tmp/getFirefox-wgetVer-$RANDOM" # version latest & esr recup_url="https://www.mozilla.org/en-US/firefox/notes/" @@ -505,13 +507,14 @@ ffx_get_versionsFF(){ # v07/09/2017 printf "." rm "$fileTmp" # versions installées - for prod in latest esr beta dev nightly; do - if [ -x "$dirInstall$prod/firefox" ]; then + for ii in latest esr beta dev nightly; do + if [ -x "$dirInstall$ii/firefox" ]; then printf "." - verFFxInstall+="$prod: $($dirInstall$prod/firefox -v | grep -Eo '[0-9].*')$tabEspaces" + verFFxInstall+="$ii: $($dirInstall$ii/firefox -v | grep -Eo '[0-9].*')$tabEspaces" fi done - printf ".\n" + unset ii + printf ".\n\n" [ "$verLatest" ] || verLatest="$RED""NA" [ "$verBeta" ] || verBeta="$RED""NA" [ "$verNightly" ] || verNightly="$RED""NA" @@ -522,7 +525,7 @@ ffx_get_versionsFF(){ # v07/09/2017 } # ascii art godzilla; ligne vide finale -ffx_godzilla(){ +ffx_godzilla(){ # 06/2017 printf "$RED" cat << 'EOF' _.-~-. @@ -543,7 +546,7 @@ echo "$COLOR" } # installation Firefox, $1 produit, $2 manuel, $3 archive -ffx_install(){ # v08/09/2017 +ffx_install(){ # 22/09/2017 [ "$EUID" -eq 0 ] || f__error "vous devez être ROOT pour installer Firefox" local verArchive dirTemp fileTemp produit="$1" if [ "$2" == "manuel" ]; then @@ -579,9 +582,10 @@ ffx_install(){ # v08/09/2017 rm -rf "$dirTemp/" # lien icône Firefox ln -sf "$dirInstall$produit/browser/chrome/icons/default/default48.png" "/usr/share/pixmaps/firefox-$produit.png" - # gestion liens lanceurs paquet debian éventuels - [ -h "/usr/bin/firefox-esr" ] && unlink "/usr/bin/firefox-esr" - [ -h "/usr/bin/firefox" ] && unlink "/usr/bin/firefox" +# # gestion liens lanceurs paquet debian éventuels +#[ -h "/usr/bin/firefox-esr" ] && unlink "/usr/bin/firefox-esr" +#[ -h "/usr/bin/firefox" ] && unlink "/usr/bin/firefox" + [ -h "/usr/bin/firefox-$produit" ] && unlink "/usr/bin/firefox-$produit" # lanceur dans /usr/bin echo '#!/bin/sh' > "/usr/bin/firefox-$produit" echo >> "/usr/bin/firefox-$produit" @@ -601,7 +605,7 @@ ffx_install(){ # v08/09/2017 } # installation d'un FF chargé manuellement, $1 produit, $2 fichier archive -ffx_install_manuel(){ # v30/08/2017 +ffx_install_manuel(){ # 30/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" @@ -609,9 +613,8 @@ ffx_install_manuel(){ # v30/08/2017 } # création lanceur.desktop -ffx_lanceur_desktop(){ #v06/2017 +ffx_lanceur_desktop(){ # 22/09/2017 local fileDesktop="/usr/share/applications/firefox-$produit.desktop" - echo "#!/usr/bin/env xdg-open" > "$fileDesktop" echo "[Desktop Entry]" >> "$fileDesktop" echo "Name=Firefox $produit" >> "$fileDesktop" echo "Name[fr]=Firefox $produit" >> "$fileDesktop" @@ -633,23 +636,24 @@ ffx_lanceur_desktop(){ #v06/2017 } # version personnalisation en ligne, assigne $prodATraiter -ffx_pers_get_version(){ # v02/09/2017 +ffx_pers_get_version(){ # 22/09/2017 local urlPers verPersOnline verPersInstall persEnPlace - for prod in latest esr beta dev nightly; do - if [ -e "$dirProfil/$prod/personnalisation.$script" ]; then - urlPers="$(sed -n '1p' $dirProfil/$prod/personnalisation.$script)" + for ii in latest esr beta dev nightly; do + if [ -e "$dirProfil/$ii/personnalisation.$script" ]; then + urlPers="$(sed -n '1p' $dirProfil/$ii/personnalisation.$script)" else urlPers="https://framagit.org/kyodev/kyopages/raw/master/scripts/" fi verPersOnline="$(wget -q --tries=2 --timeout=15 -O - $urlPers'user.js' | sed -En 's/\/\*v(.*)\*\//\1/p')" if [ "$verPersOnline" ]; then - if [ -e "$dirProfil/$prod/personnalisation.$script" ]; then - verPersInstall="$(sed -n '2p' $dirProfil/$prod/personnalisation.$script)" - if [ "$verPersInstall" != "$verPersOnline" ]; then prodATraiter+="$prod "; fi - persEnPlace+="$prod($verPersInstall) " + if [ -e "$dirProfil/$ii/personnalisation.$script" ]; then + verPersInstall="$(sed -n '2p' $dirProfil/$ii/personnalisation.$script)" + if [ "$verPersInstall" != "$verPersOnline" ]; then prodATraiter+="$ii "; fi + persEnPlace+="$ii($verPersInstall) " fi 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" if [ "$prodATraiter" ]; then f__info "version personnalisation en ligne: $verPersOnline, mise à jour possible pour $prodATraiter" @@ -659,7 +663,7 @@ ffx_pers_get_version(){ # v02/09/2017 } # recup user.js et chrome/userChrome.css, $1=canal à personnaliser ou mettre à jour -ffx_pers_install(){ # v06/09/2017 +ffx_pers_install(){ # 06/09/2017 local canal="$1" urlPers verPersDL dirTemp if [ ! -d "$dirProfil/$canal" ]; then f__info "firefox $canal inexistant" @@ -706,7 +710,7 @@ ffx_pers_install(){ # v06/09/2017 } # supprime une personnalisation pour un canal, $1=canal à traiter -ffx_pers_remove(){ # v02/09/2017 +ffx_pers_remove(){ # 02/09/2017 local canal="$1" # "$dirProfil/$canal/chrome/" répertoire laissé en place si autres fichiers rm "$dirProfil/$canal/user.js" "$dirProfil/$canal/personnalisation.$script" @@ -715,15 +719,16 @@ ffx_pers_remove(){ # v02/09/2017 } # maj user.js et chrome/userChrome.css -ffx_pers_upgrade(){ # v06/09/2017 +ffx_pers_upgrade(){ # 22/09/2017 ffx_pers_get_version if [ "$prodATraiter" ]; then - for i in $prodATraiter; do ffx_pers_install "$i"; done + for ii in $prodATraiter; do ffx_pers_install "$ii"; done + unset ii fi } # traitement utilisateur, $1=user si appel indépendant pour reconfiguration -ffx_profil_user(){ # v08/09/2017 +ffx_profil_user(){ # 08/09/2017 local profileDefault nbProfiles 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" @@ -772,7 +777,7 @@ ffx_profil_user(){ # v08/09/2017 } # calcul url téléchargement, assigne $recup_url -ffx_recup_url(){ #v06/2017 +ffx_recup_url(){ # 06/2017 if [ "$produit" == "latest" ]; then recup_url="https://download.mozilla.org/?product=firefox-$produit&os=$architecture&lang=fr" elif [ "$produit" == "esr" ] || [ "$produit" == "beta" ]; then @@ -784,7 +789,7 @@ ffx_recup_url(){ #v06/2017 } # désinstallation de Firefox, on laisse le profil user -ffx_remove(){ # v08/09/2017 +ffx_remove(){ # 08/09/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 +818,7 @@ ffx_remove(){ # v08/09/2017 } # traitement update-alternatives -ffx_update_alternatives(){ #v06/2017 +ffx_update_alternatives(){ # 06/2017 [ "$(which update-alternatives)" ] || return 0 # update-alternatives n'est pas sur cette distrib if ffx_get_canalBas ; then update-alternatives --quiet --install /usr/bin/firefox x-www-browser "/usr/bin/firefox-$firefoxCanalBas" 100 @@ -826,7 +831,7 @@ ffx_update_alternatives(){ #v06/2017 } # lien /usr/bin/firefox pour le plus bas canal Firefox installé -ffx_usr_bin(){ # v08/09/2017 +ffx_usr_bin(){ # 08/09/2017 if ffx_get_canalBas ; then ln -sf "/usr/bin/firefox-$firefoxCanalBas" "/usr/bin/firefox" f__info " - firefox lié à firefox-$firefoxCanalBas" @@ -834,7 +839,7 @@ ffx_usr_bin(){ # v08/09/2017 } # inscription dans tache upgrade en anacron hebdomadaire, via cron horaire, $1=upgrade|install|remove -fscript_cronAnacron(){ # v06/09/2017 +fscript_cronAnacron(){ # 06/09/2017 local dirAnacron dirSpool fileAnacron [ "$(type -t fscript_cronAnacron_special)" ] && fscript_cronAnacron_special # test, si fonction spécifique, appel dirAnacron="/home/$user_/.config/anacron" @@ -869,13 +874,13 @@ fscript_cronAnacron(){ # v06/09/2017 } # spécifique script -fscript_cronAnacron_special(){ # v19/08/2017 +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(){ # v07/09/2017 +fscript_get_version(){ # 07/09/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 @@ -890,7 +895,7 @@ fscript_get_version(){ # v07/09/2017 } # installation du script dans le système -fscript_install(){ # v06/09/2017 +fscript_install(){ # 06/09/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 @@ -917,7 +922,7 @@ fscript_install(){ # v06/09/2017 } # spécifique script -fscript_install_special(){ # v25/08/2017 +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" \ @@ -927,7 +932,7 @@ fscript_install_special(){ # v25/08/2017 } # suppression du script dans le système -fscript_remove(){ # v06/09/2017 +fscript_remove(){ # 06/09/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" return 1 @@ -949,7 +954,7 @@ fscript_remove(){ # v06/09/2017 } # mise à jour script si dispo -fscript_update(){ # v06/09/2017 +fscript_update(){ # 06/09/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" return @@ -997,19 +1002,20 @@ ls -d /opt/firefox-* &>/dev/null && problemOldInstall="detected" # ancienne loc [ -e "/opt/bin/$script" ] && [ "$(stat -c %G /opt/bin/$script)" == "root" ] && problemDetected+="-1" # droits inappropriés sur le script, version de dev grep -Eq '^exec.*/firefox -P.*$' '/usr/bin/firefox' && problemDetected+="-3" # raccourci /usr/bin en erreur options=$@ -if [ "$(dirname $0)" == "." ]; then options="-i" # script install +if [ "$(dirname $0)" == "." ] && [ ! -e "$fileDev" ]; then options="-i" # script install else if [ ! -w "$fileLogs" ] && ls -d "$dirInstall"* &>/dev/null ; then problemDetected+="-2"; fi # ancien système de logs via syslog fi [ "$problemDetected" ] && f__info "$RED""l'installation du script est obsolète ($problemDetected)" \ "veuillez réinstaller le script manuellement" "$GREEN""voir $urlNotice#messages-avertissement" -for i in $options; do - case $i in +for j in $options; do + case $j in i-latest | i-esr | i-dev | i-beta | i-nightly | i-all | +latest | +esr | +dev | +beta | +nightly | +all ) produit="$(sed 's/i-//; s/+//' <<< "$1")" if [ "$produit" == "all" ]; then produit="$produitAll"; fi - for i in $produit; do ffx_install "$i"; done + for k in $produit; do ffx_install "$k"; done + unset k exit ;; # install: installation canal Firefox $1=produit, (gestion ancien répertoire éventuel) m-latest | m-esr | m-dev | m-beta | m-nightly ) produit="$(sed 's/m-//' <<< "$1")" @@ -1018,21 +1024,24 @@ for i in $options; do p-latest | p-esr | p-dev | p-beta | p-nightly | p-all ) produit="$(sed 's/p-//' <<< "$1")" if [ "$produit" == "all" ]; then produit="$produitAll"; fi - for i in $produit; do ffx_pers_install "$i"; done + for k in $produit; do ffx_pers_install "$k"; done + unset k exit ;; # mise en place personnalisation pr-latest | pr-esr | pr-dev | pr-beta | pr-nightly | pr-all ) produit="$(sed 's/pr-//' <<< "$1")" if [ "$produit" == "all" ]; then produit="$produitAll"; fi - for i in $produit; do ffx_pers_remove "$i"; done + for k in $produit; do ffx_pers_remove "$k"; done + unset k exit ;; # supression personnalisation pu ) ffx_pers_upgrade - f_tb_pers_upgrade + f_tor_pers_upgrade exit ;; # mise à jour personnalisations r-latest | r-esr | r-dev | r-beta | r-nightly | r-all | -latest | -esr | -dev | -beta | -nightly | -all ) produit="$(sed 's/r-//; s/-//' <<< "$1")" if [ "$produit" == "all" ]; then produit="$produitAll"; fi - for i in $produit; do ffx_remove "$i"; done + for k in $produit; do ffx_remove "$k"; done + unset k exit ;; # remove: désinstallation Firefox (y compris ancien répertoire éventuel) u-latest | u-esr | u-dev | u-beta | u-nightly ) produit="$(sed 's/u-//' <<< "$1")" @@ -1043,29 +1052,30 @@ for i in $options; do produit="$(sed 's/d-//' <<< "$1")" [ "$problemOldInstall" ] && f__error "vous devez réinstaller firefox auparavant" if [ "$produit" == "all" ]; then produit="$produitAll"; fi - for i in $produit; do ffx_default "$i"; done + for k in $produit; do ffx_default "$k"; done + unset k exit ;; # copier un profil default sur un canal version | versions ) - ffx_get_versionsFF + ffx_get_version fscript_get_version ffx_pers_get_version - f_tb_get_version - f_tb_pers_get_version + f_tor_get_version + f_tor_pers_get_version exit ;; # affiche versions Firefox en ligne & installées, script et personnalisation i-tor ) - f_tb_install + f_tor_install exit ;; # installation tor browser m-tor ) - f_tb_install_manuel "$2" + f_tor_install_manuel "$2" exit ;; # installation manuelle archive tor browser, $2 fichier archive p-tor ) - f_tb_pers_install + f_tor_pers_install exit ;; # personnalisation pour tor browser pr-tor ) - f_tb_pers_remove + f_tor_pers_remove exit ;; # supression personnalisation pour tor browser r-tor ) - f_tb_remove + f_tor_remove exit ;; # désinstallation tor browser -i ) fscript_install @@ -1077,7 +1087,7 @@ for i in $options; do opType="upgrade" fscript_update ffx_pers_upgrade - f_tb_pers_upgrade + f_tor_pers_upgrade exit ;; # upgrade script & personnalisations -v | --version ) fscript_get_version @@ -1087,7 +1097,7 @@ for i in $options; do exit ;; # affichage help esac done - +unset j exit 0 wget -O getFirefox https://framagit.org/kyodev/kyopages/raw/master/scripts/getFirefox diff --git a/scripts/getFirefox_changelog.md b/scripts/getFirefox_changelog.md index 534e9f2..121c4c1 100644 --- a/scripts/getFirefox_changelog.md +++ b/scripts/getFirefox_changelog.md @@ -2,6 +2,16 @@ ## todo +* placé ln dans /usr/local/bin au lieu de /usr/bin ? + +## 3.8.0 22/09/2017 + +* renommage fonctions tor +* mineure correction lanceurs desktop +* renommage ffx_get_versionFF en ffx_get_version, présentation +* ffx_get_version, ffx_pers_get_version, ffx_pers_upgrade, ffx_get_canalBas unset/for +* f__requis, f__info, f__error unset/for + ## 3.7.0 09/09/2017 * remove ligne test dev