From 03a7eda48e342fc20f9f5c34320ccc5ec23e1528 Mon Sep 17 00:00:00 2001 From: Xeryus Stokkel Date: Mon, 17 Jan 2022 14:46:00 +0100 Subject: [PATCH] Create user model that supports SCIM --- scim_app/core/admin.py | 4 ++- scim_app/core/migrations/0001_initial.py | 45 ++++++++++++++++++++++++ scim_app/core/models.py | 6 +++- scim_app/scim_app/settings.py | 2 ++ 4 files changed, 55 insertions(+), 2 deletions(-) create mode 100644 scim_app/core/migrations/0001_initial.py diff --git a/scim_app/core/admin.py b/scim_app/core/admin.py index 8c38f3f..f91be8f 100644 --- a/scim_app/core/admin.py +++ b/scim_app/core/admin.py @@ -1,3 +1,5 @@ from django.contrib import admin +from django.contrib.auth.admin import UserAdmin +from .models import User -# Register your models here. +admin.site.register(User, UserAdmin) diff --git a/scim_app/core/migrations/0001_initial.py b/scim_app/core/migrations/0001_initial.py new file mode 100644 index 0000000..504f0eb --- /dev/null +++ b/scim_app/core/migrations/0001_initial.py @@ -0,0 +1,45 @@ +# Generated by Django 3.2 on 2022-01-17 13:41 + +import django.contrib.auth.models +import django.contrib.auth.validators +from django.db import migrations, models +import django.utils.timezone + + +class Migration(migrations.Migration): + + initial = True + + dependencies = [ + ('auth', '0012_alter_user_first_name_max_length'), + ] + + operations = [ + migrations.CreateModel( + name='User', + fields=[ + ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), + ('password', models.CharField(max_length=128, verbose_name='password')), + ('last_login', models.DateTimeField(blank=True, null=True, verbose_name='last login')), + ('is_superuser', models.BooleanField(default=False, help_text='Designates that this user has all permissions without explicitly assigning them.', verbose_name='superuser status')), + ('username', models.CharField(error_messages={'unique': 'A user with that username already exists.'}, help_text='Required. 150 characters or fewer. Letters, digits and @/./+/-/_ only.', max_length=150, unique=True, validators=[django.contrib.auth.validators.UnicodeUsernameValidator()], verbose_name='username')), + ('first_name', models.CharField(blank=True, max_length=150, verbose_name='first name')), + ('last_name', models.CharField(blank=True, max_length=150, verbose_name='last name')), + ('email', models.EmailField(blank=True, max_length=254, verbose_name='email address')), + ('is_staff', models.BooleanField(default=False, help_text='Designates whether the user can log into this admin site.', verbose_name='staff status')), + ('is_active', models.BooleanField(default=True, help_text='Designates whether this user should be treated as active. Unselect this instead of deleting accounts.', verbose_name='active')), + ('date_joined', models.DateTimeField(default=django.utils.timezone.now, verbose_name='date joined')), + ('scim_id', models.CharField(blank=True, default=None, help_text='A unique identifier for a SCIM resource as defined by the service provider.', max_length=254, null=True, unique=True, verbose_name='SCIM ID')), + ('scim_external_id', models.CharField(blank=True, db_index=True, default=None, help_text='A string that is an identifier for the resource as defined by the provisioning client.', max_length=254, null=True, verbose_name='SCIM External ID')), + ('scim_username', models.CharField(blank=True, db_index=True, default=None, help_text="A service provider's unique identifier for the user", max_length=254, null=True, verbose_name='SCIM Username')), + ('groups', models.ManyToManyField(blank=True, help_text='The groups this user belongs to. A user will get all permissions granted to each of their groups.', related_name='user_set', related_query_name='user', to='auth.Group', verbose_name='groups')), + ('user_permissions', models.ManyToManyField(blank=True, help_text='Specific permissions for this user.', related_name='user_set', related_query_name='user', to='auth.Permission', verbose_name='user permissions')), + ], + options={ + 'abstract': False, + }, + managers=[ + ('objects', django.contrib.auth.models.UserManager()), + ], + ), + ] diff --git a/scim_app/core/models.py b/scim_app/core/models.py index 71a8362..e471679 100644 --- a/scim_app/core/models.py +++ b/scim_app/core/models.py @@ -1,3 +1,7 @@ +from django.contrib.auth.models import AbstractUser from django.db import models -# Create your models here. +from django_scim.models import AbstractSCIMUserMixin + +class User(AbstractSCIMUserMixin, AbstractUser): + pass diff --git a/scim_app/scim_app/settings.py b/scim_app/scim_app/settings.py index 8bcc78d..dee56e4 100644 --- a/scim_app/scim_app/settings.py +++ b/scim_app/scim_app/settings.py @@ -157,3 +157,5 @@ AUTHENTICATION_BACKENDS = [ 'oauth2_provider.backends.OAuth2Backend', 'django.contrib.auth.backends.ModelBackend', ] + +AUTH_USER_MODEL = 'core.User'