#!/bin/bash
#
# Script to monitor daily backup timing
#
# @3G
#
# Parameters understood:
#
#     config    (required)
#     autoconf  (optional - used by munin-config)
#

#%# family=auto
#%# capabilities=autoconf

XL='/usr/sbin/xl'
BCKDIR='/var/log/backup'
BCKN='backup-'

if [ "$1" = "autoconf" ]; then
        if [ -e $XL -a -d $BCKDIR ]; then
                echo yes
                exit 0
        fi
        echo "no (no xen or no backup)"
        exit 0
fi

DOMAINS=$($XL list | awk '{print $1}' | egrep -v "^(Name|Domain-0)" |sort)
#"

if [ "$1" = "config" ]; then

	echo 'graph_title Xen DomU backup'
	echo 'graph_args --base 1000 -l 0'
	echo 'graph_scale no'
	echo 'graph_vlabel sec'
	echo 'graph_category backup'
	echo 'graph_info This graph shows the backup timings per domU'

	for domu in $DOMAINS; do
#		name=`echo "$domu" | sed -e 's/\./_/g'`
		name=`echo "$domu" | tr .- __`

		echo "$name.label $name"
		echo "$name.type GAUGE"
		echo "$name.draw AREASTACK"
		echo "$name.min 0"
		echo "$name.info backup time"
	done
	exit 0
fi

TODAY=`date +%y%m%d`
BTL=${BCKDIR}/${BCKN}${TODAY}.log
YDAY=`date +%y%m%d -d "yesterday"`
BYL=${BCKDIR}/${BCKN}${YDAY}.log

if [ -f $BTL ]; then
	BL=$BTL
elif [ -f $BYL ]; then
	BL=$BYL
else
	BL=""
fi

for domu in $DOMAINS; do
#	name=`echo "$domu" | sed -e 's/\./_/g'`
	name=`echo "$domu" | tr .- __`

	starttime=''
	endtime=''

	if [ -n "$BL" -a -f "$BL" ]; then
		starttime=`grep "\[$domu]\ START" $BL |tail -n1 |awk '{print $1}'`
		endtime=`grep "\[$domu]\ END" $BL |tail -n1 |awk '{print $1}'`
	fi

	if [ -n "$starttime" -a -n "$endtime" ]; then
		let value=$(date +%s -d "$endtime")-$(date +%s -d "$starttime")
	elif [ -n "$starttime" ]; then
		let value=$(date +%s)-$(date +%s -d "$starttime")
	else
		value="U"
	fi

	echo "$name.value $value"
done
