Meilleure interface admin

- Les super utilisateurs peuvent gérer les permissions
- Les chefs fanfare ont par défaut les permissions pour éditer les
  utilisateurs (avec leur profil) et les événements. Ils ne peuvent
  rien ajouter ou supprimer par ce biais. Pour créer des utilisateurs ou
  événements il faut passer par les formulaires adéquats sur le site.
This commit is contained in:
Martin Pépin 2017-01-09 00:57:38 +01:00
parent 6b67f8b779
commit e57dd68176

View file

@ -1,11 +1,20 @@
"""
Administration minimaliste du site de l'Ernestophone.
Les chefs peuvent modifier les utilisateurs et les événements.
Les super-utilisateurs peuvent en plus ajouter ou supprimer ces objets et gérer
les permissions.
"""
from django.contrib import admin from django.contrib import admin
from django.contrib.auth.models import User, Group from django.contrib.auth.models import User, Group, Permission
from gestion.models import ErnestoUser
from django.contrib.auth.admin import UserAdmin from django.contrib.auth.admin import UserAdmin
from gestion.models import ErnestoUser
from calendrier.models import Event from calendrier.models import Event
class UserProfileInline(admin.StackedInline): class UserProfileInline(admin.StackedInline):
"""Affichage du profil ernestophone dans la vue UserAdmin"""
model = ErnestoUser model = ErnestoUser
@ -27,23 +36,63 @@ User.profile_get_mails = ProfileInfo("mails", "Recevoir les mails")
class UserProfileAdmin(UserAdmin): class UserProfileAdmin(UserAdmin):
list_display = ('username', 'first_name', 'last_name', 'email', """
Management des utilisateurs de l'ernestosite.
Lors de la sauvegarde, les chefs se voient octroyées les permissions
d'édition des comptes et événements mais il ne peuvent pas en créer via
l'interface admin.
"""
list_display = ['username', 'first_name', 'last_name', 'email',
'profile_phone', 'profile_instru', 'profile_is_ern', 'profile_phone', 'profile_instru', 'profile_is_ern',
'profile_is_chef',) 'profile_is_chef']
list_display_links = ('username', 'email', 'first_name', 'last_name',) list_display_links = ['username', 'email', 'first_name', 'last_name']
list_filter = ('profile__instru',) list_filter = ['profile__instru']
ordering = ('username',) ordering = ['username']
search_fields = ('username', 'first_name', 'last_name', 'profile__phone', search_fields = ['username', 'first_name', 'last_name', 'profile__phone',
'profile__instru',) 'profile__instru']
inlines = [UserProfileInline, ] inlines = [UserProfileInline]
fieldsets = (('Général', {'fields': ('username', 'password', 'first_name',
'last_name', )}), staff_fieldsets = [
('Permissions', {'fields': ('is_active', 'is_staff', ('Général', {'fields': ['username', 'password', 'first_name',
'is_superuser')})) 'last_name']}),
('Permissions', {'fields': ['is_active']})
]
def get_fieldsets(self, request, user=None):
"""
Les super utilisateurs ont toutes les infos.
Les autres (e.g. les chefs) ne peuvent modifier qu'un nombre restreints
de choses.
"""
if not request.user.is_superuser:
return self.staff_fieldsets
return super(UserProfileAdmin, self).get_fieldsets(request, user)
def save_model(self, request, user, form, change):
"""
Ajoute le chef au group Chef.
Le groupe est créé si nécessaire.
"""
chef_group, created = Group.objects.get_or_create(name="Chef")
if created:
# Si le groupe vient d'être créé :
# On associe les bonnes permissions au groupe Chef
perms = [('change_user', 'auth', 'user'),
('change_event', 'calendrier', 'event'),
('change_ernestouser', 'gestion', 'ernestouser')]
for nat_key in perms:
perm = Permission.objects.get_by_natural_key(*nat_key)
chef_group.permissions.add(perm)
# On met tous les chef dans le groupe
chef_group.user_set = User.objects.filter(profile__is_chef=True)
# Les chefs sont dans le groupe Chef
if user.profile.is_chef:
print("J'aime la choucroute")
user.is_staff = True
user.groups.add(chef_group)
user.save()
admin.site.unregister(User) admin.site.unregister(User)
admin.site.unregister(Group)
admin.site.register(User, UserProfileAdmin) admin.site.register(User, UserProfileAdmin)
admin.site.register(Event) admin.site.register(Event)
# Register your models here.