#!/usr/bin/env python3 # -*- coding: utf-8 -*- # Copyright 2017, Florent Thiery ''' Criticality: Normal Checks that the server backups are not older than a day. ''' from datetime import datetime import imp import os import socket import subprocess import sys GREEN = '\033[92m' RED = '\033[91m' DEF = '\033[0m' def test_ssh(ip): cmd = 'ssh -o StrictHostKeyChecking=no -o PasswordAuthentication=no %s ls /tmp' % ip print('Connecting to MediaVault: %s' % cmd) try: subprocess.check_output(cmd, shell=True, timeout=2) print('%sLogged in successfully%s' % (GREEN, DEF)) except subprocess.CalledProcessError: print('%sFailed to login using SSH, run ssh-copy-id %s %s' % (RED, ip, DEF)) return False return True def test_last_backup_is_recent(server): client = socket.gethostname() path = '/backup/%s/home/latest' % client cmd = 'ssh -o StrictHostKeyChecking=no %s ls -l %s | grep latest' % (server, path) status, out = subprocess.getstatusoutput(cmd) if status == 0: date = out.strip().split(' ')[-1] pdate = datetime.strptime(date, '%Y-%m-%d-%H%M%S') if (datetime.now() - pdate).days > 2: print('Backup is older than 2 days') return False else: print('There is a backup that is less than 2 days old, this is fine') return True else: out = out or 'No output.' print('SSH access is not working (code: %s):\n%s' % (status, out)) return False def test_backup_space(server): cmd = 'ssh -o StrictHostKeyChecking=no %s df -h /backup | tail -n 1' % (server) status, out = subprocess.getstatusoutput(cmd) if status == 0: dev, total, used, free, used_perc, mount = out.strip().split() used_perc = int(used_perc.replace('%','')) if used_perc > 80: print('There is less than 20% of available space for backups') return False else: print('There is %s%% of free space' % (100 - used_perc)) return True else: print('Failed to check backup space') return False os.chdir(os.path.dirname(__file__)) if os.path.isfile('../utils.py'): es_utils = imp.load_source('es_utils', '../utils.py') conf = es_utils.load_conf() BURP_SERVER = conf.get('BURP_SERVER') if BURP_SERVER: if not test_ssh(BURP_SERVER): print('Failed to ssh into backup server') sys.exit(1) else: if not test_last_backup_is_recent(BURP_SERVER): sys.exit(1) else: if not test_backup_space(BURP_SERVER): sys.exit(1) else: sys.exit(0) else: print('No BURP_SERVER defined in config, untestable') sys.exit(2) else: print('Unable to load config, untestable') sys.exit(2)