diff options
author | hagbard <vyosdev@derith.de> | 2019-12-04 08:24:16 -0800 |
---|---|---|
committer | hagbard <vyosdev@derith.de> | 2019-12-04 15:36:12 -0800 |
commit | a93a1dbd7d18ff82246b4f7fb9a3757c14e6a9c7 (patch) | |
tree | 1af4bff652079a7d1c35ff0b76735829f24b7d30 /src/migration-scripts | |
parent | aceb4d7e187a571019e4bc24cd23efc7c2f624fe (diff) | |
download | vyos-1x-a93a1dbd7d18ff82246b4f7fb9a3757c14e6a9c7.tar.gz vyos-1x-a93a1dbd7d18ff82246b4f7fb9a3757c14e6a9c7.zip |
syslog: T1845: syslog host no longer accepts a port
- renamed interface xml
- renamed syslog.py to system-syslog.py
- moved protocol out of the facility node (bug)
- node port created
- migration script included
Diffstat (limited to 'src/migration-scripts')
-rwxr-xr-x | src/migration-scripts/system/11-to-12 | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/src/migration-scripts/system/11-to-12 b/src/migration-scripts/system/11-to-12 new file mode 100755 index 000000000..beba194fc --- /dev/null +++ b/src/migration-scripts/system/11-to-12 @@ -0,0 +1,55 @@ +#!/usr/bin/env python3 + +# converts 'set system syslog host <address>:<port>' +# to 'set system syslog host <address> port <port>' + +import sys +import re + +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) +cbase = ['system', 'syslog', 'host'] + +if not config.exists(cbase): + sys.exit(0) +else: + config.set(cbase) + config.set_tag(cbase) + for host in config.list_nodes(cbase): + h = None + pt = None + if re.search('^[a-zA-Z\-0-9\.]+', host): + h = re.search('^[a-zA-Z\-0-9\.]+', host).group(0) + if re.search(':[0-9]+$', host): + pt = re.sub(':', '', re.search(':[0-9]+$', host).group(0)) + + config.set(cbase + [h]) + for fac in config.list_nodes(cbase + [host, 'facility']): + config.set(cbase + [h, 'facility', fac]) + config.set_tag(cbase + [h, 'facility']) + lvl = config.return_value(cbase + [host, 'facility', fac, 'level']) + prot = config.return_value(cbase + [host, 'facility', fac, 'protocol']) + config.set(cbase + [h, 'facility', fac, 'level'], value=lvl) + # port can be be in each tag node and different, + # that's something we can't fix here + if prot: + config.set(cbase + [h, 'protocol'], value=prot) + config.set(cbase + [h, 'port'], value=pt) + config.delete(cbase + [host]) + + try: + open(file_name,'w').write(config.to_string()) + except OSError as e: + print("Failed to save the modified config: {}".format(e)) + sys.exit(1) + |