1 | #!/usr/bin/python |
---|
2 | import csv |
---|
3 | import os |
---|
4 | import sys |
---|
5 | |
---|
6 | if __name__ == '__main__': |
---|
7 | cur_file = os.path.abspath(__file__) |
---|
8 | django_dir = os.path.abspath(os.path.join(os.path.dirname(cur_file), '..')) |
---|
9 | sys.path.append(django_dir) |
---|
10 | os.environ['DJANGO_SETTINGS_MODULE'] = 'settings' |
---|
11 | |
---|
12 | from django.core import mail |
---|
13 | from django.template import Context, Template |
---|
14 | from django.template.loader import get_template |
---|
15 | |
---|
16 | import groups.models |
---|
17 | |
---|
18 | def get_roles(): |
---|
19 | require_any_role = False |
---|
20 | require_any_role = True |
---|
21 | roles = [ |
---|
22 | ['president', require_any_role, 'No president listed', ], |
---|
23 | ['treasurer', require_any_role, 'No treasurer listed', ], |
---|
24 | ['financial', False, 'No financial signatories listed. At minimum, this should generally be your president and treasurer.', ], |
---|
25 | ['reservation', False, 'No reservation signatories listed. Members reserving space for the group should be reservation signatories.', ], |
---|
26 | ] |
---|
27 | for role in roles: |
---|
28 | obj = groups.models.OfficerRole.objects.get(slug=role[0]) |
---|
29 | role[0] = obj |
---|
30 | return roles |
---|
31 | |
---|
32 | def check_group(group, roles, ): |
---|
33 | problems = [] |
---|
34 | fail = False |
---|
35 | if group.officer_email or group.description: |
---|
36 | pass |
---|
37 | else: |
---|
38 | problems.append("No basic group information listed") |
---|
39 | fail = True |
---|
40 | for role, cause_fail, msg in roles: |
---|
41 | if len(group.officers(role=role)) == 0: |
---|
42 | problems.append(msg) |
---|
43 | if cause_fail: fail = True |
---|
44 | return fail, problems |
---|
45 | |
---|
46 | def canonicalize_email(email): |
---|
47 | if '@' in email: return email |
---|
48 | elif email == '': return '' |
---|
49 | else: return email + "@mit.edu" |
---|
50 | |
---|
51 | def officers_lists(fd, ): |
---|
52 | reader = csv.DictReader(fd) |
---|
53 | lists = {} |
---|
54 | for d in reader: |
---|
55 | pk = int(d['ASA_STUDENT_GROUP_KEY']) |
---|
56 | lists[pk] = canonicalize_email(d['OFFICER_EMAIL']) |
---|
57 | return lists |
---|
58 | |
---|
59 | def check_groups(old_groups_data): |
---|
60 | roles = get_roles() |
---|
61 | officers = officers_lists(open(old_groups_data, 'r')) |
---|
62 | tmpl = get_template('groups/letters/missing-transition.txt') |
---|
63 | emails = [] |
---|
64 | for group in groups.models.Group.active_groups.all(): |
---|
65 | fail, problems = check_group(group, roles, ) |
---|
66 | if fail: |
---|
67 | try: |
---|
68 | to = [officers[group.pk]] |
---|
69 | except KeyError: |
---|
70 | print "Group %s not found in CSV" % (group, ) |
---|
71 | if group.officer_email: |
---|
72 | to.append(group.officer_email) |
---|
73 | ctx = Context({ |
---|
74 | 'group': group, |
---|
75 | 'problems': problems, |
---|
76 | }) |
---|
77 | body = tmpl.render(ctx) |
---|
78 | email = mail.EmailMessage( |
---|
79 | subject="[ASA] Missing information for %s" % (group.name, ), |
---|
80 | body=body, |
---|
81 | from_email='asa-exec@mit.edu', |
---|
82 | to=to, |
---|
83 | bcc=['asa-db-outgoing@mit.edu'], |
---|
84 | ) |
---|
85 | emails.append(email) |
---|
86 | |
---|
87 | connection = mail.get_connection() |
---|
88 | #connection.send_messages(emails) |
---|
89 | for email in emails: |
---|
90 | print email.subject |
---|
91 | print email.body |
---|
92 | print len(emails) |
---|
93 | |
---|
94 | if __name__ == '__main__': |
---|
95 | check_groups(sys.argv[1]) |
---|