diff options
| author | Daniil Baturin <daniil@vyos.io> | 2022-11-02 11:49:35 +0000 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2022-11-02 11:49:35 +0000 | 
| commit | 1bc2a0e8659adf32208e6a96499c569a4d42cb92 (patch) | |
| tree | 613f000e389d74fc7a589e2c60e3616224ee5748 /src/op_mode/log.py | |
| parent | f50f7b043a8636a57fc61330d94550734d2826b5 (diff) | |
| parent | f489c5ecdab5bdd8a5faa130f4c79a6f4559353b (diff) | |
| download | vyos-1x-1bc2a0e8659adf32208e6a96499c569a4d42cb92.tar.gz vyos-1x-1bc2a0e8659adf32208e6a96499c569a4d42cb92.zip | |
Merge pull request #1635 from sever-sever/T4777
T4777: Ability to get logs in machine-readable format
Diffstat (limited to 'src/op_mode/log.py')
| -rwxr-xr-x | src/op_mode/log.py | 94 | 
1 files changed, 94 insertions, 0 deletions
| diff --git a/src/op_mode/log.py b/src/op_mode/log.py new file mode 100755 index 000000000..b0abd6191 --- /dev/null +++ b/src/op_mode/log.py @@ -0,0 +1,94 @@ +#!/usr/bin/env python3 +# +# Copyright (C) 2022 VyOS maintainers and contributors +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License version 2 or later as +# published by the Free Software Foundation. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program.  If not, see <http://www.gnu.org/licenses/>. + +import json +import re +import sys +import typing + +from jinja2 import Template + +from vyos.util import rc_cmd + +import vyos.opmode + +journalctl_command_template = Template(""" +--no-hostname +--quiet + +{% if boot %} +  --boot +{% endif %} + +{% if count %} +  --lines={{ count }} +{% endif %} + +{% if reverse %} +  --reverse +{% endif %} + +{% if since %} +  --since={{ since }} +{% endif %} + +{% if unit %} +  --unit={{ unit }} +{% endif %} + +{% if utc %} +  --utc +{% endif %} + +{% if raw %} +{# By default show 100 only lines for raw option if count does not set #} +{# Protection from parsing the full log by default #} +{%    if not boot %} +  --lines={{ '' ~ count if count else '100' }} +{%    endif %} +  --no-pager +  --output=json +{% endif %} +""") + + +def show(raw: bool, +         boot: typing.Optional[bool], +         count: typing.Optional[int], +         facility: typing.Optional[str], +         reverse: typing.Optional[bool], +         utc: typing.Optional[bool], +         unit: typing.Optional[str]): +    kwargs = dict(locals()) + +    journalctl_options = journalctl_command_template.render(kwargs) +    journalctl_options = re.sub(r'\s+', ' ', journalctl_options) +    rc, output = rc_cmd(f'journalctl {journalctl_options}') +    if raw: +        # Each 'journalctl --output json' line is a separate JSON object +        # So we should return list of dict +        return [json.loads(line) for line in output.split('\n')] +    return output + + +if __name__ == '__main__': +    try: +        res = vyos.opmode.run(sys.modules[__name__]) +        if res: +            print(res) +    except (ValueError, vyos.opmode.Error) as e: +        print(e) +        sys.exit(1) | 
