diff options
author | Viacheslav Hletenko <v.gletenko@vyos.io> | 2023-11-08 09:36:54 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-11-08 09:36:54 +0200 |
commit | b083e1bbf230d4e407bd9adb508197517d15bfb1 (patch) | |
tree | 1097bfd5aa34a8efe71ffa32b3f07cd52cde1034 /src/conf_mode/service_mdns-repeater.py | |
parent | 30b5da64378d24b37fdfe35e541188449cb053a9 (diff) | |
parent | eb906739047187c322b6ce9efe7c9479bed9a024 (diff) | |
download | vyos-1x-b083e1bbf230d4e407bd9adb508197517d15bfb1.tar.gz vyos-1x-b083e1bbf230d4e407bd9adb508197517d15bfb1.zip |
Merge pull request #2459 from indrajitr/mdns-streamline
mdns: T5723: Always reload systemd daemon before applying changes
Diffstat (limited to 'src/conf_mode/service_mdns-repeater.py')
-rwxr-xr-x | src/conf_mode/service_mdns-repeater.py | 14 |
1 files changed, 11 insertions, 3 deletions
diff --git a/src/conf_mode/service_mdns-repeater.py b/src/conf_mode/service_mdns-repeater.py index 6909731ff..6526c23d1 100755 --- a/src/conf_mode/service_mdns-repeater.py +++ b/src/conf_mode/service_mdns-repeater.py @@ -29,6 +29,7 @@ from vyos import airbag airbag.enable() config_file = '/run/avahi-daemon/avahi-daemon.conf' +systemd_override = r'/run/systemd/system/avahi-daemon.service.d/override.conf' vrrp_running_file = '/run/mdns_vrrp_active' def get_config(config=None): @@ -48,6 +49,8 @@ def get_config(config=None): if mdns: mdns['vrrp_exists'] = conf.exists('high-availability vrrp') + mdns['config_file'] = config_file + return mdns def verify(mdns): @@ -101,11 +104,16 @@ def generate(mdns): return None render(config_file, 'mdns-repeater/avahi-daemon.conf.j2', mdns) + render(systemd_override, 'mdns-repeater/override.conf.j2', mdns) return None def apply(mdns): + systemd_service = 'avahi-daemon.service' + # Reload systemd manager configuration + call('systemctl daemon-reload') + if not mdns or 'disable' in mdns: - call('systemctl stop avahi-daemon.service') + call(f'systemctl stop {systemd_service}') if os.path.exists(config_file): os.unlink(config_file) @@ -120,10 +128,10 @@ def apply(mdns): os.mknod(vrrp_running_file) # vrrp script looks for this file to update mdns repeater if len(mdns['interface']) < 2: - call('systemctl stop avahi-daemon.service') + call(f'systemctl stop {systemd_service}') return None - call('systemctl restart avahi-daemon.service') + call(f'systemctl restart {systemd_service}') return None |