mirror of https://framagit.org/kyodev/kyopages.git
2.9.0
This commit is contained in:
parent
c5a35ee4af
commit
17e5ad18de
|
@ -1,6 +1,6 @@
|
|||
#!/bin/bash
|
||||
|
||||
version=2.8.0
|
||||
version=2.9.0
|
||||
date="30/08/2017"
|
||||
projet="simpledeb"
|
||||
contact="IRC freenode ##sdeb ou https://framagit.org/kyodev/kyopages/issues/"
|
||||
|
@ -53,9 +53,15 @@ f__architecture(){ # v07/2017
|
|||
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
|
||||
# test validité archive, $1 archive, assigne $archive_detect (gzip|xz|deb|zip), return 1 si inconnue
|
||||
f__archive_test(){ # v30/08/2017
|
||||
local filetest="$(file -b $1)"
|
||||
grep -q 'gzip compressed data' <<< "$filetest" && archive_detect="gzip"
|
||||
grep -q 'bzip2 compressed data' <<< "$filetest" && archive_detect="bzip2"
|
||||
grep -q 'Debian binary package' <<< "$filetest" && archive_detect="deb"
|
||||
grep -q 'Zip archive data' <<< "$filetest" && archive_detect="zip"
|
||||
grep -q 'XZ compressed data' <<< "$filetest" && archive_detect="xz"
|
||||
if [ ! "$archive_detect" ] || [ "$archive_detect" == "empty" ]; then return 1; fi
|
||||
}
|
||||
|
||||
# affichage $1 en rouge, $1++ optionnels en bleu, sortie script sur erreur, log $1 si $opType=upgrade
|
||||
|
@ -94,12 +100,12 @@ f__log(){ # v08/2017
|
|||
# si $2=debOnly et si paquets manquants: return 1 et $debOnlyPackages ( $1=liste paquets )
|
||||
# si $2=debOnly et si paquets présent: return 0 et $debOnlyPresents ( $1=liste paquets )
|
||||
# attention priorité $debOnlyPackages sur $debOnlyPresents
|
||||
f__requis(){ # v17/08/2017-3
|
||||
local dependsMissing packagesMissing
|
||||
f__requis(){ # v30/08/2017-3
|
||||
local dependsMissing packagesMissing command package
|
||||
unset debOnlyPackages debOnlyPresents
|
||||
for i in $1; do
|
||||
local command="$(cut -d '>' -f 1 <<< $i)"
|
||||
local package="$(cut -d '>' -f 2 <<< $i)"
|
||||
command="$(cut -d '>' -f 1 <<< $i)"
|
||||
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" \
|
||||
|
@ -124,13 +130,13 @@ 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(){ # v30/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"
|
||||
local user_id test root_login
|
||||
root_login="$(grep ':0:' /etc/passwd | cut -d':' -f1)" || root_login="root"
|
||||
if [ "$SUDO_UID" ]; then
|
||||
user_id="$SUDO_UID";
|
||||
elif grep -qEo '[0-9]+' <<< "$XDG_RUNTIME_DIR" ; then
|
||||
|
@ -157,9 +163,10 @@ f__user(){ # v21/08/2017-4
|
|||
|
||||
# test wget, $1 url à tester, sortie script, sur erreur ou retour à la normale
|
||||
# si $2=print affiche url testée & entêtes http & location (si présente) et sortie normale fonction
|
||||
f__wget_test(){ #v28/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="$?"
|
||||
f__wget_test(){ # v30/08/2017
|
||||
local file_test_wget retourWget retourHttp location
|
||||
file_test_wget="/tmp/testWget-$RANDOM"
|
||||
wget -Sq --tries=1 --timeout=10 --user-agent="$user_agent" --spider --save-headers "$1" &>"$file_test_wget" || retourWget="$?"
|
||||
[ "$retourWget" == 1 ] && retourWget="code erreur générique"
|
||||
[ "$retourWget" == 2 ] && retourWget="parse erreur (ligne de commande?)"
|
||||
[ "$retourWget" == 3 ] && retourWget="erreur Entrée/sortie fichier"
|
||||
|
@ -168,8 +175,8 @@ f__wget_test(){ #v28/08/2017
|
|||
[ "$retourWget" == 6 ] && retourWget="défaut authentification"
|
||||
[ "$retourWget" == 7 ] && retourWget="erreur de protocole"
|
||||
[ "$retourWget" == 8 ] && retourWget="réponse serveur en erreur"
|
||||
local retourHttp="$(grep -i 'HTTP/' "$file_test_wget" | tr -d '\n' | xargs)"
|
||||
local location="$(grep -i 'location' $file_test_wget | xargs)"
|
||||
retourHttp="$(grep -i 'HTTP/' "$file_test_wget" | tr -d '\n' | xargs)"
|
||||
location="$(grep -i 'location' $file_test_wget | xargs)"
|
||||
if [ "$2" == "print" ] && [ -z "$retourWget" ]; then
|
||||
echo -e "\n$1"
|
||||
echo "$GREEN$retourHttp$COLOR"
|
||||
|
@ -188,7 +195,7 @@ f__wget_test(){ #v28/08/2017
|
|||
}
|
||||
|
||||
# affichage help
|
||||
f_help(){ #v25/08/2017
|
||||
f_help(){ # v25/08/2017
|
||||
printf $BLUE
|
||||
cat << 'EOF'
|
||||
----------------------------------------------------------------------
|
||||
|
@ -233,32 +240,42 @@ ffx_get_canalBas(){
|
|||
}
|
||||
|
||||
# version Firefox en ligne
|
||||
ffx_get_versionsFF(){ #v28/08/2017
|
||||
ffx_get_versionsFF(){ # v30/08/2017
|
||||
local fileTmp recup_url verLatest verEsr verBeta verNightly versionInstall
|
||||
printf "."
|
||||
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\.]+')"
|
||||
fileTmp="/tmp/getFirefox-wgetVer-$RANDOM"
|
||||
# version latest & esr
|
||||
recup_url="https://www.mozilla.org/en-US/firefox/notes/"
|
||||
wget -q --tries=2 --timeout=15 --user-agent="$user_agent" -O - "$recup_url" &>"$fileTmp"
|
||||
verLatest="$(grep -Eo 'data-latest-firefox="[0-9\.]+"' $fileTmp | grep -Eo '[0-9\.]+')"
|
||||
printf "."
|
||||
local recup_url="https://download.mozilla.org/?product=firefox-beta-latest&os=linux64&lang=fr"
|
||||
verEsr="$(grep -Eo 'data-esr-versions="[0-9\.]+"' $fileTmp | grep -Eo '[0-9\.]+')"
|
||||
printf "."
|
||||
# version beta
|
||||
recup_url="https://download.mozilla.org/?product=firefox-beta-latest&os=linux64&lang=fr"
|
||||
wget -Sq --tries=1 --timeout=10 --user-agent="$user_agent" --spider --save-headers "$recup_url" &>"$fileTmp"
|
||||
local verBeta="$(grep -i 'location' $fileTmp | sed -E 's/.*firefox-(.*)\.tar.bz2/\1/')"
|
||||
verBeta="$(grep -i 'location' $fileTmp | sed -E 's/.*firefox-(.*)\.tar.bz2/\1/')"
|
||||
printf "."
|
||||
local recup_url="https://download.mozilla.org/?product=firefox-nightly-latest-l10n-ssl&os=linux64&lang=fr"
|
||||
# version nightly
|
||||
recup_url="https://download.mozilla.org/?product=firefox-nightly-latest-l10n-ssl&os=linux64&lang=fr"
|
||||
wget -Sq --tries=1 --timeout=10 --user-agent="$user_agent" --spider --save-headers "$recup_url" &>"$fileTmp"
|
||||
local verNightly="$(grep -i 'location' $fileTmp | sed -E 's/.*firefox-(.*)\.fr.linux.*/\1/')"
|
||||
verNightly="$(grep -i 'location' $fileTmp | sed -E 's/.*firefox-(.*)\.fr.linux.*/\1/')"
|
||||
printf "."
|
||||
rm "$fileTmp"
|
||||
# versions installées
|
||||
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].*')"
|
||||
versionInstall+="$prod: $($dirInstall$prod/firefox -v | grep -Eo '[0-9].*')\t"
|
||||
fi
|
||||
done
|
||||
printf ".\n"
|
||||
f__info "raw" "$GREEN""Firefox installé(s): $versionInstall$COLOR"
|
||||
f__info "version Firefox en ligne:\n Release : $verLatest\n Beta/dev: $verBeta\n Nightly : $verNightly\n ESR : $verEsr"
|
||||
[ "$verLatest" ] || verLatest="$RED""NA"
|
||||
[ "$verBeta" ] || verBeta="$RED""NA"
|
||||
[ "$verNightly" ] || verNightly="$RED""NA"
|
||||
[ "$verEsr" ] || verEsr="$RED""NA"
|
||||
f__info "raw" "version Firefox installé(s): $GREEN$versionInstall$COLOR"
|
||||
f__info "version Firefox en ligne: $YELLOW""Release: $verLatest\tBeta/dev: $verBeta\tNightly: $verNightly\tESR: $verEsr$COLORS"
|
||||
}
|
||||
|
||||
# ascii art godzilla; ligne vide finale
|
||||
|
@ -283,19 +300,20 @@ echo "$COLOR"
|
|||
}
|
||||
|
||||
# installation Firefox, $1 produit, $2 manuel, $3 archive
|
||||
ffx_install(){ #v27/08/2017
|
||||
ffx_install(){ # v30/08/2017
|
||||
[ $EUID -eq 0 ] || f__error "vous devez être ROOT pour installer Firefox"
|
||||
local versionArchive dirTemp fileTemp produit
|
||||
if [ "$2" == "manuel" ]; then
|
||||
local versionArchive="$(sed -E 's/firefox-(.*)\.linux.*/\1/' <<< $(stat -c %n $3))"
|
||||
versionArchive="$(sed -E 's/firefox-(.*)\.linux.*/\1/' <<< $(basename $3))"
|
||||
f__info "installation manuelle de firefox version $versionArchive ($3)"
|
||||
local dirTemp="$(dirname $3)/$script-$RANDOM/"
|
||||
local fileTemp="$(basename $3)"
|
||||
dirTemp="$(dirname $3)/$script-$RANDOM/"
|
||||
fileTemp="$(basename $3)"
|
||||
mkdir -p "$dirTemp"
|
||||
else
|
||||
local produit="$1"
|
||||
produit="$1"
|
||||
f__info "installation Firefox-$produit"
|
||||
local dirTemp="/tmp/$script-$RANDOM/"
|
||||
local fileTemp="$dirTemp""firefox-$produit.$architecture.tar.bz2"
|
||||
dirTemp="/tmp/$script-$RANDOM/"
|
||||
fileTemp="$dirTemp""firefox-$produit.$architecture.tar.bz2"
|
||||
mkdir -p "$dirTemp"
|
||||
# téléchargement & test archive
|
||||
f__info " - téléchargement..."
|
||||
|
@ -328,13 +346,17 @@ ffx_install(){ #v27/08/2017
|
|||
ffx_usr_bin
|
||||
# traitement user
|
||||
ffx_profil_user
|
||||
f__info "log" "Firefox-$produit installé $versionArchive"
|
||||
if [ "$1" == "manuel" ]; then
|
||||
f__info "log" "archive Firefox-$produit $versionArchive installée"
|
||||
else
|
||||
f__info "log" "Firefox-$produit installé"
|
||||
fi
|
||||
ffx_godzilla
|
||||
}
|
||||
|
||||
# installation d'un FF chargé manuellement, $1 produit, $2 fichier archive
|
||||
ffx_install_manuel(){ #v27/08/2017
|
||||
[ -e "$2" ] || f__error "fichier $1 introuvable"
|
||||
ffx_install_manuel(){ # v30/08/2017
|
||||
[ -e "$2" ] || f__error "fichier $2 introuvable"
|
||||
f__archive_test "$2" || f__error "Le fichier $2 n'est pas une archive valide"
|
||||
ffx_install "$1" "manuel" "$2"
|
||||
[ -e "$fileDev" ] || rm "$2" &>/dev/null ## on efface pas si fileDev (dev)
|
||||
|
@ -365,20 +387,20 @@ ffx_lanceur_desktop(){
|
|||
}
|
||||
|
||||
# version personnalisation en ligne, assigne $prodATraiter
|
||||
ffx_pers_get_version(){ #v28/08/2017
|
||||
ffx_pers_get_version(){ # v30/08/2017
|
||||
local urlPers versionPersOnline versionPersInstall persEnPlace
|
||||
f__requis "wget"
|
||||
if [ -e "$dirProfil/$produit/personnalisation.$script" ]; then
|
||||
local urlPers="$(sed -n '1p' "$dirProfil/$produit/personnalisation.$script")"
|
||||
urlPers="$(sed -n '1p' "$dirProfil/$produit/personnalisation.$script")"
|
||||
else
|
||||
local urlPers="https://framagit.org/kyodev/kyopages/raw/master/scripts/"
|
||||
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')"
|
||||
versionPersOnline="$(wget -q --tries=2 --timeout=15 -O - "$urlPers"user.js | sed -En 's/\/\*v(.*)\*\//\1/p')"
|
||||
if [ "$versionPersOnline" ]; then
|
||||
local versionPers persEnPlace
|
||||
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
|
||||
versionPersInstall="$(sed -n '2p' $dirProfil/$prod/personnalisation.$script)"
|
||||
if [ "$versionPersInstall" != "$versionPersOnline" ]; then prodATraiter+="$prod "; fi
|
||||
persEnPlace+="$prod "
|
||||
fi
|
||||
done
|
||||
|
@ -392,22 +414,22 @@ ffx_pers_get_version(){ #v28/08/2017
|
|||
}
|
||||
|
||||
# recup user.js et chrome/userChrome.css, $1=produit à personnaliser ou mettre à jour
|
||||
ffx_pers_install(){ #25/08/2017
|
||||
local produit="$1"
|
||||
[ ! -d "$dirProfil/$produit" ] && f__error "firefox <$produit> n'est pas installé" "personnalisation abandonnée"
|
||||
ffx_pers_install(){ # v30/08/2017
|
||||
local produit="$1" urlPers versionPersOnline dirTemp
|
||||
[ ! -d "$dirProfil/$produit" ] && return
|
||||
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")"
|
||||
urlPers="$(head -n1 "$dirProfil/$produit/personnalisation.$script")"
|
||||
else
|
||||
local urlPers="https://framagit.org/kyodev/kyopages/raw/master/scripts/"
|
||||
urlPers="https://framagit.org/kyodev/kyopages/raw/master/scripts/"
|
||||
fi
|
||||
# chargement fichiers personnalisation
|
||||
local dirTemp="/tmp/$script-$RANDOM/"
|
||||
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
|
||||
versionPersOnline="$(sed -En 's/\/\*v(.*)\*\//\1/p' "$dirTemp"user.js)" # uniquement sur user.js
|
||||
wget -q --tries=1 --timeout=15 -O "$dirTemp"userChrome.css "$urlPers"userChrome.css
|
||||
chown -R "$user_": "$dirTemp"
|
||||
# installation
|
||||
|
@ -416,14 +438,14 @@ ffx_pers_install(){ #25/08/2017
|
|||
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"
|
||||
echo "$versionPersOnline" >> "$dirProfil/$produit/personnalisation.$script"
|
||||
chown -R "$user_": "$dirProfil/$produit/personnalisation.$script"
|
||||
rm -rf "$dirTemp"
|
||||
f__info "log" "personnalisation $versionPers mise en place pour $produit"
|
||||
f__info "log" "personnalisation $versionPersOnline mise en place pour $produit"
|
||||
}
|
||||
|
||||
# maj user.js et chrome/userChrome.css
|
||||
ffx_pers_upgrade(){ #25/08/2017
|
||||
ffx_pers_upgrade(){ # v25/08/2017
|
||||
ffx_pers_get_version
|
||||
if [ "$prodATraiter" ]; then
|
||||
for i in $prodATraiter; do ffx_pers_install "$i"; done
|
||||
|
@ -450,7 +472,7 @@ ffx_profilIni_inscription(){
|
|||
}
|
||||
|
||||
# traitement utilisateur, $1=user si appel indépendant pour reconfiguration
|
||||
ffx_profil_user(){ #22/08/2017
|
||||
ffx_profil_user(){ # v22/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
|
||||
|
@ -481,7 +503,7 @@ ffx_profil_user(){ #22/08/2017
|
|||
[ "$1" == "user" ] && f__info "log" "profil <$produit> configuré pour $user_"
|
||||
}
|
||||
|
||||
# calcul url téléchargement, assigne $recup_url. fixer url pour beta et nightly dans ffx_get_versionsFF
|
||||
# calcul url téléchargement, assigne $recup_url
|
||||
ffx_recup_url(){
|
||||
if [ "$produit" == "latest" ]; then
|
||||
recup_url="https://download.mozilla.org/?product=firefox-$produit&os=$architecture&lang=fr"
|
||||
|
@ -541,11 +563,12 @@ ffx_usr_bin(){
|
|||
}
|
||||
|
||||
# inscription dans tache upgrade en anacron hebdomadaire, via cron horaire, $1=upgrade|install|remove
|
||||
fscript_cronAnacron(){ # v27/08/2017
|
||||
fscript_cronAnacron(){ # v30/08/2017
|
||||
local dirAnacron dirSpool fileAnacron
|
||||
[ "$(type -t fscript_cronAnacron_special)" ] && fscript_cronAnacron_special # test, si fonction spécifique, appel
|
||||
local dirAnacron="/home/$user_/.config/anacron"
|
||||
local dirSpool="$dirAnacron/spool"
|
||||
local fileAnacron="$dirAnacron/$script.anacrontab"
|
||||
dirAnacron="/home/$user_/.config/anacron"
|
||||
dirSpool="$dirAnacron/spool"
|
||||
fileAnacron="$dirAnacron/$script.anacrontab"
|
||||
[ $EUID -eq 0 ] && sed -i "/$script.anacrontab/d" /etc/crontab
|
||||
case "$1" in
|
||||
install | upgrade )
|
||||
|
@ -692,6 +715,7 @@ dirInstall="/opt/usr/share/firefox-"
|
|||
dirProfil="/home/$user_/.mozilla/firefox"
|
||||
fileProfileIni="$dirProfil/profiles.ini"
|
||||
produitAll="latest beta nightly"
|
||||
dirInstallTB="/opt/usr/share/tor-browser/"
|
||||
|
||||
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)" \
|
||||
|
@ -741,6 +765,7 @@ for i in $options; do
|
|||
ffx_get_versionsFF
|
||||
fscript_get_version
|
||||
ffx_pers_get_version
|
||||
f_tb_get_version
|
||||
ffx_godzilla
|
||||
exit ;; # affiche versions Firefox en ligne & installées, script et personnalisation
|
||||
-i )
|
||||
|
|
|
@ -4,6 +4,14 @@
|
|||
## todo
|
||||
* install: copie du profil du canal inférieur?
|
||||
|
||||
## 2.9.0 30/08/2017
|
||||
|
||||
* révision f__requis, f__user, f__wget_test, fscript_cronAnacron
|
||||
* révision déclaration local
|
||||
* révision f__archive_test, ffx_install_manuel
|
||||
* révision affichage ffx_get_versionsFF, ffx_pers_get_version, ffx_pers_install
|
||||
* si produit all, installation personnalisation uniquement pour les produits installés au lieu de f__error
|
||||
|
||||
## 2.8.0 30/08/2017
|
||||
|
||||
* révision conditions d'utilisations, fscript_install, fscript_remove(), fscript_update
|
||||
|
|
Loading…
Reference in New Issue