1
0
Fork 0
mirror of https://github.com/Kozea/Radicale.git synced 2025-09-15 20:36:55 +00:00

Out-of-the-box simple configuration

git-svn-id: http://svn.32rwr.info/radicale/trunk@5 74e4794c-479d-4a33-9dda-c6c359d70f12
This commit is contained in:
(no author) 2008-12-30 19:26:03 +00:00
parent 5e1a4d4131
commit e87d37703d
7 changed files with 72 additions and 13 deletions

View file

@ -22,23 +22,35 @@ import posixpath
from .. import ical
from .. import config
_folder = os.path.expanduser(config.get("support", "folder"))
def calendars():
"""
List Available Calendars Paths
"""
calendars = []
for folder in os.listdir(config.get("support", "folder")):
for cal in os.listdir(os.path.join(config.get("support", "folder"), folder)):
for folder in os.listdir(_folder):
for cal in os.listdir(os.path.join(_folder, folder)):
calendars.append(posixpath.join(folder, cal))
return calendars
def mkcalendar(name):
"""
Write new calendar
"""
user, cal = name.split(posixpath.sep)
if not os.path.exists(os.path.join(_folder, user)):
os.makedirs(os.path.join(_folder, user))
fd = open(os.path.join(_folder, user, cal), "w")
fd.write(ical.writeCalendar())
def read(cal):
"""
Read cal
"""
path = os.path.join(config.get("support", "folder"), cal.replace(posixpath.sep, os.path.sep))
path = os.path.join(_folder, cal.replace(posixpath.sep, os.path.sep))
return open(path).read()
def append(cal, vcalendar):
@ -47,7 +59,7 @@ def append(cal, vcalendar):
"""
oldCalendar = read(cal)
oldTzs = [tz.tzid for tz in ical.timezones(oldCalendar)]
path = os.path.join(config.get("support", "folder"), cal.replace(posixpath.sep, os.path.sep))
path = os.path.join(_folder, cal.replace(posixpath.sep, os.path.sep))
oldObjects = []
oldObjects.extend([event.etag() for event in ical.events(oldCalendar)])
@ -89,7 +101,7 @@ def remove(cal, etag):
"""
Remove object named uid from cal
"""
path = os.path.join(config.get("support", "folder"), cal.replace(posixpath.sep, os.path.sep))
path = os.path.join(_folder, cal.replace(posixpath.sep, os.path.sep))
cal = read(cal)
@ -102,3 +114,8 @@ def remove(cal, etag):
fd.write(ical.writeCalendar(headers, timezones, todos, events))
fd.close()
if config.get("support", "defaultCalendar"):
user, cal = config.get("support", "defaultCalendar").split(posixpath.sep)
if not os.path.exists(os.path.join(_folder, user, cal)):
mkcalendar(config.get("support", "defaultCalendar"))