mirror of https://framagit.org/kyodev/kyopages.git
0.5.0
This commit is contained in:
parent
252eb6d82c
commit
412cb93146
|
@ -1,9 +1,9 @@
|
|||
#!/bin/bash
|
||||
|
||||
version=0.4.2
|
||||
date="18/07/2017"
|
||||
version=0.5.0
|
||||
date="19/07/2017"
|
||||
projet="Kyodev"
|
||||
contact="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"
|
||||
urlNotice="https://kyodev.frama.io/kyopages/scripts/getFirefox/"
|
||||
|
@ -26,7 +26,7 @@ YELLOW=`printf "\033[0;33m"` # ?
|
|||
|
||||
#### entete ============================================================
|
||||
clear
|
||||
echo "$BLUE"
|
||||
printf "$BLUE"
|
||||
cat << 'EOF'
|
||||
_ _____ _ __
|
||||
__ _ ___| |_| ___(_)_ __ ___ / _| _____ __
|
||||
|
@ -60,7 +60,7 @@ f__architecture(){
|
|||
esac
|
||||
}
|
||||
|
||||
# user ayant initié la session graphique, assigne $user_, testé avec mate, gnome
|
||||
# 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(){
|
||||
|
@ -103,7 +103,6 @@ f__testArchive(){
|
|||
file -b "$1" | grep 'bzip2 compressed data' &>/dev/null && archive_detect="bzip2" || return 1
|
||||
}
|
||||
|
||||
|
||||
# sortie sur erreur, log $1 si upgrade
|
||||
f__error() { #affichage $1 en rouge, $1++ optionnels en bleu, sortie du script, log $1 si upgrade
|
||||
echo -e "\n$RED Erreur critique: $1 $COLOR"
|
||||
|
@ -125,6 +124,7 @@ f__root(){
|
|||
if [ $EUID -eq 0 ]; then return 0; else return 1; fi
|
||||
}
|
||||
|
||||
|
||||
#### fonctions script ==================================================
|
||||
|
||||
# install du script dans le système
|
||||
|
@ -239,13 +239,13 @@ cat << 'EOF'
|
|||
----------------------------------------------------------------------
|
||||
./getFirefox : installation du script dans le système
|
||||
|
||||
getFirefox +latest : installation Firefox Release
|
||||
getFirefox +aurora : installation de Firefox Developer Edition
|
||||
getFirefox +latest : installation de Firefox Release
|
||||
getFirefox +beta : installation de Firefox Beta
|
||||
getFirefox +nightly : installation de Firefox Nightly
|
||||
getFirefox +esr : installation de Firefox ESR
|
||||
----
|
||||
getFirefox -latest : désinstallation Firefox Release
|
||||
getFirefox -aurora : désinstallation Firefox Developer Edition
|
||||
getFirefox -beta : désinstallation Firefox Beta
|
||||
getFirefox -nightly : désinstallation Firefox Nightly
|
||||
getFirefox -esr : désinstallation Firefox ESR
|
||||
----
|
||||
|
@ -259,33 +259,41 @@ cat << 'EOF'
|
|||
----------------------------------------------------------------------
|
||||
Ce script doit être exécuté avec les droits ROOT pour
|
||||
les installations et les désinstallations.
|
||||
FERMER et DESINSTALLER un Firefox existant avant d'installer un
|
||||
nouveau canal
|
||||
Il désinstallera le *paquet Debian* firefox-esr si présent.
|
||||
----------------------------------------------------------------------
|
||||
|
||||
EOF
|
||||
}
|
||||
|
||||
# sauvegarde profil
|
||||
ffx_sauveProfil(){
|
||||
cp -a "/home/$user_".mozilla/firefox/ "/home/$user_".mozilla/"$(date -u +%Y%m%d-%H%M%S)"/
|
||||
#revoir en fonction des canaux installés
|
||||
|
||||
# version Firefox en ligne, $verLatest, $verEsr, $versionInstall, $urlOnline, si $1="quiet", pas d'affichage version en ligne
|
||||
ffx_versionFF(){
|
||||
urlOnline="https://www.mozilla.org/en-US/firefox/notes/"
|
||||
stockUrlOnline="$(wget -q --tries=2 --timeout=15 --user-agent=$user_agent -O - $urlOnline)"
|
||||
verLatest="$(echo $stockUrlOnline | grep -Eo 'data-latest-firefox="[0-9\.]+"' | grep -Eo '[0-9\.]+')"
|
||||
verEsr="$(echo $stockUrlOnline | grep -Eo 'data-esr-versions="[0-9\.]+"' | grep -Eo '[0-9\.]+')"
|
||||
for product in latest esr beta nightly; do
|
||||
if [ -x "$dirInstall$product/firefox" ]; then
|
||||
versionInstall+="\n $product: $($dirInstall$product/firefox -v | grep -Eo '[0-9].*')"
|
||||
fi
|
||||
done
|
||||
f__info "Firefox installé(s): $versionInstall"
|
||||
f__info "Version Firefox en ligne:\n Release: $verLatest\n ESR: $verEsr"
|
||||
}
|
||||
|
||||
# création lanceur
|
||||
ffx_lanceur(){
|
||||
# création lanceur.desktop
|
||||
ffx_lanceur_desktop(){
|
||||
rm -f /usr/share/applications/firefox-"$product".desktop
|
||||
cat << "EOF" >> /usr/share/applications/firefox-"$product".desktop
|
||||
#!/usr/bin/env xdg-open
|
||||
[Desktop Entry]
|
||||
EOF
|
||||
echo -e "Name=Firefox $product\nName[fr]=Firefox $product" >> /usr/share/applications/firefox-"$product".desktop
|
||||
echo -e "X-GNOME-FullName=Firefox-$product Web Browser\nX-GNOME-FullName[fr]=Firefox-$product Navigateur Web" >> /usr/share/applications/firefox-"$product".desktop
|
||||
echo -e "StartupWMClass=Firefox-$product" >> /usr/share/applications/firefox-"$product".desktop
|
||||
echo -e "Exec=/opt/firefox-$product/firefox %u" >> /usr/share/applications/firefox-"$product".desktop
|
||||
echo -e "Icon=/opt/firefox-$product/browser/icons/mozicon128.png" >> /usr/share/applications/firefox-"$product".desktop
|
||||
echo "Name=Firefox $product" >> /usr/share/applications/firefox-"$product".desktop
|
||||
echo "Name[fr]=Firefox $product" >> /usr/share/applications/firefox-"$product".desktop
|
||||
echo "X-GNOME-FullName=Firefox-$product Web Browser" >> /usr/share/applications/firefox-"$product".desktop
|
||||
echo "X-GNOME-FullName[fr]=Firefox-$product Navigateur Web" >> /usr/share/applications/firefox-"$product".desktop
|
||||
echo "StartupWMClass=Firefox-$product" >> /usr/share/applications/firefox-"$product".desktop
|
||||
echo "Exec=/usr/bin/firefox-$product %u" >> /usr/share/applications/firefox-"$product".desktop
|
||||
echo "Icon=$dirInstall$product/browser/icons/mozicon128.png" >> /usr/share/applications/firefox-"$product".desktop
|
||||
cat << "EOF" >> /usr/share/applications/firefox-"$product".desktop
|
||||
Comment=Browse the World Wide Web
|
||||
Comment[fr]=Naviguer sur Internet
|
||||
|
@ -300,83 +308,97 @@ StartupNotify=true
|
|||
EOF
|
||||
}
|
||||
|
||||
# version Firefox en ligne, $verLatest, $verEsr, $versionInstall, $urlOnline, si $1="quiet", pas d'affichage version en ligne
|
||||
ffx_versionFF(){
|
||||
urlOnline="https://www.mozilla.org/en-US/firefox/notes/"
|
||||
stockUrlOnline="$(wget -q --tries=2 --timeout=15 --user-agent=$user_agent -O - $urlOnline)"
|
||||
verLatest="$(echo $stockUrlOnline | grep -Eo 'data-latest-firefox="[0-9\.]+"' | grep -Eo '[0-9\.]+')"
|
||||
verEsr="$(echo $stockUrlOnline | grep -Eo 'data-esr-versions="[0-9\.]+"' | grep -Eo '[0-9\.]+')"
|
||||
versionInstall="-"
|
||||
if [ -x /opt/firefox-latest/firefox ]; then versionInstall+="\n Release: $(/opt/firefox-latest/firefox -v | grep -Eo '[0-9].*')"; fi
|
||||
if [ -x /opt/firefox-esr/firefox ]; then versionInstall+="\n ESR: $(/opt/firefox-esr/firefox -v | grep -Eo '[0-9].*')"; fi
|
||||
if [ -x /opt/firefox-aurora/firefox ]; then versionInstall+="\n Aurora: $(/opt/firefox-aurora/firefox -v | grep -Eo '[0-9].*')"; fi
|
||||
if [ -x /opt/firefox-nightly/firefox ]; then versionInstall+="\n Nightly: $(/opt/firefox-nightly/firefox -v | grep -Eo '[0-9].*')"; fi
|
||||
if [ "$1" != "quiet" ]; then f__info "Firefox installé(s): $versionInstall"; fi
|
||||
if [ "$1" != "quiet" ]; then f__info "Version Firefox en ligne:\n Release: $verLatest\n ESR: $verEsr"; fi
|
||||
# sauvegarde profil, uniquement si profil default et latest ou esr
|
||||
ffx_profileCopy(){
|
||||
if [ "$product" != "latest" ] && [ "$product" != "esr" ]; then return 0; fi
|
||||
profilDefault="$(grep -r '\.default' /home/$user_/.mozilla/firefox/profiles.ini | sed 's/Path=//')"
|
||||
if [ $profilDefault ] && [ ! -d "/home/$user_/.mozilla/firefox/latest" ] || [ ! -d "/home/$user_/.mozilla/firefox/esr" ]; then
|
||||
cp -R "/home/$user_/.mozilla/firefox/$profilDefault"/* "/home/$user_/.mozilla/firefox/$product/"
|
||||
fi
|
||||
}
|
||||
|
||||
# install firefox, $1 canal à installer
|
||||
# traitement de profile.ini
|
||||
ffx_profileIni(){
|
||||
fileProfil="/home/$user_/.mozilla/firefox/profiles.ini"
|
||||
#si profil existant, sortir
|
||||
if [ "$(grep -rc 'Name=$product' $fileProfil)" != 0 ]; then return; fi
|
||||
#comptage profils existants
|
||||
nbProfiles="$(grep -rEc '\[Profile[0-9]+\]' $fileProfil)"
|
||||
#création profil
|
||||
echo "" >> "$fileProfil"
|
||||
echo "[Profile$nbProfiles]" >> "$fileProfil"
|
||||
echo "Name=$product" >> "$fileProfil"
|
||||
echo "IsRelative=1" >> "$fileProfil"
|
||||
echo "Path=$product" >> "$fileProfil"
|
||||
#si existant et latest, supprimer Default=1 et attribuer à latest, dans profile.ini
|
||||
if [ "$product" == "latest" ] || [ "$product" == "esr" ]; then
|
||||
sed -i 's/Default=1//' "$fileProfil"
|
||||
echo "Default=1" >> "$fileProfil"
|
||||
else echo "" >> "$fileProfil"; fi
|
||||
return
|
||||
}
|
||||
|
||||
# calcul url téléchargement, assigne $recup_url
|
||||
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" == "nightly" ]; then
|
||||
recup_url="https://download.mozilla.org/?product=firefox-$product-latest-l10n-ssl&os=linux&lang=fr" ;fi
|
||||
}
|
||||
|
||||
# install firefox
|
||||
ffx_install(){
|
||||
# f__root || f__error "vous devez être ROOT pour installer Firefox"
|
||||
f__root || f__error "vous devez être ROOT pour installer Firefox"
|
||||
ffx_godzilla
|
||||
f__info "installation Firefox-$product"
|
||||
#ffx_versionFF "quiet"
|
||||
f__architecture
|
||||
|
||||
# calcul $file, $recup_url, affichage version pendant l'install
|
||||
file="firefox-$product.$architecture.tar.bz2"
|
||||
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"
|
||||
else recup_url="https://download.mozilla.org/?product=firefox-$product-latest-l10n-ssl&os=linux&lang=fr" ;fi
|
||||
|
||||
# dossier temporaire de travail, création $dirTemp
|
||||
# dirTemp="/tmp/$script-$RANDOM/"
|
||||
dirTemp="/tmp/getFirefox-12201/"
|
||||
dirTemp="/tmp/$script-$RANDOM/"
|
||||
mkdir -p "$dirTemp"
|
||||
|
||||
# chargement
|
||||
f__info "téléchargement..."
|
||||
# wget -q -c --show-progress --tries=2 --timeout=15 --user-agent="$user_agent" -O "$dirTemp$file" "$recup_url"
|
||||
# if [ "$?" != "0" ]; then f__testWget "$recup_url"; fi
|
||||
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__testWget "$recup_url"; fi
|
||||
f__testArchive "$dirTemp$file" || f__error "Le fichier $dirTemp$file n'est pas une archive tar.gz valide"
|
||||
|
||||
# décompression archive
|
||||
f__info "décompression...."
|
||||
f__info "décompression..."
|
||||
tar -xaf "$dirTemp$file" -C "$dirTemp"
|
||||
|
||||
f__info "installation...."
|
||||
exit
|
||||
|
||||
# on déplace le répertoire firefox en /opt
|
||||
rm -rf /opt/firefox-"$product"/
|
||||
mkdir -p /opt/firefox-"$product"/
|
||||
mv -f "$dirTemp"firefox/* /opt/firefox-"$product"/
|
||||
#ménage
|
||||
f__info "installation..."
|
||||
# on déplace le répertoire firefox dans le répertoire 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 "$dirTemp"
|
||||
|
||||
mkdir -p "/home/$user_/.mozilla/firefox/$product"
|
||||
ffx_profileCopy
|
||||
chown -R "$user_": "/home/$user_/.mozilla/firefox/$product/"
|
||||
chmod g-rx,o-rx "/home/$user_/.mozilla/firefox/$product/"
|
||||
ffx_profileIni
|
||||
ffx_lanceur_desktop
|
||||
# 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"
|
||||
|
||||
#sauvegarde du profil
|
||||
ffx_sauveProfil
|
||||
# préparer profile.ini
|
||||
#ffx_profile
|
||||
# install lanceur
|
||||
ffx_lanceur
|
||||
ln -sf "$dirInstall$product"/browser/chrome/icons/default/default48.png /usr/share/pixmaps/firefox-"$product".png
|
||||
|
||||
# lien pixmap
|
||||
ln -sf /opt/firefox-"$product"/browser/chrome/icons/default/default48.png /usr/share/pixmaps/firefox-"$product".png
|
||||
# lien dans /usr/bin pour latest en tant que firefox
|
||||
if [ "$product" == "latest" ]; then ln -sf "/usr/bin/firefox-latest" "/usr/bin/firefox"
|
||||
elif [ "$product" == "esr" ]; then ln -sf "/usr/bin/firefox-esr" "/usr/bin/firefox"; fi
|
||||
|
||||
# # alternatives, trop intrusif pour plusieurs versions simultanées?
|
||||
# update-alternatives --quiet --install /usr/bin/firefox-"$product" x-www-browser /opt/firefox-"$product"/firefox 100
|
||||
|
||||
#grep -Ec '\[Profile' ~/.mozilla/firefox/profiles.ini -> 2
|
||||
#firefox -P nightly
|
||||
|
||||
# test sans alternatives, et avec liens dans /usr/bin pour latest en tant que firefox
|
||||
if [ "$product" == "latest" ]; then ln -sf /opt/firefox-"$product"/firefox /usr/bin/firefox; fi
|
||||
|
||||
# the end
|
||||
f__info "$GREEN Firefox-$product installé."
|
||||
if [ $product == "nightly" ]; then f__info "pour savoir comment participer au développement:\nhttps://nightly.mozfr.org/participer/"; fi
|
||||
# update-alternatives --quiet --install /usr/bin/firefox-"$product" x-www-browser "$dirInstall$product"/firefox 100
|
||||
f__info "$GREEN""Firefox-$product installé."
|
||||
}
|
||||
|
||||
# désinstallation de firefox
|
||||
|
@ -387,12 +409,20 @@ ffx_remove(){
|
|||
f__info "$GREEN" "Firefox-$product n'est pas installé."
|
||||
return 0
|
||||
fi
|
||||
# suppression du répertoire firefox en /opt
|
||||
if [ -d "/opt/firefox-$product/" ]; then rm -rf "/opt/firefox-$product/"; fi
|
||||
# suppression du lanceur
|
||||
# suppression du répertoire firefox
|
||||
if [ -d "$dirInstall$product/" ]; then rm -rf "$dirInstall$product/"; fi
|
||||
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
|
||||
# suppression lanceurs
|
||||
rm -f /usr/share/applications/firefox-"$product".desktop
|
||||
# suppression lien pixmap
|
||||
unlink /usr/share/pixmaps/firefox-"$product".png &>/dev/null
|
||||
rm -f /usr/bin/firefox-"$product"
|
||||
|
||||
# suppression des liens
|
||||
unlink "/usr/share/pixmaps/firefox-$product.png" &>/dev/null
|
||||
if [ "$product" == "latest" ]; then unlink "/usr/bin/firefox" &>/dev/null
|
||||
elif [ "$product" == "esr" ]; then unlink "/usr/bin/firefox" &>/dev/null; fi
|
||||
unlink "/usr/bin/firefox-$product" &>/dev/null
|
||||
|
||||
# suppression alternatives si existantes
|
||||
if update-alternatives --display x-www-browser &>/dev/null; then
|
||||
update-alternatives --display x-www-browser | grep firefox-"$product" &>/dev/null && update-alternatives --quiet --remove x-www-browser /opt/firefox/firefox-"$product"
|
||||
|
@ -407,12 +437,17 @@ ffx_remove(){
|
|||
f__architecture || f__error "Architecture non supportée"
|
||||
f__user
|
||||
f__requis "wget" "logger" "file" "tar"
|
||||
dirInstall="/opt/usr/share/firefox-"
|
||||
|
||||
# installation du script si pas dans le système
|
||||
dirname "$0" | grep 'bin' &>/dev/null || fscript_install
|
||||
|
||||
# détection droits inappropriés sur le script
|
||||
[ "$1" != "sysremove" ] && [ -e "/opt/bin/$script" ] && ls -l "/opt/bin/$script" | grep 'root' &>/dev/null && f__error "bug sécu 01" \
|
||||
"veuillez désinstaller le script et le réinstaller" "voir: $urlNotice#supprimer-le-script"
|
||||
"veuillez désinstaller le script et le réinstaller" "voir: $urlNotice#messages-avertissement"
|
||||
#detection ancien repertoire install
|
||||
ls -ld /opt/firefox-* &>/dev/null && f__info "$RED""Ancien répertoire d'installation détecté" \
|
||||
"Il faudrait désinstaller et réinstaller pour être à jour" "version(s) détectée(s):" \
|
||||
"$(ls -ld /opt/firefox-* | sed -E 's/.*firefox-(.*)/ \1/')"
|
||||
|
||||
case "$1" in
|
||||
"sysremove" )
|
||||
|
@ -425,11 +460,10 @@ case "$1" in
|
|||
opType="upgrade"
|
||||
fscript_version
|
||||
fscript_dl ;; # upgrade script si maj possible
|
||||
+latest | +esr | +aurora | +nightly )
|
||||
f__error "script en cours de refonte, installations non permise aujourd'hui"
|
||||
+latest | +esr | +beta | +nightly )
|
||||
product="$(echo $1 | sed 's/+//')"
|
||||
ffx_install ;; # installation plugin
|
||||
-latest | -esr | -aurora | -nightly )
|
||||
-latest | -esr | -beta | -nightly )
|
||||
product="$(echo $1 | sed 's/-//')"
|
||||
ffx_remove ;; # désinstallation plugin
|
||||
"manuel" )
|
||||
|
|
|
@ -2,15 +2,27 @@
|
|||
|
||||
## todo
|
||||
|
||||
* install manuelle archive
|
||||
* installation manuelle archive
|
||||
* téléchargement archive
|
||||
* version enligne autre que esr et release
|
||||
* révision install
|
||||
* plus d'architecture? (arm)?
|
||||
* voir alternatives par ordre croissant, latest ou esr sinon beta sinon nightly
|
||||
* récupérer icône aurora pour beta?
|
||||
|
||||
## 0.5.0 19/07/17
|
||||
|
||||
* copie du profil default pour utilisation par latest
|
||||
* remplacement aurora par beta
|
||||
* révision install
|
||||
* changement répertoire installation /opt/usr/share/firefox- au lieu de /opt/firefox-
|
||||
plus en accord avec fhs
|
||||
* détection utilisation ancien répertoire
|
||||
* script remove gère ancien ou nouveau répertoire
|
||||
* détection et infor mauvais répertoire install
|
||||
|
||||
## 0.4.2 18/07/17
|
||||
|
||||
* fix bug: product, version esr en ligne
|
||||
* fix bug: version esr en ligne
|
||||
* révision traitement paramètres
|
||||
* révision traitement script
|
||||
* révision remove
|
||||
|
|
Loading…
Reference in New Issue