diff options
| author | Christian Breunig <christian@breunig.cc> | 2024-04-01 14:04:50 +0200 | 
|---|---|---|
| committer | Christian Breunig <christian@breunig.cc> | 2024-04-01 14:04:50 +0200 | 
| commit | ece425f0191762638b7c967097accd8739e9103d (patch) | |
| tree | 36c28edf28af2548cbb13cec5c00e241860019ff /python | |
| parent | a95063831f83dcfe458691b86407b70107b700ad (diff) | |
| download | vyos-1x-ece425f0191762638b7c967097accd8739e9103d.tar.gz vyos-1x-ece425f0191762638b7c967097accd8739e9103d.zip | |
dhcpv6-client: T2590: fix vyos-hostsd update for nameserver and search domains
After migrating from ISC DHCLIENT for IPv6 to wide-dhcp-client the logic which
was present to update /etc/resolv.conf with the DHCP specified nameservers and
also the search domain list was no longer present.
This commit adds a per interface rendered script to inform vyos-hostsd about
the received IPv6 nameservers and search domains.
Diffstat (limited to 'python')
| -rw-r--r-- | python/vyos/ifconfig/interface.py | 16 | 
1 files changed, 11 insertions, 5 deletions
| diff --git a/python/vyos/ifconfig/interface.py b/python/vyos/ifconfig/interface.py index 56dcde214..c87fb9c71 100644 --- a/python/vyos/ifconfig/interface.py +++ b/python/vyos/ifconfig/interface.py @@ -1375,15 +1375,19 @@ class Interface(Control):          ifname = self.ifname          config_base = directories['dhcp6_client_dir']          config_file = f'{config_base}/dhcp6c.{ifname}.conf' +        script_file = f'/etc/wide-dhcpv6/dhcp6c.{ifname}.script' # can not live under /run b/c of noexec mount option          systemd_override_file = f'/run/systemd/system/dhcp6c@{ifname}.service.d/10-override.conf'          systemd_service = f'dhcp6c@{ifname}.service' -        # Rendered client configuration files require the apsolute config path -        self.config['dhcp6_client_dir'] = directories['dhcp6_client_dir'] +        # Rendered client configuration files require additional settings +        config = deepcopy(self.config) +        config['dhcp6_client_dir'] = directories['dhcp6_client_dir'] +        config['dhcp6_script_file'] = script_file -        if enable and 'disable' not in self.config: -            render(systemd_override_file, 'dhcp-client/ipv6.override.conf.j2', self.config) -            render(config_file, 'dhcp-client/ipv6.j2', self.config) +        if enable and 'disable' not in config: +            render(systemd_override_file, 'dhcp-client/ipv6.override.conf.j2', config) +            render(config_file, 'dhcp-client/ipv6.j2', config) +            render(script_file, 'dhcp-client/dhcp6c-script.j2', config, permission=0o755)              # Reload systemd unit definitons as some options are dynamically generated              self._cmd('systemctl daemon-reload') @@ -1396,6 +1400,8 @@ class Interface(Control):                  self._cmd(f'systemctl stop {systemd_service}')              if os.path.isfile(config_file):                  os.remove(config_file) +            if os.path.isfile(script_file): +                os.remove(script_file)          return None | 
