diff options
author | Christian Poessinger <christian@poessinger.com> | 2020-05-02 21:34:59 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-05-02 21:34:59 +0200 |
commit | 3501313affa62b88fa530c4518a08269ea6f61c0 (patch) | |
tree | 8a5cbbe418c82de4cbf4e5849a6ce4c58e1d599d /src/conf_mode/interfaces-bridge.py | |
parent | b47e7ebab5b9a871ce7d37e57193692a043263a2 (diff) | |
parent | 731fdaf86ba20ead3af7e4f988ad84a321fbe12e (diff) | |
download | vyos-1x-3501313affa62b88fa530c4518a08269ea6f61c0.tar.gz vyos-1x-3501313affa62b88fa530c4518a08269ea6f61c0.zip |
Merge pull request #388 from jjakob/flush-addrs-T2367
T2367: flush addresses when adding bond/bridge members
Diffstat (limited to 'src/conf_mode/interfaces-bridge.py')
-rwxr-xr-x | src/conf_mode/interfaces-bridge.py | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/src/conf_mode/interfaces-bridge.py b/src/conf_mode/interfaces-bridge.py index 2f92aae09..9d638653c 100755 --- a/src/conf_mode/interfaces-bridge.py +++ b/src/conf_mode/interfaces-bridge.py @@ -24,6 +24,7 @@ from vyos.ifconfig import BridgeIf, Section from vyos.ifconfig.stp import STP from vyos.configdict import list_diff from vyos.config import Config +from vyos.util import cmd from vyos import ConfigError default_config_data = { @@ -346,6 +347,13 @@ def apply(bridge): # add interfaces to bridge for member in bridge['member']: + # flushes address of only children of Interfaces class + # (e.g. vlan are not) + if member['name'] in Section.interfaces(): + klass = Section.klass(member['name'], vlan=False) + klass(member['name'], create=False).flush_addrs() + # flushes all interfaces + cmd(f'ip addr flush dev "{member["name"]}"') br.add_port(member['name']) # Change interface MAC address |