diff --git a/scripts/getFirefox b/scripts/getFirefox index a7cc07f..b633dea 100755 --- a/scripts/getFirefox +++ b/scripts/getFirefox @@ -1,11 +1,11 @@ #!/bin/bash -version=2.2.1 -date="23/08/2017" +version=2.3.0 +date="25/08/2017" projet="simpledeb" -contact="IRC freenode ##sdeb ou https://framagit.org/kyodev/kyopages/issues" +contact="IRC freenode ##sdeb ou https://framagit.org/kyodev/kyopages/issues/" script="getFirefox" -urlScript="https://framagit.org/kyodev/kyopages/raw/master/scripts/getFirefox" +urlScript="https://framagit.org/kyodev/kyopages/raw/master/scripts/getFirefox/" urlNotice="https://kyodev.frama.io/kyopages/scripts/getFirefox/" user_agent="Mozilla/5.0 Firefox" lognameDev="kyodev" @@ -15,7 +15,7 @@ lognameDev="kyodev" # contributeurs: kyodev ##### -f__affichage(){ # v06/2017 définition couleurs +f__affichage(){ # v06/2017 définition couleurs YELLOW="$(printf "\033[0;33m")" # ? GREEN="$(printf "\033[0;32m")" # ok BLUE="$(printf "\033[0;34m")" # info @@ -36,7 +36,7 @@ EOF } # détection architecture, assigne $architecture : linux|linux64, return 1 si architecture inconnue -f__architecture(){ # v07/2017 +f__architecture(){ # v07/2017 case "$(uname -m)" in amd64 | x86_64 ) architecture="linux64";; @@ -55,13 +55,13 @@ f__architecture(){ # v07/2017 } # test validité archive, $1 fichier (bzip2), return 1 si invalide -f__archive_test(){ # v07/2017 +f__archive_test(){ # v07/2017 file -b "$1" | grep -q 'bzip2 compressed data' || return 1 } # affichage $1 en rouge, $1++ optionnels en bleu, sortie script sur erreur, log $1 si $opType=upgrade -f__error() { # v16/08/2017 - echo -e "\n$RED Erreur critique: $1 $COLOR" +f__error() { # v25/08/2017 + echo -e "\n$RED $script $version, erreur critique: $1 $COLOR" for (( i=2 ; i<=$# ; i++ )); do echo -e " $BLUE${!i}"; done echo "$COLOR" if [ "$opType" == "upgrade" ]; then f__log "$script $version: $1"; fi @@ -70,16 +70,17 @@ f__error() { # v16/08/2017 # affichage des paramètres en bleu, si $1=raw, pas d'espace en début de ligne, pas de ligne vide à la fin # si $1=log, uniquement $2 logué -f__info() { # v21/08/2017 - if [ "$1" == "raw" ] || [ "$1" == "log" ]; then depart=2; - else local espace=" "; local depart=1; fi +f__info() { # v24/08/2017 + local espace=" " depart=1 + if [ "$1" == "raw" ] || [ "$1" == "log" ]; then depart=2; fi + if [ "$1" == "raw" ]; then espace=""; fi [ "$1" == "log" ] && f__log "$(sed -E 's/\\t//;s/\\n// ' <<< $2 | xargs )" for (( i=$depart ; i<=$# ; i++ )); do echo -e "$espace$BLUE${!i}"; done [ "$1" == raw ] && printf "$COLOR" || echo "$COLOR" } # log spécifique, fichier log limité à 10000octets, $1 message à loguer -f__log(){ # v08/2017 +f__log(){ # v08/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" @@ -96,7 +97,7 @@ 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 +f__requis(){ # v17/08/2017-3 local dependsMissing packagesMissing unset debOnlyPackages debOnlyPresents for i in $1; do @@ -126,7 +127,7 @@ 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(){ # v21/08/2017-4 if [ "$USER_INSTALL" ]; then # user_ via variable environnement, moyen d'injecter root user_="$USER_INSTALL"; return 0 @@ -157,120 +158,22 @@ f__user(){ # v21/08/2017-4 return 0 } - # test wget, $1 url à tester, sortie script sur erreur -f__wget_test(){ # v07/2017 - echo " $1" - wget -Sq --tries=1 --timeout=15 --user-agent="$user_agent" -O /dev/null "$1" - f__error "Erreur wget" " réessayer et si persistance, contacter $projet $contact" " en indiquant les messages précédents." -} - - # spécifique getFirefox -fscript_cronAnacron_special(){ # v19/08/2017 - rm "/home/$user_/.mozilla/$script.anacrontab" &>/dev/null # ancienne localisation éventuelle - rm "/home/$user_/.config/anacron/spool/getFF"* &>/dev/null # ancien job -} - - # inscription dans tache upgrade en anacron hebdomadaire, via cron horaire -fscript_cronAnacron(){ # v23/08/2017 - [ "$(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" - [ $EUID -eq 0 ] && sed -i "/$script.anacrontab/d" /etc/crontab - case "$1" in - install | upgrade ) - mkdir -p "$dirAnacron" - # table anacron - echo "7 10 $script nice /opt/bin/$script --upgrade 1>/dev/null" > "$fileAnacron" # juste erreurs en syslog - ## anacron journalier pour dev logname - if [ "$user_" == "$lognameDev" ]; then - echo "1 00 $script""Dev nice /opt/bin/$script --upgrade 1>/dev/null" >> "$fileAnacron" # juste erreurs en syslog - fi - # création spool anacron utilisateur - mkdir -p "$dirSpool" - chown -R "$user_": "$dirAnacron" "$dirSpool" - if [ $EUID -eq 0 ]; then - # crontab pour activation horaire anacron - echo "@hourly $user_ /usr/sbin/anacron -t $fileAnacron -S $dirSpool" >> /etc/crontab - fi - [ "$(grep "$script" /etc/crontab)" ] || echo f__error "inscription crontab" \ - "certains systèmes semblent poser poser problème, merci de rapporter ce bug à $projet $contact" - ;; - remove ) - rm "$dirSpool/$script"* &>/dev/null - rm "$fileAnacron" &>/dev/null - rmdir "$dirSpool" "$dirAnacron" &>/dev/null - ;; - esac -} - - # mise à jour script si dispo -fscript_dl(){ # v22/08/2017 - f__requis "wget" - if [ "$script_aJour" == "ok" ]; then - f__info "log" "pas de mise à jour disponible pour $script" - return 0 - fi - local dirTemp="/tmp/$script-$RANDOM/" - mkdir -p "$dirTemp" - wget -q --tries=2 --timeout=15 -O "$dirTemp$script" "$urlScript" - if [ "$?" != "0" ]; then f__wget_test "$urlScript"; fi - chmod 755 "$dirTemp$script" - chown "$user_": "$dirTemp$script" - cp -d "$dirTemp$script" /opt/bin/"$script" - rm -rf "$dirTemp" - fscript_cronAnacron "upgrade" - f__info "log" "\n $script mis à jour en version $versionScript" -} - - # version script en ligne, assigne $versionScript, $script_aJour=ok|ko -fscript_get_version(){ # v19/08/2017 - f__requis "wget" - f__info "$GREEN""\n version script en cours: $version" - versionScript="$(wget -q --tries=2 --timeout=15 -O - "$urlScript" | grep '^version=' | cut -d '=' -f 2)" - if [ "$versionScript" ]; then - if [ "$version" != "$versionScript" ]; then - f__info "version script en ligne: $versionScript, mise à jour possible" - script_aJour="ko" - else - f__info "version script en ligne: $versionScript" - script_aJour="ok" - fi - else f__info "version script en ligne non accessible"; fi -} - - # installation du script dans le système -fscript_install(){ # v21/08/2017 - if dirname "$0" | grep -q 'bin' ; then - f__info "\n $script $version est déjà installé" - return 1 - fi - [ $EUID -eq 0 ] || f__error "vous devez être ROOT pour installer ce script dans le système" - f__requis "wget anacron cron" - # install /opt - mkdir -p /opt/bin/ - cp -d "$(basename $0)" "/opt/bin/$script" - ln -s "/opt/bin/$script" "/usr/bin/$script" &>/dev/null - chmod 755 "/opt/bin/$script" - # cron/anacron install - fscript_cronAnacron "install" - # création fichier log - touch "$fileLogs" - chmod 644 "$fileLogs" - chown "$user_": "$fileLogs" "/opt/bin/$script" - [ -f "$script"_changelog.md ] || rm "$(basename $0)" &>/dev/null ## on efface pas si changelog (dev) - f__info "log" "$script $version installé dans le système." "maintenant, appel du script par:$GREEN $script$BLUE (sans ./)" -} - - # suppression du script dans le système -fscript_remove(){ # v21/08/2017 - [ $EUID -eq 0 ] || 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/bin/"$script" &>/dev/null - # cron/anacron remove - fscript_cronAnacron "remove" - f__info "log" "$script $version supprimé du système." + # test wget, $1 url à tester affiche url testée & entêtes http, sortie script sur erreur +f__wget_test(){ #v25/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="$?" + [ "$retourWget" == 1 ] && retourWget="code erreur générique" + [ "$retourWget" == 2 ] && retourWget="parse erreur (ligne de commande?)" + [ "$retourWget" == 3 ] && retourWget="erreur Entrée/sortie fichier" + [ "$retourWget" == 4 ] && retourWget="défaut réseau" + [ "$retourWget" == 5 ] && retourWget="défaut vérification SSL" + [ "$retourWget" == 6 ] && retourWget="défaut authentification" + [ "$retourWget" == 7 ] && retourWget="erreur de protocole" + [ "$retourWget" == 8 ] && retourWget="réponse serveur en erreur" + retourHttp="$(grep -i 'HTTP/' "$file_test_wget" | tr -d '\n' | xargs)" + f__error "erreur wget: $retourWget" "url: $1" "$retourHttp" \ + "Erreur wget" "si persistance, contacter $projet $contact en indiquant les messages précédents" + rm "$file_test_wget" } # détermination canal bas Firefox installé, assigne $firefoxCanalBas @@ -332,19 +235,26 @@ echo "$COLOR" } # affichage help -ffx_help(){ +ffx_help(){ #v25/08/2017 printf $BLUE cat << 'EOF' ---------------------------------------------------------------------- canaux possibles latest, beta, nightly, dev, esr + all = latest, beta, nightly + exemple, installation version Release: getFirefox i-latest + installation version latest, beta, nightly: getFirefox i-all getFirefox i-canal : installation de Firefox getFirefox r-canal : désinstallation de Firefox getFirefox u-canal : ajouter ou configurer un profil firefox pour l'utilisateur en cours + getFirefox m-canal : installation sur le d'une archive téléchargée manuellement + getFirefox p-canal : personnalisation sur le de user.js & userChrome.css + getFirefox pu : mise à jour (des) personnalisation(s) getFirefox version : version(s) installée(s) et en ligne des différents canaux Firefox + version script et personnalisation ---------------------------------------------------------------------- ./getFirefox : installation du script dans le système getFirefox -h, --help : affichage aide @@ -361,16 +271,17 @@ EOF echo -e " plus d'infos:$GREEN https://framagit.org/kyodev/kyopages/raw/master/scripts/getFirefox$COLOR\n" } - # installation Firefox -ffx_install(){ + # installation Firefox, $1 produit, $2 manuel, $3 archive +ffx_install(){ #v25/08/2017 [ $EUID -eq 0 ] || f__error "vous devez être ROOT pour installer Firefox" - if [ "$1" == "manuel" ]; then - local versionArchive="$(sed -E 's/firefox-(.*)\.linux.*/\1/' <<< $(stat -c %n $2))" - f__info "installation manuelle de firefox version $versionArchive ($2)" - local dirTemp="$(dirname $2)/$script-$RANDOM/" - local fileTemp="$(basename $2)" + if [ "$2" == "manuel" ]; then + local versionArchive="$(sed -E 's/firefox-(.*)\.linux.*/\1/' <<< $(stat -c %n $3))" + f__info "installation manuelle de firefox version $versionArchive ($3)" + local dirTemp="$(dirname $3)/$script-$RANDOM/" + local fileTemp="$(basename $3)" mkdir -p "$dirTemp" else + local produit="$1" f__info "installation Firefox-$produit" local dirTemp="/tmp/$script-$RANDOM/" local fileTemp="$dirTemp""firefox-$produit.$architecture.tar.bz2" @@ -406,16 +317,16 @@ ffx_install(){ ffx_usr_bin # traitement user ffx_profil_user - f__info "log" "Firefox-$produit installé $versionArchive" + f__info "log" "Firefox-$produit installé $2 $versionArchive" ffx_godzilla } - # installation d'un FF chargé manuellement, $1 -ffx_install_manuel(){ - [ -e "$1" ] || f__error "fichier $1 introuvable" - f__archive_test "$1" || f__error "Le fichier $1 n'est pas une archive valide" - ffx_install "manuel" "$1" - [ "$user_" != "$lognameDev" ] && rm "$1" &>/dev/null # si user pas dev, effacement archive + # installation d'un FF chargé manuellement, $1 produit, $2 fichier archive +ffx_install_manuel(){ #v25/08/2017 + [ -e "$2" ] || f__error "fichier $1 introuvable" + f__archive_test "$2" || f__error "Le fichier $2 n'est pas une archive valide" + ffx_install "$1" "manuel" "$2" + [ "$user_" != "$lognameDev" ] && rm "$2" &>/dev/null # si user pas dev, effacement archive } # création lanceur.desktop @@ -442,6 +353,70 @@ ffx_lanceur_desktop(){ echo "StartupNotify=true" >> "$fileDesktop" } + # version personnalisation en ligne, assigne $prodATraiter +ffx_pers_get_version(){ #v25/08/2017 + f__requis "wget" + if [ -e "$dirProfil/$produit/personnalisation.$script" ]; then + local urlPers="$(sed -n '1p' "$dirProfil/$produit/personnalisation.$script")" + else + local 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')" + if [ "$versionPersOnline" ]; then + local versionPers + 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 + fi + done + if [ "$prodATraiter" ]; then + f__info "version personnalisation en ligne: $versionPersOnline, mise à jour possible pour $prodATraiter" + else + f__info "version personnalisation en ligne: $versionPersOnline" + fi + else f__info "version personnalisation en ligne non accessible"; fi +} + + # 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" + 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")" + else + local urlPers="https://framagit.org/kyodev/kyopages/raw/master/scripts/" + fi + # chargement fichiers personnalisation + local 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 + wget -q --tries=1 --timeout=15 -O "$dirTemp"userChrome.css "$urlPers"userChrome.css + chown -R "$user_": "$dirTemp" + # installation + mkdir -p "$dirProfil/$produit/chrome/" # répertoire pour userChrome.css + chown "$user_": "$dirProfil/$produit/chrome" + 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" + chown -R "$user_": "$dirProfil/$produit/personnalisation.$script" + rm -rf "$dirTemp" + f__info "log" "personnalisation $versionPers mise en place pour $produit" +} + + # maj user.js et chrome/userChrome.css +ffx_pers_upgrade(){ #25/08/2017 + ffx_pers_get_version + if [ "$prodATraiter" ]; then + for i in $prodATraiter; do ffx_pers_install "$i"; done + else f__info "log" "pas de personnalisation à mettre à jour"; fi +} + # traitement de profile.ini, inscription si pas déjà existante ffx_profilIni_inscription(){ # si déjà profil existant dans profil.ini, sortir @@ -479,8 +454,8 @@ ffx_profil_user(){ #22/08/2017 fi 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 + 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/$produit" # répertoire du profil chown -R "$user_": "$dirProfil/$produit/" # propriété du répertoire profil à l'user @@ -552,18 +527,128 @@ ffx_usr_bin(){ fi } + # spécifique getFirefox +fscript_cronAnacron_special(){ # v19/08/2017 + rm "/home/$user_/.mozilla/$script.anacrontab" &>/dev/null # ancienne localisation éventuelle + rm "/home/$user_/.config/anacron/spool/getFF"* &>/dev/null # ancien job +} + + # inscription dans tache upgrade en anacron hebdomadaire, via cron horaire +fscript_cronAnacron(){ # v23/08/2017 + [ "$(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" + [ $EUID -eq 0 ] && sed -i "/$script.anacrontab/d" /etc/crontab + case "$1" in + install | upgrade ) + mkdir -p "$dirAnacron" + # table anacron + echo "7 10 $script nice /opt/bin/$script --upgrade 1>/dev/null" > "$fileAnacron" # juste erreurs en syslog + ## anacron journalier pour dev logname + if [ "$user_" == "$lognameDev" ]; then + echo "1 00 $script""Dev nice /opt/bin/$script --upgrade 1>/dev/null" >> "$fileAnacron" # juste erreurs en syslog + fi + # création spool anacron utilisateur + mkdir -p "$dirSpool" + chown -R "$user_": "$dirAnacron" "$dirSpool" + if [ $EUID -eq 0 ]; then + # crontab pour activation horaire anacron + echo "@hourly $user_ /usr/sbin/anacron -t $fileAnacron -S $dirSpool" >> /etc/crontab + fi + [ "$(grep "$script" /etc/crontab)" ] || echo f__error "inscription crontab" \ + "certains systèmes semblent poser poser problème, merci de rapporter ce bug à $projet $contact" + ;; + remove ) + rm "$dirSpool/$script"* &>/dev/null + rm "$fileAnacron" &>/dev/null + rmdir "$dirSpool" "$dirAnacron" &>/dev/null + ;; + esac +} + + # version script en ligne, assigne $versionScript, $script_aJour=ok|ko +fscript_get_version(){ # v19/08/2017 + f__requis "wget" + f__info "$GREEN""\n version script en cours: $version" + versionScript="$(wget -q --tries=2 --timeout=15 -O - "$urlScript" | grep '^version=' | cut -d '=' -f 2)" + if [ "$versionScript" ]; then + if [ "$version" != "$versionScript" ]; then + f__info "version script en ligne: $versionScript, mise à jour possible" + script_aJour="ko" + else + f__info "version script en ligne: $versionScript" + script_aJour="ok" + fi + else f__info "version script en ligne non accessible"; fi +} + + # installation du script dans le système +fscript_install(){ # v24/08/2017 + if dirname "$0" | grep -q 'bin' ; then + f__info "\n $script $version est déjà installé" + return 1 + fi + [ $EUID -eq 0 ] || f__error "vous devez être ROOT pour installer ce script dans le système" + f__requis "wget anacron cron" + # install /opt + mkdir -p /opt/bin/ + cp -d "$(basename $0)" "/opt/bin/$script" + ln -s "/opt/bin/$script" "/usr/bin/$script" &>/dev/null + chmod 755 "/opt/bin/$script" + # cron/anacron install + fscript_cronAnacron "install" + # création fichier log + touch "$fileLogs" + chmod 644 "$fileLogs" + chown "$user_": "$fileLogs" "/opt/bin/$script" + [ -e "$script"_changelog.md ] || rm "$(basename $0)" &>/dev/null ## on efface pas si changelog (dev) + f__info "log" "$script $version installé dans le système." "maintenant, appel du script par:$GREEN $script$BLUE (sans ./)" +} + + # suppression du script dans le système +fscript_remove(){ # v21/08/2017 + [ $EUID -eq 0 ] || 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/bin/"$script" &>/dev/null + # cron/anacron remove + fscript_cronAnacron "remove" + f__info "log" "$script $version supprimé du système." +} + + # mise à jour script si dispo +fscript_update(){ # v25/08/2017 + fscript_get_version + if [ "$script_aJour" == "ok" ]; then + f__info "log" "pas de mise à jour disponible pour $script" + return 0 + fi + local dirTemp="/tmp/$script-$RANDOM/" + mkdir -p "$dirTemp" + wget -q --tries=2 --timeout=15 -O "$dirTemp$script" "$urlScript" + if [ "$?" != "0" ]; then f__wget_test "$urlScript"; fi + chmod 755 "$dirTemp$script" + chown "$user_": "$dirTemp$script" + cp -d "$dirTemp$script" /opt/bin/"$script" + rm -rf "$dirTemp" + fscript_cronAnacron "upgrade" + f__info "log" "\n $script mis à jour en version $versionScript" +} + # initialisation PATH='/usr/sbin:/usr/bin:/sbin:/bin' ; IFS=' '; TERM=xterm export PATH TERM f__affichage f__architecture || f__error "Seules les architecture 32 et 64 bits sont supportée (i686 & amd64) par Firefox" f__user || f__error "échec détection user" -f__requis "file tar killall>psmisc" # pour fonctionnement programme +f__requis "file tar killall>psmisc" # requis pour fonctionnement programme fileLogs="/var/log/sdeb_$script.log" dirInstall="/opt/usr/share/firefox-" dirProfil="/home/$user_/.mozilla/firefox" fileProfileIni="$dirProfil/profiles.ini" +produitAll="latest beta nightly" 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)" \ @@ -573,7 +658,7 @@ 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 options=$@ -if [ "$(dirname $0)" == "." ]; then unset options +if [ "$(dirname $0)" == "." ]; then unset options # induira script install else if [ ! -w "$fileLogs" ] && ls -d "$dirInstall"* &>/dev/null ; then problemDetected+="-2"; fi # ancien système de logs via syslog fi @@ -584,31 +669,54 @@ for i in $options; do version | versions ) ffx_get_versionsFF fscript_get_version - ffx_godzilla; break ;; # affiche versions Firefox en ligne & installées - i-latest | i-esr | i-dev | i-beta | i-nightly | +latest | +esr | +dev | +beta | +nightly ) + ffx_pers_get_version + ffx_godzilla + break ;; # affiche versions Firefox en ligne & installées, script et personnalisation + i-latest | i-esr | i-dev | i-beta | i-nightly | i-all | +latest | +esr | +dev | +beta | +nightly | +all ) produit="$(sed 's/i-//; s/+//' <<< "$1")" - ffx_install; break ;; # install: installation canal Firefox (gestion ancien répertoire éventuel) + if [ "$produit" == "all" ]; then produit="$produitAll"; fi + for i in $produit; do ffx_install "$i"; done + break ;; # 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")" - ffx_install_manuel "$2"; break ;; # installation manuelle d'un chargement, $2 archive, $3 canal à utiliser + ffx_install_manuel "$produit" "$2" + break ;; # installation manuelle d'un chargement, $2 fichier archive + 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 + break ;; # mise en place personnalisation + pu ) + ffx_pers_upgrade + break ;; # mise à jour personnalisations r-latest | r-esr | r-dev | r-beta | r-nightly | -latest | -esr | -dev | -beta | -nightly ) produit="$(sed 's/r-//; s/-//' <<< "$1")" - ffx_remove; break ;; # remove: désinstallation Firefox (y compris ancien répertoire éventuel) + ffx_remove + break ;; # 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")" [ "$problemOldInstall" ] && f__error "vous devez réinstaller firefox auparavant" - ffx_profil_user "user"; break ;; # configurer un profil firefox pour un user - "" ) if ! dirname "$0" | grep -q 'bin' ; then + ffx_profil_user "user" + break ;; # configurer un profil firefox pour un user + "" ) + if ! dirname "$0" | grep -q 'bin' ; then fscript_install - else ffx_help; fi ;; # installation du script dans le système + else ffx_help; fi + break ;; # installation du script dans le système -r | --remove | sysremove ) - fscript_remove; break ;; # désinstallation du script + fscript_remove + break ;; # désinstallation du script -u | --upgrade | upgrade ) opType="upgrade" + fscript_update + ffx_pers_upgrade + break ;; # upgrade script + -v | --version ) fscript_get_version - fscript_dl; break ;; # upgrade script - -v | --version ) fscript_get_version; break ;; # version du script, en ligne et exécuté - -h | --help | * ) ffx_help; break ;; # affichage help + break ;; # version du script, en ligne et exécuté + -h | --help | * ) + ffx_help + break ;; # affichage help esac done diff --git a/scripts/getFirefox (copie) b/scripts/getFirefox (copie) new file mode 100755 index 0000000..af759b1 --- /dev/null +++ b/scripts/getFirefox (copie) @@ -0,0 +1,618 @@ +#!/bin/bash + +version=2.2.2 +date="24/08/2017" +projet="simpledeb" +contact="IRC freenode ##sdeb ou https://framagit.org/kyodev/kyopages/issues" +script="getFirefox" +urlScript="https://framagit.org/kyodev/kyopages/raw/master/scripts/getFirefox" +urlNotice="https://kyodev.frama.io/kyopages/scripts/getFirefox/" +user_agent="Mozilla/5.0 Firefox" +lognameDev="kyodev" + +##### license LPRAB/WTFPL +# auteur: simpledeb +# contributeurs: kyodev +##### + +f__affichage(){ # v06/2017 définition couleurs + YELLOW="$(printf "\033[0;33m")" # ? + GREEN="$(printf "\033[0;32m")" # ok + BLUE="$(printf "\033[0;34m")" # info + RED="$(printf "\033[0;31m")" # alerte + COLOR="$(printf "\033[0m")" # standard + + clear + printf "$BLUE" +cat << 'EOF' + _ _____ _ __ + __ _ ___| |_| ___(_)_ __ ___ / _| _____ __ + / _' |/ _ \ __| |_ | | '__/ _ \ |_ / _ \ \/ / + | (_| | __/ |_| _| | | | | __/ _| (_) > < + \__, |\___|\__|_| |_|_| \___|_| \___/_/\_\ + |___/ +EOF + echo -e "$YELLOW version $version - $date$COLOR\n" +} + + # détection architecture, assigne $architecture : linux|linux64, return 1 si architecture inconnue +f__architecture(){ # v07/2017 + case "$(uname -m)" in + amd64 | x86_64 ) + architecture="linux64";; + i?86 | x86 ) + architecture="linux";; + * ) + case "$(getconf LONG_BIT)" in + 64 ) + architecture="linux64";; + 32 ) + architecture="linux";; + *) + return 1 + esac ;; + 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 +} + + # affichage $1 en rouge, $1++ optionnels en bleu, sortie script sur erreur, log $1 si $opType=upgrade +f__error() { # v16/08/2017 + echo -e "\n$RED Erreur critique: $1 $COLOR" + for (( i=2 ; i<=$# ; i++ )); do echo -e " $BLUE${!i}"; done + echo "$COLOR" + if [ "$opType" == "upgrade" ]; then f__log "$script $version: $1"; fi + exit 1 +} + + # affichage des paramètres en bleu, si $1=raw, pas d'espace en début de ligne, pas de ligne vide à la fin + # si $1=log, uniquement $2 logué +f__info() { # v21/08/2017 + if [ "$1" == "raw" ] || [ "$1" == "log" ]; then depart=2; + else local espace=" "; local depart=1; fi + [ "$1" == "log" ] && f__log "$(sed -E 's/\\t//;s/\\n// ' <<< $2 | xargs )" + for (( i=$depart ; i<=$# ; i++ )); do echo -e "$espace$BLUE${!i}"; done + [ "$1" == raw ] && printf "$COLOR" || echo "$COLOR" +} + + # log spécifique, fichier log limité à 10000octets, $1 message à loguer +f__log(){ # v08/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" + else + echo "$(date +%Y%m%d\ %H%M%S) $1" &>/dev/null >> "$fileLogs" + fi + else + f__info "$fileLogs doit être activé" + fi +} + + # test dépendances/paquets, $1 liste commande[>paquet] (ex: killall>psmisc) + # si manque, SORTIE & info commandes manquantes, si debian, SORTIE & proposition paquet à installer + # 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 + unset debOnlyPackages debOnlyPresents + for i in $1; do + local command="$(cut -d '>' -f 1 <<< $i)" + local 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" \ + && debOnlyPresents+="$package " || debOnlyPackages+="$package " + else f__error "dpkg n'est pas disponible sur ce système"; fi + elif [ -z "$(which $command)" ]; then + dependsMissing+="$command " + packagesMissing+="$package " + fi + done + [ "$debOnlyPackages" ] && debOnlyPackages="$(xargs <<< $debOnlyPackages)" # trim début & fin + [ "$debOnlyPresents" ] && debOnlyPresents="$(xargs <<< $debOnlyPresents)" # trim début & fin + [ "$debOnlyPackages" ] && return 1 + [ "$debOnlyPresents" ] && return 0 + if [ "$dependsMissing" ]; then + if [ -e /etc/debian_version ]; then f__error "paquet(s) manquant(s): " " $dependsMissing" \ + " vous devriez exécuter:$GREEN apt install $packagesMissing" + else f__error "commandes(s) manquante(s): " "$dependsMissing"; fi + fi +} + + # 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 + 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" + if [ "$SUDO_UID" ]; then + user_id="$SUDO_UID"; + elif grep -qEo '[0-9]+' <<< "$XDG_RUNTIME_DIR" ; then + user_id="$(grep -Eo '[0-9]+' <<< $XDG_RUNTIME_DIR | cut -d'/' -f4)" + elif grep -qEo '[0-9]+' <<< "$XAUTHORITY" ; then + user_id="$(grep -Eo '[0-9]+' <<< $XAUTHORITY | cut -d'/' -f4)" + fi + [ "$user_id" ] && user_="$(grep $user_id /etc/passwd | cut -d ":" -f 1 )" + if [ "$user_" ] && [ "$user_" != "$root_login" ]; then + return 0 + else + if [ "$SUDO_USER" ] && [ "$SUDO_USER" != "$root_login" ]; then + user_="$SUDO_USER"; + elif grep -qv 'root' <<< "$(who)"; then + user_="$(grep -v 'root' <<< $(who) | head -n1 | cut -d ' ' -f1)"; + elif grep -q 'hourly.*get[A-Z].*\.anacrontab.*\.config/anacron/spool' /etc/crontab; then + user_="$(grep 'hourly.*get[A-Z].*\.anacrontab.*\.config/anacron/spool' /etc/crontab | head -n1 | cut -d' ' -f2)"; + fi + fi + if [ -z "$user_" ]; then return 1; fi + if [ ! -d "/home/$user_" ]; then return 2; fi + return 0 +} + + # test wget, $1 url à tester, sortie script sur erreur +f__wget_test(){ # v07/2017 + echo " $1" + wget -Sq --tries=1 --timeout=15 --user-agent="$user_agent" -O /dev/null "$1" + f__error "Erreur wget" " réessayer et si persistance, contacter $projet $contact" " en indiquant les messages précédents." +} + + # spécifique getFirefox +fscript_cronAnacron_special(){ # v19/08/2017 + rm "/home/$user_/.mozilla/$script.anacrontab" &>/dev/null # ancienne localisation éventuelle + rm "/home/$user_/.config/anacron/spool/getFF"* &>/dev/null # ancien job +} + + # inscription dans tache upgrade en anacron hebdomadaire, via cron horaire +fscript_cronAnacron(){ # v23/08/2017 + [ "$(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" + [ $EUID -eq 0 ] && sed -i "/$script.anacrontab/d" /etc/crontab + case "$1" in + install | upgrade ) + mkdir -p "$dirAnacron" + # table anacron + echo "7 10 $script nice /opt/bin/$script --upgrade 1>/dev/null" > "$fileAnacron" # juste erreurs en syslog + ## anacron journalier pour dev logname + if [ "$user_" == "$lognameDev" ]; then + echo "1 00 $script""Dev nice /opt/bin/$script --upgrade 1>/dev/null" >> "$fileAnacron" # juste erreurs en syslog + fi + # création spool anacron utilisateur + mkdir -p "$dirSpool" + chown -R "$user_": "$dirAnacron" "$dirSpool" + if [ $EUID -eq 0 ]; then + # crontab pour activation horaire anacron + echo "@hourly $user_ /usr/sbin/anacron -t $fileAnacron -S $dirSpool" >> /etc/crontab + fi + [ "$(grep "$script" /etc/crontab)" ] || echo f__error "inscription crontab" \ + "certains systèmes semblent poser poser problème, merci de rapporter ce bug à $projet $contact" + ;; + remove ) + rm "$dirSpool/$script"* &>/dev/null + rm "$fileAnacron" &>/dev/null + rmdir "$dirSpool" "$dirAnacron" &>/dev/null + ;; + esac +} + + # version script en ligne, assigne $versionScript, $script_aJour=ok|ko +fscript_get_version(){ # v19/08/2017 + f__requis "wget" + f__info "$GREEN""\n version script en cours: $version" + versionScript="$(wget -q --tries=2 --timeout=15 -O - "$urlScript" | grep '^version=' | cut -d '=' -f 2)" + if [ "$versionScript" ]; then + if [ "$version" != "$versionScript" ]; then + f__info "version script en ligne: $versionScript, mise à jour possible" + script_aJour="ko" + else + f__info "version script en ligne: $versionScript" + script_aJour="ok" + fi + else f__info "version script en ligne non accessible"; fi +} + + # installation du script dans le système +fscript_install(){ # v24/08/2017 + if dirname "$0" | grep -q 'bin' ; then + f__info "\n $script $version est déjà installé" + return 1 + fi + [ $EUID -eq 0 ] || f__error "vous devez être ROOT pour installer ce script dans le système" + f__requis "wget anacron cron" + # install /opt + mkdir -p /opt/bin/ + cp -d "$(basename $0)" "/opt/bin/$script" + ln -s "/opt/bin/$script" "/usr/bin/$script" &>/dev/null + chmod 755 "/opt/bin/$script" + # cron/anacron install + fscript_cronAnacron "install" + # création fichier log + touch "$fileLogs" + chmod 644 "$fileLogs" + chown "$user_": "$fileLogs" "/opt/bin/$script" + [ -e "$script"_changelog.md ] || rm "$(basename $0)" &>/dev/null ## on efface pas si changelog (dev) + f__info "log" "$script $version installé dans le système." "maintenant, appel du script par:$GREEN $script$BLUE (sans ./)" +} + + # suppression du script dans le système +fscript_remove(){ # v21/08/2017 + [ $EUID -eq 0 ] || 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/bin/"$script" &>/dev/null + # cron/anacron remove + fscript_cronAnacron "remove" + f__info "log" "$script $version supprimé du système." +} + + # mise à jour script si dispo +fscript_update(){ # v24/08/2017 + f__requis "wget" + if [ "$script_aJour" == "ok" ]; then + f__info "log" "pas de mise à jour disponible pour $script" + return 0 + fi + local dirTemp="/tmp/$script-$RANDOM/" + mkdir -p "$dirTemp" + wget -q --tries=2 --timeout=15 -O "$dirTemp$script" "$urlScript" + if [ "$?" != "0" ]; then f__wget_test "$urlScript"; fi + chmod 755 "$dirTemp$script" + chown "$user_": "$dirTemp$script" + cp -d "$dirTemp$script" /opt/bin/"$script" + rm -rf "$dirTemp" + fscript_cronAnacron "upgrade" + f__info "log" "\n $script mis à jour en version $versionScript" +} + + # détermination canal bas Firefox installé, assigne $firefoxCanalBas +ffx_get_canalBas(){ + for ii in nightly dev beta esr latest; do + if [ -d "$dirInstall$ii/" ]; then firefoxCanalBas="$ii"; fi + done + [ "$firefoxCanalBas" ] || return 1 +} + + # version Firefox en ligne +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" + 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" + local verNightly="$(grep -i 'location' $fileTmp | sed -E 's/.*firefox-(.*)\.fr.linux.*/\1/')" + printf "." + rm "$fileTmp" + 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].*')" + fi + done + printf ".\n" + f__info "Firefox installé(s): $versionInstall" + f__info "version Firefox en ligne:\n Release : $verLatest\n Beta/dev: $verBeta\n Nightly : $verNightly\n ESR : $verEsr" +} + + # ascii art godzilla; ligne vide finale +ffx_godzilla(){ +printf "$RED" +cat << 'EOF' + _.-~-. + 7'' Q..\ + _7 (_ + _7 _/ _q. / + _7 . ___ /VVvv-'_ . + 7/ / /~- \_\\ '-._ .-' / // + ./ ( /-~-/||'=.__ '::. '-~'' { ___ / // ./{ + V V-~-~| || __''_ ':::. ''~-~.___.-'' _/ // / {_ / { / + VV/-~-~-|/ \ .'__'. '. ':: _ _ _ ''. + / /~~~~||VVV/ / \ ) \ _ __ ___ ___ ___(_) | | __ _ .::' + / (~-~-~\\.-' / \' \::::. | '_ ' _ \ / _ \_ / | | |/ _' | :::' +/..\ /..\__/ ' '::: | | | | | | (_) / /| | | | (_| | ::' +vVVv vVVv ': |_| |_| |_|\___/___|_|_|_|\__,_| '' +EOF +echo "$COLOR" +} + + # affichage help +ffx_help(){ + printf $BLUE +cat << 'EOF' + ---------------------------------------------------------------------- + canaux possibles latest, beta, nightly, dev, esr + exemple, installation version Release: getFirefox i-latest + + getFirefox i-canal : installation de Firefox + getFirefox r-canal : désinstallation de Firefox + getFirefox u-canal : ajouter ou configurer un profil firefox pour l'utilisateur en cours + getFirefox m-canal : installation sur le d'une archive téléchargée manuellement + + getFirefox version : version(s) installée(s) et en ligne des différents canaux Firefox + ---------------------------------------------------------------------- + ./getFirefox : installation du script dans le système + getFirefox -h, --help : affichage aide + getFirefox -r, --remove, sysremove : désinstallation du script du système + getFirefox -u, --upgrade, upgrade : mise à jour du script + getFirefox -v, --version : versions du script +EOF + printf "$COLOR" +cat << 'EOF' + ---------------------------------------------------------------------- + Si présent, le *paquet Debian* firefox-esr ou firefox devrait être désinstallé + ---------------------------------------------------------------------- +EOF +echo -e " plus d'infos:$GREEN https://framagit.org/kyodev/kyopages/raw/master/scripts/getFirefox$COLOR\n" +} + + # installation Firefox +ffx_install(){ + [ $EUID -eq 0 ] || f__error "vous devez être ROOT pour installer Firefox" + if [ "$1" == "manuel" ]; then + local versionArchive="$(sed -E 's/firefox-(.*)\.linux.*/\1/' <<< $(stat -c %n $2))" + f__info "installation manuelle de firefox version $versionArchive ($2)" + local dirTemp="$(dirname $2)/$script-$RANDOM/" + local fileTemp="$(basename $2)" + mkdir -p "$dirTemp" + else + f__info "installation Firefox-$produit" + local dirTemp="/tmp/$script-$RANDOM/" + local fileTemp="$dirTemp""firefox-$produit.$architecture.tar.bz2" + mkdir -p "$dirTemp" + # téléchargement & test archive + f__info " - téléchargement..." + ffx_recup_url + wget -q -c --show-progress --tries=2 --timeout=15 --user-agent="$user_agent" -O "$fileTemp" "$recup_url" + if [ "$?" != "0" ]; then f__wget_test "$recup_url"; fi + f__archive_test "$fileTemp" || f__error "Le fichier $fileTemp n'est pas une archive tar.gz valide" + echo + fi + # décompression archive téléchargée dans dossier de travail + f__info " - décompression..." + tar -xaf "$fileTemp" -C "$dirTemp" + # mise en place finale + f__info " - installation..." + rm -rf "/opt/firefox-$produit/" # effacement ancien répertoire éventuel + 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$produit/browser/chrome/icons/default/default48.png" "/usr/share/pixmaps/firefox-$produit.png" + # lanceur dans /usr/bin + echo '#!/bin/sh' > "/usr/bin/firefox-$produit" + echo >> "/usr/bin/firefox-$produit" + echo 'echo "$@"'" | grep -qE '\-P|\-\-ProfileManager' && exec $dirInstall$produit/firefox -P || \\" >> "/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 "log" "Firefox-$produit installé $versionArchive" + ffx_godzilla +} + + # installation d'un FF chargé manuellement, $1 +ffx_install_manuel(){ + [ -e "$1" ] || f__error "fichier $1 introuvable" + f__archive_test "$1" || f__error "Le fichier $1 n'est pas une archive valide" + ffx_install "manuel" "$1" + [ "$user_" != "$lognameDev" ] && rm "$1" &>/dev/null # si user pas dev, effacement archive +} + + # création lanceur.desktop +ffx_lanceur_desktop(){ + 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" + 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" + echo "GenericName[fr]=Navigateur Web" >> "$fileDesktop" + echo "Terminal=false" >> "$fileDesktop" + echo "X-MultipleArgs=false" >> "$fileDesktop" + echo "Type=Application" >> "$fileDesktop" + echo "Categories=Network;WebBrowser;" >> "$fileDesktop" + echo "MimeType=text/html;text/xml;application/xhtml+xml;application/xml;application/vnd.mozilla.xul+xml;application/rss+xml;application/rdf+xml;image/gif;image/jpeg;image/png;x-scheme-handler/http;x-scheme-handler/https;" >> "$fileDesktop" + echo "StartupNotify=true" >> "$fileDesktop" +} + + # 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=$produit $fileProfileIni)" != 0 ]; then return; fi + # comptage profils existants + local nbProfiles="$(grep -Ec '\[Profile[0-9]+\]' $fileProfileIni)" + # création profil dans profile.ini + echo "" >> "$fileProfileIni" + echo "[Profile$nbProfiles]" >> "$fileProfileIni" + echo "Name=$produit" >> "$fileProfileIni" + echo "IsRelative=1" >> "$fileProfileIni" + 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 +} + + # traitement utilisateur, $1=user si appel indépendant pour reconfiguration +ffx_profil_user(){ #22/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 + if [ -w "$fileProfileIni" ]; then # si profile.ini existe et rw, on traite default + # recherche éventuel profil tuvwxyz.default dans profile.ini + 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" ] && [ "$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/$produit" + cp -R "$dirProfil/$profileDefault"/* "$dirProfil/$produit/" + fi + fi + 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/$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 + if [ "$1" != "user" ]; then + ffx_lanceur_desktop + ffx_update_alternatives + fi + [ "$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 +ffx_recup_url(){ + if [ "$produit" == "latest" ]; then + recup_url="https://download.mozilla.org/?product=firefox-$produit&os=$architecture&lang=fr" + elif [ "$produit" == "esr" ] || [ "$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-$produit""edition-latest-ssl&os=$architecture&lang=fr" + elif [ "$produit" == "nightly" ]; then + recup_url="https://download.mozilla.org/?product=firefox-$produit-latest-l10n-ssl&os=$architecture&lang=fr" ;fi +} + + # désinstallation de Firefox, on laisse le profil user +ffx_remove(){ + [ $EUID -eq 0 ] || f__error "vous devez être ROOT pour désinstaller firefox" + 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-$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 + rm -rf "/opt/firefox-$produit/" # ancien répertoire éventuel + rm -rf "$dirInstall$produit/" + # suppression lanceurs + rm -f "/usr/share/applications/firefox-$produit.desktop" + rm -f "/usr/bin/firefox-$produit" + # suppression des liens + 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 "log" "Firefox-$produit désinstallé, mais le profil est toujours en place" \ + "\t(le supprimer manuellement si nécessaire)." + ffx_godzilla +} + + # traitement update-alternatives +ffx_update_alternatives(){ + [ "$(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 + f__info " - alternatives installées pour <$firefoxCanalBas>" + else # plus aucun canal installé, on efface + if update-alternatives --get-selections | grep firefox | grep -q x-www-browser; then + update-alternatives --quiet --remove-all x-www-browser + fi + fi +} + + # lien /usr/bin/firefox pour le plus bas canal Firefox installé, utile si update-alternatives pas fonctionnel +ffx_usr_bin(){ + if ffx_get_canalBas ; then + ln -sf "/usr/bin/firefox-$firefoxCanalBas" "/usr/bin/firefox" + f__info " - firefox lié à firefox-$firefoxCanalBas" + fi +} + + # initialisation +PATH='/usr/sbin:/usr/bin:/sbin:/bin' ; IFS=' '; TERM=xterm +export PATH TERM +f__affichage +f__architecture || f__error "Seules les architecture 32 et 64 bits sont supportée (i686 & amd64) par Firefox" +f__user || f__error "échec détection user" +f__requis "file tar killall>psmisc" # pour fonctionnement programme + +fileLogs="/var/log/sdeb_$script.log" +dirInstall="/opt/usr/share/firefox-" +dirProfil="/home/$user_/.mozilla/firefox" +fileProfileIni="$dirProfil/profiles.ini" + +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)" \ + " Il faudrait réinstaller les version(s) détectée(s):" \ + "$YELLOW""$(ls -d /opt/firefox-* | sed -E 's/.*firefox-(.*)/ getFirefox i-\1/')" \ + "$GREEN voir: $urlNotice#messages-avertissement\n" + +[ -e "/opt/bin/$script" ] && [ "$(stat -c %G /opt/bin/$script)" == "root" ] && problemDetected+="-1" # droits inappropriés sur le script, version de dev +options=$@ +if [ "$(dirname $0)" == "." ]; then unset options +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""#installation-rapide-du-script" +for i in $options; do + case $i in + version | versions ) + ffx_get_versionsFF + fscript_get_version + ffx_godzilla; break ;; # affiche versions Firefox en ligne & installées + i-latest | i-esr | i-dev | i-beta | i-nightly | +latest | +esr | +dev | +beta | +nightly ) + produit="$(sed 's/i-//; s/+//' <<< "$1")" + ffx_install; break ;; # install: installation canal Firefox (gestion ancien répertoire éventuel) + m-latest | m-esr | m-dev | m-beta | m-nightly ) + produit="$(sed 's/m-//' <<< "$1")" + ffx_install_manuel "$2"; break ;; # installation manuelle d'un chargement, $2 archive, $3 canal à utiliser + r-latest | r-esr | r-dev | r-beta | r-nightly | -latest | -esr | -dev | -beta | -nightly ) + produit="$(sed 's/r-//; s/-//' <<< "$1")" + ffx_remove; break ;; # 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")" + [ "$problemOldInstall" ] && f__error "vous devez réinstaller firefox auparavant" + ffx_profil_user "user"; break ;; # configurer un profil firefox pour un user + "" ) if ! dirname "$0" | grep -q 'bin' ; then + fscript_install + else ffx_help; fi ;; # installation du script dans le système + -r | --remove | sysremove ) + fscript_remove; break ;; # désinstallation du script + -u | --upgrade | upgrade ) + opType="upgrade" + fscript_get_version + fscript_update; break ;; # upgrade script + -v | --version ) fscript_get_version; break ;; # version du script, en ligne et exécuté + -h | --help | * ) ffx_help; break ;; # affichage help + esac +done + +exit 0 + +wget -O getFirefox https://framagit.org/kyodev/kyopages/raw/master/scripts/getFirefox +chmod +x getFirefox && ./getFirefox diff --git a/scripts/getFirefox_changelog.md b/scripts/getFirefox_changelog.md index 66dd229..0e3a2df 100644 --- a/scripts/getFirefox_changelog.md +++ b/scripts/getFirefox_changelog.md @@ -3,8 +3,17 @@ ## todo * install: copie du profil du canal inférieur? -* pocket -* user.pref (autoplay, ...) + + + +## 2.3.0 25/08/2017 + +* renommage fscript_dl en fscript_update +* révision fscript_install, fscript_update +* révision f__wget_test +* révision f__error, f__info +* option personnalisation +* canal all pour install et personnalisation ## 2.2.1 23/08/2017