mirror of https://framagit.org/kyodev/kyopages.git
1.1.1
This commit is contained in:
parent
208ddd025c
commit
8ec37dc5d5
|
@ -1,6 +1,6 @@
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
version=1.1.0
|
version=1.1.1
|
||||||
date="24/07/2017"
|
date="24/07/2017"
|
||||||
projet="simpledebian"
|
projet="simpledebian"
|
||||||
contact="IRC freenode ##sdeb ou https://framagit.org/kyodev/kyopages/issues"
|
contact="IRC freenode ##sdeb ou https://framagit.org/kyodev/kyopages/issues"
|
||||||
|
@ -32,11 +32,10 @@ cat << 'EOF'
|
||||||
| (_| | __/ |_| _| | | | | __/ _| (_) > <
|
| (_| | __/ |_| _| | | | | __/ _| (_) > <
|
||||||
\__, |\___|\__|_| |_|_| \___|_| \___/_/\_\
|
\__, |\___|\__|_| |_|_| \___|_| \___/_/\_\
|
||||||
|___/
|
|___/
|
||||||
|
|
||||||
EOF
|
EOF
|
||||||
echo -e "$YELLOW pour Debian, version $version - $date$COLOR\n"
|
echo -e "$YELLOW version $version - $date$COLOR\n"
|
||||||
|
|
||||||
# détection architecture, assign $architecture : linux|linux64, return 1 si architecture inconnue
|
# détection architecture, assigne $architecture : linux|linux64, return 1 si architecture inconnue
|
||||||
f__architecture(){
|
f__architecture(){
|
||||||
case "$(uname -m)" in
|
case "$(uname -m)" in
|
||||||
amd64 | x86_64 )
|
amd64 | x86_64 )
|
||||||
|
@ -55,9 +54,8 @@ f__architecture(){
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
# user ayant initié la session graphique, assigne $user_
|
# user ayant initié la session graphique, assigne $user_, sortie script sur erreur
|
||||||
# sortie script sur erreur, gestion variable environnement pour personnaliser l'user avec:
|
# gestion variable environnement pour personnaliser l'user avec: USER_INSTALL=user script
|
||||||
# USER_INSTALL=user script
|
|
||||||
f__user(){
|
f__user(){
|
||||||
# user_ via variable en environnement
|
# user_ via variable en environnement
|
||||||
test "$USER_INSTALL" && user_="$USER_INSTALL"
|
test "$USER_INSTALL" && user_="$USER_INSTALL"
|
||||||
|
@ -86,7 +84,7 @@ f__requis(){
|
||||||
[ -z "$testDepends" ] || f__error "Paquets manquants" " Contacter administrateur pour disposer de ces commandes"
|
[ -z "$testDepends" ] || f__error "Paquets manquants" " Contacter administrateur pour disposer de ces commandes"
|
||||||
}
|
}
|
||||||
|
|
||||||
# test wget, $1 url à tester, sortie sur erreur
|
# test wget, $1 url à tester, sortie script sur erreur
|
||||||
f__wget_test(){
|
f__wget_test(){
|
||||||
echo " $1"
|
echo " $1"
|
||||||
wget -Sq --tries=1 --timeout=15 --user-agent="$user_agent" -O /dev/null "$1"
|
wget -Sq --tries=1 --timeout=15 --user-agent="$user_agent" -O /dev/null "$1"
|
||||||
|
@ -130,7 +128,7 @@ fscript_install(){
|
||||||
fi
|
fi
|
||||||
# install /opt
|
# install /opt
|
||||||
mkdir -p /opt/bin/
|
mkdir -p /opt/bin/
|
||||||
ln -s /opt/bin/"$script" /usr/local/bin/"$script" &>/dev/null
|
ln -s "/opt/bin/$script" "/usr/bin/$script" &>/dev/null
|
||||||
cp -d "$(basename $0)" "/opt/bin/$script"
|
cp -d "$(basename $0)" "/opt/bin/$script"
|
||||||
chmod a+rwx "/opt/bin/$script"
|
chmod a+rwx "/opt/bin/$script"
|
||||||
chown "$user_": "/opt/bin/$script"
|
chown "$user_": "/opt/bin/$script"
|
||||||
|
@ -151,14 +149,14 @@ fscript_remove(){
|
||||||
f__root || f__error "vous devez être ROOT pour supprimer ce script dans le système"
|
f__root || f__error "vous devez être ROOT pour supprimer ce script dans le système"
|
||||||
# suppression de /opt
|
# suppression de /opt
|
||||||
rm /opt/bin/"$script" &>/dev/null
|
rm /opt/bin/"$script" &>/dev/null
|
||||||
unlink /usr/local/bin/"$script" &>/dev/null
|
unlink /usr/bin/"$script" &>/dev/null || unlink /usr/local/bin/"$script" &>/dev/null
|
||||||
# cron/anacron remove
|
# cron/anacron remove
|
||||||
fscript_cronAnacron remove
|
fscript_cronAnacron remove
|
||||||
f__info "$GREEN$script supprimé du système."
|
f__info "$GREEN$script supprimé du système."
|
||||||
}
|
}
|
||||||
|
|
||||||
# version script en ligne, assigne $script_aJour=ok|ko,
|
# version script en ligne, assigne $versionScript, $script_aJour=ok|ko
|
||||||
fscript_version(){
|
fscript_get_version(){
|
||||||
versionScript="$(wget -q --tries=2 --timeout=15 --user-agent="$user_agent" -O - "$urlScript" | grep '^version=' | cut -d '=' -f 2)"
|
versionScript="$(wget -q --tries=2 --timeout=15 --user-agent="$user_agent" -O - "$urlScript" | grep '^version=' | cut -d '=' -f 2)"
|
||||||
if [ "$version" != "$versionScript" ]; then
|
if [ "$version" != "$versionScript" ]; then
|
||||||
f__info "version script en ligne: $versionScript, mise à jour possible"
|
f__info "version script en ligne: $versionScript, mise à jour possible"
|
||||||
|
@ -169,7 +167,7 @@ fscript_version(){
|
||||||
# mise à jour script si dispo
|
# mise à jour script si dispo
|
||||||
fscript_dl(){
|
fscript_dl(){
|
||||||
if [ "$script_aJour" == "ok" ]; then return 0; fi
|
if [ "$script_aJour" == "ok" ]; then return 0; fi
|
||||||
dirTemp="/tmp/$script-$RANDOM/"
|
local dirTemp="/tmp/$script-$RANDOM/"
|
||||||
mkdir -p "$dirTemp"
|
mkdir -p "$dirTemp"
|
||||||
wget -q --show-progress --tries=2 --timeout=15 --user-agent="$user_agent" -O "$dirTemp$script" "$urlScript"
|
wget -q --show-progress --tries=2 --timeout=15 --user-agent="$user_agent" -O "$dirTemp$script" "$urlScript"
|
||||||
if [ "$?" != "0" ]; then f__wget_test "$urlScript"; fi
|
if [ "$?" != "0" ]; then f__wget_test "$urlScript"; fi
|
||||||
|
@ -260,21 +258,26 @@ echo -e "plus d'infos:$GREEN https://framagit.org/kyodev/kyopages/raw/master/scr
|
||||||
}
|
}
|
||||||
|
|
||||||
# version Firefox en ligne
|
# version Firefox en ligne
|
||||||
ffx_versionsFF(){
|
ffx_get_versionsFF(){
|
||||||
stockageUrlOnline="$(wget -q --tries=2 --timeout=15 --user-agent=$user_agent -O - https://www.mozilla.org/en-US/firefox/notes/)"
|
printf "."
|
||||||
verLatest="$(echo $stockageUrlOnline | grep -Eo 'data-latest-firefox="[0-9\.]+"' | grep -Eo '[0-9\.]+')"
|
local fileTmp="/tmp/getFirefox-wgetVer-$RANDOM"
|
||||||
verEsr="$(echo $stockageUrlOnline | grep -Eo 'data-esr-versions="[0-9\.]+"' | grep -Eo '[0-9\.]+')"
|
local recup_url="https://www.mozilla.org/en-US/firefox/notes/"
|
||||||
fileTmp="sdxfcggbjkl-$RANDOM"
|
wget -q --tries=2 --timeout=15 --user-agent=$user_agent -O - "$recup_url" &>"$fileTmp"
|
||||||
recup_url="https://download.mozilla.org/?product=firefox-beta-latest&os=linux64&lang=fr"
|
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"
|
wget -Sq --tries=1 --timeout=10 --user-agent="$user_agent" --spider --save-headers "$recup_url" &>"$fileTmp"
|
||||||
verBeta="$(grep -i 'location' $fileTmp | sed -E 's/.*firefox-(.*)\.tar.bz2/\1/')"
|
local verBeta="$(grep -i 'location' $fileTmp | sed -E 's/.*firefox-(.*)\.tar.bz2/\1/')"
|
||||||
recup_url="https://download.mozilla.org/?product=firefox-nightly-latest-l10n-ssl&os=linux64&lang=fr"
|
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"
|
wget -Sq --tries=1 --timeout=10 --user-agent="$user_agent" --spider --save-headers "$recup_url" &>"$fileTmp"
|
||||||
verNightly="$(grep -i 'location' $fileTmp | sed -E 's/.*firefox-(.*)\.fr.linux.*/\1/')"
|
local verNightly="$(grep -i 'location' $fileTmp | sed -E 's/.*firefox-(.*)\.fr.linux.*/\1/')"
|
||||||
|
printf ".\n"
|
||||||
rm "$fileTmp"
|
rm "$fileTmp"
|
||||||
for product in latest esr beta dev nightly; do
|
for prod in latest esr beta dev nightly; do
|
||||||
if [ -x "$dirInstall$product/firefox" ]; then
|
if [ -x "$dirInstall$prod/firefox" ]; then
|
||||||
versionInstall+="\n $product: $($dirInstall$product/firefox -v | grep -Eo '[0-9].*')"
|
versionInstall+="\n $prod: $($dirInstall$prod/firefox -v | grep -Eo '[0-9].*')"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
f__info "Firefox installé(s): $versionInstall"
|
f__info "Firefox installé(s): $versionInstall"
|
||||||
|
@ -283,16 +286,16 @@ ffx_versionsFF(){
|
||||||
|
|
||||||
# création lanceur.desktop
|
# création lanceur.desktop
|
||||||
ffx_lanceur_desktop(){
|
ffx_lanceur_desktop(){
|
||||||
fileDesktop="/usr/share/applications/firefox-$product.desktop"
|
local fileDesktop="/usr/share/applications/firefox-$product.desktop"
|
||||||
echo "#!/usr/bin/env xdg-open" > "$fileDesktop"
|
echo "#!/usr/bin/env xdg-open" > "$fileDesktop"
|
||||||
echo "[Desktop Entry]" >> "$fileDesktop"
|
echo "[Desktop Entry]" >> "$fileDesktop"
|
||||||
echo "Name=Firefox $product" >> "$fileDesktop"
|
echo "Name=Firefox $produit" >> "$fileDesktop"
|
||||||
echo "Name[fr]=Firefox $product" >> "$fileDesktop"
|
echo "Name[fr]=Firefox $produit" >> "$fileDesktop"
|
||||||
echo "X-GNOME-FullName=Firefox-$product Web Browser" >> "$fileDesktop"
|
echo "X-GNOME-FullName=Firefox-$produit Web Browser" >> "$fileDesktop"
|
||||||
echo "X-GNOME-FullName[fr]=Firefox-$product Navigateur Web" >> "$fileDesktop"
|
echo "X-GNOME-FullName[fr]=Firefox-$produit Navigateur Web" >> "$fileDesktop"
|
||||||
echo "StartupWMClass=Firefox-$product" >> "$fileDesktop"
|
echo "StartupWMClass=Firefox-$produit" >> "$fileDesktop"
|
||||||
echo "Exec=/usr/bin/firefox-$product %u" >> "$fileDesktop"
|
echo "Exec=/usr/bin/firefox-$produit %u" >> "$fileDesktop"
|
||||||
echo "Icon=$dirInstall$product/browser/icons/mozicon128.png" >> "$fileDesktop"
|
echo "Icon=$dirInstall$produit/browser/icons/mozicon128.png" >> "$fileDesktop"
|
||||||
echo "Comment=Browse the World Wide Web" >> "$fileDesktop"
|
echo "Comment=Browse the World Wide Web" >> "$fileDesktop"
|
||||||
echo "Comment[fr]=Naviguer sur Internet" >> "$fileDesktop"
|
echo "Comment[fr]=Naviguer sur Internet" >> "$fileDesktop"
|
||||||
echo "GenericName=Web Browser" >> "$fileDesktop"
|
echo "GenericName=Web Browser" >> "$fileDesktop"
|
||||||
|
@ -308,38 +311,37 @@ ffx_lanceur_desktop(){
|
||||||
# traitement de profile.ini, inscription si pas déjà existante
|
# traitement de profile.ini, inscription si pas déjà existante
|
||||||
ffx_profilIni_inscription(){
|
ffx_profilIni_inscription(){
|
||||||
# si déjà profil existant dans profil.ini, sortir
|
# si déjà profil existant dans profil.ini, sortir
|
||||||
if [ "$(grep -c Name=$product $fileProfileIni)" != 0 ]; then return; fi
|
if [ "$(grep -c Name=$produit $fileProfileIni)" != 0 ]; then return; fi
|
||||||
# comptage profils existants
|
# comptage profils existants
|
||||||
nbProfiles="$(grep -Ec '\[Profile[0-9]+\]' $fileProfileIni)"
|
local nbProfiles="$(grep -Ec '\[Profile[0-9]+\]' $fileProfileIni)"
|
||||||
# création profil dans profile.ini
|
# création profil dans profile.ini
|
||||||
echo "" >> "$fileProfileIni"
|
echo "" >> "$fileProfileIni"
|
||||||
echo "[Profile$nbProfiles]" >> "$fileProfileIni"
|
echo "[Profile$nbProfiles]" >> "$fileProfileIni"
|
||||||
echo "Name=$product" >> "$fileProfileIni"
|
echo "Name=$produit" >> "$fileProfileIni"
|
||||||
echo "IsRelative=1" >> "$fileProfileIni"
|
echo "IsRelative=1" >> "$fileProfileIni"
|
||||||
echo "Path=$product" >> "$fileProfileIni"
|
echo "Path=$produit" >> "$fileProfileIni"
|
||||||
# si existant et latest (ou esr), supprimer Default=1 et attribuer à latest, dans profile.ini
|
# si latest ou esr, attribuer Default=1
|
||||||
if [ "$product" == "latest" ] || [ "$product" == "esr" ]; then
|
if [ "$produit" == "latest" ] || [ "$produit" == "esr" ]; then
|
||||||
sed -i 's/Default=1//' "$fileProfileIni"
|
sed -i 's/Default=1//' "$fileProfileIni"
|
||||||
echo "Default=1" >> "$fileProfileIni"
|
echo "Default=1" >> "$fileProfileIni"
|
||||||
else echo "" >> "$fileProfileIni"; fi
|
else echo "" >> "$fileProfileIni"; fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# détermination canal bas Firefox installé, assigne $firefoxCanalBas
|
# détermination canal bas Firefox installé, assigne $firefoxCanalBas
|
||||||
ffx_canal_bas(){
|
ffx_get_canalBas(){
|
||||||
for i in nightly dev beta esr latest; do
|
for ii in nightly dev beta esr latest; do
|
||||||
if [ -d "$dirInstall$i/" ]; then firefoxCanalBas="$i"; fi
|
if [ -d "$dirInstall$ii/" ]; then firefoxCanalBas="$ii"; fi
|
||||||
done
|
done
|
||||||
[ "$firefoxCanalBas" ] || return 1
|
[ "$firefoxCanalBas" ] || return 1
|
||||||
f__info " - plus aucun canal Firefox installé"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
# traitement update-alternatives
|
# traitement update-alternatives
|
||||||
ffx_update_alternatives(){
|
ffx_update_alternatives(){
|
||||||
which update-alternatives &>/dev/null || return 0 # update-alternatives n'est pas sur cette distrib
|
which update-alternatives &>/dev/null || return 0 # update-alternatives n'est pas sur cette distrib
|
||||||
if ffx_canal_bas ; then
|
if ffx_get_canalBas ; then
|
||||||
update-alternatives --quiet --install /usr/bin/firefox x-www-browser "/usr/bin/firefox-$firefoxCanalBas" 100
|
update-alternatives --quiet --install /usr/bin/firefox x-www-browser "/usr/bin/firefox-$firefoxCanalBas" 100
|
||||||
f__info " - alternatives installées pour <$firefoxCanalBas>"
|
f__info " - alternatives installées pour <$firefoxCanalBas>"
|
||||||
else # plus aucun canal installé
|
else # plus aucun canal installé, on efface
|
||||||
if update-alternatives --get-selections | grep firefox | grep x-www-browser &>/dev/null; then
|
if update-alternatives --get-selections | grep firefox | grep x-www-browser &>/dev/null; then
|
||||||
update-alternatives --quiet --remove-all x-www-browser
|
update-alternatives --quiet --remove-all x-www-browser
|
||||||
fi
|
fi
|
||||||
|
@ -348,67 +350,66 @@ ffx_update_alternatives(){
|
||||||
|
|
||||||
# lien /usr/bin/firefox pour le plus bas canal Firefox installé, utile si update-alternatives pas fonctionnel
|
# lien /usr/bin/firefox pour le plus bas canal Firefox installé, utile si update-alternatives pas fonctionnel
|
||||||
ffx_usr_bin(){
|
ffx_usr_bin(){
|
||||||
if ffx_canal_bas ; then
|
if ffx_get_canalBas ; then
|
||||||
ln -sf "/usr/bin/firefox-$firefoxCanalBas" "/usr/bin/firefox"
|
ln -sf "/usr/bin/firefox-$firefoxCanalBas" "/usr/bin/firefox"
|
||||||
|
f__info " - firefox lié à firefox-$firefoxCanalBas"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# traitement utilisateur, $1 user, si appel indépendant pour reconfiguration
|
# traitement utilisateur, $1 user si appel indépendant pour reconfiguration
|
||||||
ffx_profil_User(){
|
ffx_profil_user(){
|
||||||
if [ "$1" == "user" ] && [ ! -x "/usr/bin/firefox-$product" ]; then
|
if [ "$1" == "user" ] && [ ! -x "/usr/bin/firefox-$produit" ]; then
|
||||||
f__error "firefox <$product> 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
|
||||||
# si profile.ini existe on traite default sinon on le crée avec minimum d'entête (première installation Firefox)
|
if [ -w "$fileProfileIni" ]; then # si profile.ini existe et rw, on traite default
|
||||||
if [ -w "$fileProfileIni" ]; then
|
|
||||||
# recherche éventuel profil tuvwxyz.default dans profile.ini
|
# recherche éventuel profil tuvwxyz.default dans profile.ini
|
||||||
profileDefault="$(grep '\.default' $fileProfileIni | sed 's/Path=//')"
|
local profileDefault="$(grep '\.default' $fileProfileIni | sed 's/Path=//')"
|
||||||
# si profileDefault existant, on l'utilise pour latest (ou esr) si pas déjà présent
|
# si profileDefault existant, on l'utilise pour latest (ou esr) si pas déjà présent
|
||||||
if [ "$profileDefault" ] && [ -d "$dirProfil/$profileDefault" ] && [ "$product" == "latest" ] || [ "$product" == "esr" ]; then
|
if [ "$profileDefault" ] && [ -d "$dirProfil/$profileDefault" ] && [ "$produit" == "latest" ] || [ "$produit" == "esr" ]; then
|
||||||
if [ ! -d "$dirProfil/$product" ]; then # le profil cible n'existe pas
|
if [ ! -d "$dirProfil/$produit" ]; then # le profil cible n'existe pas
|
||||||
f__info " - récupération du profil default existant <$profileDefault>"
|
f__info " - récupération du profil default existant <$profileDefault>"
|
||||||
mkdir -p "$dirProfil/$product"
|
mkdir -p "$dirProfil/$produit"
|
||||||
cp -R "$dirProfil/$profileDefault"/* "$dirProfil/$product/"
|
cp -R "$dirProfil/$profileDefault"/* "$dirProfil/$produit/"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
else
|
else # sinon on crée profile.ini avec minimum d'entête (première installation Firefox)
|
||||||
echo -e "[General]\nStartWithLastProfile=1\n\n" >> "$fileProfileIni"
|
echo -e "[General]\nStartWithLastProfile=1\n\n" >> "$fileProfileIni"
|
||||||
chown "$user_": "$fileProfileIni" # propriété 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
|
chmod u+rw,go+r "$fileProfileIni" # permissions du fichier profile.ini à l'user
|
||||||
fi
|
fi
|
||||||
mkdir -p "$dirProfil/$product"
|
mkdir -p "$dirProfil/$produit" # répertoire du profil
|
||||||
chown -R "$user_": "$dirProfil/$product/" # propriété du répertoire profile à l'user
|
chown -R "$user_": "$dirProfil/$produit/" # propriété du répertoire profil à l'user
|
||||||
chmod g-rx,o-rx "$dirProfil/$product/" # droits répertoire comme Firefox officiel
|
chmod g-rx,o-rx "$dirProfil/$produit/" # droits répertoire comme Firefox officiel
|
||||||
ffx_profilIni_inscription
|
ffx_profilIni_inscription
|
||||||
ffx_lanceur_desktop
|
ffx_lanceur_desktop
|
||||||
ffx_update_alternatives
|
ffx_update_alternatives
|
||||||
if [ "$1" == "user" ]; then f__info " - profil <$product> configuré pour $user_"; fi
|
if [ "$1" == "user" ]; then f__info " - profil <$produit> configuré pour $user_"; fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# calcul url téléchargement, assigne $recup_url. fixer url pour beta et nightly dans ffx_versionsFF
|
# calcul url téléchargement, assigne $recup_url. fixer url pour beta et nightly dans ffx_get_versionsFF
|
||||||
ffx_recup_url(){
|
ffx_recup_url(){
|
||||||
if [ "$product" == "latest" ]; then
|
if [ "$produit" == "latest" ]; then
|
||||||
recup_url="https://download.mozilla.org/?product=firefox-$product&os=$architecture&lang=fr"
|
recup_url="https://download.mozilla.org/?product=firefox-$produit&os=$architecture&lang=fr"
|
||||||
elif [ "$product" == "esr" ]; then
|
elif [ "$produit" == "esr" ]; then
|
||||||
recup_url="https://download.mozilla.org/?product=firefox-$product-latest&os=$architecture&lang=fr"
|
recup_url="https://download.mozilla.org/?product=firefox-$produit-latest&os=$architecture&lang=fr"
|
||||||
elif [ "$product" == "beta" ]; then
|
elif [ "$produit" == "beta" ]; then
|
||||||
recup_url="https://download.mozilla.org/?product=firefox-beta-latest&os=$architecture&lang=fr"
|
recup_url="https://download.mozilla.org/?product=firefox-$produit-latest&os=$architecture&lang=fr"
|
||||||
elif [ "$product" == "dev" ]; then
|
elif [ "$produit" == "dev" ]; then
|
||||||
recup_url="https://download.mozilla.org/?product=firefox-devedition-latest-ssl&os=$architecture&lang=fr"
|
recup_url="https://download.mozilla.org/?product=firefox-devedition-latest-ssl&os=$architecture&lang=fr"
|
||||||
elif [ "$product" == "nightly" ]; then
|
elif [ "$produit" == "nightly" ]; then
|
||||||
recup_url="https://download.mozilla.org/?product=firefox-$product-latest-l10n-ssl&os=$architecture&lang=fr" ;fi
|
recup_url="https://download.mozilla.org/?product=firefox-$produit-latest-l10n-ssl&os=$architecture&lang=fr" ;fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# installation Firefox
|
# installation Firefox
|
||||||
ffx_install(){
|
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
|
ffx_godzilla
|
||||||
f__info " - installation Firefox-$product"
|
f__info " - installation Firefox-$produit"
|
||||||
# dossier temporaire de travail
|
local dirTemp="/tmp/$script-$RANDOM/"
|
||||||
dirTemp="/tmp/$script-$RANDOM/"
|
local file="firefox-$produit.$architecture.tar.bz2"
|
||||||
mkdir -p "$dirTemp"
|
mkdir -p "$dirTemp" # dossier temporaire de travail
|
||||||
# téléchargement & test archive
|
# téléchargement & test archive
|
||||||
f__info " - téléchargement..."
|
f__info " - téléchargement..."
|
||||||
file="firefox-$product.$architecture.tar.bz2"
|
|
||||||
ffx_recup_url
|
ffx_recup_url
|
||||||
wget -q -c --show-progress --tries=2 --timeout=15 --user-agent="$user_agent" -O "$dirTemp$file" "$recup_url"
|
wget -q -c --show-progress --tries=2 --timeout=15 --user-agent="$user_agent" -O "$dirTemp$file" "$recup_url"
|
||||||
if [ "$?" != "0" ]; then f__wget_test "$recup_url"; fi
|
if [ "$?" != "0" ]; then f__wget_test "$recup_url"; fi
|
||||||
|
@ -418,53 +419,53 @@ ffx_install(){
|
||||||
tar -xaf "$dirTemp$file" -C "$dirTemp"
|
tar -xaf "$dirTemp$file" -C "$dirTemp"
|
||||||
# mise en place finale
|
# mise en place finale
|
||||||
f__info " - installation..."
|
f__info " - installation..."
|
||||||
rm -rf "$dirInstall$product"/ # effacement éventuel répertoire existant: "vraie" install
|
rm -rf "$dirInstall$produit"/ # effacement éventuel répertoire existant: "vraie" install
|
||||||
mkdir -p "$dirInstall$product"/
|
mkdir -p "$dirInstall$produit"/
|
||||||
mv -f "$dirTemp"firefox/* "$dirInstall$product"/
|
mv -f "$dirTemp"firefox/* "$dirInstall$produit"/
|
||||||
chown -R "$user_": "$dirInstall$product"/
|
chown -R "$user_": "$dirInstall$produit"/
|
||||||
chmod -R g+wrs,a+r "$dirInstall$product"/
|
chmod -R g+wrs,a+r "$dirInstall$produit"/
|
||||||
rm -rf "$dirTemp"
|
rm -rf "$dirTemp"
|
||||||
# lien icône Firefox
|
# lien icône Firefox
|
||||||
ln -sf "$dirInstall$product/browser/chrome/icons/default/default48.png" "/usr/share/pixmaps/firefox-$product.png"
|
ln -sf "$dirInstall$produit/browser/chrome/icons/default/default48.png" "/usr/share/pixmaps/firefox-$produit.png"
|
||||||
# lanceur dans /usr/bin
|
# lanceur dans /usr/bin
|
||||||
echo "#!/bin/sh" > "/usr/bin/firefox-$product"
|
echo "#!/bin/sh" > "/usr/bin/firefox-$produit"
|
||||||
echo "exec $dirInstall$product/firefox -P $product" "\$@" >> "/usr/bin/firefox-$product"
|
echo "exec $dirInstall$produit/firefox -P $produit" "\$@" >> "/usr/bin/firefox-$produit"
|
||||||
chmod a+x "/usr/bin/firefox-$product"
|
chmod a+x "/usr/bin/firefox-$produit"
|
||||||
ffx_usr_bin
|
ffx_usr_bin
|
||||||
# traitement user
|
# traitement user
|
||||||
ffx_profil_User
|
ffx_profil_user
|
||||||
f__info "$GREEN""Firefox-$product installé."
|
f__info "$GREEN""Firefox-$produit installé."
|
||||||
}
|
}
|
||||||
|
|
||||||
# désinstallation de Firefox
|
# désinstallation de Firefox
|
||||||
ffx_remove(){
|
ffx_remove(){
|
||||||
f__root || f__error "vous devez être ROOT pour désinstaller"
|
f__root || f__error "vous devez être ROOT pour désinstaller"
|
||||||
ffx_godzilla
|
ffx_godzilla
|
||||||
killall "/opt/usr/share/firefox-$product/firefox" &>/dev/null
|
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
|
# si pas de lanceur desktop, on considère que ce canal Firefox n'est pas installé, retour
|
||||||
if [ ! -e "/usr/share/applications/firefox-$product.desktop" ]; then # si test répertoire, on détecterait pas l'ancien répertoire éventuel
|
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-$product n'est pas installé."
|
f__info "$GREEN""Firefox-$produit n'est pas installé."
|
||||||
return 0
|
return 0
|
||||||
fi
|
fi
|
||||||
# suppression du répertoire Firefox
|
# suppression du répertoire Firefox
|
||||||
if [ -d "/opt/firefox-$product/" ]; then rm -rf "/opt/firefox-$product/"; fi # ancien répertoire éventuel
|
if [ -d "/opt/firefox-$produit/" ]; then rm -rf "/opt/firefox-$produit/"; fi # ancien répertoire éventuel
|
||||||
if [ -d "$dirInstall$product/" ]; then rm -rf "$dirInstall$product/"; fi
|
if [ -d "$dirInstall$produit/" ]; then rm -rf "$dirInstall$produit/"; fi
|
||||||
# suppression lanceurs
|
# suppression lanceurs
|
||||||
rm -f "/usr/share/applications/firefox-$product.desktop"
|
rm -f "/usr/share/applications/firefox-$produit.desktop"
|
||||||
rm -f "/usr/bin/firefox-$product"
|
rm -f "/usr/bin/firefox-$produit"
|
||||||
# suppression des liens
|
# suppression des liens
|
||||||
unlink "/usr/share/pixmaps/firefox-$product.png" &>/dev/null
|
unlink "/usr/share/pixmaps/firefox-$produit.png" &>/dev/null
|
||||||
unlink "/usr/bin/firefox-$product" &>/dev/null
|
unlink "/usr/bin/firefox-$produit" &>/dev/null
|
||||||
# recréation lanceur Firefox & update-alternatives
|
# recréation lanceur Firefox & update-alternatives
|
||||||
ffx_usr_bin
|
ffx_usr_bin
|
||||||
ffx_update_alternatives
|
ffx_update_alternatives
|
||||||
f__info "$GREEN""Firefox-$product désinstallé."
|
f__info "$GREEN""Firefox-$produit désinstallé."
|
||||||
}
|
}
|
||||||
|
|
||||||
# initialisation
|
# initialisation
|
||||||
f__architecture || f__error "Architecture non supportée"
|
f__architecture || f__error "Architecture non supportée"
|
||||||
f__user
|
f__user
|
||||||
f__requis "wget logger file tar logger"
|
f__requis "wget logger file tar logger killall"
|
||||||
dirInstall="/opt/usr/share/firefox-"
|
dirInstall="/opt/usr/share/firefox-"
|
||||||
dirProfil="/home/$user_/.mozilla/firefox"
|
dirProfil="/home/$user_/.mozilla/firefox"
|
||||||
fileProfileIni="$dirProfil/profiles.ini"
|
fileProfileIni="$dirProfil/profiles.ini"
|
||||||
|
@ -483,24 +484,24 @@ case "$1" in
|
||||||
sysremove )
|
sysremove )
|
||||||
fscript_remove ;; # désinstallation du script
|
fscript_remove ;; # désinstallation du script
|
||||||
version | -v | --version | -version )
|
version | -v | --version | -version )
|
||||||
ffx_versionsFF
|
ffx_get_versionsFF
|
||||||
fscript_version
|
fscript_get_version
|
||||||
ffx_godzilla ;; # affiche versions Firefox en ligne & installées & version script
|
ffx_godzilla ;; # affiche versions Firefox en ligne & installées & version script
|
||||||
upgrade )
|
upgrade )
|
||||||
opType="upgrade"
|
opType="upgrade"
|
||||||
fscript_version
|
fscript_get_version
|
||||||
fscript_dl ;; # upgrade script si maj possible
|
fscript_dl ;; # upgrade script si maj possible
|
||||||
i-latest | i-esr | i-dev | i-beta | i-nightly | \
|
i-latest | i-esr | i-dev | i-beta | i-nightly | \
|
||||||
+latest | +esr | +dev | +beta | +nightly )
|
+latest | +esr | +dev | +beta | +nightly )
|
||||||
product="$(echo $1 | sed 's/i-//' | sed 's/+//')"
|
produit="$(echo $1 | sed 's/i-//' | sed 's/+//')"
|
||||||
ffx_install ;; # install: installation canal Firefox
|
ffx_install ;; # install: installation canal Firefox
|
||||||
r-latest | r-esr | r-dev | r-beta | r-nightly | \
|
r-latest | r-esr | r-dev | r-beta | r-nightly | \
|
||||||
-latest | -esr | -dev | -beta | -nightly )
|
-latest | -esr | -dev | -beta | -nightly )
|
||||||
product="$(echo $1 | sed 's/r-//' | sed 's/-//' )"
|
produit="$(echo $1 | sed 's/r-//' | sed 's/-//' )"
|
||||||
ffx_remove ;; # remove: désinstallation Firefox
|
ffx_remove ;; # remove: désinstallation Firefox
|
||||||
u-latest | u-esr | u-dev | u-beta | u-nightly )
|
u-latest | u-esr | u-dev | u-beta | u-nightly )
|
||||||
product="$(echo $1 | sed 's/u-//')"
|
produit="$(echo $1 | sed 's/u-//')"
|
||||||
ffx_profil_User "user" ;; # user: profil pour utilisateur en cours ou reconfiguration
|
ffx_profil_user "user" ;; # user: profil pour utilisateur en cours ou reconfiguration
|
||||||
* )
|
* )
|
||||||
ffx_help ;; # affichage help par défaut
|
ffx_help ;; # affichage help par défaut
|
||||||
esac
|
esac
|
||||||
|
|
|
@ -2,10 +2,13 @@
|
||||||
|
|
||||||
|
|
||||||
## todo
|
## todo
|
||||||
|
|
||||||
* install: copie du profil du canal inférieur?
|
* install: copie du profil du canal inférieur?
|
||||||
|
|
||||||
|
## 1.1.1 26/07/2017
|
||||||
|
|
||||||
|
* dépendance killall
|
||||||
|
* replacement lien script dans /usr/bin/ (meilleure compat?)
|
||||||
|
* lifting
|
||||||
|
|
||||||
## 1.1.0 24/07/2017
|
## 1.1.0 24/07/2017
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue