This commit is contained in:
kyodev 2017-08-17 09:16:48 +02:00
parent 11ff12ddb2
commit 13ead0d139
2 changed files with 34 additions and 16 deletions

View File

@ -1,6 +1,6 @@
#!/bin/bash
version=0.6.0
version=0.7.0
date="17/08/2017"
projet="simpledeb"
contact="IRC freenode ##sdeb ou https://framagit.org/kyodev/kyopages/issues"
@ -13,7 +13,7 @@ urlScript="https://framagit.org/kyodev/kyopages/raw/master/scripts/$script"
#####
# affichage $1 en rouge, $1++ optionnels en bleu, sortie script sur erreur, log $1 si upgrade($opType)
f__error() { # v 16/08/2017
f__error() { # v16/08/2017
echo -e "\n$RED Erreur critique: $1 $COLOR"
for (( i=2 ; i<=$# ; i++ )); do echo -e " $BLUE${!i}"; done
echo "$COLOR"
@ -70,23 +70,27 @@ f__user(){ # v15/08/2017-4
}
# inscription dans tache upgrade en anacron hebdomadaire, via cron horaire
fscript_cronAnacron(){
fscript_cronAnacron(){ # v17/08/2017
local dirAnacron="/home/$user_/.config/anacron"
local dirSpool="$dirAnacron/spool"
local fileAnacron="$dirAnacron/$script.anacrontab"
sed -i "/$script.anacrontab/d" /etc/crontab
sed -i "/$script.anacrontab/d" /etc/crontab
case "$1" in
install )
install | upgrade )
mkdir -p "$dirAnacron"
# table anacron
echo "7 01 $script nice /opt/bin/$script --upgrade" > "$fileAnacron"
## test: anacron journalier: echo "1 01 $script test nice /opt/bin/$script --upgrade 2>/dev/null" >> "$fileAnacron"
## test: anacron journalier: echo "1 01 $script test nice /opt/bin/$script --upgrade" >> "$fileAnacron"
# création spool anacron utilisateur
mkdir -p "$dirSpool"
chown -R "$user_": "$dirAnacron" "$dirSpool"
# crontab pour activation horaire anacron
echo "@hourly $user_ /usr/sbin/anacron -t $fileAnacron -S $dirSpool" >> /etc/crontab
service cron restart &>/dev/null || /etc/init.d/cron restart &>/dev/null || f__info "redémarrer cron ou le PC"
if [ $EUID -eq 0 ]; then
# crontab pour activation horaire anacron
echo "@hourly $user_ /usr/sbin/anacron -t $fileAnacron -S $dirSpool" >> /etc/crontab
service cron restart &>/dev/null || /etc/init.d/cron restart &>/dev/null || f__info "redémarrer cron ou le PC"
fi
[ "$(grep "$script" /etc/crontab)" ] || echo f__error "inscription crontab" \
"certains systèmes semblent poser poser problème, merci de rapporter ce bug à $projet $contact"
;;
remove )
rm "$dirSpool/$script"* &>/dev/null
@ -97,26 +101,27 @@ fscript_cronAnacron(){
esac
}
# mise à jour script si disponible
fscript_dl(){
# mise à jour script si dispo
fscript_dl(){ # v17/08/2017
if [ "$script_aJour" == "ok" ]; then return 0; fi
if ! which wget &>/dev/null; then f__log "wget manquant pour upgrader"; return 1; fi #spécifique getIp
local dirTemp="/tmp/$script-$RANDOM/"
mkdir -p "$dirTemp"
opType="upgrade"
wget -q --show-progress --tries=2 --timeout=15 -O "$dirTemp$script" "$urlScript"
if [ "$?" != "0" ]; then f__error "erreur chargement, réessayer plus tard"; fi #spécifique getIp
if [ "$?" != "0" ]; then f__wget_test "$urlScript"; fi
chmod 755 "$dirTemp$script"
chown "$user_": "$dirTemp$script"
cp -d "$dirTemp$script" /opt/bin/"$script"
rm -rf "$dirTemp"
fscript_cronAnacron "upgrade"
f__info "\n $script mis à jour en version $versionScript"
f__log "$script mis à jour en version $versionScript"
$0 upgrade # spécifique getFlash, script mis à jour, on relance le script en upgrade pour le plugin
exit 0
}
# version script en ligne, assigne $versionScript, $script_aJour=ok|ko
fscript_get_version(){
fscript_get_version(){ # v08/2017
if ! which wget &>/dev/null; then f__info "wget manquant"; return 1; fi #spécifique getIp
versionScript="$(wget -q --tries=2 --timeout=15 -O - "$urlScript" | grep '^version=' | cut -d '=' -f 2)"
if [ "$?" != "0" ]; then f__error "erreur chargement, réessayer plus tard"; fi #spécifique getIp
@ -132,7 +137,7 @@ fscript_get_version(){
}
# installation du script dans le système
fscript_install(){
fscript_install(){ # v08/2017
if ! which wget &>/dev/null; then f__error "wget manquant pour exploiter ce script"; fi #spécifique getIp
if dirname "$0" | grep -q 'bin' ; then
f__info "$script $version est déjà installé"
@ -157,7 +162,7 @@ fscript_install(){
}
# suppression du script dans le système
fscript_remove(){
fscript_remove(){ # v08/2017
[ $EUID -eq 0 ] || f__error "vous devez être ROOT pour supprimer ce script dans le système"
# suppression de /opt
rm /opt/bin/"$script" &>/dev/null

View File

@ -0,0 +1,13 @@
# changelog getIp
## 0.7.0 17/08/2017
* test inscription crontab pour recherche bug siduction
* test crontab et modif anacrontab lors upgrade
## 0.6.0 16/08/2017
* révision et homogénéisation des fonctions de script
* lancement cron restart (bien que inutile?) à l'installation et à la suppression du script
* révision f__user
* révision f__requis