Return Items in upload and update methods

Related to #380
This commit is contained in:
Guillaume Ayoub 2016-04-20 08:09:00 +09:00
parent ecf53c5e1e
commit 303a53eede
2 changed files with 11 additions and 18 deletions

View File

@ -540,13 +540,8 @@ class Application(object):
# Case 1: No item and no ETag precondition: Add new item # Case 1: No item and no ETag precondition: Add new item
# Case 2: Item and ETag precondition verified: Modify item # Case 2: Item and ETag precondition verified: Modify item
# Case 3: Item and no Etag precondition: Force modifying item # Case 3: Item and no Etag precondition: Force modifying item
xmlutils.put(environ["PATH_INFO"], content, collection) new_item = xmlutils.put(environ["PATH_INFO"], content, collection)
status = client.CREATED status = client.CREATED
# Try to return the etag in the header.
# If the added item doesn't have the same name as the one given
# by the client, then there's no obvious way to generate an
# etag, we can safely ignore it.
new_item = collection.get(item_name)
if new_item: if new_item:
headers["ETag"] = new_item.etag headers["ETag"] = new_item.etag
else: else:

View File

@ -114,10 +114,9 @@ def path_to_filesystem(root, *paths):
class Item: class Item:
def __init__(self, item, href, etag, last_modified=None): def __init__(self, item, href, last_modified=None):
self.item = item self.item = item
self.href = href self.href = href
self.etag = etag
self.last_modified = last_modified self.last_modified = last_modified
def __getattr__(self, attr): def __getattr__(self, attr):
@ -265,8 +264,7 @@ class Collection:
last_modified = time.strftime( last_modified = time.strftime(
"%a, %d %b %Y %H:%M:%S GMT", "%a, %d %b %Y %H:%M:%S GMT",
time.gmtime(os.path.getmtime(path))) time.gmtime(os.path.getmtime(path)))
return Item( return Item(vobject.readOne(text), href, last_modified)
vobject.readOne(text), href, get_etag(text), last_modified)
else: else:
log.LOGGER.debug( log.LOGGER.debug(
"Can't tranlate name safely to filesystem, " "Can't tranlate name safely to filesystem, "
@ -286,22 +284,22 @@ class Collection:
"""Check if an item exists by its href.""" """Check if an item exists by its href."""
return self.get(href) is not None return self.get(href) is not None
def upload(self, href, item): def upload(self, href, vobject_item):
"""Upload a new item.""" """Upload a new item."""
# TODO: use returned object in code # TODO: use returned object in code
if is_safe_filesystem_path_component(href): if is_safe_filesystem_path_component(href):
path = path_to_filesystem(self._filesystem_path, href) path = path_to_filesystem(self._filesystem_path, href)
if not os.path.exists(path): if not os.path.exists(path):
text = item.serialize() item = Item(vobject_item, href)
with open(path, "w", encoding=STORAGE_ENCODING) as fd: with open(path, "w", encoding=STORAGE_ENCODING) as fd:
fd.write(text) fd.write(item.serialize())
return href, get_etag(text) return item
else: else:
log.LOGGER.debug( log.LOGGER.debug(
"Can't tranlate name safely to filesystem, " "Can't tranlate name safely to filesystem, "
"skipping component: %s", href) "skipping component: %s", href)
def update(self, href, item, etag=None): def update(self, href, vobject_item, etag=None):
"""Update an item.""" """Update an item."""
# TODO: use etag in code and test it here # TODO: use etag in code and test it here
# TODO: use returned object in code # TODO: use returned object in code
@ -311,10 +309,10 @@ class Collection:
with open(path, encoding=STORAGE_ENCODING) as fd: with open(path, encoding=STORAGE_ENCODING) as fd:
text = fd.read() text = fd.read()
if not etag or etag == get_etag(text): if not etag or etag == get_etag(text):
new_text = item.serialize() item = Item(vobject_item, href)
with open(path, "w", encoding=STORAGE_ENCODING) as fd: with open(path, "w", encoding=STORAGE_ENCODING) as fd:
fd.write(new_text) fd.write(item.serialize())
return get_etag(new_text) return item
else: else:
log.LOGGER.debug( log.LOGGER.debug(
"Can't tranlate name safely to filesystem, " "Can't tranlate name safely to filesystem, "