summaryrefslogtreecommitdiff
path: root/src/migration-scripts
diff options
context:
space:
mode:
authorhagbard <vyosdev@derith.de>2019-12-04 08:24:16 -0800
committerhagbard <vyosdev@derith.de>2019-12-04 15:36:12 -0800
commita93a1dbd7d18ff82246b4f7fb9a3757c14e6a9c7 (patch)
tree1af4bff652079a7d1c35ff0b76735829f24b7d30 /src/migration-scripts
parentaceb4d7e187a571019e4bc24cd23efc7c2f624fe (diff)
downloadvyos-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-xsrc/migration-scripts/system/11-to-1255
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)
+