mirror of https://framagit.org/kyodev/kyopages.git
0.7.0
This commit is contained in:
parent
11ff12ddb2
commit
13ead0d139
|
@ -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
|
||||||
|
|
|
@ -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
|
Loading…
Reference in New Issue