Merge commit 'refs/merge-requests/6' of gitorious.org:radicale/radicale into merge-requests/6

This commit is contained in:
Guillaume Ayoub 2011-04-10 18:37:23 +02:00
commit 6c65cc1539
4 changed files with 21 additions and 4 deletions

View File

@ -177,7 +177,12 @@ class CalendarHTTPHandler(server.BaseHTTPRequestHandler):
attributes = posixpath.normpath(self.path.strip("/")).split("/") attributes = posixpath.normpath(self.path.strip("/")).split("/")
if len(attributes) >= 2: if len(attributes) >= 2:
path = "%s/%s" % (attributes[0], attributes[1]) path = "%s/%s" % (attributes[0], attributes[1])
return ical.Calendar(path) elif len(attributes) == 1: # no owner
path = attributes[0]
else:
return
return ical.Calendar(path)
def _decode(self, text): def _decode(self, text):
"""Try to decode text according to various parameters.""" """Try to decode text according to various parameters."""

View File

@ -56,6 +56,9 @@ def _sha1(hash_value, password):
def has_right(owner, user, password): def has_right(owner, user, password):
"""Check if ``user``/``password`` couple is valid.""" """Check if ``user``/``password`` couple is valid."""
if owner is None: # no owner - everybody is allowed
return True
for line in open(FILENAME).readlines(): for line in open(FILENAME).readlines():
if line.strip(): if line.strip():
login, hash_value = line.strip().split(":") login, hash_value = line.strip().split(":")

View File

@ -135,8 +135,16 @@ class Calendar(object):
def __init__(self, path): def __init__(self, path):
"""Initialize the calendar with ``cal`` and ``user`` parameters.""" """Initialize the calendar with ``cal`` and ``user`` parameters."""
split_path = path.split("/")
self.encoding = "utf-8" self.encoding = "utf-8"
self.owner = path.split("/")[0]
if len(split_path) > 1:
self.owner = split_path[0]
else:
self.owner = None
self.path = os.path.join(FOLDER, path.replace("/", os.path.sep)) self.path = os.path.join(FOLDER, path.replace("/", os.path.sep))
@staticmethod @staticmethod

View File

@ -51,7 +51,7 @@ def _response(code):
def name_from_path(path): def name_from_path(path):
"""Return Radicale item name from ``path``.""" """Return Radicale item name from ``path``."""
path_parts = path.strip("/").split("/") path_parts = path.strip("/").split("/")
return path_parts[-1] if len(path_parts) > 2 else None return path_parts[-1] if len(path_parts) >= 2 else None
def delete(path, calendar): def delete(path, calendar):
@ -129,7 +129,8 @@ def propfind(path, xml_request, calendar, depth):
tag = ET.Element(_tag("D", "collection")) tag = ET.Element(_tag("D", "collection"))
element.append(tag) element.append(tag)
elif tag == _tag("D", "owner"): elif tag == _tag("D", "owner"):
element.text = calendar.owner if calendar.owner:
element.text = calendar.owner
elif tag == _tag("D", "getcontenttype"): elif tag == _tag("D", "getcontenttype"):
element.text = "text/calendar" element.text = "text/calendar"
elif tag == _tag("CS", "getctag") and is_calendar: elif tag == _tag("CS", "getctag") and is_calendar: