1
0
mirror of https://gitlab.crans.org/mediatek/med.git synced 2025-07-06 09:23:55 +02:00

Change media permissions

This commit is contained in:
Alexandre Iooss
2019-08-08 16:33:05 +02:00
parent 8a1af4c2b3
commit deb28aa93b
13 changed files with 147 additions and 275 deletions

View File

@ -10,7 +10,6 @@ from django.shortcuts import render, redirect
from django.template.context_processors import csrf
from django.utils import timezone
from reversion import revisions as reversion
from reversion.models import Version
from med.settings import PAGINATION_NUMBER
from users.models import User
@ -25,7 +24,7 @@ def form(ctx, template, request):
@login_required
@permission_required('perm')
@permission_required('media.add_auteur')
def add_auteur(request):
auteur = AuteurForm(request.POST or None)
if auteur.is_valid():
@ -39,7 +38,7 @@ def add_auteur(request):
@login_required
@permission_required('perm')
@permission_required('media.edit_auteur')
def edit_auteur(request, auteurid):
try:
auteur_instance = Auteur.objects.get(pk=auteurid)
@ -51,14 +50,15 @@ def edit_auteur(request, auteurid):
with transaction.atomic(), reversion.create_revision():
auteur.save()
reversion.set_user(request.user)
reversion.set_comment("Champs modifié(s) : %s" % ', '.join(field for field in auteur.changed_data))
reversion.set_comment("Champs modifié(s) : %s" % ', '.join(
field for field in auteur.changed_data))
messages.success(request, "Auteur modifié")
return redirect("/media/index_auteurs/")
return form({'mediaform': auteur}, 'media/media.html', request)
@login_required
@permission_required('perm')
@permission_required('media.delete_auteur')
def del_auteur(request, auteurid):
try:
auteur_instance = Auteur.objects.get(pk=auteurid)
@ -71,11 +71,12 @@ def del_auteur(request, auteurid):
reversion.set_user(request.user)
messages.success(request, "L'auteur a été détruit")
return redirect("/media/index_auteurs")
return form({'objet': auteur_instance, 'objet_name': 'auteur'}, 'media/delete.html', request)
return form({'objet': auteur_instance, 'objet_name': 'auteur'},
'media/delete.html', request)
@login_required
@permission_required('perm')
@permission_required('media.add_media')
def add_media(request):
media = MediaForm(request.POST or None)
if media.is_valid():
@ -89,7 +90,7 @@ def add_media(request):
@login_required
@permission_required('perm')
@permission_required('media.edit_media')
def edit_media(request, mediaid):
try:
media_instance = Media.objects.get(pk=mediaid)
@ -101,14 +102,15 @@ def edit_media(request, mediaid):
with transaction.atomic(), reversion.create_revision():
media.save()
reversion.set_user(request.user)
reversion.set_comment("Champs modifié(s) : %s" % ', '.join(field for field in media.changed_data))
reversion.set_comment("Champs modifié(s) : %s" % ', '.join(
field for field in media.changed_data))
messages.success(request, "Media modifié")
return redirect("/media/index_medias/")
return form({'mediaform': media}, 'media/media.html', request)
@login_required
@permission_required('perm')
@permission_required('media.delete_media')
def del_media(request, mediaid):
try:
media_instance = Media.objects.get(pk=mediaid)
@ -121,11 +123,12 @@ def del_media(request, mediaid):
reversion.set_user(request.user)
messages.success(request, "Le media a été détruit")
return redirect("/media/index_medias")
return form({'objet': media_instance, 'objet_name': 'media'}, 'media/delete.html', request)
return form({'objet': media_instance, 'objet_name': 'media'},
'media/delete.html', request)
@login_required
@permission_required('perm')
@permission_required('media.add_jeu')
def add_jeu(request):
jeu = JeuForm(request.POST or None)
if jeu.is_valid():
@ -139,7 +142,7 @@ def add_jeu(request):
@login_required
@permission_required('perm')
@permission_required('media.edit_jeu')
def edit_jeu(request, jeuid):
try:
jeu_instance = Jeu.objects.get(pk=jeuid)
@ -151,14 +154,15 @@ def edit_jeu(request, jeuid):
with transaction.atomic(), reversion.create_revision():
jeu.save()
reversion.set_user(request.user)
reversion.set_comment("Champs modifié(s) : %s" % ', '.join(field for field in jeu.changed_data))
reversion.set_comment("Champs modifié(s) : %s" % ', '.join(
field for field in jeu.changed_data))
messages.success(request, "Media modifié")
return redirect("/media/index_jeux/")
return form({'mediaform': jeu}, 'media/media.html', request)
@login_required
@permission_required('perm')
@permission_required('media.delete_jeu')
def del_jeu(request, jeuid):
try:
jeu_instance = Jeu.objects.get(pk=jeuid)
@ -171,20 +175,23 @@ def del_jeu(request, jeuid):
reversion.set_user(request.user)
messages.success(request, "Le jeu a été détruit")
return redirect("/media/index_jeux")
return form({'objet': jeu_instance, 'objet_name': 'jeu'}, 'media/delete.html', request)
return form({'objet': jeu_instance, 'objet_name': 'jeu'},
'media/delete.html', request)
@login_required
@permission_required('perm')
@permission_required('media.add_emprunt')
def add_emprunt(request, userid):
try:
user = User.objects.get(pk=userid)
except User.DoesNotExist:
messages.error(request, u"Entrée inexistante")
return redirect("/media/index_emprunts/")
emprunts_en_cours = Emprunt.objects.filter(date_rendu=None, user=user).count()
emprunts_en_cours = Emprunt.objects.filter(date_rendu=None,
user=user).count()
if emprunts_en_cours >= user.maxemprunt:
messages.error(request, "Maximum d'emprunts atteint de l'user %s" % user.maxemprunt)
messages.error(request,
"Maximum d'emprunts atteint de l'user %s" % user.maxemprunt)
return redirect("/media/index_emprunts/")
emprunt = EmpruntForm(request.POST or None)
if emprunt.is_valid():
@ -202,7 +209,7 @@ def add_emprunt(request, userid):
@login_required
@permission_required('perm')
@permission_required('media.edit_emprunt')
def edit_emprunt(request, empruntid):
try:
emprunt_instance = Emprunt.objects.get(pk=empruntid)
@ -214,14 +221,15 @@ def edit_emprunt(request, empruntid):
with transaction.atomic(), reversion.create_revision():
emprunt.save()
reversion.set_user(request.user)
reversion.set_comment("Champs modifié(s) : %s" % ', '.join(field for field in emprunt.changed_data))
reversion.set_comment("Champs modifié(s) : %s" % ', '.join(
field for field in emprunt.changed_data))
messages.success(request, "Emprunt modifié")
return redirect("/media/index_emprunts/")
return form({'mediaform': emprunt}, 'media/media.html', request)
@login_required
@permission_required('perm')
@permission_required('media.edit_emprunt')
def retour_emprunt(request, empruntid):
try:
emprunt_instance = Emprunt.objects.get(pk=empruntid)
@ -238,7 +246,7 @@ def retour_emprunt(request, empruntid):
@login_required
@permission_required('perm')
@permission_required('media.delete_emprunt')
def del_emprunt(request, empruntid):
try:
emprunt_instance = Emprunt.objects.get(pk=empruntid)
@ -251,7 +259,8 @@ def del_emprunt(request, empruntid):
reversion.set_user(request.user)
messages.success(request, "L'emprunt a été détruit")
return redirect("/media/index_emprunts")
return form({'objet': emprunt_instance, 'objet_name': 'emprunt'}, 'media/delete.html', request)
return form({'objet': emprunt_instance, 'objet_name': 'emprunt'},
'media/delete.html', request)
@login_required
@ -283,7 +292,8 @@ def index_auteurs(request):
except EmptyPage:
# If page is out of range (e.g. 9999), deliver last page of results.
auteurs_list = paginator.page(paginator.num_pages)
return render(request, 'media/index_auteurs.html', {'auteurs_list': auteurs_list})
return render(request, 'media/index_auteurs.html',
{'auteurs_list': auteurs_list})
@login_required
@ -299,7 +309,8 @@ def index_medias(request):
except EmptyPage:
# If page is out of range (e.g. 9999), deliver last page of results.
medias_list = paginator.page(paginator.num_pages)
return render(request, 'media/index_medias.html', {'medias_list': medias_list})
return render(request, 'media/index_medias.html',
{'medias_list': medias_list})
@login_required
@ -308,7 +319,8 @@ def index(request):
emprunts_list = Emprunt.objects.all()
else:
emprunts_list = Emprunt.objects.filter(user=request.user)
paginator = Paginator(emprunts_list.order_by('date_emprunt').reverse(), PAGINATION_NUMBER)
paginator = Paginator(emprunts_list.order_by('date_emprunt').reverse(),
PAGINATION_NUMBER)
page = request.GET.get('page')
try:
emprunts_list = paginator.page(page)
@ -318,44 +330,5 @@ def index(request):
except EmptyPage:
# If page is out of range (e.g. 9999), deliver last page of results.
emprunts_list = paginator.page(paginator.num_pages)
return render(request, 'media/index_emprunts.html', {'emprunts_list': emprunts_list})
@login_required
def history(request, object, id):
if object == 'auteur':
try:
object_instance = Auteur.objects.get(pk=id)
except Auteur.DoesNotExist:
messages.error(request, "Auteur inexistant")
return redirect("/media/index_auteurs")
elif object == 'media':
try:
object_instance = Media.objects.get(pk=id)
except Media.DoesNotExist:
messages.error(request, "Media inexistant")
return redirect("/media/index_medias")
elif object == 'emprunt':
try:
object_instance = Emprunt.objects.get(pk=id)
except Emprunt.DoesNotExist:
messages.error(request, "Emprunt inexistant")
return redirect("/media/index_emprunts")
elif object == 'jeu':
try:
object_instance = Jeu.objects.get(pk=id)
except Jeu.DoesNotExist:
messages.error(request, "Jeu inexistant")
return redirect("/media/index_jeux")
reversions = Version.objects.get_for_object(object_instance)
paginator = Paginator(reversions, PAGINATION_NUMBER)
page = request.GET.get('page')
try:
reversions = paginator.page(page)
except PageNotAnInteger:
# If page is not an integer, deliver first page.
reversions = paginator.page(1)
except EmptyPage:
# If page is out of range (e.g. 9999), deliver last page of results.
reversions = paginator.page(paginator.num_pages)
return render(request, 'media/history.html', {'reversions': reversions, 'object': object_instance})
return render(request, 'media/index_emprunts.html',
{'emprunts_list': emprunts_list})