catch error during create_collection

This commit is contained in:
Peter Bieringer 2025-02-11 16:20:51 +01:00
parent cd51581f38
commit 37b18cf5a2

View file

@ -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),