#!/usr/local/bin/python2.7
# vim: set ts=4 sw=4 expandtab sts=4:
# Copyright (c) 2011-2013 Christian Geier & contributors
#
# Permission is hereby granted, free of charge, to any person obtaining
# a copy of this software and associated documentation files (the
# "Software"), to deal in the Software without restriction, including
# without limitation the rights to use, copy, modify, merge, publish,
# distribute, sublicense, and/or sell copies of the Software, and to
# permit persons to whom the Software is furnished to do so, subject to
# the following conditions:
#
# The above copyright notice and this permission notice shall be
# included in all copies or substantial portions of the Software.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
# LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

try:
    import logging
    import sys

    from pycarddav import SyncConfigurationParser
    from pycarddav import capture_user_interruption
    from pycarddav.controllers.sync import sync

except ImportError as error:
    sys.stderr.write(str(error))
    sys.exit(1)



capture_user_interruption()

# Read configuration.
conf_parser = SyncConfigurationParser()
conf = conf_parser.parse()
if conf is None:
    sys.exit(1)

if conf.debug:
    conf_parser.dump(conf)

rvalue = 0
for one in conf.accounts:
    if one.name in conf.sync.accounts:
        logging.debug('start syncing account {0}'.format(one.name))
        conf.account = one
        try:
            sync(conf)
        except Exception as error:
            if conf.debug:
                raise
            logging.critical('While syncing account "{0}" an error occured:\n  '.format(one.name) + str(error))
            rvalue = 1

sys.exit(rvalue)
