fix : discord message
This commit is contained in:
@@ -17,6 +17,14 @@ APP_URLS
|
|||||||
Ajouter dans le fichier /CheckStorage/.env
|
Ajouter dans le fichier /CheckStorage/.env
|
||||||
WEBHOOK_URL
|
WEBHOOK_URL
|
||||||
|
|
||||||
|
Ajouter dans le fichier /BackupVaultWarden/.env
|
||||||
|
DATA_DIR
|
||||||
|
LOCAL_BACKUP
|
||||||
|
REMOTE_USER
|
||||||
|
REMOTE_HOST
|
||||||
|
REMOTE_DIR
|
||||||
|
SSH_KEY
|
||||||
|
|
||||||
### Added
|
### Added
|
||||||
* [#361] Script dump BDD
|
* [#361] Script dump BDD
|
||||||
* [#367] Avoir une notification discord quand les backup sont faites
|
* [#367] Avoir une notification discord quand les backup sont faites
|
||||||
|
|||||||
@@ -18,8 +18,11 @@ set -euo pipefail
|
|||||||
# 7. transfère chaque fichier vers le serveur distant ;
|
# 7. transfère chaque fichier vers le serveur distant ;
|
||||||
# 8. envoie un bilan sur Discord :
|
# 8. envoie un bilan sur Discord :
|
||||||
# - 1 message global si tout est OK ;
|
# - 1 message global si tout est OK ;
|
||||||
# - 1 message USERS si export/transfert des rôles en erreur ;
|
# - en cas d’erreur partielle :
|
||||||
# - 1 message par base si dump ou transfert en erreur.
|
# * USERS OK -> message simple ;
|
||||||
|
# * USERS KO -> message détaillé ;
|
||||||
|
# * DB OK -> message simple ;
|
||||||
|
# * DB KO -> message détaillé.
|
||||||
###############################################################################
|
###############################################################################
|
||||||
|
|
||||||
#######################################
|
#######################################
|
||||||
@@ -60,48 +63,41 @@ set +a
|
|||||||
# Configuration principale
|
# Configuration principale
|
||||||
#######################################
|
#######################################
|
||||||
|
|
||||||
# Conversion de la liste des bases en tableau Bash
|
|
||||||
read -r -a DBS_ARRAY <<< "$DBS"
|
read -r -a DBS_ARRAY <<< "$DBS"
|
||||||
|
|
||||||
# Paramètres de connexion SSH vers la machine distante
|
|
||||||
IA_SSH="${BACKUP_REMOTE_USER}@${BACKUP_REMOTE_HOST}"
|
IA_SSH="${BACKUP_REMOTE_USER}@${BACKUP_REMOTE_HOST}"
|
||||||
IA_BASE_DIR="${BACKUP_REMOTE_DIR}"
|
IA_BASE_DIR="${BACKUP_REMOTE_DIR}"
|
||||||
|
|
||||||
# Clé SSH et options utilisées pour les connexions SSH/SCP
|
SSH_OPTS=(
|
||||||
SSH_OPTS=(-i "$SSH_KEY" -o IdentitiesOnly=yes -o BatchMode=yes -o ConnectTimeout="${SSH_TIMEOUT}")
|
-i "$SSH_KEY"
|
||||||
|
-o IdentitiesOnly=yes
|
||||||
|
-o BatchMode=yes
|
||||||
|
-o ConnectTimeout="${SSH_TIMEOUT}"
|
||||||
|
)
|
||||||
|
|
||||||
# Dossier de logs local
|
|
||||||
LOG_DIR="${BACKUP_LOG_DIR}"
|
LOG_DIR="${BACKUP_LOG_DIR}"
|
||||||
mkdir -p "$LOG_DIR"
|
mkdir -p "$LOG_DIR"
|
||||||
|
|
||||||
# Timestamp unique pour identifier ce jeu de sauvegardes
|
|
||||||
TS="$(date +'%Y-%m-%d_%H-%M-%S')"
|
TS="$(date +'%Y-%m-%d_%H-%M-%S')"
|
||||||
BACKUP_DIR_NAME="backup_${TS}"
|
BACKUP_DIR_NAME="backup_${TS}"
|
||||||
LOG_FILE="${LOG_DIR}/${BACKUP_DIR_NAME}.log"
|
LOG_FILE="${LOG_DIR}/${BACKUP_DIR_NAME}.log"
|
||||||
|
|
||||||
# Dossier temporaire local où seront générés les dumps avant transfert
|
|
||||||
TMP_DIR="/tmp/pg_dump_${BACKUP_DIR_NAME}"
|
TMP_DIR="/tmp/pg_dump_${BACKUP_DIR_NAME}"
|
||||||
mkdir -p "$TMP_DIR"
|
mkdir -p "$TMP_DIR"
|
||||||
|
|
||||||
# Redirige stdout/stderr vers le fichier de log tout en gardant l'affichage console
|
|
||||||
exec > >(tee -a "$LOG_FILE") 2>&1
|
exec > >(tee -a "$LOG_FILE") 2>&1
|
||||||
|
|
||||||
# Fonction de log horodaté
|
|
||||||
log() { echo "---- $(date +'%Y-%m-%d %H:%M:%S') ---- $*"; }
|
log() { echo "---- $(date +'%Y-%m-%d %H:%M:%S') ---- $*"; }
|
||||||
|
|
||||||
# Rend le mot de passe PostgreSQL disponible à psql / pg_dump
|
|
||||||
export PGPASSWORD
|
export PGPASSWORD
|
||||||
|
|
||||||
#######################################
|
#######################################
|
||||||
# Configuration Discord
|
# Configuration Discord
|
||||||
#######################################
|
#######################################
|
||||||
|
|
||||||
# URL du webhook Discord.
|
|
||||||
# Si elle est vide, aucune notification ne sera envoyée.
|
|
||||||
DISCORD_WEBHOOK_URL="${DISCORD_WEBHOOK_URL:-}"
|
DISCORD_WEBHOOK_URL="${DISCORD_WEBHOOK_URL:-}"
|
||||||
DISCORD_PING="${DISCORD_PING:-@here}"
|
DISCORD_PING="${DISCORD_PING:-@here}"
|
||||||
|
|
||||||
# Envoie un message texte simple sur Discord via webhook
|
|
||||||
discord_send() {
|
discord_send() {
|
||||||
local msg="$1"
|
local msg="$1"
|
||||||
[[ -z "${DISCORD_WEBHOOK_URL:-}" ]] && return
|
[[ -z "${DISCORD_WEBHOOK_URL:-}" ]] && return
|
||||||
@@ -115,7 +111,6 @@ discord_send() {
|
|||||||
# Message global OK
|
# Message global OK
|
||||||
#######################################
|
#######################################
|
||||||
|
|
||||||
# Envoie un message unique quand tout le process s’est bien déroulé
|
|
||||||
discord_msg_global_ok() {
|
discord_msg_global_ok() {
|
||||||
local msg="**BACKUP BDD ${ENV_NAME} 🟢**\n"
|
local msg="**BACKUP BDD ${ENV_NAME} 🟢**\n"
|
||||||
msg+="Name: ${BACKUP_DIR_NAME}\n"
|
msg+="Name: ${BACKUP_DIR_NAME}\n"
|
||||||
@@ -126,15 +121,17 @@ discord_msg_global_ok() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#######################################
|
#######################################
|
||||||
# Message USERS
|
# Messages USERS
|
||||||
#######################################
|
#######################################
|
||||||
|
|
||||||
# Envoie un message de statut spécifique à l’export/transfert des rôles/users
|
discord_msg_users_ok_simple() {
|
||||||
# Paramètres :
|
local msg="**BACKUP BDD ${ENV_NAME} 🟢**\n"
|
||||||
# $1 = export_ok -> non vide si export OK
|
msg+="Users backup validé"
|
||||||
# $2 = transfer_ok -> non vide si transfert OK
|
|
||||||
# $3 = details -> détail textuel de l’erreur éventuelle
|
discord_send "$msg"
|
||||||
discord_msg_users() {
|
}
|
||||||
|
|
||||||
|
discord_msg_users_error() {
|
||||||
local export_ok="$1"
|
local export_ok="$1"
|
||||||
local transfer_ok="$2"
|
local transfer_ok="$2"
|
||||||
local details="$3"
|
local details="$3"
|
||||||
@@ -143,16 +140,7 @@ discord_msg_users() {
|
|||||||
export_disp=$([[ -n "$export_ok" ]] && echo "✅" || echo "❌")
|
export_disp=$([[ -n "$export_ok" ]] && echo "✅" || echo "❌")
|
||||||
transfer_disp=$([[ -n "$transfer_ok" ]] && echo "✅" || echo "❌")
|
transfer_disp=$([[ -n "$transfer_ok" ]] && echo "✅" || echo "❌")
|
||||||
|
|
||||||
local color ping
|
local msg="**${DISCORD_PING} BACKUP BDD ${ENV_NAME} 🔴**\n"
|
||||||
if [[ -n "$export_ok" && -n "$transfer_ok" ]]; then
|
|
||||||
color="🟢"
|
|
||||||
ping=""
|
|
||||||
else
|
|
||||||
color="🔴"
|
|
||||||
ping="${DISCORD_PING} "
|
|
||||||
fi
|
|
||||||
|
|
||||||
local msg="**${ping}BACKUP BDD ${ENV_NAME} ${color}**\n"
|
|
||||||
msg+="Name: ${BACKUP_DIR_NAME}\n"
|
msg+="Name: ${BACKUP_DIR_NAME}\n"
|
||||||
msg+="Users export: ${export_disp}\n"
|
msg+="Users export: ${export_disp}\n"
|
||||||
msg+="Users transfer: ${transfer_disp}"
|
msg+="Users transfer: ${transfer_disp}"
|
||||||
@@ -163,16 +151,18 @@ discord_msg_users() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#######################################
|
#######################################
|
||||||
# Message DB
|
# Messages DB
|
||||||
#######################################
|
#######################################
|
||||||
|
|
||||||
# Envoie un message de statut spécifique à une base donnée
|
discord_msg_db_ok_simple() {
|
||||||
# Paramètres :
|
local db="$1"
|
||||||
# $1 = db -> nom de la base
|
local msg="**BACKUP BDD ${ENV_NAME} 🟢**\n"
|
||||||
# $2 = dump_ok -> non vide si dump OK
|
msg+="Backup validé : ${db}"
|
||||||
# $3 = transfer_ok -> non vide si transfert OK
|
|
||||||
# $4 = details -> détail textuel de l’erreur éventuelle
|
discord_send "$msg"
|
||||||
discord_msg_db() {
|
}
|
||||||
|
|
||||||
|
discord_msg_db_error() {
|
||||||
local db="$1"
|
local db="$1"
|
||||||
local dump_ok="$2"
|
local dump_ok="$2"
|
||||||
local transfer_ok="$3"
|
local transfer_ok="$3"
|
||||||
@@ -182,16 +172,7 @@ discord_msg_db() {
|
|||||||
dump_disp=$([[ -n "$dump_ok" ]] && echo "✅" || echo "❌")
|
dump_disp=$([[ -n "$dump_ok" ]] && echo "✅" || echo "❌")
|
||||||
transfer_disp=$([[ -n "$transfer_ok" ]] && echo "✅" || echo "❌")
|
transfer_disp=$([[ -n "$transfer_ok" ]] && echo "✅" || echo "❌")
|
||||||
|
|
||||||
local color ping
|
local msg="**${DISCORD_PING} BACKUP BDD ${ENV_NAME} 🔴**\n"
|
||||||
if [[ -n "$dump_ok" && -n "$transfer_ok" ]]; then
|
|
||||||
color="🟢"
|
|
||||||
ping=""
|
|
||||||
else
|
|
||||||
color="🔴"
|
|
||||||
ping="${DISCORD_PING} "
|
|
||||||
fi
|
|
||||||
|
|
||||||
local msg="**${ping}BACKUP BDD ${ENV_NAME} ${color}**\n"
|
|
||||||
msg+="Name: ${BACKUP_DIR_NAME}\n"
|
msg+="Name: ${BACKUP_DIR_NAME}\n"
|
||||||
msg+="Database: ${db}\n"
|
msg+="Database: ${db}\n"
|
||||||
msg+="Dump: ${dump_disp}\n"
|
msg+="Dump: ${dump_disp}\n"
|
||||||
@@ -225,7 +206,7 @@ LOCK_DIR="/tmp/pg_multi_dump_stream.lock.d"
|
|||||||
|
|
||||||
if ! mkdir "$LOCK_DIR" 2>/dev/null; then
|
if ! mkdir "$LOCK_DIR" 2>/dev/null; then
|
||||||
log "ERROR: Backup déjà en cours"
|
log "ERROR: Backup déjà en cours"
|
||||||
discord_msg_users "" "" "Lock already exists"
|
discord_msg_users_error "" "" "Lock already exists"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -241,7 +222,7 @@ log "Creating remote directories"
|
|||||||
|
|
||||||
if ! ssh "${SSH_OPTS[@]}" "$IA_SSH" "mkdir -p '${REMOTE_DIR}/ferme' '${REMOTE_DIR}/sirh' '${REMOTE_DIR}/inventory' '${REMOTE_DIR}/user'"; then
|
if ! ssh "${SSH_OPTS[@]}" "$IA_SSH" "mkdir -p '${REMOTE_DIR}/ferme' '${REMOTE_DIR}/sirh' '${REMOTE_DIR}/inventory' '${REMOTE_DIR}/user'"; then
|
||||||
log "ERROR: remote mkdir failed"
|
log "ERROR: remote mkdir failed"
|
||||||
discord_msg_users "" "" "Remote mkdir failed"
|
discord_msg_users_error "" "" "Remote mkdir failed"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -271,7 +252,11 @@ RET=$?
|
|||||||
if [[ $RET -ne 0 ]]; then
|
if [[ $RET -ne 0 ]]; then
|
||||||
USERS_OK=
|
USERS_OK=
|
||||||
USERS_TRANSFER_OK=
|
USERS_TRANSFER_OK=
|
||||||
USERS_DETAILS+=" roles transfer failed"
|
if [[ -n "$USERS_DETAILS" ]]; then
|
||||||
|
USERS_DETAILS+=" | roles transfer failed"
|
||||||
|
else
|
||||||
|
USERS_DETAILS="roles transfer failed"
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
set -e
|
set -e
|
||||||
@@ -283,17 +268,15 @@ set -e
|
|||||||
set +e
|
set +e
|
||||||
|
|
||||||
for DB in "${DBS_ARRAY[@]}"; do
|
for DB in "${DBS_ARRAY[@]}"; do
|
||||||
|
|
||||||
FILE="${TMP_DIR}/${DB}_${TS}.dump"
|
FILE="${TMP_DIR}/${DB}_${TS}.dump"
|
||||||
|
|
||||||
DB_DUMP_OK["$DB"]=true
|
DB_DUMP_OK["$DB"]=true
|
||||||
DB_TRANSFER_OK["$DB"]=true
|
DB_TRANSFER_OK["$DB"]=true
|
||||||
DB_DETAILS["$DB"]="OK"
|
DB_DETAILS["$DB"]=""
|
||||||
|
|
||||||
log "Dump $DB"
|
log "Dump $DB"
|
||||||
|
|
||||||
pg_dump -h "$PGHOST" -p "$PGPORT" -U "$PGUSER" -Fc -d "$DB" -f "$FILE"
|
pg_dump -h "$PGHOST" -p "$PGPORT" -U "$PGUSER" -Fc -d "$DB" -f "$FILE"
|
||||||
|
|
||||||
RET=$?
|
RET=$?
|
||||||
|
|
||||||
if [[ $RET -ne 0 ]]; then
|
if [[ $RET -ne 0 ]]; then
|
||||||
@@ -305,7 +288,6 @@ for DB in "${DBS_ARRAY[@]}"; do
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
scp "${SSH_OPTS[@]}" "$FILE" "$IA_SSH:${REMOTE_DIR}/${DB}/"
|
scp "${SSH_OPTS[@]}" "$FILE" "$IA_SSH:${REMOTE_DIR}/${DB}/"
|
||||||
|
|
||||||
RET=$?
|
RET=$?
|
||||||
|
|
||||||
if [[ $RET -ne 0 ]]; then
|
if [[ $RET -ne 0 ]]; then
|
||||||
@@ -313,7 +295,6 @@ for DB in "${DBS_ARRAY[@]}"; do
|
|||||||
DB_TRANSFER_OK["$DB"]=
|
DB_TRANSFER_OK["$DB"]=
|
||||||
DB_DETAILS["$DB"]="transfer failed"
|
DB_DETAILS["$DB"]="transfer failed"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
done
|
done
|
||||||
|
|
||||||
set -e
|
set -e
|
||||||
@@ -338,10 +319,18 @@ if [[ -z "${MODE_KO:-}" ]]; then
|
|||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
discord_msg_users "${USERS_EXPORT_OK:+true}" "${USERS_TRANSFER_OK:+true}" "$USERS_DETAILS"
|
if [[ -n "${USERS_EXPORT_OK:-}" && -n "${USERS_TRANSFER_OK:-}" ]]; then
|
||||||
|
discord_msg_users_ok_simple
|
||||||
|
else
|
||||||
|
discord_msg_users_error "${USERS_EXPORT_OK:+true}" "${USERS_TRANSFER_OK:+true}" "$USERS_DETAILS"
|
||||||
|
fi
|
||||||
|
|
||||||
for DB in "${DBS_ARRAY[@]}"; do
|
for DB in "${DBS_ARRAY[@]}"; do
|
||||||
discord_msg_db "$DB" "${DB_DUMP_OK[$DB]:+true}" "${DB_TRANSFER_OK[$DB]:+true}" "${DB_DETAILS[$DB]}"
|
if [[ -n "${DB_DUMP_OK[$DB]:-}" && -n "${DB_TRANSFER_OK[$DB]:-}" ]]; then
|
||||||
|
discord_msg_db_ok_simple "$DB"
|
||||||
|
else
|
||||||
|
discord_msg_db_error "$DB" "${DB_DUMP_OK[$DB]:+true}" "${DB_TRANSFER_OK[$DB]:+true}" "${DB_DETAILS[$DB]}"
|
||||||
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
exit 2
|
exit 2
|
||||||
@@ -87,7 +87,6 @@ discord_ping() {
|
|||||||
|
|
||||||
local msg="**${ping_prefix}CHECK APP ${ENV_NAME} $color**\n"
|
local msg="**${ping_prefix}CHECK APP ${ENV_NAME} $color**\n"
|
||||||
msg+="Application: ${site}\n"
|
msg+="Application: ${site}\n"
|
||||||
msg+="Status: ${icon}\n"
|
|
||||||
msg+="Details: ${detail}"
|
msg+="Details: ${detail}"
|
||||||
|
|
||||||
curl -fsS -H "Content-Type: application/json" \
|
curl -fsS -H "Content-Type: application/json" \
|
||||||
|
|||||||
Reference in New Issue
Block a user