1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
|
from django.core.management.base import BaseCommand, CommandError
from sbhs_server import settings, helpers
from sbhs_server.tables.models import Board
import os, json
from datetime import datetime
class Command(BaseCommand):
args = ''
help = 'Sends email to admin'
def handle(self, *args, **options):
# Store all Raspberry Pi IP's in a list
with open(os.path.join(settings.BASE_DIR, "sbhs_server/RPi_data/ipaddrs.txt"), "r") as filehandler:
ipaddrs = filehandler.readlines()
# Strip whitespaces (in case)
ipaddrs = [ip.strip() for ip in ipaddrs]
new_offlines = []
faulty_boards = {}
# Create data for offline and faulty boards
for ip in ipaddrs:
filename = "sbhs_server/RPi_data/report/" + ip + ".txt"
with open(os.path.join(settings.BASE_DIR, filename), "r") as filehandler:
data = filehandler.read()
data = json.loads(data)
new_offlines.append(set(data["new_offlines"]))
faulty_boards.update(data["faulty_boards"])
# Find intersection of offline boards from all RPi's
new_offlines = list(set.intersection(*new_offlines))
# Update database
if len(new_offlines) > 0:
Board.objects.filter(mid__in=new_offlines).update(online=False)
if len(faulty_boards.keys()) > 0:
Board.objects.filter(mid__in=faulty_boards.keys()).update(online=True,temp_offline=True)
# Compose body for the email
message = "SBHS Administrator,\n\n"
message += "Following issue requires immidiate attention.\n\n"
if len(new_offlines) > 0:
message += "SBHS could not be connected\n"
for n in new_offlines:
message += ("MID: %d\n" % n)
if bool(faulty_boards):
message += "Following devices are suspected to be faulty.\n\n"
for key in faulty_boards:
message += "MID : {} Cause : {}\n" .format(key,faulty_boards[key])
message += "\nYou can check the SBHS status on http://vlabs.iitb.ac.in/sbhs/admin/."
message += " Possible correction actions are:\n"
message += "1. Run this command without brackets -> ( cd $SBHS_SERVER_ROOT; ./new_cron_job.sh )\n"
message += "2. If same machine comes offline multiple times, replacement of the machine is advised.\n\n\n"
message += "Regards,\nSBHS Vlabs Server Code"
print "New offline board mids", new_offlines
subject = "SBHS Vlabs: Notice - SBHS not connected"
# Send email
try:
if len(new_offlines) > 0 or len(faulty_boards)>0:
for admin in settings.SBHS_ADMINS:
helpers.mailer.email(admin[2], subject, message)
except Exception as e:
with open("mail_dump.txt", "a") as handler:
delimiter = " " + "#"*10 + " "
handler.write("\n" + delimiter + datetime.now().strftime("%Y-%m-%d %H:%M:%S") + delimiter + "\n")
handler.write(message)
print message
|