diff options
| author | Christian Breunig <christian@breunig.cc> | 2023-01-22 08:20:10 +0100 | 
|---|---|---|
| committer | Christian Breunig <christian@breunig.cc> | 2023-01-22 08:20:10 +0100 | 
| commit | 33c3a02729ae95a8173f902cddd039c17262fbcb (patch) | |
| tree | 73d18dc9b74683696e5c9110e2bc4e54d2871abb | |
| parent | 275ea7303cfdb79c042da1b710622aee17a488a8 (diff) | |
| download | vyos-1x-33c3a02729ae95a8173f902cddd039c17262fbcb.tar.gz vyos-1x-33c3a02729ae95a8173f902cddd039c17262fbcb.zip | |
T4911: op-mode: bugfix AttributeError: 'str' object has no attribute 'items'
One can not always ensure that "interface" is of type list, add safeguard.
E.G. Juniper Networks, Inc. ex2300-c-12t only has a dict, not a list of dicts
So this is actually an upstream lldpd bug where the output depends on the amount
of data transmitted.
| -rwxr-xr-x | src/op_mode/lldp.py | 6 | 
1 files changed, 5 insertions, 1 deletions
| diff --git a/src/op_mode/lldp.py b/src/op_mode/lldp.py index bfcb8f8c7..1a1b94783 100755 --- a/src/op_mode/lldp.py +++ b/src/op_mode/lldp.py @@ -64,7 +64,11 @@ def _get_formatted_output(raw_data):      tmp = dict_search('lldp.interface', raw_data)      if not tmp:          return None -    for neighbor in dict_search('lldp.interface', raw_data): +    # One can not always ensure that "interface" is of type list, add safeguard. +    # E.G. Juniper Networks, Inc. ex2300-c-12t only has a dict, not a list of dicts +    if isinstance(tmp, dict): +        tmp = [tmp] +    for neighbor in tmp:          for local_if, values in neighbor.items():              tmp = [] | 
