diff options
author | John Estabrook <jestabro@vyos.io> | 2024-08-08 11:24:00 -0500 |
---|---|---|
committer | Mergify <37929162+mergify[bot]@users.noreply.github.com> | 2024-08-09 08:43:28 +0000 |
commit | d2ba8f755de1c5817ae2c70e06e55868613a0d33 (patch) | |
tree | d49c2287901758e8ec6c7ec57b721c0f95a790b3 /python/vyos/configverify.py | |
parent | 7a4a462ef60a9e53a222d03d106fed793c33ec9e (diff) | |
download | vyos-1x-d2ba8f755de1c5817ae2c70e06e55868613a0d33.tar.gz vyos-1x-d2ba8f755de1c5817ae2c70e06e55868613a0d33.zip |
qos: T6638: require interface state existence in verify conditional
(cherry picked from commit ed63c9d1896a218715e13e1799fc059f4561f75e)
Diffstat (limited to 'python/vyos/configverify.py')
-rw-r--r-- | python/vyos/configverify.py | 13 |
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): |