Skip to content

Commit

Permalink
Retry PUT 409 errors - delete and re-create event
Browse files Browse the repository at this point in the history
Attempt to address #963

I would appreciate a code review here - there might be a more elegant way to address this problem, but it works for my (very limited) use case.
  • Loading branch information
telotortium committed May 20, 2022
1 parent 24e3625 commit c54d7fd
Showing 1 changed file with 20 additions and 2 deletions.
22 changes: 20 additions & 2 deletions vdirsyncer/storage/dav.py
Original file line number Diff line number Diff line change
Expand Up @@ -587,12 +587,30 @@ async def _put(self, href, item, etag):
async def update(self, href, item, etag):
if etag is None:
raise ValueError("etag must be given and must not be None.")
href, etag = await self._put(self._normalize_href(href), item, etag)
try:
href, etag = await self._put(self._normalize_href(href), item, etag)
except aiohttp.ClientResponseError as e:
if e.status == 409:
dav_logger.debug("Conflict, will delete old event and recreate it.")
await self.delete(self._normalize_href(href), None)
dav_logger.debug("Now trying again")
href, etag = await self._put(self._normalize_href(href), item, None)
else:
raise e
return etag

async def upload(self, item: Item):
href = self._get_href(item)
rv = await self._put(href, item, None)
try:
rv = await self._put(href, item, None)
except aiohttp.ClientResponseError as e:
if e.status == 409:
dav_logger.debug("Conflict, will delete old event and recreate it.")
await self.delete(href, None)
dav_logger.debug("Now trying again")
rv = await self._put(href, item, None)
else:
raise e
return rv

async def delete(self, href, etag):
Expand Down

0 comments on commit c54d7fd

Please sign in to comment.