Compare commits

..

No commits in common. "8853bc812970e763dc663d4f129b7adc89efcf17" and "53d26e83b623f9da0463feb477fb7e79f6dc97a2" have entirely different histories.

3 changed files with 0 additions and 175 deletions

1
.gitignore vendored
View file

@ -1 +0,0 @@
.env

View file

@ -1,60 +0,0 @@
#!/bin/bash
#
#This script will automatically make an encrypted backup to a restic repository as specified with --source
#
helpFunction()
{
echo ""
echo "Usage: $0 -i INPUT -c CONFIG_DIR -l LOG_DIR"
echo -e "\t-i Input folder that should be backed up."
echo -e "\t-c Location of config directory containing repository, password and uuid files."
echo -e "\t-l Location of where the log should be outputted to."
echo -e "Example:"
echo -e "If you pass -i ~/MyServices/SeRvIce1, then the directory you pass as -c must contain files service1_repository, service1_password and service1_uuid (note lower case)"
exit 1 # Exit script after printing help
}
while getopts "i:c:l:" opt
do
case "$opt" in
i ) INPUT="$OPTARG" ;;
c ) CONFIG_DIR="$OPTARG" ;;
l ) LOG_DIR="$OPTARG" ;;
? ) helpFunction ;; # Print helpFunction in case parameter is non-existent
esac
done
# Print helpFunction in case parameters are empty
if [ -z "$INPUT" ] || [ -z "$CONFIG_DIR" ] || [ -z "$LOG_DIR" ]
then
echo "Some or all of the parameters are empty";
helpFunction
fi
# Begin script in case all parameters are correct
# Set environment variables
set -a && source .env && set +a
SERVICE=${INPUT##*/}
SERVICE=${SERVICE,,}
DATE=$(date +%Y-%m-%d_%H%M%S)
LOG_FILE="${LOG_DIR}/${SERVICE}_${DATE}.log"
REPOSITORY_FILE="${CONFIG_DIR}/${SERVICE}_repository"
PASSWORD_FILE="${CONFIG_DIR}/${SERVICE}_password"
UUID_FILE="${CONFIG_DIR}/${SERVICE}_uuid"
echo -e "--- START OF BACKUP FOR ${SERVICE^^} - ${DATE} ---\n\n" > $LOG_FILE
restic backup $INPUT --verbose --repository-file $REPOSITORY_FILE --password-file $PASSWORD_FILE >> $LOG_FILE
echo -e "\n\n Current snapshots:\n\n" >> $LOG_FILE
restic snapshots --verbose --repository-file $REPOSITORY_FILE --password-file $PASSWORD_FILE >> $LOG_FILE
echo -e "\n\n Health check:\n\n" >> $LOG_FILE
restic check --verbose --repository-file $REPOSITORY_FILE --password-file $PASSWORD_FILE >> $LOG_FILE
echo -e "\n\n Move to external storage:\n\n" >> $LOG_FILE
rsync -rahPv --delete-after -e "ssh -p ${EXTERNAL_STORAGE_PORT}" "$(<$REPOSITORY_FILE)" $EXTERNAL_STORAGE_USER@$EXTERNAL_STORAGE_URL:$EXTERNAL_STORAGE_ROOT_DIR/"$(<$UUID_FILE)" >> $LOG_FILE

View file

@ -1,114 +0,0 @@
#!/bin/bash
#
#This script will initialise the required files and directories for automatic backup of Docker data.
#
helpFunction()
{
echo ""
echo "Usage: $0 -i INPUT -c CONFIG_DIR -l LOG_DIR"
echo -e "\t-i Input folder to create a repository for."
echo -e "\t-c Location of config directory where the repository, password and uuid files are stored."
echo -e "\t-n Name of the Docker container. Required to stop the container and restart it before backing up."
exit 1 # Exit script after printing help
}
while getopts "i:c:n:f" opt
do
case "$opt" in
i ) INPUT="$OPTARG" ;;
c ) CONFIG_DIR="$OPTARG" ;;
n ) CONTAINER_NAME="$OPTARG" ;;
f ) FORCE=true ;;
? ) helpFunction ;; # Print helpFunction in case parameter is non-existent
esac
done
# Verify that required parameters are present
set -a && source .env && set +a
REQUIRED_PARAMS=(
INPUT
CONFIG_DIR
CONTAINER_NAME
EXTERNAL_STORAGE_URL
EXTERNAL_STORAGE_USER
EXTERNAL_STORAGE_PORT
EXTERNAL_STORAGE_ROOT_DIR
INTERNAL_STORAGE_ROOT_DIR
)
for variable in "${REQUIRED_PARAMS[@]}" ; do
if [ -z "${!variable+x}" ]; then
echo "$variable is not set. Make sure your .env file is complete, and you have passed in all required flags.";
exit;
fi
done
echo $FORCE
# Parse the input to create the SERVICE variable (lower case)
SERVICE=${INPUT##*/}
SERVICE=${SERVICE,,}
# Set the location of the internal repo
INTERNAL_REPO_LOCATION=$INTERNAL_STORAGE_ROOT_DIR/$SERVICE
# Generate random password and UUID
PASSWORD=$(tr -dc 'A-Za-z0-9!?%=' < /dev/urandom | head -c 50)
UUID=$(uuidgen)
# Set filenames
REPO_FILE_PATH="$CONFIG_DIR/${SERVICE}_repository"
PWD_FILE_PATH="$CONFIG_DIR/${SERVICE}_password"
UUID_FILE_PATH="$CONFIG_DIR/${SERVICE}_uuid"
CONTAINER_NAME_FILE_PATH="$CONFIG_DIR/${SERVICE}_container_name"
# Make the config directory if it does not already exist
if [ ! -d "$CONFIG_DIR" ]; then
mkdir $CONFIG_DIR
fi
# Run the code only if the config files for the service does not already exist, or if force overwrite is specified
if [[ ! -f "$CONFIG_DIR/${SERVICE}_repository" ]] || [[ $FORCE == true ]]; then
# Prompt user if they are sure whether to force overwrite
if [[ $FORCE == true ]]; then
while true; do
read -p "The config for ${INPUT} already exists, but you specified to force overwrite. This will also delete what is already in the restic repository and recreate an empty repo. Are you sure? [y/n] " yn
case $yn in
[Yy]* ) break;;
[Nn]* ) echo "Exiting without overwriting..."; exit;;
* ) echo "Please anser yes or no."
esac
done
fi
# Write the config files
echo $INTERNAL_REPO_LOCATION > $REPO_FILE_PATH
echo $PASSWORD > $PWD_FILE_PATH
echo $UUID > $UUID_FILE_PATH
echo $CONTAINER_NAME > $CONTAINER_NAME_FILE_PATH
echo "Created required backup directories for $INPUT"
echo "Password: $PASSWORD"
echo "UUID: $UUID"
echo "Make sure to note this down in your password manager to be able to decrypt the repositories, and to map the repositories on the external storage"
# Make the internal restic repository
if [ -d "$INTERNAL_REPO_LOCATION" ]; then
cp -r $INTERNAL_REPO_LOCATION ${INTERNAL_REPO_LOCATION}_old_$(date +%Y%m%d_%H%M%S)
rm -r $INTERNAL_REPO_LOCATION
fi
restic init --repository-file $REPO_FILE_PATH -p $PWD_FILE_PATH
else
echo "Repository config already exists for the service you specified. You can override this by passing the -f flag."
fi