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
|
#!/bin/bash
|
||||||
|
|
||||||
version=2.8.0
|
version=2.9.0
|
||||||
date="30/08/2017"
|
date="30/08/2017"
|
||||||
projet="simpledeb"
|
projet="simpledeb"
|
||||||
contact="IRC freenode ##sdeb ou https://framagit.org/kyodev/kyopages/issues/"
|
contact="IRC freenode ##sdeb ou https://framagit.org/kyodev/kyopages/issues/"
|
||||||
|
@ -53,9 +53,15 @@ f__architecture(){ # v07/2017
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
# test validité archive, $1 fichier (bzip2), return 1 si invalide
|
# test validité archive, $1 archive, assigne $archive_detect (gzip|xz|deb|zip), return 1 si inconnue
|
||||||
f__archive_test(){ # v07/2017
|
f__archive_test(){ # v30/08/2017
|
||||||
file -b "$1" | grep -q 'bzip2 compressed data' || return 1
|
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
|
# 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 manquants: return 1 et $debOnlyPackages ( $1=liste paquets )
|
||||||
# si $2=debOnly et si paquets présent: return 0 et $debOnlyPresents ( $1=liste paquets )
|
# si $2=debOnly et si paquets présent: return 0 et $debOnlyPresents ( $1=liste paquets )
|
||||||
# attention priorité $debOnlyPackages sur $debOnlyPresents
|
# attention priorité $debOnlyPackages sur $debOnlyPresents
|
||||||
f__requis(){ # v17/08/2017-3
|
f__requis(){ # v30/08/2017-3
|
||||||
local dependsMissing packagesMissing
|
local dependsMissing packagesMissing command package
|
||||||
unset debOnlyPackages debOnlyPresents
|
unset debOnlyPackages debOnlyPresents
|
||||||
for i in $1; do
|
for i in $1; do
|
||||||
local command="$(cut -d '>' -f 1 <<< $i)"
|
command="$(cut -d '>' -f 1 <<< $i)"
|
||||||
local package="$(cut -d '>' -f 2 <<< $i)"
|
package="$(cut -d '>' -f 2 <<< $i)"
|
||||||
if [ "$2" == "debOnly" ]; then
|
if [ "$2" == "debOnly" ]; then
|
||||||
if [ "$(which dpkg)" ]; then # package only et debian
|
if [ "$(which dpkg)" ]; then # package only et debian
|
||||||
LC_ALL=C dpkg --get-selections | grep -qE "^$package[[:space:]]+install" \
|
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_
|
# user ayant initié la session graphique, assigne $user_
|
||||||
# return 1 sur échec identification user, return 2 sur absence home/
|
# return 1 sur échec identification user, return 2 sur absence home/
|
||||||
# gestion variable environnement user avec: USER_INSTALL=user script
|
# 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
|
if [ "$USER_INSTALL" ]; then # user_ via variable environnement, moyen d'injecter root
|
||||||
user_="$USER_INSTALL";
|
user_="$USER_INSTALL";
|
||||||
return 0
|
return 0
|
||||||
fi
|
fi
|
||||||
local user_id test
|
local user_id test root_login
|
||||||
local root_login="$(grep ':0:' /etc/passwd | cut -d':' -f1)" || local root_login="root"
|
root_login="$(grep ':0:' /etc/passwd | cut -d':' -f1)" || root_login="root"
|
||||||
if [ "$SUDO_UID" ]; then
|
if [ "$SUDO_UID" ]; then
|
||||||
user_id="$SUDO_UID";
|
user_id="$SUDO_UID";
|
||||||
elif grep -qEo '[0-9]+' <<< "$XDG_RUNTIME_DIR" ; then
|
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
|
# 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
|
# si $2=print affiche url testée & entêtes http & location (si présente) et sortie normale fonction
|
||||||
f__wget_test(){ #v28/08/2017
|
f__wget_test(){ # v30/08/2017
|
||||||
local file_test_wget="/tmp/testWget-$RANDOM"
|
local file_test_wget retourWget retourHttp location
|
||||||
wget -Sq --tries=1 --timeout=10 --user-agent="$user_agent" --spider --save-headers "$1" &>"$file_test_wget" || local retourWget="$?"
|
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" == 1 ] && retourWget="code erreur générique"
|
||||||
[ "$retourWget" == 2 ] && retourWget="parse erreur (ligne de commande?)"
|
[ "$retourWget" == 2 ] && retourWget="parse erreur (ligne de commande?)"
|
||||||
[ "$retourWget" == 3 ] && retourWget="erreur Entrée/sortie fichier"
|
[ "$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" == 6 ] && retourWget="défaut authentification"
|
||||||
[ "$retourWget" == 7 ] && retourWget="erreur de protocole"
|
[ "$retourWget" == 7 ] && retourWget="erreur de protocole"
|
||||||
[ "$retourWget" == 8 ] && retourWget="réponse serveur en erreur"
|
[ "$retourWget" == 8 ] && retourWget="réponse serveur en erreur"
|
||||||
local retourHttp="$(grep -i 'HTTP/' "$file_test_wget" | tr -d '\n' | xargs)"
|
retourHttp="$(grep -i 'HTTP/' "$file_test_wget" | tr -d '\n' | xargs)"
|
||||||
local location="$(grep -i 'location' $file_test_wget | xargs)"
|
location="$(grep -i 'location' $file_test_wget | xargs)"
|
||||||
if [ "$2" == "print" ] && [ -z "$retourWget" ]; then
|
if [ "$2" == "print" ] && [ -z "$retourWget" ]; then
|
||||||
echo -e "\n$1"
|
echo -e "\n$1"
|
||||||
echo "$GREEN$retourHttp$COLOR"
|
echo "$GREEN$retourHttp$COLOR"
|
||||||
|
@ -188,7 +195,7 @@ f__wget_test(){ #v28/08/2017
|
||||||
}
|
}
|
||||||
|
|
||||||
# affichage help
|
# affichage help
|
||||||
f_help(){ #v25/08/2017
|
f_help(){ # v25/08/2017
|
||||||
printf $BLUE
|
printf $BLUE
|
||||||
cat << 'EOF'
|
cat << 'EOF'
|
||||||
----------------------------------------------------------------------
|
----------------------------------------------------------------------
|
||||||
|
@ -233,32 +240,42 @@ ffx_get_canalBas(){
|
||||||
}
|
}
|
||||||
|
|
||||||
# version Firefox en ligne
|
# 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 "."
|
printf "."
|
||||||
local fileTmp="/tmp/getFirefox-wgetVer-$RANDOM"
|
fileTmp="/tmp/getFirefox-wgetVer-$RANDOM"
|
||||||
local recup_url="https://www.mozilla.org/en-US/firefox/notes/"
|
# version latest & esr
|
||||||
wget -q --tries=2 --timeout=15 --user-agent=$user_agent -O - "$recup_url" &>"$fileTmp"
|
recup_url="https://www.mozilla.org/en-US/firefox/notes/"
|
||||||
local verLatest="$(grep -Eo 'data-latest-firefox="[0-9\.]+"' $fileTmp | grep -Eo '[0-9\.]+')"
|
wget -q --tries=2 --timeout=15 --user-agent="$user_agent" -O - "$recup_url" &>"$fileTmp"
|
||||||
local verEsr="$(grep -Eo 'data-esr-versions="[0-9\.]+"' $fileTmp | grep -Eo '[0-9\.]+')"
|
verLatest="$(grep -Eo 'data-latest-firefox="[0-9\.]+"' $fileTmp | grep -Eo '[0-9\.]+')"
|
||||||
printf "."
|
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"
|
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 "."
|
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"
|
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 "."
|
printf "."
|
||||||
rm "$fileTmp"
|
rm "$fileTmp"
|
||||||
|
# versions installées
|
||||||
for prod in latest esr beta dev nightly; do
|
for prod in latest esr beta dev nightly; do
|
||||||
if [ -x "$dirInstall$prod/firefox" ]; then
|
if [ -x "$dirInstall$prod/firefox" ]; then
|
||||||
printf "."
|
printf "."
|
||||||
versionInstall+="\n $prod: $($dirInstall$prod/firefox -v | grep -Eo '[0-9].*')"
|
versionInstall+="$prod: $($dirInstall$prod/firefox -v | grep -Eo '[0-9].*')\t"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
printf ".\n"
|
printf ".\n"
|
||||||
f__info "raw" "$GREEN""Firefox installé(s): $versionInstall$COLOR"
|
[ "$verLatest" ] || verLatest="$RED""NA"
|
||||||
f__info "version Firefox en ligne:\n Release : $verLatest\n Beta/dev: $verBeta\n Nightly : $verNightly\n ESR : $verEsr"
|
[ "$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
|
# ascii art godzilla; ligne vide finale
|
||||||
|
@ -283,19 +300,20 @@ echo "$COLOR"
|
||||||
}
|
}
|
||||||
|
|
||||||
# installation Firefox, $1 produit, $2 manuel, $3 archive
|
# 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"
|
[ $EUID -eq 0 ] || f__error "vous devez être ROOT pour installer Firefox"
|
||||||
|
local versionArchive dirTemp fileTemp produit
|
||||||
if [ "$2" == "manuel" ]; then
|
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)"
|
f__info "installation manuelle de firefox version $versionArchive ($3)"
|
||||||
local dirTemp="$(dirname $3)/$script-$RANDOM/"
|
dirTemp="$(dirname $3)/$script-$RANDOM/"
|
||||||
local fileTemp="$(basename $3)"
|
fileTemp="$(basename $3)"
|
||||||
mkdir -p "$dirTemp"
|
mkdir -p "$dirTemp"
|
||||||
else
|
else
|
||||||
local produit="$1"
|
produit="$1"
|
||||||
f__info "installation Firefox-$produit"
|
f__info "installation Firefox-$produit"
|
||||||
local dirTemp="/tmp/$script-$RANDOM/"
|
dirTemp="/tmp/$script-$RANDOM/"
|
||||||
local fileTemp="$dirTemp""firefox-$produit.$architecture.tar.bz2"
|
fileTemp="$dirTemp""firefox-$produit.$architecture.tar.bz2"
|
||||||
mkdir -p "$dirTemp"
|
mkdir -p "$dirTemp"
|
||||||
# téléchargement & test archive
|
# téléchargement & test archive
|
||||||
f__info " - téléchargement..."
|
f__info " - téléchargement..."
|
||||||
|
@ -328,13 +346,17 @@ ffx_install(){ #v27/08/2017
|
||||||
ffx_usr_bin
|
ffx_usr_bin
|
||||||
# traitement user
|
# traitement user
|
||||||
ffx_profil_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
|
ffx_godzilla
|
||||||
}
|
}
|
||||||
|
|
||||||
# installation d'un FF chargé manuellement, $1 produit, $2 fichier archive
|
# installation d'un FF chargé manuellement, $1 produit, $2 fichier archive
|
||||||
ffx_install_manuel(){ #v27/08/2017
|
ffx_install_manuel(){ # v30/08/2017
|
||||||
[ -e "$2" ] || f__error "fichier $1 introuvable"
|
[ -e "$2" ] || f__error "fichier $2 introuvable"
|
||||||
f__archive_test "$2" || f__error "Le fichier $2 n'est pas une archive valide"
|
f__archive_test "$2" || f__error "Le fichier $2 n'est pas une archive valide"
|
||||||
ffx_install "$1" "manuel" "$2"
|
ffx_install "$1" "manuel" "$2"
|
||||||
[ -e "$fileDev" ] || rm "$2" &>/dev/null ## on efface pas si fileDev (dev)
|
[ -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
|
# 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"
|
f__requis "wget"
|
||||||
if [ -e "$dirProfil/$produit/personnalisation.$script" ]; then
|
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
|
else
|
||||||
local urlPers="https://framagit.org/kyodev/kyopages/raw/master/scripts/"
|
urlPers="https://framagit.org/kyodev/kyopages/raw/master/scripts/"
|
||||||
fi
|
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
|
if [ "$versionPersOnline" ]; then
|
||||||
local versionPers persEnPlace
|
|
||||||
for prod in latest esr beta dev nightly; do
|
for prod in latest esr beta dev nightly; do
|
||||||
if [ -e "$dirProfil/$prod/personnalisation.$script" ]; then
|
if [ -e "$dirProfil/$prod/personnalisation.$script" ]; then
|
||||||
versionPers="$(sed -n '2p' $dirProfil/$prod/personnalisation.$script)"
|
versionPersInstall="$(sed -n '2p' $dirProfil/$prod/personnalisation.$script)"
|
||||||
if [ "$versionPers" != "$versionPersOnline" ]; then prodATraiter+="$prod "; fi
|
if [ "$versionPersInstall" != "$versionPersOnline" ]; then prodATraiter+="$prod "; fi
|
||||||
persEnPlace+="$prod "
|
persEnPlace+="$prod "
|
||||||
fi
|
fi
|
||||||
done
|
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
|
# recup user.js et chrome/userChrome.css, $1=produit à personnaliser ou mettre à jour
|
||||||
ffx_pers_install(){ #25/08/2017
|
ffx_pers_install(){ # v30/08/2017
|
||||||
local produit="$1"
|
local produit="$1" urlPers versionPersOnline dirTemp
|
||||||
[ ! -d "$dirProfil/$produit" ] && f__error "firefox <$produit> n'est pas installé" "personnalisation abandonnée"
|
[ ! -d "$dirProfil/$produit" ] && return
|
||||||
f__requis "wget"
|
f__requis "wget"
|
||||||
# détermination url chargement fichiers personnalisation, std ou spécifique dans personnalisation.getFirefox
|
# détermination url chargement fichiers personnalisation, std ou spécifique dans personnalisation.getFirefox
|
||||||
if [ -e "$dirProfil/$produit/personnalisation.$script" ]; then
|
if [ -e "$dirProfil/$produit/personnalisation.$script" ]; then
|
||||||
local urlPers="$(head -n1 "$dirProfil/$produit/personnalisation.$script")"
|
urlPers="$(head -n1 "$dirProfil/$produit/personnalisation.$script")"
|
||||||
else
|
else
|
||||||
local urlPers="https://framagit.org/kyodev/kyopages/raw/master/scripts/"
|
urlPers="https://framagit.org/kyodev/kyopages/raw/master/scripts/"
|
||||||
fi
|
fi
|
||||||
# chargement fichiers personnalisation
|
# chargement fichiers personnalisation
|
||||||
local dirTemp="/tmp/$script-$RANDOM/"
|
dirTemp="/tmp/$script-$RANDOM/"
|
||||||
mkdir -p "$dirTemp"
|
mkdir -p "$dirTemp"
|
||||||
wget -q --tries=2 --timeout=15 -O "$dirTemp"user.js "$urlPers"user.js
|
wget -q --tries=2 --timeout=15 -O "$dirTemp"user.js "$urlPers"user.js
|
||||||
if [ "$?" != "0" ]; then f__wget_test "$urlPers"user.js; fi
|
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
|
wget -q --tries=1 --timeout=15 -O "$dirTemp"userChrome.css "$urlPers"userChrome.css
|
||||||
chown -R "$user_": "$dirTemp"
|
chown -R "$user_": "$dirTemp"
|
||||||
# installation
|
# installation
|
||||||
|
@ -416,14 +438,14 @@ ffx_pers_install(){ #25/08/2017
|
||||||
cp "$dirTemp"user.js "$dirProfil/$produit/"
|
cp "$dirTemp"user.js "$dirProfil/$produit/"
|
||||||
[ -e "$dirTemp"userChrome.css ] && cp "$dirTemp"userChrome.css "$dirProfil/$produit/chrome"
|
[ -e "$dirTemp"userChrome.css ] && cp "$dirTemp"userChrome.css "$dirProfil/$produit/chrome"
|
||||||
echo "$urlPers" > "$dirProfil/$produit/personnalisation.$script"
|
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"
|
chown -R "$user_": "$dirProfil/$produit/personnalisation.$script"
|
||||||
rm -rf "$dirTemp"
|
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
|
# maj user.js et chrome/userChrome.css
|
||||||
ffx_pers_upgrade(){ #25/08/2017
|
ffx_pers_upgrade(){ # v25/08/2017
|
||||||
ffx_pers_get_version
|
ffx_pers_get_version
|
||||||
if [ "$prodATraiter" ]; then
|
if [ "$prodATraiter" ]; then
|
||||||
for i in $prodATraiter; do ffx_pers_install "$i"; done
|
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
|
# 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
|
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"
|
f__error "firefox <$produit> n'est pas installé" " il faut donc utiliser l'installation et pas l'ajout d'un nouveau profil"
|
||||||
fi
|
fi
|
||||||
|
@ -481,7 +503,7 @@ ffx_profil_user(){ #22/08/2017
|
||||||
[ "$1" == "user" ] && f__info "log" "profil <$produit> configuré pour $user_"
|
[ "$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(){
|
ffx_recup_url(){
|
||||||
if [ "$produit" == "latest" ]; then
|
if [ "$produit" == "latest" ]; then
|
||||||
recup_url="https://download.mozilla.org/?product=firefox-$produit&os=$architecture&lang=fr"
|
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
|
# 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
|
[ "$(type -t fscript_cronAnacron_special)" ] && fscript_cronAnacron_special # test, si fonction spécifique, appel
|
||||||
local dirAnacron="/home/$user_/.config/anacron"
|
dirAnacron="/home/$user_/.config/anacron"
|
||||||
local dirSpool="$dirAnacron/spool"
|
dirSpool="$dirAnacron/spool"
|
||||||
local fileAnacron="$dirAnacron/$script.anacrontab"
|
fileAnacron="$dirAnacron/$script.anacrontab"
|
||||||
[ $EUID -eq 0 ] && sed -i "/$script.anacrontab/d" /etc/crontab
|
[ $EUID -eq 0 ] && sed -i "/$script.anacrontab/d" /etc/crontab
|
||||||
case "$1" in
|
case "$1" in
|
||||||
install | upgrade )
|
install | upgrade )
|
||||||
|
@ -692,6 +715,7 @@ dirInstall="/opt/usr/share/firefox-"
|
||||||
dirProfil="/home/$user_/.mozilla/firefox"
|
dirProfil="/home/$user_/.mozilla/firefox"
|
||||||
fileProfileIni="$dirProfil/profiles.ini"
|
fileProfileIni="$dirProfil/profiles.ini"
|
||||||
produitAll="latest beta nightly"
|
produitAll="latest beta nightly"
|
||||||
|
dirInstallTB="/opt/usr/share/tor-browser/"
|
||||||
|
|
||||||
ls -d /opt/firefox-* &>/dev/null && problemOldInstall="detected" # ancienne localisation install firefox
|
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)" \
|
[ "$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
|
ffx_get_versionsFF
|
||||||
fscript_get_version
|
fscript_get_version
|
||||||
ffx_pers_get_version
|
ffx_pers_get_version
|
||||||
|
f_tb_get_version
|
||||||
ffx_godzilla
|
ffx_godzilla
|
||||||
exit ;; # affiche versions Firefox en ligne & installées, script et personnalisation
|
exit ;; # affiche versions Firefox en ligne & installées, script et personnalisation
|
||||||
-i )
|
-i )
|
||||||
|
|
|
@ -4,6 +4,14 @@
|
||||||
## todo
|
## todo
|
||||||
* install: copie du profil du canal inférieur?
|
* 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
|
## 2.8.0 30/08/2017
|
||||||
|
|
||||||
* révision conditions d'utilisations, fscript_install, fscript_remove(), fscript_update
|
* révision conditions d'utilisations, fscript_install, fscript_remove(), fscript_update
|
||||||
|
|
Loading…
Reference in New Issue