43 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			43 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| 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
 | |
| from data.model import InvalidNotificationException
 | |
| 
 | |
| logger = logging.getLogger(__name__)
 | |
| 
 | |
| class NotificationWorker(QueueWorker):
 | |
|   def process_queue_item(self, job_details):
 | |
|     notification_uuid = job_details['notification_uuid']
 | |
| 
 | |
|     try:
 | |
|       notification = model.notification.get_repo_notification(notification_uuid)
 | |
|     except InvalidNotificationException:
 | |
|       # 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()
 |