Fix a bug with DELETE requests when deleted item is not found

This commit is contained in:
Guillaume Ayoub 2012-03-21 11:26:06 +01:00
parent 085c9f0aca
commit f6ace2b6ec

View File

@ -285,17 +285,16 @@ class Application(object):
item = collection.get_item( item = collection.get_item(
xmlutils.name_from_path(environ["PATH_INFO"], collection)) xmlutils.name_from_path(environ["PATH_INFO"], collection))
# Evolution bug workaround if item:
etag = environ.get("HTTP_IF_MATCH", item.etag).replace("\\", "") # Evolution bug workaround
if item and etag == item.etag: etag = environ.get("HTTP_IF_MATCH", item.etag).replace("\\", "")
# No ETag precondition or precondition verified, delete item if etag == item.etag:
answer = xmlutils.delete(environ["PATH_INFO"], collection) # No ETag precondition or precondition verified, delete item
status = client.NO_CONTENT answer = xmlutils.delete(environ["PATH_INFO"], collection)
else: return client.NO_CONTENT, {}, answer
# No item or ETag precondition not verified, do not delete item
answer = None # No item or ETag precondition not verified, do not delete item
status = client.PRECONDITION_FAILED return client.PRECONDITION_FAILED, {}, None
return status, {}, answer
def get(self, environ, collections, content, user): def get(self, environ, collections, content, user):
"""Manage GET request. """Manage GET request.