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 #!/bin/bash
version=0.6.0 version=0.7.0
date="17/08/2017" date="17/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"
@ -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) # 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" echo -e "\n$RED Erreur critique: $1 $COLOR"
for (( i=2 ; i<=$# ; i++ )); do echo -e " $BLUE${!i}"; done for (( i=2 ; i<=$# ; i++ )); do echo -e " $BLUE${!i}"; done
echo "$COLOR" echo "$COLOR"
@ -70,23 +70,27 @@ f__user(){ # v15/08/2017-4
} }
# inscription dans tache upgrade en anacron hebdomadaire, via cron horaire # inscription dans tache upgrade en anacron hebdomadaire, via cron horaire
fscript_cronAnacron(){ fscript_cronAnacron(){ # v17/08/2017
local dirAnacron="/home/$user_/.config/anacron" local dirAnacron="/home/$user_/.config/anacron"
local dirSpool="$dirAnacron/spool" local dirSpool="$dirAnacron/spool"
local fileAnacron="$dirAnacron/$script.anacrontab" local fileAnacron="$dirAnacron/$script.anacrontab"
sed -i "/$script.anacrontab/d" /etc/crontab sed -i "/$script.anacrontab/d" /etc/crontab
case "$1" in case "$1" in
install ) install | upgrade )
mkdir -p "$dirAnacron" mkdir -p "$dirAnacron"
# table anacron # table anacron
echo "7 01 $script nice /opt/bin/$script --upgrade" > "$fileAnacron" 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 # création spool anacron utilisateur
mkdir -p "$dirSpool" mkdir -p "$dirSpool"
chown -R "$user_": "$dirAnacron" "$dirSpool" chown -R "$user_": "$dirAnacron" "$dirSpool"
# crontab pour activation horaire anacron if [ $EUID -eq 0 ]; then
echo "@hourly $user_ /usr/sbin/anacron -t $fileAnacron -S $dirSpool" >> /etc/crontab # crontab pour activation horaire anacron
service cron restart &>/dev/null || /etc/init.d/cron restart &>/dev/null || f__info "redémarrer cron ou le PC" 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 ) remove )
rm "$dirSpool/$script"* &>/dev/null rm "$dirSpool/$script"* &>/dev/null
@ -97,26 +101,27 @@ fscript_cronAnacron(){
esac esac
} }
# mise à jour script si disponible # mise à jour script si dispo
fscript_dl(){ fscript_dl(){ # v17/08/2017
if [ "$script_aJour" == "ok" ]; then return 0; fi 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/" local dirTemp="/tmp/$script-$RANDOM/"
mkdir -p "$dirTemp" mkdir -p "$dirTemp"
opType="upgrade" opType="upgrade"
wget -q --show-progress --tries=2 --timeout=15 -O "$dirTemp$script" "$urlScript" 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" chmod 755 "$dirTemp$script"
chown "$user_": "$dirTemp$script" chown "$user_": "$dirTemp$script"
cp -d "$dirTemp$script" /opt/bin/"$script" cp -d "$dirTemp$script" /opt/bin/"$script"
rm -rf "$dirTemp" rm -rf "$dirTemp"
fscript_cronAnacron "upgrade"
f__info "\n $script mis à jour en version $versionScript" f__info "\n $script mis à jour en version $versionScript"
f__log "$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 exit 0
} }
# version script en ligne, assigne $versionScript, $script_aJour=ok|ko # 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 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)" 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 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 # 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 ! which wget &>/dev/null; then f__error "wget manquant pour exploiter ce script"; fi #spécifique getIp
if dirname "$0" | grep -q 'bin' ; then if dirname "$0" | grep -q 'bin' ; then
f__info "$script $version est déjà installé" f__info "$script $version est déjà installé"
@ -157,7 +162,7 @@ fscript_install(){
} }
# suppression du script dans le système # 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" [ $EUID -eq 0 ] || 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

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