ded824bddd
KFetGroup model - Provides a distinction from non-kfet Groups. - Convert code appropriately. - Initially filled from Groups containing K-Fêt (this was the previous distinction) in the kfetauth.0002 migration. Permission proxy model (kfetauth app) - Proxy of the django.contrib.auth Permission model. - Adds the 'kfet' manager which returns only kfet-related permissions. KeepUnselectableModelFormMixin - Helps to keep the unselectable items of many-to-many field for ModelForm. - 'kfetauth' forms (related to KFetGroup) use this mixin. Using KFetGroup allows to simplify the 'kfet/account_group_form.html' template. A bug is also fixed in 'kfet/form_field_snippet.html', which could lead to prevent field displays if they used CheckboxSelectMultiple widget.
74 lines
2.3 KiB
Python
74 lines
2.3 KiB
Python
from django.contrib import messages
|
|
from django.contrib.messages.views import SuccessMessageMixin
|
|
from django.contrib.auth import authenticate, login
|
|
from django.contrib.auth.decorators import permission_required
|
|
from django.contrib.auth.models import User
|
|
from django.core.urlresolvers import reverse_lazy
|
|
from django.db.models import Prefetch
|
|
from django.shortcuts import render
|
|
from django.utils.crypto import get_random_string
|
|
from django.views.generic.edit import CreateView, UpdateView
|
|
|
|
from django_cas_ng.views import logout as cas_logout_view
|
|
|
|
from kfet.decorators import teamkfet_required
|
|
|
|
from .forms import GroupForm
|
|
from .models import GenericTeamToken, Group
|
|
|
|
|
|
@teamkfet_required
|
|
def login_genericteam(request):
|
|
# Check si besoin de déconnecter l'utilisateur de CAS
|
|
cas_logout = None
|
|
if request.user.profile.login_clipper:
|
|
# Récupèration de la vue de déconnexion de CAS
|
|
# Ici, car request sera modifié après
|
|
next_page = request.META.get('HTTP_REFERER', None)
|
|
cas_logout = cas_logout_view(request, next_page=next_page)
|
|
|
|
# Authentification du compte générique
|
|
token = GenericTeamToken.objects.create(token=get_random_string(50))
|
|
user = authenticate(username="kfet_genericteam", token=token.token)
|
|
login(request, user)
|
|
|
|
messages.success(request, "Connecté en utilisateur partagé")
|
|
|
|
return cas_logout or render(request, "kfet/login_genericteam.html")
|
|
|
|
|
|
@permission_required('kfet.manage_perms')
|
|
def account_group(request):
|
|
user_pre = Prefetch(
|
|
'user_set',
|
|
queryset=User.objects.select_related('profile__account_kfet'),
|
|
)
|
|
groups = (
|
|
Group.objects
|
|
.prefetch_related('permissions', user_pre)
|
|
)
|
|
return render(request, 'kfet/account_group.html', {
|
|
'groups': groups,
|
|
})
|
|
|
|
|
|
class BaseAccountGroupFormViewMixin:
|
|
model = Group
|
|
form_class = GroupForm
|
|
template_name = 'kfet/account_group_form.html'
|
|
success_url = reverse_lazy('kfet.account.group')
|
|
|
|
|
|
class AccountGroupFormViewMixin(
|
|
SuccessMessageMixin,
|
|
BaseAccountGroupFormViewMixin,
|
|
):
|
|
pass
|
|
|
|
|
|
class AccountGroupCreate(AccountGroupFormViewMixin, CreateView):
|
|
success_message = 'Nouveau groupe : %(name)s'
|
|
|
|
|
|
class AccountGroupUpdate(AccountGroupFormViewMixin, UpdateView):
|
|
success_message = 'Groupe modifié : %(name)s'
|