X-Git-Url: https://git.mdrn.pl/edumed.git/blobdiff_plain/543746a467e90915f7eaf60b7b09f5fa498056e0..5d78f2b7af4ee0f1aa48f1e2538ef40ea6b19b00:/wtem/management/commands/wtem_generate_keys.py?ds=inline diff --git a/wtem/management/commands/wtem_generate_keys.py b/wtem/management/commands/wtem_generate_keys.py index 8a14ff9..48cd8b2 100644 --- a/wtem/management/commands/wtem_generate_keys.py +++ b/wtem/management/commands/wtem_generate_keys.py @@ -1,26 +1,21 @@ -from django.core.management.base import BaseCommand, CommandError +# -*- coding: utf-8 -*- +from django.core.management.base import BaseCommand -from contact.models import Contact -from wtem.models import Submission +from wtem.models import Submission, Confirmation class Command(BaseCommand): - - def handle(self, *args, **options): + + def handle(self, **options): new = 0 skipped = 0 - for wtem_contact in Contact.objects.filter(form_tag = 'wtem').order_by('-created_at'): - for student in wtem_contact.body['student']: - if not Submission.objects.filter(email = student['email']).exists(): - args = dict() - for attr in ['first_name', 'last_name', 'email']: - args[attr] = student[attr] - args['contact'] = wtem_contact - Submission.create(**args) - new += 1 - else: - self.stdout.write('skipping ' + student['email'] + ': already exists.') - skipped += 1 + emails = list(Submission.objects.values_list('email', flat=True)) + for confirmation in Confirmation.objects.exclude(email__in=emails): + args = {} + for attr in ['first_name', 'last_name', 'email', 'contact']: + args[attr] = getattr(confirmation, attr) + Submission.create(**args) + new += 1 self.stdout.write('New: ' + str(new) + ', skipped: ' + str(skipped))