aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorElrond <elrond+mediagoblin.org@samba-tng.org>2011-06-02 14:25:31 +0200
committerElrond <elrond+mediagoblin.org@samba-tng.org>2011-06-02 14:26:53 +0200
commitc849e690925cb656b8c00ccbeda12aeab22c2fdd (patch)
treef7326dd919e1910dd6ea2ba12323db377b22bcab
parent98857207ccb432117709f64137ca20f81635f288 (diff)
downloadmediagoblin-c849e690925cb656b8c00ccbeda12aeab22c2fdd.tar.lz
mediagoblin-c849e690925cb656b8c00ccbeda12aeab22c2fdd.tar.xz
mediagoblin-c849e690925cb656b8c00ccbeda12aeab22c2fdd.zip
Check for edit permission.
You need to own the media, or be an admin to use the edit form. As simple as that, for now.
-rw-r--r--mediagoblin/edit/views.py13
1 files changed, 13 insertions, 0 deletions
diff --git a/mediagoblin/edit/views.py b/mediagoblin/edit/views.py
index 050ece4e..e5dccc81 100644
--- a/mediagoblin/edit/views.py
+++ b/mediagoblin/edit/views.py
@@ -5,9 +5,22 @@ from webob import Response, exc
from mediagoblin.edit import forms
from mediagoblin.decorators import require_active_login, get_media_entry_by_id
+
+def may_edit_media(request, media):
+ """Check, if the request's user may edit the media details"""
+ if media['uploader'] == request.user['_id']:
+ return True
+ if request.user['is_admin']:
+ return True
+ return False
+
+
@get_media_entry_by_id
@require_active_login
def edit_media(request, media):
+ if not may_edit_media(request, media):
+ return exc.HTTPForbidden()
+
form = forms.EditForm(request.POST,
title = media['title'],
slug = media['slug'],