diff options
| author | Jernej Jakob <jernej.jakob@gmail.com> | 2020-07-19 21:21:52 +0200 | 
|---|---|---|
| committer | Jernej Jakob <jernej.jakob@gmail.com> | 2020-07-19 21:21:52 +0200 | 
| commit | fabd8b4bbb150b237121cd3eeffa8026903a159e (patch) | |
| tree | de5763bb2d447bec5bfe542c52b3ae06cd53339c /python | |
| parent | dadb09fd14046720e7898c3cbad8c5def408db9d (diff) | |
| download | vyos-1x-fabd8b4bbb150b237121cd3eeffa8026903a159e.tar.gz vyos-1x-fabd8b4bbb150b237121cd3eeffa8026903a159e.zip | |
interface: T2519: add broadcast address when adding IPv4 addresses
This adds the last IP of the subnet being added as the broadcast address.
Example: adding 192.0.2.1/24 would yield:
inet 192.0.2.1/24 brd 192.0.2.255 scope global dum0
Without this the broadcast address would be missing.
Addidionally join two is_ipv4 calls into one.
Diffstat (limited to 'python')
| -rw-r--r-- | python/vyos/ifconfig/interface.py | 7 | 
1 files changed, 5 insertions, 2 deletions
| diff --git a/python/vyos/ifconfig/interface.py b/python/vyos/ifconfig/interface.py index c73a3bbf8..8d7b247fc 100644 --- a/python/vyos/ifconfig/interface.py +++ b/python/vyos/ifconfig/interface.py @@ -667,10 +667,12 @@ class Interface(Control):          if addr in self._addr:              return False +        addr_is_v4 = is_ipv4(addr) +          # we can't have both DHCP and static IPv4 addresses assigned          for a in self._addr:              if ( ( addr == 'dhcp' and a != 'dhcpv6' and is_ipv4(a) ) or -                    ( a == 'dhcp' and addr != 'dhcpv6' and is_ipv4(addr) ) ): +                    ( a == 'dhcp' and addr != 'dhcpv6' and addr_is_v4 ) ):                  raise ConfigError((                      "Can't configure both static IPv4 and DHCP address "                      "on the same interface")) @@ -681,7 +683,8 @@ class Interface(Control):          elif addr == 'dhcpv6':              self.dhcp.v6.set()          elif not is_intf_addr_assigned(self.ifname, addr): -            self._cmd(f'ip addr add "{addr}" dev "{self.ifname}"') +            self._cmd(f'ip addr add "{addr}" ' +                    f'{"brd + " if addr_is_v4 else ""}dev "{self.ifname}"')          else:              return False | 
