summaryrefslogtreecommitdiff
path: root/src/op_mode
diff options
context:
space:
mode:
authorChristian Poessinger <christian@poessinger.com>2020-03-04 19:38:01 +0100
committerChristian Poessinger <christian@poessinger.com>2020-03-04 21:43:59 +0100
commitbb705d1a90cad14f07b5e61c44365868283feee9 (patch)
treec00bea605d8308a724a9dcf5fbc422ca62a239ff /src/op_mode
parente2a46280601aee4846776ebad08ed367aa115460 (diff)
downloadvyos-1x-bb705d1a90cad14f07b5e61c44365868283feee9.tar.gz
vyos-1x-bb705d1a90cad14f07b5e61c44365868283feee9.zip
vrf: T31: remove superfluous vyos.vrf library functions
vyos.vrf.list_vrfs() was only used in one function thus building a library is no longer needed. If it is needed in the future it should be placed into a library again.
Diffstat (limited to 'src/op_mode')
-rwxr-xr-xsrc/op_mode/show_vrf.py27
1 files changed, 24 insertions, 3 deletions
diff --git a/src/op_mode/show_vrf.py b/src/op_mode/show_vrf.py
index 210b3c9a4..ec894d572 100755
--- a/src/op_mode/show_vrf.py
+++ b/src/op_mode/show_vrf.py
@@ -1,7 +1,28 @@
#!/usr/bin/env python3
+#
+# Copyright (C) 2020 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 argparse
-import vyos.vrf
+
+from subprocess import check_output
+from json import loads
+
+def list_vrfs():
+ command = 'ip -j -br link show type vrf'
+ answer = loads(check_output(command.split()).decode())
+ return [_ for _ in answer if _]
parser = argparse.ArgumentParser()
group = parser.add_mutually_exclusive_group()
@@ -15,7 +36,7 @@ args = parser.parse_args()
if args.extensive:
print('{:16} {:7} {:17} {}'.format('interface', 'state', 'mac', 'flags'))
print('{:16} {:7} {:17} {}'.format('---------', '-----', '---', '-----'))
- for vrf in vyos.vrf.list_vrfs():
+ for vrf in list_vrfs():
name = vrf['ifname']
if args.interface and name != args.interface:
continue
@@ -24,4 +45,4 @@ if args.extensive:
info = ','.join([_.lower() for _ in vrf['flags']])
print(f'{name:16} {state:7} {mac:17} {info}')
else:
- print(" ".join([vrf['ifname'] for vrf in vyos.vrf.list_vrfs()]))
+ print(" ".join([vrf['ifname'] for vrf in list_vrfs()]))