X-Git-Url: https://git.mdrn.pl/edumed.git/blobdiff_plain/277c595277997742a3d4efda1ca984734f95125e..d555d988764995ea1f9f5ece46f453a66f09b334:/wtem/management/commands/wtem_send_results_csv.py?ds=sidebyside diff --git a/wtem/management/commands/wtem_send_results_csv.py b/wtem/management/commands/wtem_send_results_csv.py deleted file mode 100644 index c0f5261..0000000 --- a/wtem/management/commands/wtem_send_results_csv.py +++ /dev/null @@ -1,115 +0,0 @@ -# -*- coding: utf-8 -*- - -from optparse import make_option - -from django.core.management.base import BaseCommand -from django.template.loader import render_to_string -from django.utils import translation - -from wtem.management.commands import send_mail -from wtem.models import Submission - - -def get_submissions(): - return sorted(Submission.objects.exclude(answers=None).all(), key=lambda s: -s.final_result) - -minimum = 52 - - -class Command(BaseCommand): - args = 'csv_filename' - - option_list = BaseCommand.option_list + ( - make_option( - '--to-teachers', - action='store_true', - dest='to_teachers', - default=False, - help='Send emails to teachers'), - make_option( - '--to-students', - action='store_true', - dest='to_students', - default=False, - help='Send emails to students'), - make_option( - '--only-to', - action='store', - dest='only_to', - default=None, - help='Send emails only to listed addresses'), - ) - - def handle(self, csv_filename, *args, **options): - translation.activate('pl') - self.results = [line.decode('utf-8').strip('\n').split(',') for line in open(csv_filename)] - for target in ['to_teachers', 'to_students']: - if options[target]: - self.sent = 0 - self.failed = 0 - getattr(self, 'handle_' + target)(*args, **options) - - def handle_to_students(self, *args, **options): - self.stdout.write('>>> Sending results to students') - subject = 'Wyniki I etapu Wielkiego Turnieju Edukacji Medialnej' - - for email, last_name, first_name, final_result in self.results: - if options['only_to'] and email != options['only_to']: - continue - if final_result == 'dyskwalifikacja': - template = 'results_student_disqualified.txt' - elif float(final_result) < minimum: - template = 'results_student_failed.txt' - else: - template = 'results_student_passed.txt' - message = render_to_string('wtem/' + template, dict(final_result=final_result)) - self.send_message(message, subject, email) - - self.sum_up() - - def handle_to_teachers(self, *args, **options): - self.stdout.write('>>> Sending results to teachers') - subject = 'Wyniki I etapu Wielkiego Turnieju Edukacji Medialnej' - - submissions_by_contact = dict() - - from decimal import Decimal, InvalidOperation - - def dec_or_0(s): - try: - return Decimal(s) - except InvalidOperation: - return Decimal(0) - - sorted_results = sorted(self.results, key=lambda r: dec_or_0(r[3]), reverse=True) - for email, last_name, first_name, final_result in sorted_results: - submission = Submission.objects.get(email=email) - teacher_email = submission.contact.contact - if options['only_to'] and teacher_email != options['only_to']: - continue - submissions_by_contact.setdefault(teacher_email, []).append({ - 'first_name': first_name, - 'last_name': last_name, - 'final_result': final_result, - }) - - for email, submissions in submissions_by_contact.items(): - # contact = Contact.objects.get(id=contact_id) - message = render_to_string('wtem/results_teacher.txt', dict(submissions=submissions)) - self.send_message(message, subject, email) - - self.sum_up() - - def sum_up(self): - self.stdout.write('sent: %s, failed: %s' % (self.sent, self.failed)) - - def send_message(self, message, subject, email): - self.stdout.write('>>> sending results to %s' % email) - try: - send_mail(subject=subject, body=message, to=[email]) - except BaseException, e: - self.failed += 1 - self.stdout.write('failed sending to: ' + email + ': ' + str(e)) - else: - self.sent += 1 - self.stdout.write('message sent to: ' + email)