.
This commit is contained in:
94
scripts/duplicati-influxdb-notify
Normal file
94
scripts/duplicati-influxdb-notify
Normal file
@@ -0,0 +1,94 @@
|
||||
#!/bin/bash
|
||||
|
||||
#/etc/default/influxdb-connection example
|
||||
#INFLUDB_SERVER=http://192.168.1.201:8086
|
||||
#INFLUDB_BUCKET=bucketname
|
||||
#INFLUDB_ORG=orgname
|
||||
#INFLUDB_TOKEN=Token xxxx
|
||||
if [ -f "/etc/default/duplicati-influxdb" ]; then
|
||||
export $(cat /etc/default/duplicati-influxdb)
|
||||
fi
|
||||
|
||||
if [ -f "~/.config/duplicati-influxdb" ]; then
|
||||
export $(cat ~/default/duplicati-influxdb)
|
||||
fi
|
||||
|
||||
#duplicati
|
||||
#DUPLICATI__EVENTNAME="zbf dc fbz"
|
||||
#DUPLICATI__OPERATIONNAME="yy"
|
||||
#DUPLICATI__PARSED_RESULT="p gfh uasd"
|
||||
#DUPLICATI__backup_name="puggb"
|
||||
#DUPLICATI__RESULTFILE="sd gasd"
|
||||
#DUPLICATI__LOCALPATH="sagd"
|
||||
#
|
||||
|
||||
TAGS=""
|
||||
MESSAGE_FIELD_VALUE=""
|
||||
|
||||
|
||||
UNSCAPED=""
|
||||
ESCAPED=""
|
||||
|
||||
escape_tag_str () {
|
||||
ESCAPED=${UNSCAPED//[ ]/\\ }
|
||||
}
|
||||
|
||||
|
||||
|
||||
if [[ ! -z "$HOSTNAME" ]]; then
|
||||
UNSCAPED=$HOSTNAME
|
||||
escape_tag_str
|
||||
TAGS="${TAGS},host=${ESCAPED}"
|
||||
MESSAGE_FIELD_VALUE="${MESSAGE_FIELD_VALUE} ${HOSTNAME}"
|
||||
fi
|
||||
|
||||
if [[ ! -z "$DUPLICATI__EVENTNAME" ]]; then
|
||||
UNSCAPED=$DUPLICATI__EVENTNAME
|
||||
escape_tag_str
|
||||
TAGS="${TAGS},eventName=\"${ESCAPED}\""
|
||||
fi
|
||||
|
||||
if [[ ! -z "$DUPLICATI__OPERATIONNAME" ]]; then
|
||||
UNSCAPED=$DUPLICATI__OPERATIONNAME
|
||||
escape_tag_str
|
||||
TAGS="${TAGS},operationName=${ESCAPED}"
|
||||
MESSAGE_FIELD_VALUE="${MESSAGE_FIELD_VALUE} ${DUPLICATI__OPERATIONNAME}"
|
||||
fi
|
||||
|
||||
if [[ ! -z "$DUPLICATI__backup_name" ]]; then
|
||||
UNSCAPED=$DUPLICATI__backup_name
|
||||
escape_tag_str
|
||||
TAGS="${TAGS},backupName=${ESCAPED}"
|
||||
MESSAGE_FIELD_VALUE="${MESSAGE_FIELD_VALUE} ${DUPLICATI__backup_name}"
|
||||
fi
|
||||
|
||||
if [[ ! -z "$DUPLICATI__PARSED_RESULT" ]]; then
|
||||
UNSCAPED=$DUPLICATI__PARSED_RESULT
|
||||
escape_tag_str
|
||||
TAGS="${TAGS},status=${ESCAPED}"
|
||||
MESSAGE_FIELD_VALUE="${MESSAGE_FIELD_VALUE} ${DUPLICATI__PARSED_RESULT}"
|
||||
fi
|
||||
|
||||
if [[ ! -z "$DUPLICATI__RESULTFILE" ]]; then
|
||||
UNSCAPED=$DUPLICATI__RESULTFILE
|
||||
escape_tag_str
|
||||
TAGS="${TAGS},resultFile=${ESCAPED}"
|
||||
fi
|
||||
|
||||
if [[ ! -z "$DUPLICATI__LOCALPATH" ]]; then
|
||||
UNSCAPED=$DUPLICATI__LOCALPATH
|
||||
escape_tag_str
|
||||
TAGS="${TAGS},localPath=${ESCAPED}"
|
||||
fi
|
||||
|
||||
FIELDS="message=\"Duplicati ${MESSAGE_FIELD_VALUE}\""
|
||||
#echo $TAGS
|
||||
|
||||
curl --request POST \
|
||||
"$INFLUXDB_SERVER/write?db=$INFLUXDB_BUCKET&ORG=$INFLUXDB_ORG" \
|
||||
--header "Authorization: Token $INFLUXDB_TOKEN" \
|
||||
--header "Content-Type: text/plain; charset=utf-8" \
|
||||
--header "Accept: application/json" \
|
||||
--data-raw "duplicati${TAGS} ${FIELDS}" > /dev/null 2>&1
|
||||
|
||||
exit 0
|
||||
49
scripts/duplicati-mysql-backup
Normal file
49
scripts/duplicati-mysql-backup
Normal file
@@ -0,0 +1,49 @@
|
||||
#!/bin/bash
|
||||
# mysql database backup.
|
||||
# executed by duplicati run-script-before-required
|
||||
# required environment variables:
|
||||
# DESTINATION
|
||||
# MYSQL_HOST
|
||||
# MYSQL_USER
|
||||
# MYSQL_PASSWORD
|
||||
# MYSQL_DATABASE
|
||||
|
||||
#any error must stop execution
|
||||
set -e
|
||||
|
||||
if [ $DUPLICATI__OPERATIONNAME == "Backup" ]
|
||||
then
|
||||
echo "Backup Job!!"
|
||||
else
|
||||
echo "Not a backup operation. exiting!"
|
||||
#OK, run operation
|
||||
exit
|
||||
fi
|
||||
|
||||
|
||||
if [ -z ${DESTINATION} ]
|
||||
then
|
||||
echo "\$DESTINATION environment variable cannot be empty empty"
|
||||
#5: Error don't run operation
|
||||
exit 5
|
||||
fi
|
||||
|
||||
TARGETFILENAME=${MYSQL_DATABASE}_dump_$(date -d "today" +"%Y%m%d%H%M%S").sql
|
||||
echo "dump file name:$TARGETFILENAME"
|
||||
|
||||
if [ -f /tmp/${TARGETFILENAME} ]
|
||||
then
|
||||
rm /tmp/${TARGETFILENAME}
|
||||
fi
|
||||
|
||||
|
||||
mysqldump -h ${MYSQL_HOST} --user=${MYSQL_USER} -p"${MYSQL_PASSWORD}" ${MYSQL_DATABASE} > /tmp/${TARGETFILENAME}
|
||||
|
||||
|
||||
if [ x$(find "$DESTINATION" -prune -empty) = x"$DESTINATION" ]; then
|
||||
echo "folder is empty... ignoring clean db dump folder"
|
||||
else
|
||||
rm -r ${DESTINATION}/*
|
||||
fi
|
||||
|
||||
mv /tmp/${TARGETFILENAME} ${DESTINATION}/${TARGETFILENAME}
|
||||
Reference in New Issue
Block a user