diff options
author | Christian Poessinger <christian@poessinger.com> | 2019-11-04 20:17:12 +0100 |
---|---|---|
committer | Christian Poessinger <christian@poessinger.com> | 2019-11-04 20:17:12 +0100 |
commit | a5b4d854695524b0c20b70069e5151d052aa4c19 (patch) | |
tree | 29c978a08b66bc18395415abcd57fae1ead3f66f /python | |
parent | 1964144258b3bfd0bf2afac07fef26d535b95eba (diff) | |
download | vyos-1x-a5b4d854695524b0c20b70069e5151d052aa4c19.tar.gz vyos-1x-a5b4d854695524b0c20b70069e5151d052aa4c19.zip |
Python/ifconfig: T1557: do not allow both IPv4 and dhcp address on interfaces
Diffstat (limited to 'python')
-rw-r--r-- | python/vyos/ifconfig.py | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/python/vyos/ifconfig.py b/python/vyos/ifconfig.py index df86e3c93..66ccc85e9 100644 --- a/python/vyos/ifconfig.py +++ b/python/vyos/ifconfig.py @@ -23,6 +23,8 @@ import time import vyos.interfaces from vyos.validate import * from vyos.config import Config +from vyos import ConfigError + from ipaddress import IPv4Network, IPv6Address from netifaces import ifaddresses, AF_INET, AF_INET6 from subprocess import Popen, PIPE, STDOUT @@ -113,6 +115,9 @@ class Interface: 'dhcpv6_temporary' : False } + # list of assigned IP addresses + self._addr = [] + def _debug_msg(self, msg): if os.path.isfile('/tmp/vyos.ifconfig.debug'): print('DEBUG/{:<6} {}'.format(self._ifname, msg)) @@ -432,6 +437,18 @@ class Interface: >>> j.get_addr() ['192.0.2.1/24', '2001:db8::ffff/64'] """ + + # cache new IP address which is assigned to interface + self._addr.append(addr) + + # we can not have both DHCP and static IPv4 addresses assigned to an interface + if 'dhcp' in self._addr: + for addr in self._addr: + # do not change below 'if' ordering esle you will get an exception as: + # ValueError: 'dhcp' does not appear to be an IPv4 or IPv6 address + if addr != 'dhcp' and is_ipv4(addr): + raise ConfigError("Can't configure both static IPv4 and DHCP address on the same interface") + if addr == 'dhcp': self._set_dhcp() elif addr == 'dhcpv6': |