"""Workflow for students. """ import grok from datetime import datetime from hurry.workflow.workflow import Transition, WorkflowState, NullCondition from hurry.workflow.interfaces import IWorkflowState, IWorkflowTransitionEvent from waeup.sirp.students.interfaces import IStudent from waeup.sirp.interfaces import IObjectHistory, IWAeUPWorkflowInfo from waeup.sirp.workflow import WAeUPWorkflow, WAeUPWorkflowInfo from waeup.sirp.utils.helpers import get_current_principal CREATED = 'created' ADMITTED = 'admitted' CLEARANCE = 'clearance started' REQUESTED = 'clearance requested' CLEARED = 'cleared' REGISTRATION_TRANSITIONS = ( Transition( transition_id = 'create', title = 'Create student', source = None, condition = NullCondition, msg = 'Student record created', destination = CREATED), Transition( transition_id = 'admit', title = 'Admit student', msg = 'Student admitted', source = CREATED, destination = ADMITTED), Transition( transition_id = 'reset1', title = 'Reset student', msg = 'Student record reset', source = ADMITTED, destination = CREATED), Transition( transition_id = 'start_clearance', title = 'Start clearance', msg = 'Clearance started', source = ADMITTED, destination = CLEARANCE), Transition( transition_id = 'reset2', title = 'Reset to admitted', msg = 'Student record reset to admitted', source = CLEARANCE, destination = ADMITTED), Transition( transition_id = 'request_clearance', title = 'Request clearance', msg = 'Clearance requested', source = CLEARANCE, destination = REQUESTED), Transition( transition_id = 'reset3', title = 'Reset to clearance', msg = 'Student record reset to clearance', source = REQUESTED, destination = CLEARANCE), Transition( transition_id = 'clear', title = 'Clear student', msg = 'Cleared', source = REQUESTED, destination = CLEARED), Transition( transition_id = 'reset4', title = 'Reset to clearance', msg = 'Student record reset to clearance', source = CLEARED, destination = CLEARANCE), ) LOCK_CLEARANCE_TRANS = ('reset2', 'request_clearance') UNLOCK_CLEARANCE_TRANS = ('reset3', 'reset4', 'start_clearance') registration_workflow = WAeUPWorkflow(REGISTRATION_TRANSITIONS) class RegistrationWorkflowState(WorkflowState, grok.Adapter): """An adapter to adapt Student objects to workflow states. """ grok.context(IStudent) grok.provides(IWorkflowState) state_key = 'wf.registration.state' state_id = 'wf.registration.id' class RegistrationWorkflowInfo(WAeUPWorkflowInfo, grok.Adapter): """Adapter to adapt Student objects to workflow info objects. """ grok.context(IStudent) grok.provides(IWAeUPWorkflowInfo) def __init__(self, context): self.context = context self.wf = registration_workflow @grok.subscribe(IStudent, IWorkflowTransitionEvent) def handle_student_transition_event(obj, event): """Append message to student history and log file when transition happened. """ msg = '%s' % event.transition.user_data['msg'] history = IObjectHistory(obj) history.addMessage(msg) if event.transition.transition_id in LOCK_CLEARANCE_TRANS: obj.clearance_locked = True if event.transition.transition_id in UNLOCK_CLEARANCE_TRANS: obj.clearance_locked = False # In some tests we don't have a students container or a user try: user = get_current_principal() students_container = grok.getSite()['students'] students_container.logger.info('%s - %s - %s' % (user.id,obj.student_id,msg)) except (TypeError, AttributeError): pass return