From e16fa08b915562c6ab77ce7bb79a9d766b5a4036 Mon Sep 17 00:00:00 2001 From: Mitch Riedstra Date: Thu, 2 Nov 2017 16:03:14 -0400 Subject: Initial setup to use a custom User model, I still need to figure out how to use the built in Django permissions though --- app/dispatchAuth/admin.py | 90 +++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 90 insertions(+) create mode 100644 app/dispatchAuth/admin.py (limited to 'app/dispatchAuth/admin.py') diff --git a/app/dispatchAuth/admin.py b/app/dispatchAuth/admin.py new file mode 100644 index 0000000..67b1170 --- /dev/null +++ b/app/dispatchAuth/admin.py @@ -0,0 +1,90 @@ +from django import forms +from django.contrib import admin +from django.contrib.auth.models import Group +from django.contrib.auth.admin import UserAdmin as BaseUserAdmin +from django.contrib.auth.forms import ReadOnlyPasswordHashField + +# Register your models here. + + +from .models import User + +class UserCreationForm(forms.ModelForm): + """A form for creating new users. Includes all the required + fields, plus a repeated password.""" + password1 = forms.CharField(label='Password', widget=forms.PasswordInput) + password2 = forms.CharField(label='Password confirmation', widget=forms.PasswordInput) + + class Meta: + model = User + fields = ('email', 'first_name', 'last_name') + + def clean_password2(self): + # Check that the two password entries match + password1 = self.cleaned_data.get("password1") + password2 = self.cleaned_data.get("password2") + if password1 and password2 and password1 != password2: + raise forms.ValidationError("Passwords don't match") + return password2 + + def save(self, commit=True): + # Save the provided password in hashed format + user = super(UserCreationForm, self).save(commit=False) + user.set_password(self.cleaned_data["password1"]) + if commit: + user.save() + return user + + +class UserChangeForm(forms.ModelForm): + """A form for updating users. Includes all the fields on + the user, but replaces the password field with admin's + password hash display field. + """ + password = ReadOnlyPasswordHashField() + + class Meta: + model = User + fields = ('email', 'password', 'first_name', 'last_name', 'is_active', + 'is_superuser') + + def clean_password(self): + # Regardless of what the user provides, return the initial value. + # This is done here, rather than on the field, because the + # field does not have access to the initial value + return self.initial["password"] + + +class UserAdmin(BaseUserAdmin): + # The forms to add and change user instances + form = UserChangeForm + add_form = UserCreationForm + + # The fields to be used in displaying the User model. + # These override the definitions on the base UserAdmin + # that reference specific fields on auth.User. + list_display = ('email', 'is_superuser') + list_filter = ('is_superuser',) + fieldsets = ( + (None, {'fields': ('email', 'password')}), + ('Personal info', {'fields': ('first_name','last_name')}), + ('Permissions', {'fields': ('is_superuser',)}), + ) + # add_fieldsets is not a standard ModelAdmin attribute. UserAdmin + # overrides get_fieldsets to use this attribute when creating a user. + add_fieldsets = ( + (None, { + 'classes': ('wide',), + 'fields': ('email', 'first_name', 'last_name', 'password1', 'password2')} + ), + ) + search_fields = ('email',) + ordering = ('email',) + filter_horizontal = () + +# Now register the new UserAdmin... +admin.site.register(User, UserAdmin) + +# ... and, since we're not using Django's built-in permissions, +# unregister the Group model from admin. +# admin.site.unregister(Group) -- cgit v1.2.3