Skip to content

Commit

Permalink
dhcpv6-server: T3493: add proper validation for prefix-delegation sta…
Browse files Browse the repository at this point in the history
…rt/stop address

ISC DHCP server expects a string: "prefix6 2001:db8:290:: 2001:db8:29f:: /64;"
where the IPv6 prefix/range must be :: terminaated with a delegated prefix
length at the end.

This commit changes the validator that the IPv6 address defined on the CLI must
always end with ::. In addition a verify() step is added to check that the
stop address is greater than start address.
  • Loading branch information
c-po committed May 26, 2024
1 parent b6c343c commit ccd564c
Show file tree
Hide file tree
Showing 3 changed files with 24 additions and 9 deletions.
6 changes: 4 additions & 2 deletions interface-definitions/service_dhcpv6-server.xml.in
Original file line number Diff line number Diff line change
Expand Up @@ -229,7 +229,8 @@
<description>IPv6 address used in prefix delegation</description>
</valueHelp>
<constraint>
<validator name="ipv6-address"/>
<!-- IPv6 address used MUST end with :: -->
<regex>([a-fA-F0-9]{1,4}:)+:</regex>
</constraint>
</properties>
<children>
Expand All @@ -254,7 +255,8 @@
<description>IPv6 address used in prefix delegation</description>
</valueHelp>
<constraint>
<validator name="ipv6-address"/>
<!-- IPv6 address used MUST end with :: -->
<regex>([a-fA-F0-9]{1,4}:)+:</regex>
</constraint>
</properties>
</leafNode>
Expand Down
8 changes: 7 additions & 1 deletion smoketest/scripts/cli/test_service_dhcpv6-server.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@

from base_vyostest_shim import VyOSUnitTestSHIM

from vyos.configsession import ConfigSessionError
from vyos.template import inc_ip
from vyos.utils.process import process_named_running
from vyos.utils.file import read_file
Expand Down Expand Up @@ -143,9 +144,14 @@ def test_prefix_delegation(self):
pool = base_path + ['shared-network-name', shared_net_name, 'subnet', subnet]

self.cli_set(pool + ['address-range', 'start', range_start, 'stop', range_stop])
self.cli_set(pool + ['prefix-delegation', 'start', delegate_start, 'stop', delegate_stop])
self.cli_set(pool + ['prefix-delegation', 'start', delegate_start, 'prefix-length', delegate_len])

self.cli_set(pool + ['prefix-delegation', 'start', delegate_start, 'stop', delegate_start])
# Prefix delegation stop address must be greater then start address
with self.assertRaises(ConfigSessionError):
self.cli_commit()
self.cli_set(pool + ['prefix-delegation', 'start', delegate_start, 'stop', delegate_stop])

# commit changes
self.cli_commit()

Expand Down
19 changes: 13 additions & 6 deletions src/conf_mode/service_dhcpv6-server.py
Original file line number Diff line number Diff line change
Expand Up @@ -105,22 +105,29 @@ def verify(dhcpv6):
if 'prefix' in subnet_config:
for prefix in subnet_config['prefix']:
if ip_network(prefix) not in ip_network(subnet):
raise ConfigError(f'address-range prefix "{prefix}" is not in subnet "{subnet}""')
raise ConfigError(f'address-range prefix "{prefix}" is not in subnet "{subnet}"!')

# Prefix delegation sanity checks
if 'prefix_delegation' in subnet_config:
if 'start' not in subnet_config['prefix_delegation']:
raise ConfigError('prefix-delegation start address not defined!')
raise ConfigError(f'Start address of delegated IPv6 prefix range "{prefix}" '\
f'must be configured!')

for prefix, prefix_config in subnet_config['prefix_delegation']['start'].items():
if 'stop' not in prefix_config:
raise ConfigError(f'Stop address of delegated IPv6 '\
f'prefix range "{prefix}" '\
f'must be configured')
raise ConfigError(f'Stop address of delegated IPv6 prefix range "{prefix}" '\
f'must be configured!')

start_addr = prefix
stop_addr = prefix_config['stop']

if ip_address(stop_addr) <= ip_address(start_addr):
raise ConfigError(f'Stop address of delegated IPv6 prefix range "{prefix}" '\
f'must be greater than start address!')

if 'prefix_length' not in prefix_config:
raise ConfigError(f'Length of delegated IPv6 prefix '\
f'must be configured')
f'must be configured!')

# Static mappings don't require anything (but check if IP is in subnet if it's set)
if 'static_mapping' in subnet_config:
Expand Down

0 comments on commit ccd564c

Please sign in to comment.