This commit is contained in:
kyodev 2017-06-11 09:43:59 +02:00
parent 2374db0c9c
commit 5c89968aa4
2 changed files with 163 additions and 92 deletions

View File

@ -1,5 +1,5 @@
# getFirefox # getFirefox
**version 0.2.0b** **version 0.3.0beta**
## charger le script ## charger le script
@ -16,9 +16,10 @@ su
exit exit
``` ```
* le script est maintenant dans le système et tout utilisateur peut s'en servir. * le script est maintenant dans le système et tout utilisateur peut s'en servir.
* si le paquet `firefox-esr` est présent, il sera **désinstallé**. * si le paquet Debian `firefox-esr` est présent, il sera **désinstallé**.
* **Fermer Firefox existant** avant installation * **Fermer un Firefox existant** avant installation
* si ce paquet devait être ré-installé, il semble préférable de désinstaller le plugin auparavant. * si ce paquet devait être ré-installé, il semble préférable de désinstaller ces version
officielles auparavant.
## help ## help
@ -33,30 +34,34 @@ lancer le script sans arguments: `getFirefox`
\__, |\___|\__|_| |_|_| \___|_| \___/_/\_\ \__, |\___|\__|_| |_|_| \___|_| \___/_/\_\
|___/ |___/
Firefox-latest pour Debian, version 0.2.0b - 10/06/2017 pour Debian, version 0.3.0beta - 10/06/2017
----------------------------------------------------------------------- -----------------------------------------------------------------------
./getFirefox : installation du script dans le système ./getFirefox : installation du script dans le système
getFirefox version : version en ligne de Firefox-latest getFirefox +latest : installation Firefox Release
getFirefox +latest : téléchargement & installation de Firefox-latest getFirefox -latest : désinstallation Firefox Release
getFirefox +esr : installation de Firefox-esr getFirefox version : version en ligne Firefox Release & ESR
getFirefox : installation branche Developer Edition de Firefox ----
getFirefox : installation branche Nightly de Firefox getFirefox +aurora : installation de Firefox Developer Edition
getFirefox : installation TorBrowser getFirefox -aurora : désinstallation Firefox Developer Edition
getFirefox -latest : désinstallation de Firefox-latest getFirefox +nightly : installation de Firefox Nightly
getFirefox -esr : désinstallation de Firefox-esr getFirefox -nightly : désinstallation Firefox Nightly
getFirefox +esr : installation de Firefox ESR
getFirefox -esr : désinstallation Firefox ESR
----
getFirefox sysremove : désinstall du script du système getFirefox sysremove : désinstall du script du système
----------------------------------------------------------------------- -----------------------------------------------------------------------
Ce script doit être exécuté avec les droits ROOT. Ce script doit être exécuté avec les droits ROOT.
Il désinstallera le paquet firefox-esr si présent. FERMER et DESINSTALLER un Firefox existant avant d'installer un
nouveau canal
Il désinstallera le paquet Debian firefox-esr si présent.
Ce script devrait fonctionner sur Ubuntu. Ce script devrait fonctionner sur Ubuntu.
----------------------------------------------------------------------- -----------------------------------------------------------------------
``` ```
## installation version _latest_ ## installation _Release_
``` ```
su su
@ -80,32 +85,75 @@ vVVv vVVv ': |_| |_| |_|\___/___|_|_|_|\__,_| ''
``` ```
* Firefox est installé, en étant directement chargé du site Mozilla. * Firefox est installé, en étant directement chargé du site Mozilla.
* c'est la dernière release officielle, qui se met à jour automatiquement. * c'est la dernière release officielle, qui se met à jour automatiquement.
* mise à jour majeure toutes les 6 semaines environ. * mise à jour majeure toutes les 6 à 8 semaines environ.
* version 53 en juin 2017.
## désinstallation Firefox
`getFirefox` ## versions en ligne
* A venir `getFirefox version`: affiche la version en ligne de:
## version en ligne
`getFirefox version`: affiche la version en ligne de
* Firefox version latest release * Firefox version latest release
* Firexos version esr * Firexos version esr
## installation version _esr_ ## installation autres canaux
`getFirefox +esr` 3 autres canaux sont possibles:
* Firefox Esr est installé, en étant directement chargé du site Mozilla. * Developer Developer (**aurora**), orientée développeurs, version _beta_ comme _testing_,
* c'est la dernière Esr officielle. [Mozilla developer](https://www.mozilla.org/fr/firefox/developer/)
* mise à jour majeure toutes les ans environ. * Nightly, réservé aux aventuriers, mise à jour tous les jours, version _alpha_ comme _sid_
* version 52 en juin 2017. [Mozilla Nightly](https://blog.nightly.mozilla.org/)
* ESR, mise à jour majeure toutes les ans environ, avec support à plus long terme.
mise à jour majeure toutes les ans environ, en savoir plus
[Mozilla ESR](https://developer.mozilla.org/fr/Firefox/Firefox_ESR)
l'installation est lancée avec _getFirefox _**+canal**, soit:
`getFirefox +aurora`, `getFirefox +nightly`, `getFirefox +esr`
## Avertissement
** seules les versions **ESR** et **latest** sont intallables sans risques avec ce script**
le reste est en cours de développement
les versions des autres canaux, sont à utiliser avec prudence, seulement si vous maitrisez la technique.
les versions des canaux par ordre croissant:
```
ESR <= release < aurora < nightly
```
* il n'est **pas conseillé de descendre de version** au risque de voir le profil utilisateur **corrompu**.
* par contre les profils suivent plus sûrement les montées de version
* le script sauvegarde automatiquement, avant installation, le profil firefox de l'utilisateur qui a ouvert la
session graphique
* le profil, par ex. `/home/user/.mozilla/firefox/`, est sauvegardé en `/home/user/.mozilla/AAAAMMDD-HHMMSS/`,
avec un suffixe correspondant à la date UTC.
* ce profil pourrait servir en cas de problème, notamment lors d'une tentative de revenir à une version inférieure
### upgrade en aurora
exemple, Firefox est en release, vous voulez suivre le canal **Nightly**
* **fermer Firefox**
* désinstaller _latest_
* installer _nightly_
```shell
su
getFirefox -latest
getFirefox +nightly
exit
```
* le profil existant a été sauvegardé en `/home/user/.mozilla/20170610-173205`
* le profil original est toujours en `/home/user/.mozilla/firefox/` et sera utilisé par la nouvelle
version installée
## désinstallation Firefox
l'installation est lancée avec _getFirefox _**-canal**, soit:
`getFirefox -esr`, `getFirefox -aurora`, `getFirefox -nightly`
## supprimer le script sur le systeme ## supprimer le script sur le systeme
@ -113,13 +161,17 @@ vVVv vVVv ': |_| |_| |_|\___/___|_|_|_|\__,_| ''
en **root**: `getFirefox sysremove` en **root**: `getFirefox sysremove`
## évolution
* Firefox version Developer Edition
* Firefox version Nightly
* Firefox version TorBrowser
## sources ## sources
sur [framagit](https://framagit.org/kyodev/kyopages/blob/master/scripts/getFirefox) sur [framagit](https://framagit.org/kyodev/kyopages/blob/master/scripts/getFirefox)
## Contact
pour tout problème ou suggestion concernant ce script, n'hésitez pas à ouvrir une issue
[Framagit](https://framagit.org/kyodev/kyopages/issues)
## LPRAB/WTFPL
[license](../about/LICENSE)

View File

@ -1,12 +1,12 @@
#!/bin/bash #!/bin/bash
version="0.2.2b" version="0.3.0beta"
projet="Kyodev" projet="Kyodev"
contact="https://framagit.org/kyodev/kyopages/issues" contact="https://framagit.org/kyodev/kyopages/issues"
date="10/06/2017" date="10/06/2017"
script="getFirefox" script="getFirefox"
##### licence LPRAB/WTFPL ##### license LPRAB/WTFPL
# auteurs: kyodev # auteurs: kyodev
# contibuteurs: - # contibuteurs: -
##### #####
@ -31,7 +31,7 @@ cat << 'EOF'
|___/ |___/
EOF EOF
echo -e "$YELLOW Firefox-latest pour Debian, version $version - $date\n$COLOR" echo -e "$YELLOW pour Debian, version $version - $date\n$COLOR"
#### fonctions diverses ================================================ #### fonctions diverses ================================================
@ -65,6 +65,11 @@ f_scriptBin(){
if [ "$(echo $0 | grep -Eo '\.\/')" != "./" ]; then return 0; else return 1; fi if [ "$(echo $0 | grep -Eo '\.\/')" != "./" ]; then return 0; else return 1; fi
} }
# user ayant démarré la session graphique; $userHome
f_userHome(){
userHome=$(echo $XAUTHORITY | sed -E 's/(.*)\.Xauthority/\1/')
}
#### fonctions script ================================================== #### fonctions script ==================================================
@ -79,6 +84,7 @@ f_versionFF(){
if [ "$1" != "quiet" ]; then f_info "Version Firefox en ligne: $verLatest\n Version esr: $verEsr"; fi if [ "$1" != "quiet" ]; then f_info "Version Firefox en ligne: $verLatest\n Version esr: $verEsr"; fi
} }
# ascii art godzilla # ascii art godzilla
f_godzilla(){ f_godzilla(){
cat << 'EOF' cat << 'EOF'
@ -103,27 +109,30 @@ EOF
f_help(){ f_help(){
printf $BLUE printf $BLUE
cat << 'EOF' cat << 'EOF'
----------------------------------------------------------------------- ----------------------------------------------------------------------
./getFirefox : installation du script dans le système ./getFirefox : installation du script dans le système
getFirefox version : version en ligne de Firefox-latest getFirefox +latest : installation Firefox Release
getFirefox +latest : téléchargement & installation de Firefox Release getFirefox -latest : désinstallation Firefox Release
getFirefox +esr : installation de Firefox Esr getFirefox version : version en ligne Firefox Release & ESR
getFirefox : installation branche Developer Edition (aurora) ----
getFirefox : installation branche Nightly de Firefox getFirefox +aurora : installation de Firefox Developer Edition
getFirefox : installation TorBrowser getFirefox -aurora : désinstallation Firefox Developer Edition
getFirefox -latest : désinstallation de Firefox-latest getFirefox +nightly : installation de Firefox Nightly
getFirefox -esr : désinstallation de Firefox-esr getFirefox -nightly : désinstallation Firefox Nightly
getFirefox +esr : installation de Firefox ESR
getFirefox sysremove : désinstall du script du système getFirefox -esr : désinstallation Firefox ESR
----
getFirefox sysremove : désinstallation du script du système
EOF EOF
printf $COLOR printf $COLOR; cat << 'EOF'
cat << 'EOF' ----------------------------------------------------------------------
-----------------------------------------------------------------------
Ce script doit être exécuté avec les droits ROOT. Ce script doit être exécuté avec les droits ROOT.
Il désinstallera le paquet firefox-esr si présent. FERMER et DESINSTALLER un Firefox existant avant d'installer un
nouveau canal
Il désinstallera le paquet Debian firefox-esr si présent.
Ce script devrait fonctionner sur Ubuntu. Ce script devrait fonctionner sur Ubuntu.
----------------------------------------------------------------------- ----------------------------------------------------------------------
EOF EOF
printf $COLOR printf $COLOR
@ -151,6 +160,11 @@ f_sysremove(){
f_info "$GREEN$script est supprimé du système.\n" f_info "$GREEN$script est supprimé du système.\n"
} }
# sauvegarde profil
f_sauveProfil(){
f_userHome
cp -a "$userHome".mozilla/firefox/ "$userHome".mozilla/"$(date -u +%Y%m%d-%H%M%S)"/
}
# install firefox # install firefox
f_install(){ f_install(){
@ -159,9 +173,7 @@ f_install(){
# debian? sinon dehors / utile? / # debian? sinon dehors / utile? /
if ! f_debian ; then f_error "désolé, vous n'utilisez pas Debian :( adieu o/"; fi if ! f_debian ; then f_error "désolé, vous n'utilisez pas Debian :( adieu o/"; fi
printf $RED printf $RED; f_godzilla; printf $COLOR
f_godzilla
printf $COLOR
# on vire 'firefox-esr' si installé # on vire 'firefox-esr' si installé
if [ "$( dpkg-query -l firefox-esr &>/dev/null | grep -Eo ^ii)" == "ii" ]; then apt-get remove firefox-esr; fi if [ "$( dpkg-query -l firefox-esr &>/dev/null | grep -Eo ^ii)" == "ii" ]; then apt-get remove firefox-esr; fi
@ -172,13 +184,16 @@ f_install(){
# calcul $file, $url, affichage version pendant l'install # calcul $file, $url, affichage version pendant l'install
file="firefox-$product.$architecture.tar.bz2" file="firefox-$product.$architecture.tar.bz2"
if [ "$product" == "esr" ]; then if [ "$product" == "latest" ]; then
f_info "installation Firefox-esr, version $verEsr" f_info "installation Firefox-$product, version $verLatest"
url="https://download.mozilla.org/?product=firefox-esr-latest&os=$architecture&lang=fr" url="https://download.mozilla.org/?product=firefox-$product&os=$architecture&lang=fr"
elif [ "$product" == "latest" ]; then elif [ "$product" == "esr" ]; then
f_info "installation Firefox-latest, version $verLatest" f_info "installation Firefox-$product, version $verEsr"
url="https://download.mozilla.org/?product=firefox-latest&os=$architecture&lang=fr" url="https://download.mozilla.org/?product=firefox-$product-latest&os=$architecture&lang=fr"
else f_error "branche firefox inconnue"; fi else
f_info "installation Firefox-$product"
url="https://download.mozilla.org/?product=firefox-$product-latest-l10n-ssl&os=linux&lang=fr"
fi
# dossier temporaire de travail, création $dirTemp # dossier temporaire de travail, création $dirTemp
dirTemp="/tmp/$script/" dirTemp="/tmp/$script/"
@ -201,6 +216,9 @@ f_install(){
f_info "installation...." f_info "installation...."
#sauvegarde du profil
f_sauveProfil
# install lanceur # install lanceur
f_lanceur(){ f_lanceur(){
rm -f /usr/share/applications/firefox-"$product".desktop rm -f /usr/share/applications/firefox-"$product".desktop
@ -236,22 +254,21 @@ EOF
# lien pixmap # lien pixmap
ln -sf /opt/firefox-"$product"/browser/chrome/icons/default/default48.png /usr/share/pixmaps/firefox-"$product".png ln -sf /opt/firefox-"$product"/browser/chrome/icons/default/default48.png /usr/share/pixmaps/firefox-"$product".png
# # liens /usr/bin inutile? # # alternatives
# ln -sf /opt/firefox/firefox-"$product" /usr/bin/firefox # update-alternatives --quiet --install /usr/bin/firefox-"$product" x-www-browser /opt/firefox-"$product"/firefox 100
# alternatives # test sans alternatives, et avec liens dans /usr/bin pour latest en tant que firefox
update-alternatives --quiet --install /usr/bin/firefox-"$product" x-www-browser /opt/firefox-"$product"/firefox 100 if [ "$product" == "latest" ]; then ln -sf /opt/firefox-"$product"/firefox /usr/bin/firefox; fi
# update-alternatives --quiet --install /usr/bin/firefox-"$product" gnome-www-browser /opt/firefox-"$product"/firefox 100
# update-alternatives: erreur: le lien alternatif /usr/bin/firefox-latest est déjà géré par x-www-browser
#ménage #ménage
rm -rf "$dirTemp" rm -rf "$dirTemp"
# the end # the end
f_info "$GREEN""Firefox-$product est installé.\n" f_info "$GREEN""Firefox-$product est installé.\n"
if [ $product == "nightly" ]; then f_info "pour savoir comment participer au développement: https://nightly.mozfr.org/participer/"; fi
} }
# suppression de firefox # désinstallation de firefox
f_remove(){ f_remove(){
if ! f_root ; then f_error "vous devez être ROOT pour désinstaller"; fi if ! f_root ; then f_error "vous devez être ROOT pour désinstaller"; fi
@ -273,34 +290,36 @@ f_remove(){
#### traitements arguments ============================================= #### traitements arguments =============================================
if [ "$#" -gt 1 ]; then cmd="help" && f_info "$RED trop d'arguments"
if [ "$#" -gt 1 ]; then cmd="help" && f_info "$RED trop d'arguments" elif [ "$1" == "version" ]; then cmd="version"
elif [ "$1" == "version" ]; then cmd="version" elif [ "$1" == "+latest" ]; then cmd="install"; product='latest'
elif [ "$1" == "+latest" ]; then cmd="install"; product='latest' elif [ "$1" == "-latest" ]; then cmd="remove"; product='latest'
elif [ "$1" == "-latest" ]; then cmd="remove"; product='latest' elif [ "$1" == "+esr" ]; then cmd="install"; product='esr'
elif [ "$1" == "+esr" ]; then cmd="install"; product='esr' elif [ "$1" == "-esr" ]; then cmd="remove"; product='esr'
elif [ "$1" == "-esr" ]; then cmd="remove"; product='esr' elif [ "$1" == "+aurora" ]; then cmd="install"; product='aurora'
elif [ "$1" == "sysremove" ]; then cmd="sysremove" elif [ "$1" == "-aurora" ]; then cmd="remove"; product='aurora'
elif [ "$1" == "+nightly" ]; then cmd="install"; product='nightly'
elif [ "$1" == "-nightly" ]; then cmd="remove"; product='nightly'
elif [ "$1" == "sysremove" ]; then cmd="sysremove"
else cmd="help" else cmd="help"
fi fi
#### installation du script si pas dans le système =====================
#### installation script si pas dans le système ========================
if ! f_scriptBin ; then f_sysinstall; fi if ! f_scriptBin ; then f_sysinstall; fi
#### désinstallation du script =========================================
if [ "$cmd" == "sysremove" ]; then f_sysremove; fi
#### help ============================================================== #### help ==============================================================
if [ "$cmd" == "help" ]; then f_help; fi if [ "$cmd" == "help" ]; then f_help; fi
#### système remove ==================================================== #### version en ligne ==================================================
if [ "$cmd" == "sysremove" ]; then f_sysremove; fi
#### fonction version en ligne =========================================
if [ "$cmd" == "version" ]; then f_versionFF; fi if [ "$cmd" == "version" ]; then f_versionFF; fi
#### remove, on vire flash =============================================
if [ "$cmd" == "remove" ]; then f_remove; fi
#### installation ====================================================== #### installation ======================================================
if [ "$cmd" == "install" ]; then f_install; fi if [ "$cmd" == "install" ]; then f_install; fi
#### désinstallation ===================================================
if [ "$cmd" == "remove" ]; then f_remove; fi
exit 0 exit 0