From d93efd69083c153c1586dd08d65f1d10769820b7 Mon Sep 17 00:00:00 2001
From: Christian Poessinger <christian@poessinger.com>
Date: Wed, 4 Mar 2020 19:10:49 +0100
Subject: vrf: T31: make 'show vrf' command behave like other 'show interface
 commands'

- remove the additional depth for querying discrete VRF names
- retrieve available VRF names from via <path> from CLI rather then invoking
  an external script
---
 src/op_mode/show_vrf.py | 27 +++++++++++++++++++++++++++
 1 file changed, 27 insertions(+)
 create mode 100755 src/op_mode/show_vrf.py

(limited to 'src/op_mode')

diff --git a/src/op_mode/show_vrf.py b/src/op_mode/show_vrf.py
new file mode 100755
index 000000000..210b3c9a4
--- /dev/null
+++ b/src/op_mode/show_vrf.py
@@ -0,0 +1,27 @@
+#!/usr/bin/env python3
+
+import argparse
+import vyos.vrf
+
+parser = argparse.ArgumentParser()
+group = parser.add_mutually_exclusive_group()
+group.add_argument("-e", "--extensive", action="store_true",
+                   help="provide detailed vrf informatio")
+parser.add_argument('interface', metavar='I', type=str, nargs='?',
+                    help='interface to display')
+
+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():
+        name = vrf['ifname']
+        if args.interface and name != args.interface:
+            continue
+        state = vrf['operstate'].lower()
+        mac = vrf['address'].lower()
+        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()]))
-- 
cgit v1.2.3