104 lines
3.6 KiB
Python
Executable file
104 lines
3.6 KiB
Python
Executable file
from django import forms
|
|
from django.contrib import admin
|
|
from django.contrib.auth.admin import UserAdmin as BaseUserAdmin
|
|
from django.contrib.auth.forms import ReadOnlyPasswordHashField
|
|
|
|
from .models import CustomUser, StripeCustomer
|
|
|
|
|
|
# Refer https://docs.djangoproject.com/en/2.0/topics/auth/customizing/
|
|
# for understanding custom auth user model
|
|
|
|
|
|
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 = CustomUser
|
|
fields = ('email', 'user_permissions', 'email', 'is_admin')
|
|
|
|
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().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(
|
|
label="Password",
|
|
help_text=(
|
|
"Raw passwords are not stored, so there is no way to see "
|
|
"this user's password, but you can change the password "
|
|
"using <a href=\"../password/\">this form</a>.")
|
|
)
|
|
|
|
class Meta:
|
|
model = CustomUser
|
|
fields = ('email', 'password', 'is_admin')
|
|
|
|
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 CustomUserAdmin(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_admin', 'is_superuser'
|
|
)
|
|
list_filter = ()
|
|
fieldsets = (
|
|
(None, {'fields': ('email',)}),
|
|
('Change Password',
|
|
{'fields': ('password',),
|
|
'description': "Raw passwords are not stored, so there is no way to "
|
|
"see this user's password, but you can change the "
|
|
"password using <a href=\"../password/\">this "
|
|
"form</a>."
|
|
}
|
|
),
|
|
('Permissions', {'fields': ('is_admin', 'user_permissions',
|
|
'groups')}),
|
|
)
|
|
# 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', 'password1', 'password2')}
|
|
),
|
|
)
|
|
search_fields = ('email',)
|
|
ordering = ('email',)
|
|
filter_horizontal = ()
|
|
|
|
|
|
admin.site.register(CustomUser, CustomUserAdmin)
|
|
admin.site.register(StripeCustomer)
|