forked from 0x2620/pandora
support all metadata keys in add (item)
This commit is contained in:
parent
4f14b923fa
commit
7ac8fefcf4
1 changed files with 47 additions and 36 deletions
|
@ -517,12 +517,45 @@ def get(request, data):
|
||||||
return render_to_json_response(response)
|
return render_to_json_response(response)
|
||||||
actions.register(get)
|
actions.register(get)
|
||||||
|
|
||||||
|
def edit_item(request, item, data):
|
||||||
|
update_clips = False
|
||||||
|
response = json_response(status=200, text='ok')
|
||||||
|
if 'rightslevel' in data:
|
||||||
|
if request.user.profile.capability('canEditRightsLevel'):
|
||||||
|
item.level = int(data['rightslevel'])
|
||||||
|
else:
|
||||||
|
response = json_response(status=403, text='permission denied')
|
||||||
|
del data['rightslevel']
|
||||||
|
if 'user' in data:
|
||||||
|
if request.user.profile.get_level() in ('admin', 'staff') and \
|
||||||
|
models.User.objects.filter(username=data['user']).exists():
|
||||||
|
new_user = models.User.objects.get(username=data['user'])
|
||||||
|
if new_user != item.user:
|
||||||
|
item.user = new_user
|
||||||
|
update_clips = True
|
||||||
|
del data['user']
|
||||||
|
if 'groups' in data:
|
||||||
|
if not request.user.profile.capability('canManageUsers'):
|
||||||
|
# Users wihtout canManageUsers can only add/remove groups they are not in
|
||||||
|
groups = set([g.name for g in item.groups.all()])
|
||||||
|
user_groups = set([g.name for g in request.user.groups.all()])
|
||||||
|
other_groups = list(groups - user_groups)
|
||||||
|
data['groups'] = [g for g in data['groups'] if g in user_groups] + other_groups
|
||||||
|
r = item.edit(data)
|
||||||
|
if r:
|
||||||
|
r.wait()
|
||||||
|
if update_clips:
|
||||||
|
tasks.update_clips.delay(item.public_id)
|
||||||
|
return response
|
||||||
|
|
||||||
@login_required_json
|
@login_required_json
|
||||||
def add(request, data):
|
def add(request, data):
|
||||||
'''
|
'''
|
||||||
Adds a new item (without video)
|
Adds a new item (without video)
|
||||||
takes {
|
takes {
|
||||||
title: string, // title (optional)
|
title: string, // title (optional)
|
||||||
|
|
||||||
|
... // more key/value pairs (like edit, can be passed to add)
|
||||||
}
|
}
|
||||||
returns {
|
returns {
|
||||||
id: string, // item id
|
id: string, // item id
|
||||||
|
@ -535,18 +568,22 @@ def add(request, data):
|
||||||
if not request.user.profile.capability('canAddItems'):
|
if not request.user.profile.capability('canAddItems'):
|
||||||
response = json_response(status=403, text='permission denied')
|
response = json_response(status=403, text='permission denied')
|
||||||
else:
|
else:
|
||||||
|
response = json_response(status=200, text='created')
|
||||||
data['title'] = data.get('title', 'Untitled')
|
data['title'] = data.get('title', 'Untitled')
|
||||||
i = models.Item()
|
request_data = data.copy()
|
||||||
i.data['title'] = data['title']
|
item = models.Item()
|
||||||
i.user = request.user
|
item.data['title'] = data['title']
|
||||||
p = i.save()
|
item.user = request.user
|
||||||
|
p = item.save()
|
||||||
if p:
|
if p:
|
||||||
p.wait()
|
p.wait()
|
||||||
else:
|
else:
|
||||||
i.make_poster()
|
i.make_poster()
|
||||||
response = json_response(status=200, text='created')
|
del data['title']
|
||||||
response['data'] = i.get_json()
|
if data:
|
||||||
add_changelog(request, data, i.public_id)
|
response = edit_item(request, item, data)
|
||||||
|
response['data'] = item.get_json()
|
||||||
|
add_changelog(request, request_data, item.public_id)
|
||||||
return render_to_json_response(response)
|
return render_to_json_response(response)
|
||||||
actions.register(add, cache=False)
|
actions.register(add, cache=False)
|
||||||
|
|
||||||
|
@ -565,38 +602,12 @@ def edit(request, data):
|
||||||
}
|
}
|
||||||
see: add, find, get, lookup, remove, upload
|
see: add, find, get, lookup, remove, upload
|
||||||
'''
|
'''
|
||||||
update_clips = False
|
|
||||||
item = get_object_or_404_json(models.Item, public_id=data['id'])
|
item = get_object_or_404_json(models.Item, public_id=data['id'])
|
||||||
if item.editable(request.user):
|
if item.editable(request.user):
|
||||||
response = json_response(status=200, text='ok')
|
request_data = data.copy()
|
||||||
if 'rightslevel' in data:
|
response = edit_item(request, item, data)
|
||||||
if request.user.profile.capability('canEditRightsLevel'):
|
|
||||||
item.level = int(data['rightslevel'])
|
|
||||||
else:
|
|
||||||
response = json_response(status=403, text='permission denied')
|
|
||||||
del data['rightslevel']
|
|
||||||
if 'user' in data:
|
|
||||||
if request.user.profile.get_level() in ('admin', 'staff') and \
|
|
||||||
models.User.objects.filter(username=data['user']).exists():
|
|
||||||
new_user = models.User.objects.get(username=data['user'])
|
|
||||||
if new_user != item.user:
|
|
||||||
item.user = new_user
|
|
||||||
update_clips = True
|
|
||||||
del data['user']
|
|
||||||
if 'groups' in data:
|
|
||||||
if not request.user.profile.capability('canManageUsers'):
|
|
||||||
# Users wihtout canManageUsers can only add/remove groups they are not in
|
|
||||||
groups = set([g.name for g in item.groups.all()])
|
|
||||||
user_groups = set([g.name for g in request.user.groups.all()])
|
|
||||||
other_groups = list(groups - user_groups)
|
|
||||||
data['groups'] = [g for g in data['groups'] if g in user_groups] + other_groups
|
|
||||||
add_changelog(request, data)
|
|
||||||
r = item.edit(data)
|
|
||||||
if r:
|
|
||||||
r.wait()
|
|
||||||
if update_clips:
|
|
||||||
tasks.update_clips.delay(item.public_id)
|
|
||||||
response['data'] = item.get_json()
|
response['data'] = item.get_json()
|
||||||
|
add_changelog(request, request_data)
|
||||||
else:
|
else:
|
||||||
response = json_response(status=403, text='permission denied')
|
response = json_response(status=403, text='permission denied')
|
||||||
return render_to_json_response(response)
|
return render_to_json_response(response)
|
||||||
|
|
Loading…
Reference in a new issue