This commit is contained in:
kyodev 2017-08-30 22:51:31 +02:00
parent c5a35ee4af
commit 17e5ad18de
2 changed files with 96 additions and 63 deletions

View File

@ -1,6 +1,6 @@
#!/bin/bash #!/bin/bash
version=2.8.0 version=2.9.0
date="30/08/2017" date="30/08/2017"
projet="simpledeb" projet="simpledeb"
contact="IRC freenode ##sdeb ou https://framagit.org/kyodev/kyopages/issues/" contact="IRC freenode ##sdeb ou https://framagit.org/kyodev/kyopages/issues/"
@ -53,9 +53,15 @@ f__architecture(){ # v07/2017
esac esac
} }
# test validité archive, $1 fichier (bzip2), return 1 si invalide # test validité archive, $1 archive, assigne $archive_detect (gzip|xz|deb|zip), return 1 si inconnue
f__archive_test(){ # v07/2017 f__archive_test(){ # v30/08/2017
file -b "$1" | grep -q 'bzip2 compressed data' || return 1 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 # 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 manquants: return 1 et $debOnlyPackages ( $1=liste paquets )
# si $2=debOnly et si paquets présent: return 0 et $debOnlyPresents ( $1=liste paquets ) # si $2=debOnly et si paquets présent: return 0 et $debOnlyPresents ( $1=liste paquets )
# attention priorité $debOnlyPackages sur $debOnlyPresents # attention priorité $debOnlyPackages sur $debOnlyPresents
f__requis(){ # v17/08/2017-3 f__requis(){ # v30/08/2017-3
local dependsMissing packagesMissing local dependsMissing packagesMissing command package
unset debOnlyPackages debOnlyPresents unset debOnlyPackages debOnlyPresents
for i in $1; do for i in $1; do
local command="$(cut -d '>' -f 1 <<< $i)" command="$(cut -d '>' -f 1 <<< $i)"
local package="$(cut -d '>' -f 2 <<< $i)" package="$(cut -d '>' -f 2 <<< $i)"
if [ "$2" == "debOnly" ]; then if [ "$2" == "debOnly" ]; then
if [ "$(which dpkg)" ]; then # package only et debian if [ "$(which dpkg)" ]; then # package only et debian
LC_ALL=C dpkg --get-selections | grep -qE "^$package[[:space:]]+install" \ 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_ # user ayant initié la session graphique, assigne $user_
# return 1 sur échec identification user, return 2 sur absence home/ # return 1 sur échec identification user, return 2 sur absence home/
# gestion variable environnement user avec: USER_INSTALL=user script # 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 if [ "$USER_INSTALL" ]; then # user_ via variable environnement, moyen d'injecter root
user_="$USER_INSTALL"; user_="$USER_INSTALL";
return 0 return 0
fi fi
local user_id test local user_id test root_login
local root_login="$(grep ':0:' /etc/passwd | cut -d':' -f1)" || local root_login="root" root_login="$(grep ':0:' /etc/passwd | cut -d':' -f1)" || root_login="root"
if [ "$SUDO_UID" ]; then if [ "$SUDO_UID" ]; then
user_id="$SUDO_UID"; user_id="$SUDO_UID";
elif grep -qEo '[0-9]+' <<< "$XDG_RUNTIME_DIR" ; then 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 # 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=print affiche url testée & entêtes http & location (si présente) et sortie normale fonction
f__wget_test(){ #v28/08/2017 f__wget_test(){ # v30/08/2017
local file_test_wget="/tmp/testWget-$RANDOM" local file_test_wget retourWget retourHttp location
wget -Sq --tries=1 --timeout=10 --user-agent="$user_agent" --spider --save-headers "$1" &>"$file_test_wget" || local 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="$?"
[ "$retourWget" == 1 ] && retourWget="code erreur générique" [ "$retourWget" == 1 ] && retourWget="code erreur générique"
[ "$retourWget" == 2 ] && retourWget="parse erreur (ligne de commande?)" [ "$retourWget" == 2 ] && retourWget="parse erreur (ligne de commande?)"
[ "$retourWget" == 3 ] && retourWget="erreur Entrée/sortie fichier" [ "$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" == 6 ] && retourWget="défaut authentification"
[ "$retourWget" == 7 ] && retourWget="erreur de protocole" [ "$retourWget" == 7 ] && retourWget="erreur de protocole"
[ "$retourWget" == 8 ] && retourWget="réponse serveur en erreur" [ "$retourWget" == 8 ] && retourWget="réponse serveur en erreur"
local retourHttp="$(grep -i 'HTTP/' "$file_test_wget" | tr -d '\n' | xargs)" retourHttp="$(grep -i 'HTTP/' "$file_test_wget" | tr -d '\n' | xargs)"
local location="$(grep -i 'location' $file_test_wget | xargs)" location="$(grep -i 'location' $file_test_wget | xargs)"
if [ "$2" == "print" ] && [ -z "$retourWget" ]; then if [ "$2" == "print" ] && [ -z "$retourWget" ]; then
echo -e "\n$1" echo -e "\n$1"
echo "$GREEN$retourHttp$COLOR" echo "$GREEN$retourHttp$COLOR"
@ -188,7 +195,7 @@ f__wget_test(){ #v28/08/2017
} }
# affichage help # affichage help
f_help(){ #v25/08/2017 f_help(){ # v25/08/2017
printf $BLUE printf $BLUE
cat << 'EOF' cat << 'EOF'
---------------------------------------------------------------------- ----------------------------------------------------------------------
@ -233,32 +240,42 @@ ffx_get_canalBas(){
} }
# version Firefox en ligne # 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 "." printf "."
local fileTmp="/tmp/getFirefox-wgetVer-$RANDOM" fileTmp="/tmp/getFirefox-wgetVer-$RANDOM"
local recup_url="https://www.mozilla.org/en-US/firefox/notes/" # version latest & esr
wget -q --tries=2 --timeout=15 --user-agent=$user_agent -O - "$recup_url" &>"$fileTmp" recup_url="https://www.mozilla.org/en-US/firefox/notes/"
local verLatest="$(grep -Eo 'data-latest-firefox="[0-9\.]+"' $fileTmp | grep -Eo '[0-9\.]+')" wget -q --tries=2 --timeout=15 --user-agent="$user_agent" -O - "$recup_url" &>"$fileTmp"
local verEsr="$(grep -Eo 'data-esr-versions="[0-9\.]+"' $fileTmp | grep -Eo '[0-9\.]+')" verLatest="$(grep -Eo 'data-latest-firefox="[0-9\.]+"' $fileTmp | grep -Eo '[0-9\.]+')"
printf "." 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" 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 "." 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" 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 "." printf "."
rm "$fileTmp" rm "$fileTmp"
# versions installées
for prod in latest esr beta dev nightly; do for prod in latest esr beta dev nightly; do
if [ -x "$dirInstall$prod/firefox" ]; then if [ -x "$dirInstall$prod/firefox" ]; then
printf "." printf "."
versionInstall+="\n $prod: $($dirInstall$prod/firefox -v | grep -Eo '[0-9].*')" versionInstall+="$prod: $($dirInstall$prod/firefox -v | grep -Eo '[0-9].*')\t"
fi fi
done done
printf ".\n" printf ".\n"
f__info "raw" "$GREEN""Firefox installé(s): $versionInstall$COLOR" [ "$verLatest" ] || verLatest="$RED""NA"
f__info "version Firefox en ligne:\n Release : $verLatest\n Beta/dev: $verBeta\n Nightly : $verNightly\n ESR : $verEsr" [ "$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 # ascii art godzilla; ligne vide finale
@ -283,19 +300,20 @@ echo "$COLOR"
} }
# installation Firefox, $1 produit, $2 manuel, $3 archive # 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" [ $EUID -eq 0 ] || f__error "vous devez être ROOT pour installer Firefox"
local versionArchive dirTemp fileTemp produit
if [ "$2" == "manuel" ]; then 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)" f__info "installation manuelle de firefox version $versionArchive ($3)"
local dirTemp="$(dirname $3)/$script-$RANDOM/" dirTemp="$(dirname $3)/$script-$RANDOM/"
local fileTemp="$(basename $3)" fileTemp="$(basename $3)"
mkdir -p "$dirTemp" mkdir -p "$dirTemp"
else else
local produit="$1" produit="$1"
f__info "installation Firefox-$produit" f__info "installation Firefox-$produit"
local dirTemp="/tmp/$script-$RANDOM/" dirTemp="/tmp/$script-$RANDOM/"
local fileTemp="$dirTemp""firefox-$produit.$architecture.tar.bz2" fileTemp="$dirTemp""firefox-$produit.$architecture.tar.bz2"
mkdir -p "$dirTemp" mkdir -p "$dirTemp"
# téléchargement & test archive # téléchargement & test archive
f__info " - téléchargement..." f__info " - téléchargement..."
@ -328,13 +346,17 @@ ffx_install(){ #v27/08/2017
ffx_usr_bin ffx_usr_bin
# traitement user # traitement user
ffx_profil_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 ffx_godzilla
} }
# installation d'un FF chargé manuellement, $1 produit, $2 fichier archive # installation d'un FF chargé manuellement, $1 produit, $2 fichier archive
ffx_install_manuel(){ #v27/08/2017 ffx_install_manuel(){ # v30/08/2017
[ -e "$2" ] || f__error "fichier $1 introuvable" [ -e "$2" ] || f__error "fichier $2 introuvable"
f__archive_test "$2" || f__error "Le fichier $2 n'est pas une archive valide" f__archive_test "$2" || f__error "Le fichier $2 n'est pas une archive valide"
ffx_install "$1" "manuel" "$2" ffx_install "$1" "manuel" "$2"
[ -e "$fileDev" ] || rm "$2" &>/dev/null ## on efface pas si fileDev (dev) [ -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 # 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" f__requis "wget"
if [ -e "$dirProfil/$produit/personnalisation.$script" ]; then 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 else
local urlPers="https://framagit.org/kyodev/kyopages/raw/master/scripts/" urlPers="https://framagit.org/kyodev/kyopages/raw/master/scripts/"
fi 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 if [ "$versionPersOnline" ]; then
local versionPers persEnPlace
for prod in latest esr beta dev nightly; do for prod in latest esr beta dev nightly; do
if [ -e "$dirProfil/$prod/personnalisation.$script" ]; then if [ -e "$dirProfil/$prod/personnalisation.$script" ]; then
versionPers="$(sed -n '2p' $dirProfil/$prod/personnalisation.$script)" versionPersInstall="$(sed -n '2p' $dirProfil/$prod/personnalisation.$script)"
if [ "$versionPers" != "$versionPersOnline" ]; then prodATraiter+="$prod "; fi if [ "$versionPersInstall" != "$versionPersOnline" ]; then prodATraiter+="$prod "; fi
persEnPlace+="$prod " persEnPlace+="$prod "
fi fi
done 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 # recup user.js et chrome/userChrome.css, $1=produit à personnaliser ou mettre à jour
ffx_pers_install(){ #25/08/2017 ffx_pers_install(){ # v30/08/2017
local produit="$1" local produit="$1" urlPers versionPersOnline dirTemp
[ ! -d "$dirProfil/$produit" ] && f__error "firefox <$produit> n'est pas installé" "personnalisation abandonnée" [ ! -d "$dirProfil/$produit" ] && return
f__requis "wget" f__requis "wget"
# détermination url chargement fichiers personnalisation, std ou spécifique dans personnalisation.getFirefox # détermination url chargement fichiers personnalisation, std ou spécifique dans personnalisation.getFirefox
if [ -e "$dirProfil/$produit/personnalisation.$script" ]; then if [ -e "$dirProfil/$produit/personnalisation.$script" ]; then
local urlPers="$(head -n1 "$dirProfil/$produit/personnalisation.$script")" urlPers="$(head -n1 "$dirProfil/$produit/personnalisation.$script")"
else else
local urlPers="https://framagit.org/kyodev/kyopages/raw/master/scripts/" urlPers="https://framagit.org/kyodev/kyopages/raw/master/scripts/"
fi fi
# chargement fichiers personnalisation # chargement fichiers personnalisation
local dirTemp="/tmp/$script-$RANDOM/" dirTemp="/tmp/$script-$RANDOM/"
mkdir -p "$dirTemp" mkdir -p "$dirTemp"
wget -q --tries=2 --timeout=15 -O "$dirTemp"user.js "$urlPers"user.js wget -q --tries=2 --timeout=15 -O "$dirTemp"user.js "$urlPers"user.js
if [ "$?" != "0" ]; then f__wget_test "$urlPers"user.js; fi 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 wget -q --tries=1 --timeout=15 -O "$dirTemp"userChrome.css "$urlPers"userChrome.css
chown -R "$user_": "$dirTemp" chown -R "$user_": "$dirTemp"
# installation # installation
@ -416,14 +438,14 @@ ffx_pers_install(){ #25/08/2017
cp "$dirTemp"user.js "$dirProfil/$produit/" cp "$dirTemp"user.js "$dirProfil/$produit/"
[ -e "$dirTemp"userChrome.css ] && cp "$dirTemp"userChrome.css "$dirProfil/$produit/chrome" [ -e "$dirTemp"userChrome.css ] && cp "$dirTemp"userChrome.css "$dirProfil/$produit/chrome"
echo "$urlPers" > "$dirProfil/$produit/personnalisation.$script" 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" chown -R "$user_": "$dirProfil/$produit/personnalisation.$script"
rm -rf "$dirTemp" 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 # maj user.js et chrome/userChrome.css
ffx_pers_upgrade(){ #25/08/2017 ffx_pers_upgrade(){ # v25/08/2017
ffx_pers_get_version ffx_pers_get_version
if [ "$prodATraiter" ]; then if [ "$prodATraiter" ]; then
for i in $prodATraiter; do ffx_pers_install "$i"; done 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 # 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 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" f__error "firefox <$produit> n'est pas installé" " il faut donc utiliser l'installation et pas l'ajout d'un nouveau profil"
fi fi
@ -481,7 +503,7 @@ ffx_profil_user(){ #22/08/2017
[ "$1" == "user" ] && f__info "log" "profil <$produit> configuré pour $user_" [ "$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(){ ffx_recup_url(){
if [ "$produit" == "latest" ]; then if [ "$produit" == "latest" ]; then
recup_url="https://download.mozilla.org/?product=firefox-$produit&os=$architecture&lang=fr" 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 # 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 [ "$(type -t fscript_cronAnacron_special)" ] && fscript_cronAnacron_special # test, si fonction spécifique, appel
local dirAnacron="/home/$user_/.config/anacron" dirAnacron="/home/$user_/.config/anacron"
local dirSpool="$dirAnacron/spool" dirSpool="$dirAnacron/spool"
local fileAnacron="$dirAnacron/$script.anacrontab" fileAnacron="$dirAnacron/$script.anacrontab"
[ $EUID -eq 0 ] && sed -i "/$script.anacrontab/d" /etc/crontab [ $EUID -eq 0 ] && sed -i "/$script.anacrontab/d" /etc/crontab
case "$1" in case "$1" in
install | upgrade ) install | upgrade )
@ -692,6 +715,7 @@ dirInstall="/opt/usr/share/firefox-"
dirProfil="/home/$user_/.mozilla/firefox" dirProfil="/home/$user_/.mozilla/firefox"
fileProfileIni="$dirProfil/profiles.ini" fileProfileIni="$dirProfil/profiles.ini"
produitAll="latest beta nightly" produitAll="latest beta nightly"
dirInstallTB="/opt/usr/share/tor-browser/"
ls -d /opt/firefox-* &>/dev/null && problemOldInstall="detected" # ancienne localisation install firefox 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)" \ [ "$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 ffx_get_versionsFF
fscript_get_version fscript_get_version
ffx_pers_get_version ffx_pers_get_version
f_tb_get_version
ffx_godzilla ffx_godzilla
exit ;; # affiche versions Firefox en ligne & installées, script et personnalisation exit ;; # affiche versions Firefox en ligne & installées, script et personnalisation
-i ) -i )

View File

@ -4,6 +4,14 @@
## todo ## todo
* install: copie du profil du canal inférieur? * 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 ## 2.8.0 30/08/2017
* révision conditions d'utilisations, fscript_install, fscript_remove(), fscript_update * révision conditions d'utilisations, fscript_install, fscript_remove(), fscript_update