Alex | 3ebc563 | 2019-04-18 16:47:18 -0500 | [diff] [blame] | 1 | from cfg_checker.common import logger_cli |
Alex | 205546c | 2020-12-30 19:22:30 -0600 | [diff] [blame] | 2 | from cfg_checker.modules.network.mapper import SaltNetworkMapper, \ |
| 3 | KubeNetworkMapper |
Alex | 3ebc563 | 2019-04-18 16:47:18 -0500 | [diff] [blame] | 4 | from cfg_checker.modules.network.network_errors import NetworkErrors |
Alex Savatieiev | f526dc0 | 2019-03-06 10:11:32 -0600 | [diff] [blame] | 5 | from cfg_checker.reports import reporter |
Alex Savatieiev | 9b2f651 | 2019-02-20 18:05:00 -0600 | [diff] [blame] | 6 | |
| 7 | |
Alex | e0c5b9e | 2019-04-23 18:51:23 -0500 | [diff] [blame] | 8 | class NetworkChecker(object): |
Alex | 205546c | 2020-12-30 19:22:30 -0600 | [diff] [blame] | 9 | def __init__(self): |
Alex | e0c5b9e | 2019-04-23 18:51:23 -0500 | [diff] [blame] | 10 | logger_cli.debug("... init error logs folder") |
Alex | 3ebc563 | 2019-04-18 16:47:18 -0500 | [diff] [blame] | 11 | self.errors = NetworkErrors() |
| 12 | |
Alex | 3cdb1bd | 2021-09-10 15:51:11 -0500 | [diff] [blame] | 13 | def _check_duplicate_ips(self): |
| 14 | # shortcuts |
| 15 | logger_cli.debug("... checking for duplicate ips") |
| 16 | _map = self.mapper.map |
| 17 | for _net in _map.keys(): |
| 18 | _ips = set() |
| 19 | for _node_name, _interfaces in _map[_net].items(): |
| 20 | for _if in _interfaces: |
| 21 | if _if["ip_address"] not in _ips: |
| 22 | # there was no such ip yet |
| 23 | _ips.add(_if["ip_address"]) |
| 24 | else: |
| 25 | # this ip already used |
| 26 | logger_cli.warning( |
| 27 | "Warning: Duplicate ip address: " |
| 28 | "'{}: {}' at {} -> {}".format( |
| 29 | _if["interface"], |
| 30 | _if["ip_address"], |
| 31 | _net, |
| 32 | _node_name |
| 33 | ) |
| 34 | ) |
| 35 | self.errors.add_error( |
| 36 | self.errors.NET_DUPLICATE_IP, |
| 37 | network=_net, |
| 38 | node_name=_node_name, |
| 39 | if_name=_if["interface"], |
| 40 | ip_address=_if["ip_address"] |
| 41 | ) |
| 42 | return |
| 43 | |
| 44 | def _check_non_uniform_mtu(self): |
| 45 | # shortcuts |
| 46 | logger_cli.debug("... checking for duplicate ips") |
| 47 | _map = self.mapper.map |
| 48 | for _net in _map.keys(): |
| 49 | _mtus = set() |
| 50 | for _node_name, _interfaces in _map[_net].items(): |
| 51 | for _if in _interfaces: |
| 52 | if len(_mtus) < 1: |
| 53 | # this is the 1st iteration |
| 54 | _mtus.add(_if["rt_mtu"]) |
| 55 | elif _if["rt_mtu"] not in _mtus: |
| 56 | # this ip already used |
| 57 | logger_cli.warning( |
| 58 | "Non-uniform MTU value of '{}' in '{}': " |
| 59 | "{}:{}:{}".format( |
| 60 | _net, |
| 61 | _node_name, |
| 62 | _if["interface"], |
| 63 | _if["ip_address"], |
| 64 | _if["rt_mtu"] |
| 65 | ) |
| 66 | ) |
| 67 | self.errors.add_error( |
| 68 | self.errors.NET_DUPLICATE_IP, |
| 69 | network=_net, |
| 70 | node_name=_node_name, |
| 71 | if_name=_if["interface"], |
| 72 | ip_address=_if["ip_address"], |
| 73 | mtu=_if["rt_mtu"] |
| 74 | ) |
| 75 | return |
| 76 | |
| 77 | def check_networks(self, map=True, skip_keywords=None): |
| 78 | # Load map |
Alex | 1f90e7b | 2021-09-03 15:31:28 -0500 | [diff] [blame] | 79 | self.mapper.map_networks() |
Alex | 3cdb1bd | 2021-09-10 15:51:11 -0500 | [diff] [blame] | 80 | self.mapper.create_map(skip_keywords=skip_keywords) |
| 81 | # Check for errors that is not detectable during mapping |
| 82 | self._check_duplicate_ips() |
| 83 | self._check_non_uniform_mtu() |
| 84 | # print map if requested |
Alex | 836fac8 | 2019-08-22 13:36:16 -0500 | [diff] [blame] | 85 | if map: |
| 86 | self.mapper.print_map() |
Alex Savatieiev | 42b89fa | 2019-03-07 18:45:26 -0600 | [diff] [blame] | 87 | |
Alex | 3ebc563 | 2019-04-18 16:47:18 -0500 | [diff] [blame] | 88 | def print_summary(self): |
Alex | 3ebc563 | 2019-04-18 16:47:18 -0500 | [diff] [blame] | 89 | logger_cli.info(self.errors.get_summary(print_zeros=False)) |
Alex | 3ebc563 | 2019-04-18 16:47:18 -0500 | [diff] [blame] | 90 | |
| 91 | def print_error_details(self): |
| 92 | # Detailed errors |
Alex | b151fbe | 2019-04-22 16:53:30 -0500 | [diff] [blame] | 93 | logger_cli.info( |
| 94 | "\n{}\n".format( |
| 95 | self.errors.get_errors() |
| 96 | ) |
| 97 | ) |
Alex | 3ebc563 | 2019-04-18 16:47:18 -0500 | [diff] [blame] | 98 | |
Alex Savatieiev | 9b2f651 | 2019-02-20 18:05:00 -0600 | [diff] [blame] | 99 | def create_html_report(self, filename): |
| 100 | """ |
| 101 | Create static html showing network schema-like report |
| 102 | |
| 103 | :return: none |
| 104 | """ |
| 105 | logger_cli.info("### Generating report to '{}'".format(filename)) |
| 106 | _report = reporter.ReportToFile( |
Alex | 205546c | 2020-12-30 19:22:30 -0600 | [diff] [blame] | 107 | reporter.HTMLNetworkReport(self.mapper.master), |
Alex Savatieiev | 9b2f651 | 2019-02-20 18:05:00 -0600 | [diff] [blame] | 108 | filename |
| 109 | ) |
Alex | 9a4ad21 | 2020-10-01 18:04:25 -0500 | [diff] [blame] | 110 | _report( |
| 111 | { |
| 112 | "domain": self.mapper.domain, |
| 113 | "nodes": self.mapper.nodes, |
| 114 | "map": self.mapper.map, |
| 115 | "mcp_release": self.mapper.cluster['mcp_release'], |
| 116 | "openstack_release": self.mapper.cluster['openstack_release'] |
| 117 | } |
| 118 | ) |
Alex Savatieiev | 9b2f651 | 2019-02-20 18:05:00 -0600 | [diff] [blame] | 119 | logger_cli.info("-> Done") |
Alex | 205546c | 2020-12-30 19:22:30 -0600 | [diff] [blame] | 120 | |
| 121 | |
| 122 | class SaltNetworkChecker(NetworkChecker): |
| 123 | def __init__( |
| 124 | self, |
| 125 | config, |
| 126 | skip_list=None, |
| 127 | skip_list_file=None |
| 128 | ): |
| 129 | super(SaltNetworkChecker, self).__init__() |
| 130 | self.mapper = SaltNetworkMapper( |
| 131 | config, |
| 132 | errors_class=self.errors, |
| 133 | skip_list=skip_list, |
| 134 | skip_list_file=skip_list_file |
| 135 | ) |
| 136 | |
Alex | 359e575 | 2021-08-16 17:28:30 -0500 | [diff] [blame] | 137 | |
Alex | 205546c | 2020-12-30 19:22:30 -0600 | [diff] [blame] | 138 | class KubeNetworkChecker(NetworkChecker): |
| 139 | def __init__( |
| 140 | self, |
| 141 | config, |
| 142 | skip_list=None, |
| 143 | skip_list_file=None |
| 144 | ): |
Alex | c4f5962 | 2021-08-27 13:42:00 -0500 | [diff] [blame] | 145 | super(KubeNetworkChecker, self).__init__() |
Alex | 205546c | 2020-12-30 19:22:30 -0600 | [diff] [blame] | 146 | self.mapper = KubeNetworkMapper( |
| 147 | config, |
| 148 | errors_class=self.errors, |
| 149 | skip_list=skip_list, |
| 150 | skip_list_file=skip_list_file |
Alex | e864364 | 2021-08-23 14:08:46 -0500 | [diff] [blame] | 151 | ) |