diff --git a/scripts/getIp b/scripts/getIp index 9ffd47f..803ea49 100755 --- a/scripts/getIp +++ b/scripts/getIp @@ -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 diff --git a/scripts/getIp_changelog b/scripts/getIp_changelog index e69de29..63d2b8a 100644 --- a/scripts/getIp_changelog +++ b/scripts/getIp_changelog @@ -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