summaryrefslogtreecommitdiff
path: root/python
diff options
context:
space:
mode:
authorJohn Estabrook <jestabro@vyos.io>2024-08-09 13:28:48 -0500
committerGitHub <noreply@github.com>2024-08-09 13:28:48 -0500
commit30506a53fa02bc514f3570af4d870eba9695aa08 (patch)
tree2dfddec7aefb1245c15588d03031b92bae8f7469 /python
parentc0ce26f995e48e29050791a6adb4bc09a2630201 (diff)
parentd9c9c48a0993524fa6443e317e5046e0e01d7641 (diff)
downloadvyos-1x-30506a53fa02bc514f3570af4d870eba9695aa08.tar.gz
vyos-1x-30506a53fa02bc514f3570af4d870eba9695aa08.zip
Merge pull request #3963 from vyos/mergify/bp/circinus/pr-3960circinus-merge-commit-handling
qos: T6638: require interface state existence in verify conditional (backport #3960)
Diffstat (limited to 'python')
-rw-r--r--python/vyos/configverify.py13
1 files changed, 7 insertions, 6 deletions
diff --git a/python/vyos/configverify.py b/python/vyos/configverify.py
index 4cb84194a..b49d66c36 100644
--- a/python/vyos/configverify.py
+++ b/python/vyos/configverify.py
@@ -237,7 +237,7 @@ def verify_bridge_delete(config):
raise ConfigError(f'Interface "{interface}" cannot be deleted as it '
f'is a member of bridge "{bridge_name}"!')
-def verify_interface_exists(ifname, warning_only=False):
+def verify_interface_exists(ifname, state_required=False, warning_only=False):
"""
Common helper function used by interface implementations to perform
recurring validation if an interface actually exists. We first probe
@@ -249,11 +249,12 @@ def verify_interface_exists(ifname, warning_only=False):
from vyos.utils.dict import dict_search_recursive
from vyos.utils.network import interface_exists
- # Check if interface is present in CLI config
- config = ConfigTreeQuery()
- tmp = config.get_config_dict(['interfaces'], get_first_key=True)
- if bool(list(dict_search_recursive(tmp, ifname))):
- return True
+ if not state_required:
+ # Check if interface is present in CLI config
+ config = ConfigTreeQuery()
+ tmp = config.get_config_dict(['interfaces'], get_first_key=True)
+ if bool(list(dict_search_recursive(tmp, ifname))):
+ return True
# Interface not found on CLI, try Linux Kernel
if interface_exists(ifname):