Many small updates to various scripts.
deleted: cronjob-update-packages-list.new deleted: cronjob-updatedb-mirrors renamed: rsync-notify-upload -> notify-rsync-upload modified: colour-changelog modified: cronjob-clean-php modified: cronjob-dehydrated modified: cronjob-fix-log-acls modified: cronjob-rotate-logs-today-symlink modified: cronjob-update-mirrors-search-db modified: cronjob-update-packages-list modified: cronjob-warn-git-status modified: cronjob-warn-smtp-queue modified: do-backup modified: dovecot-service-checksuspended modified: firewall-initscript modified: git-auto-merge modified: mirror modified: mirror-new-slackware-release.gpg modified: mirror-wrapper modified: notify-rsync-upload modified: sbosrcarch-wrapper
This commit is contained in:
parent
500b36e5f8
commit
041ebf1b1a
21 changed files with 83 additions and 181 deletions
48
notify-rsync-upload
Executable file
48
notify-rsync-upload
Executable file
|
|
@ -0,0 +1,48 @@
|
|||
#!/bin/bash
|
||||
# Send an email notification whenever someone pushes an update to rsyncd.
|
||||
|
||||
# Default configuration.
|
||||
# This can be overridden in /etc/default/notify-rsync-upload.
|
||||
EMAIL_FROM="\"Server: ${HOSTNAME%%.*}\" <noreply@slackware.uk.net>"
|
||||
EMAIL_TO=("Systems' Administrator <sysadmin@slackware.uk>")
|
||||
LOGSDIR="/var/log/duplication/rsync-uploads"
|
||||
|
||||
# Read /etc/default/notify-rsync-upload if it exists.
|
||||
[[ -e /etc/default/notify-rsync-upload ]] && {
|
||||
# shellcheck disable=SC1091
|
||||
source /etc/default/notify-rsync-upload || {
|
||||
printf "%s: %s\\n" "${0##*/}" "failed reading /etc/default/notify-rsync-upload" >&2
|
||||
exit 1
|
||||
}
|
||||
}
|
||||
|
||||
# Make sure the logs directory exists.
|
||||
mkdir -p "$LOGSDIR" 2>/dev/null || {
|
||||
printf "%s: %s\\n" "${0##*/}" "Failed to create logs directory" >&2
|
||||
exit 1
|
||||
}
|
||||
|
||||
# Update the log with this upload date/time.
|
||||
printf "%s - %s\\n" "$(printf "%(%c)T")" "{RSYNC_USER_NAME:-(none)}@${RSYNC_HOST_NAME:-$RSYNC_HOST_ADDR}" >>"$LOGSDIR/${RSYNC_MODULE_NAME%%-upload}"
|
||||
|
||||
# Determine the subject of the message.
|
||||
if (( RSYNC_EXIT_STATUS == 0 )); then
|
||||
EMAIL_SUBJECT="Upload success: ${RSYNC_MODULE_NAME%%-upload}"
|
||||
elif (( RSYNC_EXIT_STATUS == -1 )); then
|
||||
EMAIL_SUBJECT="Upload error: ${RSYNC_MODULE_NAME%%-upload}"
|
||||
else
|
||||
EMAIL_SUBJECT="Upload failure: ${RSYNC_MODULE_NAME%%-upload}"
|
||||
fi
|
||||
|
||||
# Send the message.
|
||||
if [[ -n "$EMAIL_FROM" ]] && (( "${#EMAIL_TO[@]}" != 0 )); then
|
||||
printf "%s:\\t%s\\n%s:\\t\\t%s\\n%s:\\t%s\\n%s:\\t\\t%s\\n" "Auth'd user" "$RSYNC_USER_NAME@$RSYNC_HOST_NAME [$RSYNC_HOST_ADDR]" "Module" "$RSYNC_MODULE_NAME ($RSYNC_MODULE_PATH)" "Exit code" "$RSYNC_EXIT_STATUS" "PID" "$RSYNC_PID" | mail -r "$EMAIL_FROM" -s "$EMAIL_SUBJECT" "${EMAIL_TO[@]}" >/dev/null 2>&1 || {
|
||||
printf "%s: %s\\n" "${0##*/}" "mail command failed" >&2
|
||||
exit 1
|
||||
}
|
||||
else
|
||||
printf "%s: %s\\n" "${0##*/}" "no sender and/or recipient configured for mail delivery" >&2
|
||||
exit 1
|
||||
fi
|
||||
|
||||
exit 0
|
||||
Loading…
Add table
Add a link
Reference in a new issue