added group to custom user
This commit is contained in:
10
rog/admin.py
10
rog/admin.py
@ -18,18 +18,18 @@ class ShopRouteAdmin(LeafletAdminListMixin, LeafletGeoAdminMixin, admin.ModelAdm
|
|||||||
list_display=['name',]
|
list_display=['name',]
|
||||||
|
|
||||||
class UserAdminConfig(UserAdmin):
|
class UserAdminConfig(UserAdmin):
|
||||||
search_fields = ('email',)
|
search_fields = ('email', 'group',)
|
||||||
list_filter = ('email',)
|
list_filter = ('email', 'group')
|
||||||
ordering = ('email',)
|
ordering = ('email',)
|
||||||
list_display = ('email', 'is_active', 'is_staff',)
|
list_display = ('email', 'group', 'is_active', 'is_staff',)
|
||||||
|
|
||||||
fieldsets = (
|
fieldsets = (
|
||||||
(None, {'fields':('email',)}),
|
(None, {'fields':('email', 'group')}),
|
||||||
('Permissions', {'fields':('is_staff', 'is_active',)}),
|
('Permissions', {'fields':('is_staff', 'is_active',)}),
|
||||||
)
|
)
|
||||||
|
|
||||||
add_fieldsets = (
|
add_fieldsets = (
|
||||||
(None, {'classes':('wide',), 'fields':('email','password1', 'password2')}),
|
(None, {'classes':('wide',), 'fields':('email', 'group', 'password1', 'password2')}),
|
||||||
)
|
)
|
||||||
|
|
||||||
class LocationAdmin(LeafletGeoAdmin):
|
class LocationAdmin(LeafletGeoAdmin):
|
||||||
|
|||||||
18
rog/migrations/0024_customuser_group.py
Normal file
18
rog/migrations/0024_customuser_group.py
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
# Generated by Django 3.2.9 on 2022-08-29 14:11
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('rog', '0023_alter_location_cp'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='customuser',
|
||||||
|
name='group',
|
||||||
|
field=models.CharField(choices=[('G1', '大垣-初心者'), ('G2', '大垣-3時間'), ('G3', '大垣-5時間')], default='G1', max_length=2),
|
||||||
|
),
|
||||||
|
]
|
||||||
@ -35,20 +35,20 @@ db = Db(dbname=env("POSTGRES_DBNAME"), user=env("POSTGRES_USER"), password=env("
|
|||||||
|
|
||||||
class CustomUserManager(BaseUserManager):
|
class CustomUserManager(BaseUserManager):
|
||||||
|
|
||||||
def create_user(self, email, password, **other_fields):
|
def create_user(self, email, password, group, **other_fields):
|
||||||
|
|
||||||
if not email:
|
if not email:
|
||||||
raise ValueError(_("You must provide an email address"))
|
raise ValueError(_("You must provide an email address"))
|
||||||
|
|
||||||
email = self.normalize_email(email)
|
email = self.normalize_email(email)
|
||||||
user=self.model(email=email, **other_fields)
|
user=self.model(email=email, group=group, **other_fields)
|
||||||
user.set_password(password)
|
user.set_password(password)
|
||||||
user.save()
|
user.save()
|
||||||
|
|
||||||
return user
|
return user
|
||||||
|
|
||||||
|
|
||||||
def create_superuser(self, email, password, **other_fields):
|
def create_superuser(self, email, password, group, **other_fields):
|
||||||
other_fields.setdefault('is_staff', True)
|
other_fields.setdefault('is_staff', True)
|
||||||
other_fields.setdefault('is_superuser', True)
|
other_fields.setdefault('is_superuser', True)
|
||||||
other_fields.setdefault('is_active', True)
|
other_fields.setdefault('is_active', True)
|
||||||
@ -58,7 +58,7 @@ class CustomUserManager(BaseUserManager):
|
|||||||
if other_fields.get('is_superuser') is not True:
|
if other_fields.get('is_superuser') is not True:
|
||||||
raise ValueError(_('Supperuser must assigned to superuser=True'))
|
raise ValueError(_('Supperuser must assigned to superuser=True'))
|
||||||
|
|
||||||
return self.create_user(email, password, **other_fields)
|
return self.create_user(email, password, group, **other_fields)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -138,10 +138,19 @@ class GifuAreas(models.Model):
|
|||||||
|
|
||||||
|
|
||||||
class CustomUser(AbstractBaseUser, PermissionsMixin):
|
class CustomUser(AbstractBaseUser, PermissionsMixin):
|
||||||
|
class Groups(models.TextChoices):
|
||||||
|
GB1 = 'G1', '大垣-初心者'
|
||||||
|
GB2 = 'G2', '大垣-3時間'
|
||||||
|
GB3 = 'G3', '大垣-5時間'
|
||||||
|
|
||||||
email = models.EmailField(_("email address"), unique=True)
|
email = models.EmailField(_("email address"), unique=True)
|
||||||
is_staff = models.BooleanField(default=False)
|
is_staff = models.BooleanField(default=False)
|
||||||
is_active = models.BooleanField(default=True)
|
is_active = models.BooleanField(default=True)
|
||||||
|
group = models.CharField(max_length=2,
|
||||||
|
choices=Groups.choices,
|
||||||
|
default=Groups.GB1)
|
||||||
USERNAME_FIELD = 'email'
|
USERNAME_FIELD = 'email'
|
||||||
|
REQUIRED_FIELDS = ['group',]
|
||||||
|
|
||||||
objects = CustomUserManager()
|
objects = CustomUserManager()
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user