Coverage for portality / events / consumers / application_assed_inprogress_notify.py: 96%

27 statements  

« prev     ^ index     » next       coverage.py v7.13.5, created at 2026-05-04 09:41 +0100

1# ~~ApplicationAssedInProgressNotify:Consumer~~ 

2from portality.events import consumer_utils 

3from portality.util import url_for 

4from portality.events.consumer import EventConsumer 

5from portality import constants 

6from portality import models 

7from portality.bll import DOAJ, exceptions 

8 

9 

10class ApplicationAssedInprogressNotify(EventConsumer): 

11 ID = "application:assed:inprogress:notify" 

12 

13 @classmethod 

14 def should_consume(cls, event): 

15 return event.id == constants.EVENT_APPLICATION_STATUS and \ 

16 event.context.get("application") is not None and \ 

17 event.context.get("old_status") in [constants.APPLICATION_STATUS_COMPLETED, constants.APPLICATION_STATUS_READY] and \ 

18 event.context.get("new_status") == constants.APPLICATION_STATUS_IN_PROGRESS 

19 

20 @classmethod 

21 def consume(cls, event): 

22 app_source = event.context.get("application") 

23 

24 application = consumer_utils.parse_application(app_source) 

25 if not application.editor: 

26 return None 

27 

28 # ~~-> Notifications:Service ~~ 

29 svc = DOAJ.notificationsService() 

30 

31 notification = models.Notification() 

32 notification.who = application.editor 

33 notification.created_by = cls.ID 

34 notification.classification = constants.NOTIFICATION_CLASSIFICATION_STATUS_CHANGE 

35 notification.long = svc.long_notification(cls.ID).format( 

36 application_title=application.bibjson().title) 

37 

38 notification.short = svc.short_notification(cls.ID).format( 

39 issns=application.bibjson().issns_as_text() 

40 ) 

41 notification.action = url_for("editor.application", application_id=application.id) 

42 

43 svc.notify(notification) 

44 return notification