import logging from app import notification_queue from endpoints.notificationmethod import NotificationMethod, InvalidNotificationMethodException from endpoints.notificationevent import NotificationEvent, InvalidNotificationEventException from workers.queueworker import QueueWorker, JobException from data import model logger = logging.getLogger(__name__) class NotificationWorker(QueueWorker): def process_queue_item(self, job_details): notification_uuid = job_details['notification_uuid'] notification = model.notification.get_repo_notification(notification_uuid) if not notification: # Probably deleted. return event_name = notification.event.name method_name = notification.method.name try: event_handler = NotificationEvent.get_event(event_name) method_handler = NotificationMethod.get_method(method_name) except InvalidNotificationMethodException as ex: logger.exception('Cannot find notification method: %s', ex.message) raise JobException('Cannot find notification method: %s' % ex.message) except InvalidNotificationEventException as ex: logger.exception('Cannot find notification event: %s', ex.message) raise JobException('Cannot find notification event: %s' % ex.message) method_handler.perform(notification, event_handler, job_details) if __name__ == "__main__": worker = NotificationWorker(notification_queue, poll_period_seconds=10, reservation_seconds=30, retry_after_seconds=30) worker.start()