Tryag File Manager
Home
-
Turbo Force
Current Path :
/
proc
/
self
/
root
/
usr
/
share
/
rhsm
/
subscription_manager
/
Upload File :
New :
File
Dir
//proc/self/root/usr/share/rhsm/subscription_manager/facts.py
# # Copyright (c) 2011 Red Hat, Inc. # # This software is licensed to you under the GNU General Public # License as published by the Free Software Foundation; either version # 2 of the License (GPLv2) or (at your option) any later version. # There is NO WARRANTY for this software, express or implied, # including the implied warranties of MERCHANTABILITY, # NON-INFRINGEMENT, or FITNESS FOR A PARTICULAR PURPOSE. You should # have received a copy of GPLv2 along with this software; if not, see # http://www.gnu.org/licenses/old-licenses/gpl-2.0.txt. # from datetime import datetime import gettext import glob import logging import os import rhsm.config from subscription_manager.injection import PLUGIN_MANAGER, require from subscription_manager.cache import CacheManager import subscription_manager.injection as inj from rhsm import ourjson as json _ = gettext.gettext log = logging.getLogger('rhsm-app.' + __name__) # Hardcoded value for the version of certificates this version of the client # prefers: CERT_VERSION = "3.2" class Facts(CacheManager): """ Manages the facts for this system, maintains a cache of the most recent set sent to server, and checks for changes. Includes both those hard coded in the app itself, as well as custom facts to be loaded from /etc/rhsm/facts/. """ CACHE_FILE = "/var/lib/rhsm/facts/facts.json" def __init__(self, ent_dir=None, prod_dir=None): self.facts = {} self.entitlement_dir = ent_dir or inj.require(inj.ENT_DIR) self.product_dir = prod_dir or inj.require(inj.PROD_DIR) # see bz #627962 # we would like to have this info, but for now, since it # can change constantly on laptops, it makes for a lot of # fact churn, so we report it, but ignore it as an indicator # that we need to update self.graylist = ['cpu.cpu_mhz', 'lscpu.cpu_mhz'] # plugin manager so we can add custom facst via plugin self.plugin_manager = require(PLUGIN_MANAGER) def get_last_update(self): try: return datetime.fromtimestamp(os.stat(self.CACHE_FILE).st_mtime) except Exception: return None def has_changed(self): """ return a dict of any key/values that have changed including new keys or deleted keys """ if not self._cache_exists(): log.info("Cache %s does not exit" % self.CACHE_FILE) return True cached_facts = self._read_cache() or {} # In order to accurately check for changes, we must refresh local data self.facts = self.get_facts(True) for key in (set(self.facts) | set(cached_facts)) - set(self.graylist): if self.facts.get(key) != cached_facts.get(key): return True return False def get_facts(self, refresh=False): if ((len(self.facts) == 0) or refresh): facts = {} facts.update(self._load_hw_facts()) # Set the preferred entitlement certificate version: facts.update({"system.certificate_version": CERT_VERSION}) facts.update(self._load_custom_facts()) self.plugin_manager.run('post_facts_collection', facts=facts) self.facts = facts return self.facts def to_dict(self): return self.get_facts() def _load_hw_facts(self): import hwprobe return hwprobe.Hardware().get_all() def _parse_facts_json(self, json_buffer, file_path): custom_facts = None try: custom_facts = json.loads(json_buffer) except ValueError: log.warn("Unable to load custom facts file: %s" % file_path) return custom_facts def _open_custom_facts(self, file_path): if not os.access(file_path, os.R_OK): log.warn("Unable to access custom facts file: %s" % file_path) return None try: f = open(file_path) except IOError: log.warn("Unabled to open custom facts file: %s" % file_path) return None json_buffer = f.read() f.close() return json_buffer def _load_custom_facts(self): """ Load custom facts from .facts files in /etc/rhsm/facts. """ facts_file_glob = "%s/facts/*.facts" % rhsm.config.DEFAULT_CONFIG_DIR file_facts = {} for file_path in glob.glob(facts_file_glob): log.info("Loading custom facts from: %s" % file_path) json_buffer = self._open_custom_facts(file_path) if json_buffer is None: continue custom_facts = self._parse_facts_json(json_buffer, file_path) if custom_facts: file_facts.update(custom_facts) return file_facts def _sync_with_server(self, uep, consumer_uuid): log.debug("Updating facts on server") uep.updateConsumer(consumer_uuid, facts=self.get_facts()) def _load_data(self, open_file): json_str = open_file.read() return json.loads(json_str)