diff --git a/server/core/management/commands/create_teacher.py b/server/core/management/commands/create_teacher.py new file mode 100644 index 00000000..b7cd2471 --- /dev/null +++ b/server/core/management/commands/create_teacher.py @@ -0,0 +1,40 @@ +import csv + +from django.core.management import BaseCommand +import os +from django.conf import settings + +from users.models import User, SchoolClass, Role, UserRole + + +class Command(BaseCommand): + def add_arguments(self, parser): + parser.add_argument('first_name') + parser.add_argument('last_name') + parser.add_argument('email') + + def handle(self, *args, **options): + first_name = options['first_name'] + last_name = options['last_name'] + email = options['email'] + self.stdout.write('Creating user {} {} with email {}'.format(first_name, last_name, email)) + try: + school_class_name = 'Klasse {} {}'.format(first_name, last_name) + + user, created = User.objects.get_or_create(email=email, username=email) + user.first_name = first_name + user.last_name = last_name + user.set_password(User.objects.make_random_password()) + user.save() + + self.stdout.write("Assigning teacher role") + teacher = Role.objects.get(key='teacher') + UserRole.objects.get_or_create(user=user, role=teacher) + + school, _ = SchoolClass.objects.get_or_create(name=school_class_name) + user.school_classes.add(school) + + self.stdout.write("") + + except Exception as e: + self.stdout.write(e) diff --git a/server/users/migrations/0008_auto_20190904_1410.py b/server/users/migrations/0008_auto_20190904_1410.py new file mode 100644 index 00000000..ac10c2dc --- /dev/null +++ b/server/users/migrations/0008_auto_20190904_1410.py @@ -0,0 +1,19 @@ +# Generated by Django 2.0.6 on 2019-09-04 14:10 + +from django.conf import settings +from django.db import migrations, models + + +class Migration(migrations.Migration): + + dependencies = [ + ('users', '0007_usersetting'), + ] + + operations = [ + migrations.AlterField( + model_name='schoolclass', + name='users', + field=models.ManyToManyField(blank=True, related_name='school_classes', to=settings.AUTH_USER_MODEL), + ), + ] diff --git a/server/users/models.py b/server/users/models.py index 5fb2f2ea..b6d01c69 100644 --- a/server/users/models.py +++ b/server/users/models.py @@ -57,7 +57,7 @@ class User(AbstractUser): class SchoolClass(models.Model): name = models.CharField(max_length=100, blank=False, null=False, unique=True) is_deleted = models.BooleanField(blank=False, null=False, default=False) - users = models.ManyToManyField(get_user_model(), related_name='school_classes') + users = models.ManyToManyField(get_user_model(), related_name='school_classes', blank=True) def __str__(self): return 'SchoolClass {}-{}'.format(self.id, self.name)