diff options
| -rw-r--r-- | data/templates/mdns-repeater/avahi-daemon.j2 | 1 | ||||
| -rw-r--r-- | interface-definitions/interfaces-wireguard.xml.in | 2 | ||||
| -rw-r--r-- | interface-definitions/service-mdns-repeater.xml.in | 1 | ||||
| -rw-r--r-- | python/vyos/config_mgmt.py | 34 | ||||
| -rwxr-xr-x | smoketest/scripts/cli/test_service_mdns-repeater.py | 35 | ||||
| -rwxr-xr-x | src/op_mode/powerctrl.py | 12 | 
6 files changed, 63 insertions, 22 deletions
| diff --git a/data/templates/mdns-repeater/avahi-daemon.j2 b/data/templates/mdns-repeater/avahi-daemon.j2 index 3aaa7fc82..e0dfd897e 100644 --- a/data/templates/mdns-repeater/avahi-daemon.j2 +++ b/data/templates/mdns-repeater/avahi-daemon.j2 @@ -1,3 +1,4 @@ +### Autogenerated by service_mdns-repeater.py ###  [server]  use-ipv4=yes  use-ipv6=yes diff --git a/interface-definitions/interfaces-wireguard.xml.in b/interface-definitions/interfaces-wireguard.xml.in index 6342b21cf..03f169c05 100644 --- a/interface-definitions/interfaces-wireguard.xml.in +++ b/interface-definitions/interfaces-wireguard.xml.in @@ -5,7 +5,7 @@        <tagNode name="wireguard" owner="${vyos_conf_scripts_dir}/interfaces-wireguard.py">          <properties>            <help>WireGuard Interface</help> -          <priority>459</priority> +          <priority>381</priority>            <constraint>              <regex>wg[0-9]+</regex>            </constraint> diff --git a/interface-definitions/service-mdns-repeater.xml.in b/interface-definitions/service-mdns-repeater.xml.in index 4aab9a558..653dbbbe4 100644 --- a/interface-definitions/service-mdns-repeater.xml.in +++ b/interface-definitions/service-mdns-repeater.xml.in @@ -38,6 +38,7 @@                    <constraint>                      <regex>[-_.a-zA-Z0-9]+</regex>                    </constraint> +                  <constraintErrorMessage>Service name must be alphanumeric and can contain hyphens and underscores</constraintErrorMessage>                    <multi/>                  </properties>                </leafNode> diff --git a/python/vyos/config_mgmt.py b/python/vyos/config_mgmt.py index fade3081c..57563a9c1 100644 --- a/python/vyos/config_mgmt.py +++ b/python/vyos/config_mgmt.py @@ -26,6 +26,7 @@ from tabulate import tabulate  from vyos.config import Config  from vyos.configtree import ConfigTree, ConfigTreeError, show_diff  from vyos.defaults import directories +from vyos.version import get_full_version_data  from vyos.util import is_systemd_service_active, ask_yes_no, rc_cmd  SAVE_CONFIG = '/opt/vyatta/sbin/vyatta-save-config.pl' @@ -56,6 +57,21 @@ formatter = logging.Formatter('%(funcName)s: %(levelname)s:%(message)s')  ch.setFormatter(formatter)  logger.addHandler(ch) +def save_config(target): +    cmd = f'{SAVE_CONFIG} {target}' +    rc, out = rc_cmd(cmd) +    if rc != 0: +        logger.critical(f'save config failed: {out}') + +def unsaved_commits() -> bool: +    if get_full_version_data()['boot_via'] == 'livecd': +        return False +    tmp_save = '/tmp/config.running' +    save_config(tmp_save) +    ret = not cmp(tmp_save, config_file, shallow=False) +    os.unlink(tmp_save) +    return ret +  class ConfigMgmtError(Exception):      pass @@ -98,20 +114,6 @@ class ConfigMgmt:          self.active_config = config._running_config          self.working_config = config._session_config -    @staticmethod -    def save_config(target): -        cmd = f'{SAVE_CONFIG} {target}' -        rc, out = rc_cmd(cmd) -        if rc != 0: -            logger.critical(f'save config failed: {out}') - -    def _unsaved_commits(self) -> bool: -        tmp_save = '/tmp/config.boot.check-save' -        self.save_config(tmp_save) -        ret = not cmp(tmp_save, config_file, shallow=False) -        os.unlink(tmp_save) -        return ret -      # Console script functions      #      def commit_confirm(self, minutes: int=DEFAULT_TIME_MINUTES, @@ -123,7 +125,7 @@ class ConfigMgmt:              msg = 'Another confirm is pending'              return msg, 1 -        if self._unsaved_commits(): +        if unsaved_commits():              W = '\nYou should save previous commits before commit-confirm !\n'          else:              W = '' @@ -450,7 +452,7 @@ Proceed ?'''          ext = os.getpid()          tmp_save = f'/tmp/config.boot.{ext}' -        self.save_config(tmp_save) +        save_config(tmp_save)          try:              if cmp(tmp_save, archive_config_file, shallow=False): diff --git a/smoketest/scripts/cli/test_service_mdns-repeater.py b/smoketest/scripts/cli/test_service_mdns-repeater.py index f99a98da1..880c13043 100755 --- a/smoketest/scripts/cli/test_service_mdns-repeater.py +++ b/smoketest/scripts/cli/test_service_mdns-repeater.py @@ -1,6 +1,6 @@  #!/usr/bin/env python3  # -# Copyright (C) 2020 VyOS maintainers and contributors +# Copyright (C) 2020-2023 VyOS maintainers and contributors  #  # This program is free software; you can redistribute it and/or modify  # it under the terms of the GNU General Public License version 2 or later as @@ -18,30 +18,57 @@ import unittest  from base_vyostest_shim import VyOSUnitTestSHIM +from configparser import ConfigParser  from vyos.util import process_named_running  base_path = ['service', 'mdns', 'repeater']  intf_base = ['interfaces', 'dummy'] +config_file = '/run/avahi-daemon/avahi-daemon.conf' +  class TestServiceMDNSrepeater(VyOSUnitTestSHIM.TestCase):      def tearDown(self): +        # Check for running process +        self.assertTrue(process_named_running('avahi-daemon')) +          self.cli_delete(base_path)          self.cli_delete(intf_base + ['dum10'])          self.cli_delete(intf_base + ['dum20'])          self.cli_commit() +        # Check that there is no longer a running process +        self.assertFalse(process_named_running('avahi-daemon')) +      def test_service(self): -        # Service required a configured IP address on the interface +        # mDNS browsing domains in addition to the default one (local) +        domains = ['dom1.home.arpa', 'dom2.home.arpa'] + +        # mDNS services to be repeated +        services = ['_ipp._tcp', '_smb._tcp', '_ssh._tcp'] +        # Service required a configured IP address on the interface          self.cli_set(intf_base + ['dum10', 'address', '192.0.2.1/30'])          self.cli_set(intf_base + ['dum20', 'address', '192.0.2.5/30'])          self.cli_set(base_path + ['interface', 'dum10'])          self.cli_set(base_path + ['interface', 'dum20']) + +        for domain in domains: +            self.cli_set(base_path + ['browse-domain', domain]) + +        for service in services: +            self.cli_set(base_path + ['allow-service', service]) +          self.cli_commit() -        # Check for running process -        self.assertTrue(process_named_running('avahi-daemon')) +        # Validate configuration values +        conf = ConfigParser(delimiters='=') +        conf.read(config_file) + +        self.assertEqual(conf['server']['allow-interfaces'], 'dum10, dum20') +        self.assertEqual(conf['server']['browse-domains'], ', '.join(domains)) +        self.assertEqual(conf['reflector']['enable-reflector'], 'yes') +        self.assertEqual(conf['reflector']['reflect-filters'], ', '.join(services))  if __name__ == '__main__':      unittest.main(verbosity=2) diff --git a/src/op_mode/powerctrl.py b/src/op_mode/powerctrl.py index fd4f86d88..239f766fd 100755 --- a/src/op_mode/powerctrl.py +++ b/src/op_mode/powerctrl.py @@ -1,6 +1,6 @@  #!/usr/bin/env python3  # -# Copyright (C) 2018 VyOS maintainers and contributors +# Copyright (C) 2023 VyOS maintainers and contributors  #  # This program is free software; you can redistribute it and/or modify  # it under the terms of the GNU General Public License version 2 or later as @@ -102,8 +102,18 @@ def cancel_shutdown():      else:          print("Reboot or poweroff is not scheduled") +def check_unsaved_config(): +    from vyos.config_mgmt import unsaved_commits + +    if unsaved_commits(): +        print("Warning: there are unsaved configuration changes!") +        print("Run 'save' command if you do not want to lose those changes after reboot/shutdown.") +    else: +        pass  def execute_shutdown(time, reboot=True, ask=True): +    check_unsaved_config() +      action = "reboot" if reboot else "poweroff"      if not ask:          if not ask_yes_no(f"Are you sure you want to {action} this system?"): | 
