Reclass networks and data collection refactoring
diff --git a/cfg_checker/modules/network/__init__.py b/cfg_checker/modules/network/__init__.py
index 627c7d5..8074a71 100644
--- a/cfg_checker/modules/network/__init__.py
+++ b/cfg_checker/modules/network/__init__.py
@@ -6,6 +6,7 @@
 def do_check(args):
     logger_cli.info("# Network check (CLI output)")
     netChecker = checker.NetworkChecker()
+    netChecker.collect_reclass_networks()
     netChecker.collect_network_info()
     netChecker.print_network_report()
 
diff --git a/cfg_checker/modules/network/checker.py b/cfg_checker/modules/network/checker.py
index 629e01d..ccc7d62 100644
--- a/cfg_checker/modules/network/checker.py
+++ b/cfg_checker/modules/network/checker.py
@@ -13,6 +13,23 @@
 
 
 class NetworkChecker(SaltNodes):
+    @staticmethod
+    def _map_network_for_host(host, if_class, net_list, data):
+        if not any(if_class.ip in net for net in net_list.keys()):
+            # IP not fits into existing networks
+            if if_class.network not in net_list.keys():
+                # create subnet key
+                net_list[if_class.network] = {}
+            # add the host to the dict
+            net_list[if_class.network][host] = data
+        else:
+            # There is a network that ip fits into
+            for _net in net_list.keys():
+                if if_class.ip in _net:
+                    net_list[_net][host] = data
+
+        return net_list
+
     def collect_network_info(self):
         """
         Collects info on the network using ifs_data.py script
@@ -20,7 +37,7 @@
         :return: none
         """
         logger_cli.info("### Collecting network data")
-        _result = self.execute_script("ifs_data.py", args=["json"])
+        _result = self.execute_script_on_active_nodes("ifs_data.py", args=["json"])
 
         for key in self.nodes.keys():
             # due to much data to be passed from salt, it is happening in order
@@ -45,53 +62,56 @@
         #     _nodes = json.loads(ff.read())
 
         logger_cli.info("### Building network tree")
-        # match physical interfaces by MAC addresses
+        # match interfaces by IP subnets
         _all_nets = {}
         for host, node_data in self.nodes.iteritems():
             for net_name, net_data in node_data['networks'].iteritems():
                 # get ips and calculate subnets
                 if net_name == 'lo':
+                    # skip the localhost
                     continue
                 _ip4s = net_data['ipv4']
                 for _ip_str in _ip4s.keys():
+                     # create interface class
                     _if = ipaddress.IPv4Interface(_ip_str)
-                    if not any(_if.ip in net for net in _all_nets.keys()):
-                        # IP not fits into existing networks
-                        if _if.network not in _all_nets.keys():
-                            _all_nets[_if.network] = {}
-                        
-                        _all_nets[_if.network][host] = {}
-                        _all_nets[_if.network][host]['text'] = \
-                                "{0:30}: {1:19} {2:5} {3:4}".format(
-                                    net_name,
-                                    str(_if.ip),
-                                    net_data['mtu'],
-                                    net_data['state']
-                                )
-                        _all_nets[_if.network][host]['if_data'] = net_data
-                    else:
-                        # There is a network that ip fits into
-                        for _net in _all_nets.keys():
-                            if _if.ip in _net:
-                                if host not in _all_nets[_net]:
-                                    _all_nets[_net][host] = {}
-                                _all_nets[_net][host]['text'] = \
-                                    "{0:30}: {1:19} {2:5} {3:4}".format(
-                                        net_name,
-                                        str(_if.ip),
-                                        net_data['mtu'],
-                                        net_data['state']
-                                    )
-                                _all_nets[_net][host]['if_data'] = \
-                                    net_data
+                    net_data['name'] = net_name
+                    net_data['if'] = _if
+
+                    _all_nets = self._map_network_for_host(
+                        host,
+                        _if,
+                        _all_nets,
+                        net_data
+                    )
 
         # save collected info
         self.all_networks = _all_nets
 
-        # Get networks from reclass
-        # TODO: 
 
-        return
+    def collect_reclass_networks(self):
+        # Get networks from reclass and mark them
+        _reclass_nets = {}
+        # Get required pillars
+        self.get_specific_pillar_for_nodes("linux:network")
+        for node in self.nodes.keys():
+            _pillar = self.nodes[node]['pillars']['linux']['network']['interface']
+            for _if_name, _if_data in _pillar.iteritems():
+                if 'address' in _if_data:
+                    _if = ipaddress.IPv4Interface(
+                        _if_data['address'] + '/' + _if_data['netmask']
+                    )
+                    _if_data['name'] = _if_name
+                    _if_data['if'] = _if
+
+                    _reclass_nets = self._map_network_for_host(
+                        node,
+                        _if,
+                        _reclass_nets,
+                        _if_data
+                    )
+
+        self.reclass_nets = _reclass_nets
+
 
     def print_network_report(self):
         """
@@ -104,11 +124,14 @@
             names = sorted(nodes.keys())
 
             for hostname in names:
+                _text = "{0:30}: {1:19} {2:5} {3:4}".format(
+                    nodes[hostname]['name'],
+                    str(nodes[hostname]['if'].ip),
+                    nodes[hostname]['mtu'],
+                    nodes[hostname]['state']
+                )
                 logger_cli.info(
-                    "\t{0:10} {1}".format(
-                        hostname.split('.')[0],
-                        nodes[hostname]['text']
-                    )
+                    "\t{0:10} {1}".format(hostname.split('.')[0], _text)
                 )
     
     def create_html_report(self, filename):
diff --git a/cfg_checker/modules/packages/checker.py b/cfg_checker/modules/packages/checker.py
index 81ba20e..61e84b5 100644
--- a/cfg_checker/modules/packages/checker.py
+++ b/cfg_checker/modules/packages/checker.py
@@ -20,7 +20,7 @@
         :return: none
         """
         logger_cli.info("### Collecting installed packages")
-        _result = self.execute_script("pkg_versions.py")
+        _result = self.execute_script_on_active_nodes("pkg_versions.py")
 
         for key in self.nodes.keys():
             # due to much data to be passed from salt, it is happening in order