View file File name : journald.py Content :""" A simple beacon to watch journald for specific entries """ import logging import salt.utils.beacons import salt.utils.data try: import systemd.journal # pylint: disable=no-name-in-module HAS_SYSTEMD = True except ImportError: HAS_SYSTEMD = False log = logging.getLogger(__name__) __virtualname__ = "journald" def __virtual__(): if HAS_SYSTEMD: return __virtualname__ return False def _get_journal(): """ Return the active running journal object """ if "systemd.journald" in __context__: return __context__["systemd.journald"] __context__["systemd.journald"] = systemd.journal.Reader() # get to the end of the journal __context__["systemd.journald"].seek_tail() __context__["systemd.journald"].get_previous() return __context__["systemd.journald"] def validate(config): """ Validate the beacon configuration """ # Configuration for journald beacon should be a list of dicts if not isinstance(config, list): return (False, "Configuration for journald beacon must be a list.") else: config = salt.utils.beacons.list_to_dict(config) for name in config.get("services", {}): if not isinstance(config["services"][name], dict): return ( False, "Services configuration for journald beacon must be a list of" " dictionaries.", ) return True, "Valid beacon configuration" def beacon(config): """ The journald beacon allows for the systemd journal to be parsed and linked objects to be turned into events. This beacons config will return all sshd jornal entries .. code-block:: yaml beacons: journald: - services: sshd: SYSLOG_IDENTIFIER: sshd PRIORITY: 6 """ ret = [] journal = _get_journal() config = salt.utils.beacons.list_to_dict(config) while True: cur = journal.get_next() if not cur: break for name in config.get("services", {}): n_flag = 0 for key in config["services"][name]: if isinstance(key, str): key = salt.utils.data.decode(key) if key in cur: if config["services"][name][key] == cur[key]: n_flag += 1 if n_flag == len(config["services"][name]): # Match! sub = salt.utils.data.simple_types_filter(cur) sub.update({"tag": name}) ret.append(sub) return ret