diff options
author | Daniil Baturin <daniil@baturin.org> | 2018-05-29 23:07:52 +0200 |
---|---|---|
committer | Daniil Baturin <daniil@baturin.org> | 2018-05-29 23:07:52 +0200 |
commit | 737d72dc07e630231202fe1ae513c6195b6d250b (patch) | |
tree | 057ced5d09ae9567c889ee8bdea442e028467cf0 /src/migration-scripts/system/7-to-8 | |
parent | a331911473ddf3d9313a45a9cf126a4d1ead4753 (diff) | |
download | vyos-1x-737d72dc07e630231202fe1ae513c6195b6d250b.tar.gz vyos-1x-737d72dc07e630231202fe1ae513c6195b6d250b.zip |
T667: add a migration script for converting "system gateway-address" to "protocols static route 0.0.0.0".
Code-wise that option was in vyatta-cfg-quagga, but the syntax is inside "system", so let's keep
the script under system too.
Diffstat (limited to 'src/migration-scripts/system/7-to-8')
-rwxr-xr-x | src/migration-scripts/system/7-to-8 | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/src/migration-scripts/system/7-to-8 b/src/migration-scripts/system/7-to-8 new file mode 100755 index 000000000..4cbb21f17 --- /dev/null +++ b/src/migration-scripts/system/7-to-8 @@ -0,0 +1,45 @@ +#!/usr/bin/env python3 + +# Converts "system gateway-address" option to "protocols static route 0.0.0.0/0 next-hop $gw" + +import sys + +from vyos.configtree import ConfigTree + +if (len(sys.argv) < 1): + print("Must specify file name!") + sys.exit(1) + +file_name = sys.argv[1] + +with open(file_name, 'r') as f: + config_file = f.read() + +config = ConfigTree(config_file) + +if not config.exists(['system', 'gateway-address']): + # Nothing to do + sys.exit(0) +else: + # Save the address + gw = config.return_value(['system', 'gateway-address']) + + # Create the node for the new syntax + # Note: next-hop is a tag node, gateway address is its child, not a value + config.set(['protocols', 'static', 'route', '0.0.0.0/0', 'next-hop', gw]) + + # Delete the node with the old syntax + config.delete(['system', 'gateway-address']) + + # Now, the interesting part. Both route and next-hop are supposed to be tag nodes, + # which you can verify with "cli-shell-api isTag $configPath". + # They must be formatted as such to load correctly. + config.set_tag(['protocols', 'static', 'route']) + config.set_tag(['protocols', 'static', 'route', '0.0.0.0/0', 'next-hop']) + + try: + with open(file_name, 'w') as f: + f.write(config.to_string()) + except OSError as e: + print("Failed to save the modified config: {}".format(e)) + sys.exit(1) |