summaryrefslogtreecommitdiff
path: root/src/conf_mode/dhcp_server.py
diff options
context:
space:
mode:
authorChristian Poessinger <christian@poessinger.com>2018-08-29 22:28:29 +0200
committerChristian Poessinger <christian@poessinger.com>2018-08-29 22:28:29 +0200
commitf5311c1732009f927ea1b47966e4a296d62b2ce8 (patch)
treeb3c08ca1f2d0d74ee9b6f2e90038c32fcbd2bd43 /src/conf_mode/dhcp_server.py
parent37aeb227c346ee52d4fbed91c79cb59774ceb5ae (diff)
downloadvyos-1x-f5311c1732009f927ea1b47966e4a296d62b2ce8.tar.gz
vyos-1x-f5311c1732009f927ea1b47966e4a296d62b2ce8.zip
dhcp_server.py: check if AF_INET address is configure before using it in verify()
Diffstat (limited to 'src/conf_mode/dhcp_server.py')
-rwxr-xr-xsrc/conf_mode/dhcp_server.py11
1 files changed, 7 insertions, 4 deletions
diff --git a/src/conf_mode/dhcp_server.py b/src/conf_mode/dhcp_server.py
index 8ca72164a..556545e6d 100755
--- a/src/conf_mode/dhcp_server.py
+++ b/src/conf_mode/dhcp_server.py
@@ -703,10 +703,13 @@ def verify(dhcp):
# There must be one subnet connected to a real interface
#
for interface in netifaces.interfaces():
- # Retrieve IP address of network interface
- ip = netifaces.ifaddresses(interface)[netifaces.AF_INET][0]['addr']
- if ipaddress.ip_address(ip) in ipaddress.ip_network(subnet['network']):
- listen_ok = True
+ # Test if IPv4 addresses are configured at all
+ if netifaces.AF_INET in netifaces.ifaddresses(interface).keys():
+ # An interface can have multiple addresses, but ISC DHCP only supports the first :(
+ ip = netifaces.ifaddresses(interface)[netifaces.AF_INET][0]['addr']
+ if ipaddress.ip_address(ip) in ipaddress.ip_network(subnet['network']):
+ # Bingo! At least one subnet connected to an interface on this machine
+ listen_ok = True
#
# Subnets must be non overlapping