summaryrefslogtreecommitdiff
path: root/src/conf_mode/protocols_bfd.py
diff options
context:
space:
mode:
authorChristian Poessinger <christian@poessinger.com>2019-06-16 19:59:33 +0200
committerChristian Poessinger <christian@poessinger.com>2019-06-22 01:01:21 +0200
commitecbe6c1c1b87792048512e3aa4913c1ce5b75c82 (patch)
tree88afcabf679dd31da26bca9cd3d96f1b2677e0a6 /src/conf_mode/protocols_bfd.py
parentefb1a1c88f436a3704c4ca6e15b65aeded4b9654 (diff)
downloadvyos-1x-ecbe6c1c1b87792048512e3aa4913c1ce5b75c82.tar.gz
vyos-1x-ecbe6c1c1b87792048512e3aa4913c1ce5b75c82.zip
bfd: T1183: initial CLI implementation
vyos@vyos# show protocols bfd peer 172.18.202.10 { local-address 172.18.201.10 local-interface eth0.201 shutdown } peer 172.18.202.12 { shutdown }
Diffstat (limited to 'src/conf_mode/protocols_bfd.py')
-rwxr-xr-xsrc/conf_mode/protocols_bfd.py76
1 files changed, 76 insertions, 0 deletions
diff --git a/src/conf_mode/protocols_bfd.py b/src/conf_mode/protocols_bfd.py
new file mode 100755
index 000000000..7e137c484
--- /dev/null
+++ b/src/conf_mode/protocols_bfd.py
@@ -0,0 +1,76 @@
+#!/usr/bin/env python3
+#
+# Copyright (C) 2019 VyOS maintainers and contributors
+#
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License version 2 or later as
+# published by the Free Software Foundation.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+#
+
+import copy
+from vyos.config import Config
+
+default_config_data = {
+ 'peers': []
+}
+
+def get_config():
+ bfd = copy.deepcopy(default_config_data)
+ conf = Config()
+ if not conf.exists('protocols bfd'):
+ return None
+ else:
+ conf.set_level('protocols bfd')
+
+ for peer in conf.list_nodes('peer'):
+ conf.set_level('protocols bfd peer {0}'.format(peer))
+ bfd_peer = {
+ 'peer': peer,
+ 'shutdown': False,
+ 'local-interface': '',
+ 'local-address': '',
+ }
+
+ # Check if individual peer is disabled
+ if conf.exists('shutdown'):
+ bfd_peer['shutdown'] = True
+
+ # Check if peer has a local source interface configured
+ if conf.exists('local-interface'):
+ bfd_peer['local-interface'] = conf.return_value('local-interface')
+
+ # Check if peer has a local source address configured - this is mandatory for IPv6
+ if conf.exists('local-address'):
+ bfd_peer['local-address'] = conf.return_value('local-address')
+
+ bfd['peers'].append(bfd_peer)
+
+ print(bfd)
+ return bfd
+
+def verify(bfd):
+ return None
+
+def generate(bfd):
+ return None
+
+def apply(bfd):
+ return None
+
+if __name__ == '__main__':
+ try:
+ c = get_config()
+ verify(c)
+ generate(c)
+ apply(c)
+ except ConfigError as e:
+ print(e)
+ sys.exit(1)