blechreiz-website/eventplanner_gcal/signals.py

52 lines
1.7 KiB
Python
Raw Normal View History

from django.db.models.signals import post_save, pre_delete
from django.dispatch import receiver
from eventplanner.models import Event, EventParticipation
from eventplanner_gcal.google_sync import getServiceObject, \
createGCalEvent, deleteGCalEvent, updateGCalEvent, onGcalEventCreated
2014-04-18 13:43:02 +02:00
2014-04-26 11:17:10 +02:00
import logging
2014-04-18 13:43:02 +02:00
logger = logging.getLogger(__name__)
2014-04-18 13:43:02 +02:00
# @receiver( post_save, sender=User )
# def user_changed( **kwargs ):
# logger.info("Synchronizing with google - user information changed")
# syncFromLocalToGoogle( getServiceObject() )
@receiver(post_save, sender=Event)
def event_post_save_handler(**kwargs):
2014-04-26 11:17:10 +02:00
event = kwargs['instance']
created = kwargs['created']
2014-09-15 11:12:04 +02:00
try:
if created:
logger.info("Creating Gcal event")
response = createGCalEvent(getServiceObject(), event).execute()
onGcalEventCreated(None, response, None)
2014-09-15 11:12:04 +02:00
else:
logger.info("Updating Gcal event")
updateGCalEvent(getServiceObject(), event).execute()
2014-09-15 11:12:04 +02:00
except:
logger.error("Error updating Gcal event")
@receiver(pre_delete, sender=Event)
def event_pre_delete_handler(**kwargs):
2014-09-15 11:12:04 +02:00
try:
event = kwargs['instance']
logger.info("Deleting GCAL event")
deleteGCalEvent(getServiceObject(), event).execute()
2014-09-15 11:12:04 +02:00
except:
logger.error("Error deleting GCAL event")
@receiver(post_save, sender=EventParticipation)
def participation_post_save_handler(**kwargs):
2014-09-15 11:12:04 +02:00
try:
participation = kwargs['instance']
logger.info("Participation post save -> update gcal")
updateGCalEvent(getServiceObject(), participation.event).execute()
2014-09-15 11:12:04 +02:00
except:
logger.error("Error deleting GCAL event")