Skip to content

Commit

Permalink
Added support for webcal-subscriptions
Browse files Browse the repository at this point in the history
  • Loading branch information
leso-kn committed Mar 28, 2022
1 parent 0baf1dc commit e914b9d
Show file tree
Hide file tree
Showing 3 changed files with 16 additions and 4 deletions.
13 changes: 12 additions & 1 deletion radicale/app/propfind.py
Original file line number Diff line number Diff line change
Expand Up @@ -85,7 +85,7 @@ def xml_propfind_response(

if isinstance(item, storage.BaseCollection):
is_collection = True
is_leaf = item.tag in ("VADDRESSBOOK", "VCALENDAR")
is_leaf = item.tag in ("VADDRESSBOOK", "VCALENDAR", "VSUBSCRIBED")
collection = item
# Some clients expect collections to end with `/`
uri = pathutils.unstrip_path(item.path, True)
Expand Down Expand Up @@ -258,6 +258,9 @@ def xml_propfind_response(
elif collection.tag == "VCALENDAR":
child_element = ET.Element(
xmlutils.make_clark("C:calendar"))
elif item.get_meta("tag") == "VSUBSCRIBED":
child_element = ET.Element(
xmlutils.make_clark("CS:subscribed"))
element.append(child_element)
child_element = ET.Element(xmlutils.make_clark("D:collection"))
element.append(child_element)
Expand Down Expand Up @@ -286,6 +289,14 @@ def xml_propfind_response(
element.text, _ = collection.sync()
else:
is404 = True
elif tag == xmlutils.make_clark("CS:source"):
if is_leaf:
child_element = ET.Element(xmlutils.make_clark("D:href"))
child_element.text = item.get_meta('CS:source')
element.append(child_element)
else:
is404 = True

else:
human_tag = xmlutils.make_human_tag(tag)
tag_text = collection.get_meta(human_tag)
Expand Down
4 changes: 2 additions & 2 deletions radicale/item/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -91,7 +91,7 @@ def check_and_sanitize_items(
The ``tag`` of the collection.
"""
if tag and tag not in ("VCALENDAR", "VADDRESSBOOK"):
if tag and tag not in ("VCALENDAR", "VADDRESSBOOK", "VSUBSCRIBED"):
raise ValueError("Unsupported collection tag: %r" % tag)
if not is_collection and len(vobject_items) != 1:
raise ValueError("Item contains %d components" % len(vobject_items))
Expand Down Expand Up @@ -230,7 +230,7 @@ def check_and_sanitize_props(props: MutableMapping[Any, Any]
raise ValueError("Value of %r must be %r not %r: %r" % (
k, str.__name__, type(v).__name__, v))
if k == "tag":
if v not in ("", "VCALENDAR", "VADDRESSBOOK"):
if v not in ("", "VCALENDAR", "VADDRESSBOOK", "VSUBSCRIBED"):
raise ValueError("Unsupported collection tag: %r" % v)
return props

Expand Down
3 changes: 2 additions & 1 deletion radicale/xmlutils.py
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,8 @@

MIMETYPES: Mapping[str, str] = {
"VADDRESSBOOK": "text/vcard",
"VCALENDAR": "text/calendar"}
"VCALENDAR": "text/calendar",
"VSUBSCRIBED": "text/calendar"}

OBJECT_MIMETYPES: Mapping[str, str] = {
"VCARD": "text/vcard",
Expand Down

0 comments on commit e914b9d

Please sign in to comment.