blob: 797c0fe6d48a4e8a5e11e773faf23de920bd0284 [file] [log] [blame]
import json
import os
#import sys
from copy import deepcopy
from cfg_checker.reports import reporter
from cfg_checker.common import utils, const
from cfg_checker.common import config, logger, logger_cli, pkg_dir
from cfg_checker.common import salt_utils
from cfg_checker.nodes import SaltNodes, node_tmpl
class CloudPackageChecker(SaltNodes):
def collect_installed_packages(self):
"""
Collect installed packages on each node
sets 'installed' dict property in the class
:return: none
"""
logger_cli.info("# Collecting installed packages")
_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
if key in _result:
_text = _result[key]
_dict = json.loads(_text[_text.find('{'):])
self.nodes[key]['packages'] = _dict
else:
self.nodes[key]['packages'] = {}
logger_cli.debug("... {} has {} packages installed".format(
key,
len(self.nodes[key]['packages'].keys())
))
logger_cli.info("-> Done")
def collect_packages(self):
"""
Check package versions in repos vs installed
:return: no return values, all date put to dict in place
"""
_all_packages = {}
for node_name, node_value in self.nodes.iteritems():
for package_name in node_value['packages']:
if package_name not in _all_packages:
_all_packages[package_name] = {}
_all_packages[package_name][node_name] = node_value
# TODO: process data for per-package basis
self.all_packages = _all_packages
def create_html_report(self, filename):
"""
Create static html showing packages diff per node
:return: buff with html
"""
logger_cli.info("# Generating report to '{}'".format(filename))
_report = reporter.ReportToFile(
reporter.HTMLPackageCandidates(),
filename
)
_report({
"nodes": self.nodes,
"diffs": {}
})
logger_cli.info("-> Done")