diff options
author | David Runge <dave@sleepmap.de> | 2015-03-20 01:02:04 +0100 |
---|---|---|
committer | David Runge <dave@sleepmap.de> | 2015-03-20 01:02:04 +0100 |
commit | c10efa7645f9f135b0a8513eeb69cb9d162d1728 (patch) | |
tree | 2d8768103e4cfbb84512e78570fd60fa5d689a53 /scripts | |
parent | a7b06bdff0d67ad640074e3760dcc5b667b64663 (diff) | |
download | crypted-backups-c10efa7645f9f135b0a8513eeb69cb9d162d1728.tar.gz crypted-backups-c10efa7645f9f135b0a8513eeb69cb9d162d1728.tar.bz2 crypted-backups-c10efa7645f9f135b0a8513eeb69cb9d162d1728.tar.xz crypted-backups-c10efa7645f9f135b0a8513eeb69cb9d162d1728.zip |
backup-mail: Adding first version of backup-mail script, service and timer.
Diffstat (limited to 'scripts')
-rwxr-xr-x | scripts/backup-mail | 78 |
1 files changed, 78 insertions, 0 deletions
diff --git a/scripts/backup-mail b/scripts/backup-mail new file mode 100755 index 0000000..c37af58 --- /dev/null +++ b/scripts/backup-mail @@ -0,0 +1,78 @@ +#!/usr/bin/env bash + +timestamp="$(date +"%Y%m%d-%H%M%S")-" + +# If the backup location doesn't exist yet, create it +if [ ! -d $mail_folder_destination ]; then + mkdir -p $mail_folder_destination +fi + +# If the parent directory of the backup source exists, enter it +if [ -d $mail_folder_source ]; then + cd $mail_folder_source +else + exit 1 +fi + +# Loop through all subdirectories of $mail_folder_source +for subfolder in $mail_folder_source* +do + # use basename + subfolder=$(basename $subfolder) + # If it is a folder + if [ -d $subfolder ]; then + cd $subfolder + # If the backup location for that domain doesn't exist yet, create it + if [ ! -d $mail_folder_destination$subfolder ]; then + mkdir -p $mail_folder_destination$subfolder + fi + # Loop through all subsubdirectories (mailboxes) of $subfolder (domain name) + for subsubfolder in $mail_folder_source$subfolder/* + do + # use basename + subsubfolder=$(basename $subsubfolder) + echo "$subsubfolder --> $mail_folder_destination$subfolder/$timestamp$subsubfolder$tar_suffix$gpg_suffix" + # tar to /tmp + tar cfJ $tmp$timestamp$subsubfolder$tar_suffix $subsubfolder + # gpg to backup location + gpg -e \ + -r "$gpg_public_key" \ + -o "$mail_folder_destination$subfolder/$timestamp$subsubfolder$tar_suffix$gpg_suffix" \ + $tmp$timestamp$subsubfolder$tar_suffix + # remove tar in /tmp + rm -f $tmp$timestamp$subsubfolder$tar_suffix + done + fi +done + +# Backup mailman mailing lists +# If the backup location doesn't exist yet, create it +if [ ! -d $mailman_folder_destination ]; then + mkdir -p $mailman_folder_destination +fi + +# If the parent directory of the backup source exists, enter it +if [ -d $mailman_folder_source ]; then + cd $mailman_folder_source +else + exit 1 +fi +# Loop through all subdirectories of $mailman_folder_source +for subfolder in $mailman_folder_source* +do + # use basename + subfolder=$(basename $subfolder) + if [ $subfolder = archives ] || [ $subfolder = data ] || [ $subfolder = lists ]; then + echo "$subfolder --> $mailman_folder_destination$timestamp$subfolder$tar_suffix$gpg_suffix" + # tar to /tmp + tar cfJ "$tmp$timestamp$subfolder$tar_suffix" $subfolder + # gpg to backup location + gpg -e \ + -r "$gpg_public_key" \ + -o $mailman_folder_destination$timestamp$subfolder$tar_suffix$gpg_suffix \ + $tmp$timestamp$subfolder$tar_suffix + # remove tar in /tmp + rm -f $tmp$timestamp$subfolder$tar_suffix + fi +done + |