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 |