diff options
author | khramshinr <khramshinr@gmail.com> | 2024-04-16 15:49:19 +0800 |
---|---|---|
committer | khramshinr <khramshinr@gmail.com> | 2024-04-16 15:49:19 +0800 |
commit | da40bd2b2a826986de128354ea1bfc041ada0016 (patch) | |
tree | 29ccba696202cd9fe4bfcfad1b88e67a99bbfc97 /python | |
parent | a6ccf358c7148781be438c4a2f89468ebfe5d48f (diff) | |
download | vyos-1x-da40bd2b2a826986de128354ea1bfc041ada0016.tar.gz vyos-1x-da40bd2b2a826986de128354ea1bfc041ada0016.zip |
qos: T4248: Allow to remove the only rule from the qos class
Diffstat (limited to 'python')
-rw-r--r-- | python/vyos/qos/base.py | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/python/vyos/qos/base.py b/python/vyos/qos/base.py index f9366c6b1..4173a1a43 100644 --- a/python/vyos/qos/base.py +++ b/python/vyos/qos/base.py @@ -246,6 +246,7 @@ class QoSBase: filter_cmd_base += ' protocol all' if 'match' in cls_config: + is_filtered = False for index, (match, match_config) in enumerate(cls_config['match'].items(), start=1): filter_cmd = filter_cmd_base if self.qostype == 'shaper' and 'prio ' not in filter_cmd: @@ -330,11 +331,13 @@ class QoSBase: cls = int(cls) filter_cmd += f' flowid {self._parent:x}:{cls:x}' self._cmd(filter_cmd) + is_filtered = True vlan_expression = "match.*.vif" match_vlan = jmespath.search(vlan_expression, cls_config) - if any(tmp in ['exceed', 'bandwidth', 'burst'] for tmp in cls_config): + if any(tmp in ['exceed', 'bandwidth', 'burst'] for tmp in cls_config) \ + and is_filtered: # For "vif" "basic match" is used instead of "action police" T5961 if not match_vlan: filter_cmd += f' action police' |