mirror of
https://gitlab2.federez.net/re2o/re2o
synced 2024-12-23 23:43:47 +00:00
Refactor serviceuser admin
This commit is contained in:
parent
eb5becb0db
commit
ee0fe7b24e
2 changed files with 12 additions and 38 deletions
|
@ -51,8 +51,7 @@ from .models import (
|
||||||
)
|
)
|
||||||
from .forms import (
|
from .forms import (
|
||||||
UserAdminForm,
|
UserAdminForm,
|
||||||
ServiceUserChangeForm,
|
ServiceUserAdminForm,
|
||||||
ServiceUserCreationForm,
|
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
@ -230,15 +229,15 @@ class ServiceUserAdmin(VersionAdmin, BaseUserAdmin):
|
||||||
mot de passe; etc"""
|
mot de passe; etc"""
|
||||||
|
|
||||||
# The forms to add and change user instances
|
# The forms to add and change user instances
|
||||||
form = ServiceUserChangeForm
|
form = ServiceUserAdminForm
|
||||||
add_form = ServiceUserCreationForm
|
add_form = ServiceUserAdminForm
|
||||||
|
|
||||||
# The fields to be used in displaying the User model.
|
# The fields to be used in displaying the User model.
|
||||||
# These override the definitions on the base UserAdmin
|
# These override the definitions on the base UserAdmin
|
||||||
# that reference specific fields on auth.User.
|
# that reference specific fields on auth.User.
|
||||||
list_display = ("pseudo", "access_group")
|
list_display = ("pseudo", "access_group")
|
||||||
list_filter = ()
|
list_filter = ()
|
||||||
fieldsets = ((None, {"fields": ("pseudo", "password", "access_group")}),)
|
fieldsets = ((None, {"fields": ("pseudo", "access_group", "comment", "password1", "password2")}),)
|
||||||
# add_fieldsets is not a standard ModelAdmin attribute. UserAdmin
|
# add_fieldsets is not a standard ModelAdmin attribute. UserAdmin
|
||||||
# overrides get_fieldsets to use this attribute when creating a user.
|
# overrides get_fieldsets to use this attribute when creating a user.
|
||||||
add_fieldsets = (
|
add_fieldsets = (
|
||||||
|
@ -263,9 +262,6 @@ admin.site.register(Ban, BanAdmin)
|
||||||
admin.site.register(EMailAddress, EMailAddressAdmin)
|
admin.site.register(EMailAddress, EMailAddressAdmin)
|
||||||
admin.site.register(Whitelist, WhitelistAdmin)
|
admin.site.register(Whitelist, WhitelistAdmin)
|
||||||
admin.site.register(Request, RequestAdmin)
|
admin.site.register(Request, RequestAdmin)
|
||||||
# Now register the new UserAdmin...
|
|
||||||
admin.site.unregister(ServiceUser)
|
|
||||||
admin.site.register(ServiceUser, ServiceUserAdmin)
|
|
||||||
# ... and, since we're not using Django's built-in permissions,
|
# ... and, since we're not using Django's built-in permissions,
|
||||||
# unregister the Group model from admin.
|
# unregister the Group model from admin.
|
||||||
admin.site.unregister(Group)
|
admin.site.unregister(Group)
|
||||||
|
|
|
@ -122,7 +122,7 @@ class PassForm(FormRevMixin, FieldPermissionFormMixin, forms.ModelForm):
|
||||||
|
|
||||||
|
|
||||||
class UserAdminForm(FormRevMixin, forms.ModelForm):
|
class UserAdminForm(FormRevMixin, forms.ModelForm):
|
||||||
"""A form for creating new users. Includes all the required
|
"""A form for creating new and editing users. Includes all the required
|
||||||
fields, plus a repeated password.
|
fields, plus a repeated password.
|
||||||
|
|
||||||
Formulaire pour la création d'un user. N'est utilisé que pour
|
Formulaire pour la création d'un user. N'est utilisé que pour
|
||||||
|
@ -171,7 +171,7 @@ class UserAdminForm(FormRevMixin, forms.ModelForm):
|
||||||
return user
|
return user
|
||||||
|
|
||||||
|
|
||||||
class ServiceUserCreationForm(FormRevMixin, forms.ModelForm):
|
class ServiceUserAdminForm(FormRevMixin, forms.ModelForm):
|
||||||
"""A form for creating new users. Includes all the required
|
"""A form for creating new users. Includes all the required
|
||||||
fields, plus a repeated password.
|
fields, plus a repeated password.
|
||||||
|
|
||||||
|
@ -179,25 +179,26 @@ class ServiceUserCreationForm(FormRevMixin, forms.ModelForm):
|
||||||
Requiert seulement un mot de passe; et un pseudo"""
|
Requiert seulement un mot de passe; et un pseudo"""
|
||||||
|
|
||||||
password1 = forms.CharField(
|
password1 = forms.CharField(
|
||||||
label=_("Password"), widget=forms.PasswordInput, min_length=8, max_length=255
|
label=_("Password"),
|
||||||
|
widget=forms.PasswordInput,
|
||||||
|
max_length=255,
|
||||||
)
|
)
|
||||||
password2 = forms.CharField(
|
password2 = forms.CharField(
|
||||||
label=_("Password confirmation"),
|
label=_("Password confirmation"),
|
||||||
widget=forms.PasswordInput,
|
widget=forms.PasswordInput,
|
||||||
min_length=8,
|
|
||||||
max_length=255,
|
max_length=255,
|
||||||
)
|
)
|
||||||
|
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
prefix = kwargs.pop("prefix", self.Meta.model.__name__)
|
prefix = kwargs.pop("prefix", self.Meta.model.__name__)
|
||||||
super(ServiceUserCreationForm, self).__init__(*args, prefix=prefix, **kwargs)
|
super(ServiceUserAdminForm, self).__init__(*args, prefix=prefix, **kwargs)
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
model = ServiceUser
|
model = ServiceUser
|
||||||
fields = ("pseudo",)
|
fields = ("pseudo",)
|
||||||
|
|
||||||
def clean_password2(self):
|
def clean_password2(self):
|
||||||
"""Verifie que password1 et 2 sont indentiques"""
|
"""Verifie que password1 et 2 sont identiques"""
|
||||||
# Check that the two password entries match
|
# Check that the two password entries match
|
||||||
password1 = self.cleaned_data.get("password1")
|
password1 = self.cleaned_data.get("password1")
|
||||||
password2 = self.cleaned_data.get("password2")
|
password2 = self.cleaned_data.get("password2")
|
||||||
|
@ -207,35 +208,12 @@ class ServiceUserCreationForm(FormRevMixin, forms.ModelForm):
|
||||||
|
|
||||||
def save(self, commit=True):
|
def save(self, commit=True):
|
||||||
# Save the provided password in hashed format
|
# Save the provided password in hashed format
|
||||||
user = super(ServiceUserCreationForm, self).save(commit=False)
|
user = super(ServiceUserAdminForm, self).save(commit=False)
|
||||||
user.set_password(self.cleaned_data["password1"])
|
user.set_password(self.cleaned_data["password1"])
|
||||||
user.save()
|
user.save()
|
||||||
return user
|
return user
|
||||||
|
|
||||||
|
|
||||||
class ServiceUserChangeForm(FormRevMixin, 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.
|
|
||||||
|
|
||||||
Formulaire pour l'edition des service users coté admin
|
|
||||||
"""
|
|
||||||
|
|
||||||
password = ReadOnlyPasswordHashField()
|
|
||||||
|
|
||||||
def __init__(self, *args, **kwargs):
|
|
||||||
prefix = kwargs.pop("prefix", self.Meta.model.__name__)
|
|
||||||
super(ServiceUserChangeForm, self).__init__(*args, prefix=prefix, **kwargs)
|
|
||||||
|
|
||||||
class Meta:
|
|
||||||
model = ServiceUser
|
|
||||||
fields = ("pseudo",)
|
|
||||||
|
|
||||||
def clean_password(self):
|
|
||||||
"""Dummy fun"""
|
|
||||||
return self.initial["password"]
|
|
||||||
|
|
||||||
|
|
||||||
class ResetPasswordForm(forms.Form):
|
class ResetPasswordForm(forms.Form):
|
||||||
"""Formulaire de demande de reinitialisation de mot de passe,
|
"""Formulaire de demande de reinitialisation de mot de passe,
|
||||||
mdp oublié"""
|
mdp oublié"""
|
||||||
|
|
Loading…
Reference in a new issue