# An example configuration for vdirsyncer.
# Optional parameters are commented out.

[general]
# A folder where vdirsyncer can store some metadata about each pair.
status_path = ~/.vdirsyncer/status/

# The amount of processes to use when synchronizing. If the CPU of your server
# is the bottleneck (which is plausible for small homeservers), set this to the
# number of cores * 2. Defaults to one process for each collection, which means
# all collections will be synced at once. The value 0 will be ignored, the
# value 1 disables multiprocessing.
processes = 2

# CONTACTS
#[pair google_contacts]
## A `[pair <name>]` block defines two storages `a` and `b` that should be
## synchronized. The definition of these storages follows in `[storage <name>]`
## blocks. This is similar to accounts in OfflineIMAP.
#a = google_contacts_local
#b = google_contacts_remote

## If you want to synchronize several addressbooks, calendars etc that share
## the same storage location and differ only in a suffix to this location
## (i.e., a subdirectory) you can use collections. The comma-separated values
## in this parameter represent these subdirectories and are added as URL
## segments or similar.

## Together with the definition of the following two `[storage]` blocks below
## in this example it means that
##   - https://owncloud.example.com/remote.php/carddav/addressbooks/bob/default/
##     will get synced with ~/.contacts/default/
##   - https://owncloud.example.com/remote.php/carddav/addressbooks/bob/work/
##     will get synced with ~/.contacts/work/

## Omitting this parameter implies that the given path and URL in the
## corresponding `[storage <name>]` blocks are already pointing to a
## collection each.
##collections = default,work

## conflict_resolution = None  # abort when collisions occur (default)
## conflict_resolution = a wins  # assume a's items to be more up-to-date
## conflict_resolution = b wins  # assume b's items to be more up-to-date

#[storage google_contacts_local]
## A storage references actual data on a remote server or on the local disk.
## Similar to repositories in OfflineIMAP.
#type = filesystem
#path = ~/.contacts/
#fileext = .vcf
#create = True  # create directory if it doesn't exist
#encoding = utf-8

#[storage google_contacts_remote]
#type = carddav
#url = http://google.com
##auth = basic  # basic|digest
#username = dustinswan@gmail.com # for http auth, if empty, no auth will be used

#true: The NSA can spy on you with some effort
#false: Everybody can spy on you with no effort
#path to SSL cert: People will call you paranoid
#verify = True

# CALDAV
[pair google_calendar]
a = google_calendar_local
b = google_calendar_remote
#collections = private,work

[storage google_calendar_local]
type = filesystem
path = ~/.calendar
fileext = .ics

[storage google_calendar_remote]
type = caldav
url = https://www.google.com/calendar/dav/dustinswan@gmail.com/user
auth = basic
username = dustinswan
#verify = True

# Optional: Specify a time range which should be synchronized. Either both
# start_date and end_date or neither have to be set. The default is to
# synchronize everything.  The following example synchronizes from one year in
# the past to one year in the future.

# All Python expressions are allowed here. The global namespace contains
# everything from the datetime module. The expression has to evaluate to a
# datetime.
#start_date = datetime.now() - timedelta(days=365)

# Here, start_date is also in the namespace.
#end_date = datetime.now() + timedelta(days=365)

# HTTP CALENDAR
#[pair holidays]
#a = holidays_local
#b = holidays_remote

#[storage holidays_local]
#type = filesystem
#path = ~/.config/vdir/calendars/holidays/
#fileext = .ics

#[storage holidays_remote]
#type = http
#url = https://mozorg.cdn.mozilla.net/media/caldata/QueenslandHolidays.ics
#auth = basic
#username =
#password =
#verify = True