Merge remote-tracking branch 'origin/develop'
This commit is contained in:
commit
e31bd1757c
|
|
@ -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)
|
||||||
|
|
@ -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),
|
||||||
|
),
|
||||||
|
]
|
||||||
|
|
@ -57,7 +57,7 @@ class User(AbstractUser):
|
||||||
class SchoolClass(models.Model):
|
class SchoolClass(models.Model):
|
||||||
name = models.CharField(max_length=100, blank=False, null=False, unique=True)
|
name = models.CharField(max_length=100, blank=False, null=False, unique=True)
|
||||||
is_deleted = models.BooleanField(blank=False, null=False, default=False)
|
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):
|
def __str__(self):
|
||||||
return 'SchoolClass {}-{}'.format(self.id, self.name)
|
return 'SchoolClass {}-{}'.format(self.id, self.name)
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue