diff options
author | John Estabrook <jestabro@vyos.io> | 2022-10-20 13:21:37 -0500 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-10-20 13:21:37 -0500 |
commit | 66fb698a106ed56677fdaaef1a934d0ea7b96561 (patch) | |
tree | 161cfb75244c7526017202ae95840399698df7c8 /python | |
parent | 0ac50cd67c14d011b600fa2362b7f6b405299b30 (diff) | |
parent | 36c475ec3524739f9ae49420e60a57a5266fa575 (diff) | |
download | vyos-1x-66fb698a106ed56677fdaaef1a934d0ea7b96561.tar.gz vyos-1x-66fb698a106ed56677fdaaef1a934d0ea7b96561.zip |
Merge pull request #1607 from dmbaturin/op-mode-field-normalization
T4765: normalize dict fields in op mode ouputs
Diffstat (limited to 'python')
-rw-r--r-- | python/vyos/opmode.py | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/python/vyos/opmode.py b/python/vyos/opmode.py index 7e3545c87..ac9c0c353 100644 --- a/python/vyos/opmode.py +++ b/python/vyos/opmode.py @@ -44,6 +44,13 @@ class PermissionDenied(Error): """ pass +class InternalError(Error): + """ Any situation when VyOS detects that it could not perform + an operation correctly due to logic errors in its own code + or errors in underlying software. + """ + pass + def _is_op_mode_function_name(name): if re.match(r"^(show|clear|reset|restart)", name): @@ -93,6 +100,39 @@ def _get_arg_type(t): else: return t +def _normalize_field_name(name): + # Replace all separators with underscores + name = re.sub(r'(\s|[\(\)\[\]\{\}\-\.\,:\"\'\`])+', '_', name) + + # Replace specific characters with textual descriptions + name = re.sub(r'@', '_at_', name) + name = re.sub(r'%', '_percentage_', name) + name = re.sub(r'~', '_tilde_', name) + + # Force all letters to lowercase + name = name.lower() + + # Remove leading and trailing underscores, if any + name = re.sub(r'(^(_+)(?=[^_])|_+$)', '', name) + + # Ensure there are only single underscores + name = re.sub(r'_+', '_', name) + + return name + +def _normalize_field_names(old_dict): + new_dict = {} + + for key in old_dict: + new_key = _normalize_field_name(key) + new_dict[new_key] = old_dict[key] + + # Sanity check + if len(old_dict) != len(new_dict): + raise InternalError("Dictionary fields do not allow unique normalization") + else: + return new_dict + def run(module): from argparse import ArgumentParser @@ -145,6 +185,7 @@ def run(module): # they may return human-formatted output # or a raw dict that we need to serialize in JSON for printing res = func(**args) + res = _normalize_field_names(res) if not args["raw"]: return res else: |