From 8ec37dc5d56d83acc10bfe8c42fb6e4a7d1ae046 Mon Sep 17 00:00:00 2001 From: kyodev Date: Wed, 26 Jul 2017 12:37:41 +0200 Subject: [PATCH] 1.1.1 --- scripts/getFirefox | 215 ++++++++++++++++---------------- scripts/getFirefox_changelog.md | 5 +- 2 files changed, 112 insertions(+), 108 deletions(-) diff --git a/scripts/getFirefox b/scripts/getFirefox index c33eb95..654b59c 100755 --- a/scripts/getFirefox +++ b/scripts/getFirefox @@ -1,6 +1,6 @@ #!/bin/bash -version=1.1.0 +version=1.1.1 date="24/07/2017" projet="simpledebian" contact="IRC freenode ##sdeb ou https://framagit.org/kyodev/kyopages/issues" @@ -32,11 +32,10 @@ cat << 'EOF' | (_| | __/ |_| _| | | | | __/ _| (_) > < \__, |\___|\__|_| |_|_| \___|_| \___/_/\_\ |___/ - EOF -echo -e "$YELLOW pour Debian, version $version - $date$COLOR\n" +echo -e "$YELLOW version $version - $date$COLOR\n" - # détection architecture, assign $architecture : linux|linux64, return 1 si architecture inconnue + # détection architecture, assigne $architecture : linux|linux64, return 1 si architecture inconnue f__architecture(){ case "$(uname -m)" in amd64 | x86_64 ) @@ -55,9 +54,8 @@ f__architecture(){ esac } - # user ayant initié la session graphique, assigne $user_ - # sortie script sur erreur, gestion variable environnement pour personnaliser l'user avec: - # USER_INSTALL=user script + # user ayant initié la session graphique, assigne $user_, sortie script sur erreur + # gestion variable environnement pour personnaliser l'user avec: USER_INSTALL=user script f__user(){ # user_ via variable en environnement test "$USER_INSTALL" && user_="$USER_INSTALL" @@ -86,7 +84,7 @@ f__requis(){ [ -z "$testDepends" ] || f__error "Paquets manquants" " Contacter administrateur pour disposer de ces commandes" } - # test wget, $1 url à tester, sortie sur erreur + # test wget, $1 url à tester, sortie script sur erreur f__wget_test(){ echo " $1" wget -Sq --tries=1 --timeout=15 --user-agent="$user_agent" -O /dev/null "$1" @@ -130,7 +128,7 @@ fscript_install(){ fi # install /opt mkdir -p /opt/bin/ - ln -s /opt/bin/"$script" /usr/local/bin/"$script" &>/dev/null + ln -s "/opt/bin/$script" "/usr/bin/$script" &>/dev/null cp -d "$(basename $0)" "/opt/bin/$script" chmod a+rwx "/opt/bin/$script" chown "$user_": "/opt/bin/$script" @@ -151,14 +149,14 @@ fscript_remove(){ f__root || f__error "vous devez être ROOT pour supprimer ce script dans le système" # suppression de /opt rm /opt/bin/"$script" &>/dev/null - unlink /usr/local/bin/"$script" &>/dev/null + unlink /usr/bin/"$script" &>/dev/null || unlink /usr/local/bin/"$script" &>/dev/null # cron/anacron remove fscript_cronAnacron remove f__info "$GREEN$script supprimé du système." } - # version script en ligne, assigne $script_aJour=ok|ko, -fscript_version(){ + # version script en ligne, assigne $versionScript, $script_aJour=ok|ko +fscript_get_version(){ versionScript="$(wget -q --tries=2 --timeout=15 --user-agent="$user_agent" -O - "$urlScript" | grep '^version=' | cut -d '=' -f 2)" if [ "$version" != "$versionScript" ]; then f__info "version script en ligne: $versionScript, mise à jour possible" @@ -169,7 +167,7 @@ fscript_version(){ # mise à jour script si dispo fscript_dl(){ if [ "$script_aJour" == "ok" ]; then return 0; fi - dirTemp="/tmp/$script-$RANDOM/" + local dirTemp="/tmp/$script-$RANDOM/" mkdir -p "$dirTemp" wget -q --show-progress --tries=2 --timeout=15 --user-agent="$user_agent" -O "$dirTemp$script" "$urlScript" if [ "$?" != "0" ]; then f__wget_test "$urlScript"; fi @@ -260,21 +258,26 @@ echo -e "plus d'infos:$GREEN https://framagit.org/kyodev/kyopages/raw/master/scr } # version Firefox en ligne -ffx_versionsFF(){ - stockageUrlOnline="$(wget -q --tries=2 --timeout=15 --user-agent=$user_agent -O - https://www.mozilla.org/en-US/firefox/notes/)" - verLatest="$(echo $stockageUrlOnline | grep -Eo 'data-latest-firefox="[0-9\.]+"' | grep -Eo '[0-9\.]+')" - verEsr="$(echo $stockageUrlOnline | grep -Eo 'data-esr-versions="[0-9\.]+"' | grep -Eo '[0-9\.]+')" - fileTmp="sdxfcggbjkl-$RANDOM" - recup_url="https://download.mozilla.org/?product=firefox-beta-latest&os=linux64&lang=fr" +ffx_get_versionsFF(){ + 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\.]+')" + printf "." + local 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" - verBeta="$(grep -i 'location' $fileTmp | sed -E 's/.*firefox-(.*)\.tar.bz2/\1/')" - recup_url="https://download.mozilla.org/?product=firefox-nightly-latest-l10n-ssl&os=linux64&lang=fr" + local 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" wget -Sq --tries=1 --timeout=10 --user-agent="$user_agent" --spider --save-headers "$recup_url" &>"$fileTmp" - verNightly="$(grep -i 'location' $fileTmp | sed -E 's/.*firefox-(.*)\.fr.linux.*/\1/')" + local verNightly="$(grep -i 'location' $fileTmp | sed -E 's/.*firefox-(.*)\.fr.linux.*/\1/')" + printf ".\n" rm "$fileTmp" - for product in latest esr beta dev nightly; do - if [ -x "$dirInstall$product/firefox" ]; then - versionInstall+="\n $product: $($dirInstall$product/firefox -v | grep -Eo '[0-9].*')" + for prod in latest esr beta dev nightly; do + if [ -x "$dirInstall$prod/firefox" ]; then + versionInstall+="\n $prod: $($dirInstall$prod/firefox -v | grep -Eo '[0-9].*')" fi done f__info "Firefox installé(s): $versionInstall" @@ -283,16 +286,16 @@ ffx_versionsFF(){ # création lanceur.desktop ffx_lanceur_desktop(){ - fileDesktop="/usr/share/applications/firefox-$product.desktop" + local fileDesktop="/usr/share/applications/firefox-$product.desktop" echo "#!/usr/bin/env xdg-open" > "$fileDesktop" echo "[Desktop Entry]" >> "$fileDesktop" - echo "Name=Firefox $product" >> "$fileDesktop" - echo "Name[fr]=Firefox $product" >> "$fileDesktop" - echo "X-GNOME-FullName=Firefox-$product Web Browser" >> "$fileDesktop" - echo "X-GNOME-FullName[fr]=Firefox-$product Navigateur Web" >> "$fileDesktop" - echo "StartupWMClass=Firefox-$product" >> "$fileDesktop" - echo "Exec=/usr/bin/firefox-$product %u" >> "$fileDesktop" - echo "Icon=$dirInstall$product/browser/icons/mozicon128.png" >> "$fileDesktop" + echo "Name=Firefox $produit" >> "$fileDesktop" + echo "Name[fr]=Firefox $produit" >> "$fileDesktop" + echo "X-GNOME-FullName=Firefox-$produit Web Browser" >> "$fileDesktop" + echo "X-GNOME-FullName[fr]=Firefox-$produit Navigateur Web" >> "$fileDesktop" + echo "StartupWMClass=Firefox-$produit" >> "$fileDesktop" + echo "Exec=/usr/bin/firefox-$produit %u" >> "$fileDesktop" + echo "Icon=$dirInstall$produit/browser/icons/mozicon128.png" >> "$fileDesktop" echo "Comment=Browse the World Wide Web" >> "$fileDesktop" echo "Comment[fr]=Naviguer sur Internet" >> "$fileDesktop" echo "GenericName=Web Browser" >> "$fileDesktop" @@ -308,38 +311,37 @@ ffx_lanceur_desktop(){ # traitement de profile.ini, inscription si pas déjà existante ffx_profilIni_inscription(){ # si déjà profil existant dans profil.ini, sortir - if [ "$(grep -c Name=$product $fileProfileIni)" != 0 ]; then return; fi + if [ "$(grep -c Name=$produit $fileProfileIni)" != 0 ]; then return; fi # comptage profils existants - nbProfiles="$(grep -Ec '\[Profile[0-9]+\]' $fileProfileIni)" + local nbProfiles="$(grep -Ec '\[Profile[0-9]+\]' $fileProfileIni)" # création profil dans profile.ini echo "" >> "$fileProfileIni" echo "[Profile$nbProfiles]" >> "$fileProfileIni" - echo "Name=$product" >> "$fileProfileIni" + echo "Name=$produit" >> "$fileProfileIni" echo "IsRelative=1" >> "$fileProfileIni" - echo "Path=$product" >> "$fileProfileIni" - # si existant et latest (ou esr), supprimer Default=1 et attribuer à latest, dans profile.ini - if [ "$product" == "latest" ] || [ "$product" == "esr" ]; then + echo "Path=$produit" >> "$fileProfileIni" + # si latest ou esr, attribuer Default=1 + if [ "$produit" == "latest" ] || [ "$produit" == "esr" ]; then sed -i 's/Default=1//' "$fileProfileIni" echo "Default=1" >> "$fileProfileIni" else echo "" >> "$fileProfileIni"; fi } # détermination canal bas Firefox installé, assigne $firefoxCanalBas -ffx_canal_bas(){ - for i in nightly dev beta esr latest; do - if [ -d "$dirInstall$i/" ]; then firefoxCanalBas="$i"; fi +ffx_get_canalBas(){ + for ii in nightly dev beta esr latest; do + if [ -d "$dirInstall$ii/" ]; then firefoxCanalBas="$ii"; fi done [ "$firefoxCanalBas" ] || return 1 - f__info " - plus aucun canal Firefox installé" } # traitement update-alternatives ffx_update_alternatives(){ - which update-alternatives &>/dev/null || return 0 # update-alternatives n'est pas sur cette distrib - if ffx_canal_bas ; then + which update-alternatives &>/dev/null || 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 f__info " - alternatives installées pour <$firefoxCanalBas>" - else # plus aucun canal installé + else # plus aucun canal installé, on efface if update-alternatives --get-selections | grep firefox | grep x-www-browser &>/dev/null; then update-alternatives --quiet --remove-all x-www-browser fi @@ -348,67 +350,66 @@ ffx_update_alternatives(){ # lien /usr/bin/firefox pour le plus bas canal Firefox installé, utile si update-alternatives pas fonctionnel ffx_usr_bin(){ - if ffx_canal_bas ; then + if ffx_get_canalBas ; then ln -sf "/usr/bin/firefox-$firefoxCanalBas" "/usr/bin/firefox" + f__info " - firefox lié à firefox-$firefoxCanalBas" fi } - # traitement utilisateur, $1 user, si appel indépendant pour reconfiguration -ffx_profil_User(){ - if [ "$1" == "user" ] && [ ! -x "/usr/bin/firefox-$product" ]; then - f__error "firefox <$product> n'est pas installé" " il faut donc utiliser l'installation et pas l'ajout d'un nouveau profil" + # traitement utilisateur, $1 user si appel indépendant pour reconfiguration +ffx_profil_user(){ + 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 - # si profile.ini existe on traite default sinon on le crée avec minimum d'entête (première installation Firefox) - if [ -w "$fileProfileIni" ]; then + if [ -w "$fileProfileIni" ]; then # si profile.ini existe et rw, on traite default # recherche éventuel profil tuvwxyz.default dans profile.ini - profileDefault="$(grep '\.default' $fileProfileIni | sed 's/Path=//')" + local profileDefault="$(grep '\.default' $fileProfileIni | sed 's/Path=//')" # si profileDefault existant, on l'utilise pour latest (ou esr) si pas déjà présent - if [ "$profileDefault" ] && [ -d "$dirProfil/$profileDefault" ] && [ "$product" == "latest" ] || [ "$product" == "esr" ]; then - if [ ! -d "$dirProfil/$product" ]; then # le profil cible n'existe pas + if [ "$profileDefault" ] && [ -d "$dirProfil/$profileDefault" ] && [ "$produit" == "latest" ] || [ "$produit" == "esr" ]; then + if [ ! -d "$dirProfil/$produit" ]; then # le profil cible n'existe pas f__info " - récupération du profil default existant <$profileDefault>" - mkdir -p "$dirProfil/$product" - cp -R "$dirProfil/$profileDefault"/* "$dirProfil/$product/" + mkdir -p "$dirProfil/$produit" + cp -R "$dirProfil/$profileDefault"/* "$dirProfil/$produit/" fi fi - else + else # sinon on crée profile.ini avec minimum d'entête (première installation Firefox) echo -e "[General]\nStartWithLastProfile=1\n\n" >> "$fileProfileIni" chown "$user_": "$fileProfileIni" # propriété du fichier profile.ini à l'user chmod u+rw,go+r "$fileProfileIni" # permissions du fichier profile.ini à l'user fi - mkdir -p "$dirProfil/$product" - chown -R "$user_": "$dirProfil/$product/" # propriété du répertoire profile à l'user - chmod g-rx,o-rx "$dirProfil/$product/" # droits répertoire comme Firefox officiel + mkdir -p "$dirProfil/$produit" # répertoire du profil + chown -R "$user_": "$dirProfil/$produit/" # propriété du répertoire profil à l'user + chmod g-rx,o-rx "$dirProfil/$produit/" # droits répertoire comme Firefox officiel ffx_profilIni_inscription ffx_lanceur_desktop ffx_update_alternatives - if [ "$1" == "user" ]; then f__info " - profil <$product> configuré pour $user_"; fi + if [ "$1" == "user" ]; then f__info " - profil <$produit> configuré pour $user_"; fi } - # calcul url téléchargement, assigne $recup_url. fixer url pour beta et nightly dans ffx_versionsFF + # calcul url téléchargement, assigne $recup_url. fixer url pour beta et nightly dans ffx_get_versionsFF ffx_recup_url(){ - if [ "$product" == "latest" ]; then - recup_url="https://download.mozilla.org/?product=firefox-$product&os=$architecture&lang=fr" - elif [ "$product" == "esr" ]; then - recup_url="https://download.mozilla.org/?product=firefox-$product-latest&os=$architecture&lang=fr" - elif [ "$product" == "beta" ]; then - recup_url="https://download.mozilla.org/?product=firefox-beta-latest&os=$architecture&lang=fr" - elif [ "$product" == "dev" ]; then + if [ "$produit" == "latest" ]; then + recup_url="https://download.mozilla.org/?product=firefox-$produit&os=$architecture&lang=fr" + elif [ "$produit" == "esr" ]; then + recup_url="https://download.mozilla.org/?product=firefox-$produit-latest&os=$architecture&lang=fr" + elif [ "$produit" == "beta" ]; then + recup_url="https://download.mozilla.org/?product=firefox-$produit-latest&os=$architecture&lang=fr" + elif [ "$produit" == "dev" ]; then recup_url="https://download.mozilla.org/?product=firefox-devedition-latest-ssl&os=$architecture&lang=fr" - elif [ "$product" == "nightly" ]; then - recup_url="https://download.mozilla.org/?product=firefox-$product-latest-l10n-ssl&os=$architecture&lang=fr" ;fi + elif [ "$produit" == "nightly" ]; then + recup_url="https://download.mozilla.org/?product=firefox-$produit-latest-l10n-ssl&os=$architecture&lang=fr" ;fi } # installation Firefox ffx_install(){ f__root || f__error "vous devez être ROOT pour installer Firefox" ffx_godzilla - f__info " - installation Firefox-$product" - # dossier temporaire de travail - dirTemp="/tmp/$script-$RANDOM/" - mkdir -p "$dirTemp" + f__info " - installation Firefox-$produit" + local dirTemp="/tmp/$script-$RANDOM/" + local file="firefox-$produit.$architecture.tar.bz2" + mkdir -p "$dirTemp" # dossier temporaire de travail # téléchargement & test archive f__info " - téléchargement..." - file="firefox-$product.$architecture.tar.bz2" ffx_recup_url wget -q -c --show-progress --tries=2 --timeout=15 --user-agent="$user_agent" -O "$dirTemp$file" "$recup_url" if [ "$?" != "0" ]; then f__wget_test "$recup_url"; fi @@ -418,53 +419,53 @@ ffx_install(){ tar -xaf "$dirTemp$file" -C "$dirTemp" # mise en place finale f__info " - installation..." - rm -rf "$dirInstall$product"/ # effacement éventuel répertoire existant: "vraie" install - mkdir -p "$dirInstall$product"/ - mv -f "$dirTemp"firefox/* "$dirInstall$product"/ - chown -R "$user_": "$dirInstall$product"/ - chmod -R g+wrs,a+r "$dirInstall$product"/ + rm -rf "$dirInstall$produit"/ # effacement éventuel répertoire existant: "vraie" install + mkdir -p "$dirInstall$produit"/ + mv -f "$dirTemp"firefox/* "$dirInstall$produit"/ + chown -R "$user_": "$dirInstall$produit"/ + chmod -R g+wrs,a+r "$dirInstall$produit"/ rm -rf "$dirTemp" # lien icône Firefox - ln -sf "$dirInstall$product/browser/chrome/icons/default/default48.png" "/usr/share/pixmaps/firefox-$product.png" + ln -sf "$dirInstall$produit/browser/chrome/icons/default/default48.png" "/usr/share/pixmaps/firefox-$produit.png" # lanceur dans /usr/bin - echo "#!/bin/sh" > "/usr/bin/firefox-$product" - echo "exec $dirInstall$product/firefox -P $product" "\$@" >> "/usr/bin/firefox-$product" - chmod a+x "/usr/bin/firefox-$product" + echo "#!/bin/sh" > "/usr/bin/firefox-$produit" + echo "exec $dirInstall$produit/firefox -P $produit" "\$@" >> "/usr/bin/firefox-$produit" + chmod a+x "/usr/bin/firefox-$produit" ffx_usr_bin # traitement user - ffx_profil_User - f__info "$GREEN""Firefox-$product installé." + ffx_profil_user + f__info "$GREEN""Firefox-$produit installé." } # désinstallation de Firefox ffx_remove(){ f__root || f__error "vous devez être ROOT pour désinstaller" ffx_godzilla - killall "/opt/usr/share/firefox-$product/firefox" &>/dev/null + killall "/opt/usr/share/firefox-$produit/firefox" &>/dev/null # si pas de lanceur desktop, on considère que ce canal Firefox n'est pas installé, retour - if [ ! -e "/usr/share/applications/firefox-$product.desktop" ]; then # si test répertoire, on détecterait pas l'ancien répertoire éventuel - f__info "$GREEN""Firefox-$product n'est pas installé." + if [ ! -e "/usr/share/applications/firefox-$produit.desktop" ]; then # si test répertoire, on détecterait pas l'ancien répertoire éventuel + f__info "$GREEN""Firefox-$produit n'est pas installé." return 0 fi # suppression du répertoire Firefox - if [ -d "/opt/firefox-$product/" ]; then rm -rf "/opt/firefox-$product/"; fi # ancien répertoire éventuel - if [ -d "$dirInstall$product/" ]; then rm -rf "$dirInstall$product/"; fi + if [ -d "/opt/firefox-$produit/" ]; then rm -rf "/opt/firefox-$produit/"; fi # ancien répertoire éventuel + if [ -d "$dirInstall$produit/" ]; then rm -rf "$dirInstall$produit/"; fi # suppression lanceurs - rm -f "/usr/share/applications/firefox-$product.desktop" - rm -f "/usr/bin/firefox-$product" + rm -f "/usr/share/applications/firefox-$produit.desktop" + rm -f "/usr/bin/firefox-$produit" # suppression des liens - unlink "/usr/share/pixmaps/firefox-$product.png" &>/dev/null - unlink "/usr/bin/firefox-$product" &>/dev/null + unlink "/usr/share/pixmaps/firefox-$produit.png" &>/dev/null + unlink "/usr/bin/firefox-$produit" &>/dev/null # recréation lanceur Firefox & update-alternatives ffx_usr_bin ffx_update_alternatives - f__info "$GREEN""Firefox-$product désinstallé." + f__info "$GREEN""Firefox-$produit désinstallé." } # initialisation f__architecture || f__error "Architecture non supportée" f__user -f__requis "wget logger file tar logger" +f__requis "wget logger file tar logger killall" dirInstall="/opt/usr/share/firefox-" dirProfil="/home/$user_/.mozilla/firefox" fileProfileIni="$dirProfil/profiles.ini" @@ -483,24 +484,24 @@ case "$1" in sysremove ) fscript_remove ;; # désinstallation du script version | -v | --version | -version ) - ffx_versionsFF - fscript_version + ffx_get_versionsFF + fscript_get_version ffx_godzilla ;; # affiche versions Firefox en ligne & installées & version script upgrade ) opType="upgrade" - fscript_version + fscript_get_version fscript_dl ;; # upgrade script si maj possible i-latest | i-esr | i-dev | i-beta | i-nightly | \ +latest | +esr | +dev | +beta | +nightly ) - product="$(echo $1 | sed 's/i-//' | sed 's/+//')" + produit="$(echo $1 | sed 's/i-//' | sed 's/+//')" ffx_install ;; # install: installation canal Firefox r-latest | r-esr | r-dev | r-beta | r-nightly | \ -latest | -esr | -dev | -beta | -nightly ) - product="$(echo $1 | sed 's/r-//' | sed 's/-//' )" + produit="$(echo $1 | sed 's/r-//' | sed 's/-//' )" ffx_remove ;; # remove: désinstallation Firefox u-latest | u-esr | u-dev | u-beta | u-nightly ) - product="$(echo $1 | sed 's/u-//')" - ffx_profil_User "user" ;; # user: profil pour utilisateur en cours ou reconfiguration + produit="$(echo $1 | sed 's/u-//')" + ffx_profil_user "user" ;; # user: profil pour utilisateur en cours ou reconfiguration * ) ffx_help ;; # affichage help par défaut esac diff --git a/scripts/getFirefox_changelog.md b/scripts/getFirefox_changelog.md index a4c6f2c..24be385 100644 --- a/scripts/getFirefox_changelog.md +++ b/scripts/getFirefox_changelog.md @@ -2,10 +2,13 @@ ## todo - * install: copie du profil du canal inférieur? +## 1.1.1 26/07/2017 +* dépendance killall +* replacement lien script dans /usr/bin/ (meilleure compat?) +* lifting ## 1.1.0 24/07/2017