mirror of
https://github.com/Kozea/Radicale.git
synced 2025-04-04 13:47:37 +03:00
catch error during create_collection
This commit is contained in:
parent
cd51581f38
commit
37b18cf5a2
1 changed files with 24 additions and 20 deletions
|
@ -50,27 +50,31 @@ class StoragePartCreateCollection(StorageBase):
|
||||||
self._makedirs_synced(parent_dir)
|
self._makedirs_synced(parent_dir)
|
||||||
|
|
||||||
# Create a temporary directory with an unsafe name
|
# Create a temporary directory with an unsafe name
|
||||||
with TemporaryDirectory(prefix=".Radicale.tmp-", dir=parent_dir
|
try:
|
||||||
) as tmp_dir:
|
with TemporaryDirectory(prefix=".Radicale.tmp-", dir=parent_dir
|
||||||
# The temporary directory itself can't be renamed
|
) as tmp_dir:
|
||||||
tmp_filesystem_path = os.path.join(tmp_dir, "collection")
|
# The temporary directory itself can't be renamed
|
||||||
os.makedirs(tmp_filesystem_path)
|
tmp_filesystem_path = os.path.join(tmp_dir, "collection")
|
||||||
col = self._collection_class(
|
os.makedirs(tmp_filesystem_path)
|
||||||
cast(multifilesystem.Storage, self),
|
col = self._collection_class(
|
||||||
pathutils.unstrip_path(sane_path, True),
|
cast(multifilesystem.Storage, self),
|
||||||
filesystem_path=tmp_filesystem_path)
|
pathutils.unstrip_path(sane_path, True),
|
||||||
col.set_meta(props)
|
filesystem_path=tmp_filesystem_path)
|
||||||
if items is not None:
|
col.set_meta(props)
|
||||||
if props.get("tag") == "VCALENDAR":
|
if items is not None:
|
||||||
col._upload_all_nonatomic(items, suffix=".ics")
|
if props.get("tag") == "VCALENDAR":
|
||||||
elif props.get("tag") == "VADDRESSBOOK":
|
col._upload_all_nonatomic(items, suffix=".ics")
|
||||||
col._upload_all_nonatomic(items, suffix=".vcf")
|
elif props.get("tag") == "VADDRESSBOOK":
|
||||||
|
col._upload_all_nonatomic(items, suffix=".vcf")
|
||||||
|
|
||||||
if os.path.lexists(filesystem_path):
|
if os.path.lexists(filesystem_path):
|
||||||
pathutils.rename_exchange(tmp_filesystem_path, filesystem_path)
|
pathutils.rename_exchange(tmp_filesystem_path, filesystem_path)
|
||||||
else:
|
else:
|
||||||
os.rename(tmp_filesystem_path, filesystem_path)
|
os.rename(tmp_filesystem_path, filesystem_path)
|
||||||
self._sync_directory(parent_dir)
|
self._sync_directory(parent_dir)
|
||||||
|
except Exception as e:
|
||||||
|
raise ValueError("Failed to create collection %r as %r %s" %
|
||||||
|
(href, filesystem_path, e)) from e
|
||||||
|
|
||||||
return self._collection_class(
|
return self._collection_class(
|
||||||
cast(multifilesystem.Storage, self),
|
cast(multifilesystem.Storage, self),
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue