1
0
mirror of https://github.com/kellyjonbrazil/jc.git synced 2025-06-17 00:07:37 +02:00
Files
jc/jc/parsers/systemctl.py

124 lines
2.8 KiB
Python
Raw Normal View History

2019-11-15 11:58:17 -08:00
"""jc - JSON CLI output utility systemctl Parser
Usage:
2019-12-12 09:47:14 -08:00
2019-11-15 11:58:17 -08:00
specify --systemctl as the first argument if the piped input is coming from systemctl
2019-12-12 09:35:42 -08:00
Compatibility:
2019-12-12 09:47:14 -08:00
2019-12-12 09:35:42 -08:00
'linux'
2019-11-15 11:58:17 -08:00
Examples:
$ systemctl -a | jc --systemctl -p
[
{
"unit": "proc-sys-fs-binfmt_misc.automount",
"load": "loaded",
"active": "active",
"sub": "waiting",
"description": "Arbitrary Executable File Formats File System Automount Point"
},
{
"unit": "dev-block-8:2.device",
"load": "loaded",
"active": "active",
"sub": "plugged",
"description": "LVM PV 3klkIj-w1qk-DkJi-0XBJ-y3o7-i2Ac-vHqWBM on /dev/sda2 2"
},
{
"unit": "dev-cdrom.device",
"load": "loaded",
"active": "active",
"sub": "plugged",
"description": "VMware_Virtual_IDE_CDROM_Drive"
},
...
]
"""
import jc.utils
2019-12-13 20:01:51 -08:00
class info():
version = '1.0'
description = 'systemctl parser'
author = 'Kelly Brazil'
author_email = 'kellyjonbrazil@gmail.com'
# compatible options: linux, darwin, cygwin, win32, aix, freebsd
compatible = ['linux']
2020-02-03 16:11:58 -08:00
__version__ = info.version
2019-11-15 11:58:17 -08:00
def process(proc_data):
"""
Final processing to conform to the schema.
Parameters:
proc_data: (dictionary) raw structured data to process
Returns:
2019-12-17 09:56:09 -08:00
List of dictionaries. Structured data with the following schema:
2019-11-15 11:58:17 -08:00
[
{
"unit": string,
"load": string,
"active": string,
"sub": string,
"description": string
}
]
"""
# nothing more to process
return proc_data
def parse(data, raw=False, quiet=False):
"""
Main text parsing function
Parameters:
data: (string) text data to parse
raw: (boolean) output preprocessed JSON if True
quiet: (boolean) suppress warning messages if True
Returns:
2019-12-17 10:09:19 -08:00
List of dictionaries. Raw or processed structured data.
2019-11-15 11:58:17 -08:00
"""
if not quiet:
2019-12-13 20:01:51 -08:00
jc.utils.compatibility(__name__, info.compatible)
2019-11-15 11:58:17 -08:00
linedata = data.splitlines()
# Clear any blank lines
linedata = list(filter(None, linedata))
# clean up non-ascii characters, if any
cleandata = []
for entry in linedata:
cleandata.append(entry.encode('ascii', errors='ignore').decode())
header_text = cleandata[0]
header_list = header_text.lower().split()
raw_output = []
for entry in cleandata[1:]:
if entry.find('LOAD = ') != -1:
break
else:
2019-11-15 18:36:12 -08:00
entry_list = entry.rstrip().split(maxsplit=4)
2019-11-15 11:58:17 -08:00
output_line = dict(zip(header_list, entry_list))
raw_output.append(output_line)
if raw:
return raw_output
else:
return process(raw_output)