2017-07-24 21:56:37 +11:00
|
|
|
#!/bin/bash
|
|
|
|
#------------------------------------------------------------------------------------------------------------------
|
|
|
|
# Script : sys_refresh_ref_cron.sh
|
|
|
|
# Auteur : Doug Le Tough
|
|
|
|
# Date : 24-07-2017
|
|
|
|
# Version : 1.0.0
|
|
|
|
# Objet : Met à jour le référentiel des jobs cron de l'ensemble de l'infra
|
|
|
|
# accessible par https://ref.tetalab.org
|
|
|
|
#
|
|
|
|
#
|
|
|
|
#------------------------------------------------------------------------------------------------------------------
|
|
|
|
# Mise a jour :
|
|
|
|
#
|
|
|
|
# 1.0.0 22/07/2017 - Doug Le Tough - Cre : Mise en production
|
|
|
|
#
|
|
|
|
#------------------------------------------------------------------------------------------------------------------
|
|
|
|
# Dependances : Aucune
|
|
|
|
#
|
|
|
|
#
|
|
|
|
#------------------------------------------------------------------------------------------------------------------
|
|
|
|
# Liste des options et arguments:
|
|
|
|
#
|
|
|
|
# Ce script n'accepte *aucune* option
|
|
|
|
#
|
2017-07-25 17:56:52 +11:00
|
|
|
# @OPT: f:force:force:1/1:false:::
|
2017-07-24 21:56:37 +11:00
|
|
|
#
|
|
|
|
#------------------------------------------------------------------------------------------------------------------
|
|
|
|
# Liste des erreurs:
|
|
|
|
#
|
|
|
|
# 2 | erreur | stop | ${ERROR}
|
|
|
|
#
|
|
|
|
#------------------------------------------------------------------------------------------------------------------
|
|
|
|
# Liste des paramètres de configuration:
|
|
|
|
#
|
|
|
|
# PGPASSFILE=/home/asr/.pgpass
|
|
|
|
# DB_TABLE=ref_cron
|
|
|
|
# TETALAB_USERS[0]=root
|
|
|
|
# TETALAB_USERS[1]=asr
|
|
|
|
# TETALAB_VM[0]=sousetsuken.local.tetalab.org
|
|
|
|
# TETALAB_VM[1]=jimmy.local.tetalab.org
|
|
|
|
# TETALAB_VM[2]=billy.local.tetalab.org
|
|
|
|
# TETALAB_VM[3]=marian.local.tetalab.org
|
|
|
|
# TETALAB_VM[4]=sonny.local.tetalab.org
|
|
|
|
# TETALAB_VM[5]=web.local.tetalab.org
|
|
|
|
#
|
|
|
|
##------------------------------------------------------------------------------------------------------------------
|
|
|
|
##
|
|
|
|
## Syntaxe :
|
|
|
|
## --------
|
|
|
|
##
|
2017-07-25 17:56:52 +11:00
|
|
|
## prompt> sys_refresh_ref_cron.sh [-force true]
|
2017-07-24 21:56:37 +11:00
|
|
|
##
|
|
|
|
## Prérequis:
|
|
|
|
## ----------
|
|
|
|
## - Le script doit être executé par l'utilisateur asr
|
|
|
|
##
|
|
|
|
## Fonctionnement:
|
|
|
|
## ---------------
|
|
|
|
## Récupère l'ensemble des cronjobs des utilisateurs listés dans TETALAB_USERS
|
|
|
|
## mis en place sur les VM définies dans TETALAB_VM et les enregistre dans la table
|
|
|
|
## DB_TABLE de la base de données "referentiel".
|
|
|
|
##
|
2017-07-25 17:56:52 +11:00
|
|
|
## À moins que l'option -force soit passée à true, le script ne fait qu'ajouter les nouvelles
|
|
|
|
## entrées dans la base. Par défaut cette option est positionnée à false, de ce fait
|
|
|
|
## aucune données n'est supprimée dans la base y compris si le cronjob n'existe plus sur le
|
|
|
|
## système concernée.
|
|
|
|
##
|
|
|
|
## Lorsqu'un cron job est supprimé, forcer une régénération complète des entrées de la base est
|
|
|
|
## donc nécessaire (sys_refresh_ref_cron.sh -force true)
|
|
|
|
##
|
2017-07-24 21:56:37 +11:00
|
|
|
## Les informations de connexion à la base de données doivent être stockées dans
|
|
|
|
## le fichier PGPASSFILE sur sousetsuken au format suivant:
|
|
|
|
##
|
|
|
|
## hostname:port:database:username:password
|
|
|
|
##
|
|
|
|
## https://www.postgresql.org/docs/9.6/static/libpq-pgpass.html
|
|
|
|
##
|
|
|
|
##
|
|
|
|
#------------------------------------------------------------------------------------------------------------------
|
|
|
|
# Initialisation de l'environement
|
|
|
|
#------------------------------------------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
if [ "${USER}" != "asr" ]; then
|
|
|
|
ERROR="Seul l'utilisateur asr peut utiliser ce script"
|
|
|
|
echo -e "\033[91m${ERROR}\033[0m"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
source /etc/profile.d/tetalab.sh
|
|
|
|
|
|
|
|
if [ ! -f ${NC_EXPL_CFG}/init.conf ]; then
|
|
|
|
echo "Le fichier d'initialisation du socle \${NC_EXPL_CFG}/init.conf n'éxiste pas !"
|
|
|
|
echo "Arrêt du script par sécurité"
|
|
|
|
exit 250
|
|
|
|
fi
|
|
|
|
|
|
|
|
source ${NC_EXPL_CFG}/init.conf
|
|
|
|
|
|
|
|
#------------------------------------------------------------------------------------------------------------------
|
|
|
|
# Fonctions
|
|
|
|
#------------------------------------------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
function check_config
|
|
|
|
{
|
|
|
|
fct_message "Vérification de la configuration:" -color jaune
|
|
|
|
if [ ! -r ${SH_FICCFG} ]; then
|
|
|
|
ERROR="Fichier de configuration ${SH_FICCFG} absent ou illisible"
|
|
|
|
fct_erreur 2
|
|
|
|
fi
|
|
|
|
if [ ! -r ${PGPASSFILE} ]; then
|
|
|
|
ERROR="Fichier des informations de connexion ${PGPASSFILE} absent ou illisible"
|
|
|
|
fct_erreur 2
|
|
|
|
fi
|
2017-07-25 17:56:52 +11:00
|
|
|
fct_message " * PGPASSFILE: ${PGPASSFILE}"
|
2017-07-24 21:56:37 +11:00
|
|
|
if [ ${#DB_TABLE} -eq 0 ]; then
|
|
|
|
ERROR="Paramètre manquant ou vide dans le fichier de configuration: DB_TABLE"
|
|
|
|
fct_erreur 2
|
|
|
|
fi
|
2017-07-25 17:56:52 +11:00
|
|
|
fct_message " * DB_TABLE: ${DB_TABLE}"
|
2017-07-25 17:58:00 +11:00
|
|
|
fct_message " * Force: ${force}"
|
2017-07-24 21:56:37 +11:00
|
|
|
if [ ${#TETALAB_USERS[*]} -eq 0 ]; then
|
|
|
|
ERROR="Aucune VM définie dans le fichier de configuration"
|
|
|
|
fct_erreur 2
|
|
|
|
fi
|
|
|
|
INDEX=0
|
|
|
|
for TETALAB_USER in ${TETALAB_USERS[@]}
|
|
|
|
do
|
|
|
|
fct_message " * TETALAB_USERS[${INDEX}]: ${TETALAB_USER}"
|
|
|
|
INDEX=$(( INDEX+1 ))
|
|
|
|
done
|
|
|
|
if [ ${#TETALAB_VM[*]} -eq 0 ]; then
|
|
|
|
ERROR="Aucune VM définie dans le fichier de configuration"
|
|
|
|
fct_erreur 2
|
|
|
|
fi
|
|
|
|
INDEX=0
|
|
|
|
for VM in ${TETALAB_VM[@]}
|
|
|
|
do
|
|
|
|
fct_message " * VM[${INDEX}]: ${VM}"
|
|
|
|
INDEX=$(( INDEX+1 ))
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
2017-07-25 21:20:46 +11:00
|
|
|
function get_db_info
|
|
|
|
{
|
|
|
|
DB_HOST=$(cat ${PGPASSFILE} | cut -d: -f1)
|
|
|
|
DB_DATABASE=$(cat ${PGPASSFILE} | cut -d: -f3)
|
|
|
|
DB_USER=$(cat ${PGPASSFILE} | cut -d: -f4)
|
|
|
|
}
|
|
|
|
|
|
|
|
function refresh_cronjobs
|
2017-07-24 21:56:37 +11:00
|
|
|
{
|
|
|
|
fct_message "Récupération des cronjobs:" -color jaune
|
|
|
|
for VM in ${TETALAB_VM[@]}
|
|
|
|
do
|
|
|
|
fct_message " * ${VM}" -color rose
|
|
|
|
for TETALAB_USER in ${TETALAB_USERS[@]}
|
|
|
|
do
|
|
|
|
fct_message " * ${TETALAB_USER}" -color orange
|
|
|
|
IFS_BAK=${IFS}
|
|
|
|
IFS=$'\n'
|
2017-07-24 22:24:34 +11:00
|
|
|
CRONJOBS=$(ssh ${VM} "sudo crontab -u ${TETALAB_USER} -l 2>&1 | grep -v '^\#' | grep -v '^$' | grep -vP '^ +$'")
|
2017-07-24 22:16:02 +11:00
|
|
|
for CRONJOB in ${CRONJOBS}
|
2017-07-24 21:56:37 +11:00
|
|
|
do
|
2017-07-24 22:32:37 +11:00
|
|
|
COLOR="blanc"
|
|
|
|
MESSAGE=" - ${CRONJOB}"
|
2017-07-24 22:48:43 +11:00
|
|
|
if [ $(echo "${CRONJOB}" | grep "run-parts" | wc -l) -eq 1 ]; then
|
2017-07-24 22:51:07 +11:00
|
|
|
COLOR="vert"
|
2017-07-24 22:48:43 +11:00
|
|
|
elif [ $(echo "${CRONJOB}" | grep "no crontab for" | wc -l) -eq 1 ]; then
|
2017-07-24 22:51:07 +11:00
|
|
|
COLOR="cyan"
|
2017-07-24 22:48:43 +11:00
|
|
|
fi
|
2017-07-24 22:32:37 +11:00
|
|
|
fct_message ${MESSAGE} -color ${COLOR}
|
2017-07-25 21:20:46 +11:00
|
|
|
if [ ${#CRONJOB} -gt 0 ]; then
|
|
|
|
fct_message "Checking database:"
|
|
|
|
CRONJOB="$@"
|
|
|
|
MINUTES=$(echo ${CRONJOB} | cut -d' ' -f1)
|
|
|
|
HOURS=$(echo ${CRONJOB} | cut -d' ' -f2)
|
|
|
|
DAYS=$(echo ${CRONJOB} | cut -d' ' -f3)
|
|
|
|
MONTHS=$(echo ${CRONJOB} | cut -d' ' -f4)
|
|
|
|
DAYOFWEEK=$(echo ${CRONJOB} | cut -d' ' -f5)
|
|
|
|
COMMAND=$(echo ${CRONJOB} | cut -d' ' -f6-)
|
|
|
|
REQUEST_ID_PARAMS="host='${VM}' and s_user='${TETALAB_USER}' and minutes='${MINUTES}'
|
|
|
|
and hours='${HOURS}' and days='${DAYS}' and daysofweek='${DAYSOFWEEKS}' and command='${COMMAND}'"
|
|
|
|
RESULT=$(psql -t -h ${DB_HOST} -U ${DB_USER} -d ${DB_DATABASE} -c "select ID from ref_cron where ${REQUEST_ID_PARAMS};")
|
|
|
|
if [ ${#RESULT} -gt 0 ];
|
|
|
|
fct_message "Cronjob not in database, inserting..."
|
|
|
|
REQUEST_INSERT_PARAMS=$(echo ${REQUEST_ID_PARAMS} | sed -s 's/and/,/g')
|
2017-07-25 21:21:57 +11:00
|
|
|
psql -t -h ${DB_HOST} -U ${DB_USER} -d ${DB_DATABASE} -c "insert in ref_cron values (${REQUEST_INSERT_PARAMS});"
|
2017-07-25 21:20:46 +11:00
|
|
|
else
|
|
|
|
fct_message "Cronjob already in database"
|
|
|
|
fi
|
|
|
|
fi
|
2017-07-24 21:56:37 +11:00
|
|
|
done
|
|
|
|
IFS=${IFS_BAK}
|
|
|
|
done
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
|
|
|
#------------------------------------------------------------------------------------------------------------------
|
|
|
|
# Traitement
|
|
|
|
#------------------------------------------------------------------------------------------------------------------
|
|
|
|
|
2017-07-25 21:20:46 +11:00
|
|
|
DB_HOST=""
|
|
|
|
DB_DATABASE=""
|
|
|
|
DB_USER=""
|
|
|
|
|
2017-07-24 21:56:37 +11:00
|
|
|
check_config
|
2017-07-25 21:20:46 +11:00
|
|
|
get_db_info
|
|
|
|
refresh_cronjobs
|
2017-07-24 21:56:37 +11:00
|
|
|
fct_erreur 0
|