This commit is contained in:
kyodev 2017-09-23 10:57:40 +02:00
parent 523b9f5de2
commit f13f972281
2 changed files with 108 additions and 88 deletions

View File

@ -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

View File

@ -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