diff options
author | Daniil Baturin <daniil@baturin.org> | 2018-11-29 07:08:09 +0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-11-29 07:08:09 +0700 |
commit | 51d5bc278e6cb370abe89aff41e70236f5586638 (patch) | |
tree | 63151c1e695b579a6f34aae6710be3992821d950 | |
parent | bd536044ce753e1cc40753c296752b4303291021 (diff) | |
parent | bf55a3a40f1e247b944eea266d4cd384d20087d1 (diff) | |
download | vyos-1x-51d5bc278e6cb370abe89aff41e70236f5586638.tar.gz vyos-1x-51d5bc278e6cb370abe89aff41e70236f5586638.zip |
Merge pull request #60 from arnehaak/current
T1001: Bugfix: Handle backslashes in values with "show configuration commands"
-rwxr-xr-x | src/utils/vyos-config-to-commands | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/src/utils/vyos-config-to-commands b/src/utils/vyos-config-to-commands index 8b50f7c5d..7147bc5ff 100755 --- a/src/utils/vyos-config-to-commands +++ b/src/utils/vyos-config-to-commands @@ -19,6 +19,14 @@ else: except OSError as e: print("Could not read config file {0}: {1}".format(file_name, e), file=sys.stderr) +# This script is usually called with the output of "cli-shell-api showCfg", which does not +# escape backslashes. "ConfigTree()" expects escaped backslashes when parsing a config +# string (and also prints them itself). Therefore this script would fail. +# Manually escape backslashes here to handle backslashes in any configuration strings +# properly. The alternative would be to modify the output of "cli-shell-api showCfg", +# but that may be break other things who rely on that specific output. +config_string = config_string.replace("\\", "\\\\") + try: config = ConfigTree(config_string) commands = config.to_commands() |