summaryrefslogtreecommitdiff
path: root/src/conf_mode/interfaces-bridge.py
diff options
context:
space:
mode:
authorChristian Poessinger <christian@poessinger.com>2020-05-02 21:34:59 +0200
committerGitHub <noreply@github.com>2020-05-02 21:34:59 +0200
commit3501313affa62b88fa530c4518a08269ea6f61c0 (patch)
tree8a5cbbe418c82de4cbf4e5849a6ce4c58e1d599d /src/conf_mode/interfaces-bridge.py
parentb47e7ebab5b9a871ce7d37e57193692a043263a2 (diff)
parent731fdaf86ba20ead3af7e4f988ad84a321fbe12e (diff)
downloadvyos-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-xsrc/conf_mode/interfaces-bridge.py8
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