| Total Complexity | 3 |
| Total Lines | 43 |
| Duplicated Lines | 0 % |
| Coverage | 0% |
| Changes | 1 | ||
| Bugs | 0 | Features | 0 |
| 1 | """ |
||
| 15 | class NagiosMessageEventHandler(NodeActionMessageBaseEventHandler): |
||
| 16 | """ |
||
| 17 | An event handler for a NagiosMessage received events. |
||
| 18 | """ |
||
| 19 | |||
| 20 | # ------------------------------------------------------------------------------------------------------------------ |
||
| 21 | @staticmethod |
||
| 22 | def handle(_event, _message, controller): |
||
| 23 | """ |
||
| 24 | Handles a NagiosMessage received event. |
||
| 25 | |||
| 26 | :param * _event: Not used. |
||
| 27 | :param * _message: Not used. |
||
| 28 | :param enarksh.controller.Controller.Controller controller: The controller. |
||
| 29 | """ |
||
| 30 | del _event, _message |
||
| 31 | |||
| 32 | log = logging.getLogger('enarksh') |
||
| 33 | |||
| 34 | rst_count = {C.ENK_RST_ID_COMPLETED: 0, |
||
| 35 | C.ENK_RST_ID_ERROR: 0, |
||
| 36 | C.ENK_RST_ID_QUEUED: 0, |
||
| 37 | C.ENK_RST_ID_RUNNING: 0, |
||
| 38 | C.ENK_RST_ID_WAITING: 0} |
||
| 39 | |||
| 40 | response = {'ret': 0, |
||
| 41 | 'rst_count': rst_count, |
||
| 42 | 'sch_count': len(controller.schedules)} |
||
| 43 | |||
| 44 | try: |
||
| 45 | for schedule in controller.schedules.values(): |
||
| 46 | schedule.nagios_performance_data(rst_count) |
||
| 47 | |||
| 48 | except Exception as exception: |
||
| 49 | log.exception('Error') |
||
| 50 | |||
| 51 | response['ret'] = -1 |
||
| 52 | response['message'] = str(exception) |
||
| 53 | |||
| 54 | DataLayer.rollback() |
||
| 55 | |||
| 56 | # Send response message to the CLI client. |
||
| 57 | controller.message_controller.send_message('lockstep', response) |
||
| 58 | |||
| 60 |