editor api DELETE support

This commit is contained in:
Laura Klünder 2018-11-21 22:56:14 +01:00
parent 0b6321c7e0
commit 8e15e7d0a4
2 changed files with 8 additions and 5 deletions

View file

@ -36,6 +36,9 @@ def sidebar_view(func=None, select_related=None, api_hybrid=False):
if not can_access_editor(request):
raise PermissionDenied
if api_hybrid and api and func.__name__ == 'edit':
kwargs['delete'] = request.method == 'DELETE'
request.changeset = ChangeSet.get_for_request(request, select_related)
if api:
@ -110,7 +113,7 @@ class APIHybridMessageRedirectResponse(APIHybridResponse):
def __init__(self, level, message, redirect_to):
self.level = level
self.message = message
self.redirect_to = self.redirect_to
self.redirect_to = redirect_to
def get_api_response(self, request):
return {self.level: self.message}

View file

@ -124,7 +124,7 @@ def get_changeset_exceeded(request):
@sidebar_view(api_hybrid=True)
@etag(etag_func)
def edit(request, pk=None, model=None, level=None, space=None, on_top_of=None, explicit_edit=False):
def edit(request, pk=None, model=None, level=None, space=None, on_top_of=None, explicit_edit=False, delete=True):
changeset_exceeded = get_changeset_exceeded(request)
model_changes = {}
if changeset_exceeded:
@ -281,7 +281,7 @@ def edit(request, pk=None, model=None, level=None, space=None, on_top_of=None, e
message=_('You need to log in to create Wifi Measurements.'))
error = None
if request.method == 'POST':
if request.method == 'POST' or (not new and delete):
if nosave:
return APIHybridMessageRedirectResponse(
level='error', message=_('You can not edit this object because your changeset is full.'),
@ -294,7 +294,7 @@ def edit(request, pk=None, model=None, level=None, space=None, on_top_of=None, e
redirect_to=request.path
)
if not new and request.POST.get('delete') == '1':
if not new and ((request.POST.get('delete') == '1' and delete is not False) or delete):
# Delete this mapitem!
try:
if not request.changeset.get_changed_object(obj).can_delete():
@ -306,7 +306,7 @@ def edit(request, pk=None, model=None, level=None, space=None, on_top_of=None, e
redirect_to=request.path
)
if request.POST.get('delete_confirm') == '1':
if request.POST.get('delete_confirm') == '1' or delete:
with request.changeset.lock_to_edit(request) as changeset:
if changeset.can_edit(request):
obj.delete()