diff options
author | Christian Poessinger <christian@poessinger.com> | 2022-03-23 10:58:02 +0100 |
---|---|---|
committer | Christian Poessinger <christian@poessinger.com> | 2022-04-07 09:44:35 +0200 |
commit | 7581a5c6cbbc3f0e38ac69028b814252805d5c98 (patch) | |
tree | b208839db99f33ca1318723ff25a34f5010931af /python/vyos/configverify.py | |
parent | 4ecf558f53d1740b5ddb0de1f7effbaf0f44ff5f (diff) | |
download | vyos-1x-7581a5c6cbbc3f0e38ac69028b814252805d5c98.tar.gz vyos-1x-7581a5c6cbbc3f0e38ac69028b814252805d5c98.zip |
qos: T4284: verify mirror/redirect target interface exists
Diffstat (limited to 'python/vyos/configverify.py')
-rw-r--r-- | python/vyos/configverify.py | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/python/vyos/configverify.py b/python/vyos/configverify.py index 9f2771854..1062d51ee 100644 --- a/python/vyos/configverify.py +++ b/python/vyos/configverify.py @@ -185,15 +185,26 @@ def verify_mirror_redirect(config): It makes no sense to mirror traffic back at yourself! """ + import os if {'mirror', 'redirect'} <= set(config): raise ConfigError('Mirror and redirect can not be enabled at the same time!') if 'mirror' in config: for direction, mirror_interface in config['mirror'].items(): + if not os.path.exists(f'/sys/class/net/{mirror_interface}'): + raise ConfigError(f'Requested mirror interface "{mirror_interface}" '\ + 'does not exist!') + if mirror_interface == config['ifname']: - raise ConfigError(f'Can not mirror "{direction}" traffic back ' \ + raise ConfigError(f'Can not mirror "{direction}" traffic back '\ 'the originating interface!') + if 'redirect' in config: + redirect_ifname = config['redirect'] + if not os.path.exists(f'/sys/class/net/{redirect_ifname}'): + raise ConfigError(f'Requested redirect interface "{redirect_ifname}" '\ + 'does not exist!') + if dict_search('traffic_policy.in', config) != None: # XXX: support combination of limiting and redirect/mirror - this is an # artificial limitation |