diff options
Diffstat (limited to 'src')
| -rwxr-xr-x | src/conf_mode/protocols_bfd.py | 3 | ||||
| -rwxr-xr-x | src/conf_mode/service_dhcp-server.py | 28 | ||||
| -rwxr-xr-x | src/conf_mode/system_option.py | 11 | ||||
| -rwxr-xr-x | src/migration-scripts/https/5-to-6 | 4 | ||||
| -rwxr-xr-x | src/op_mode/image_installer.py | 12 | ||||
| -rwxr-xr-x | src/op_mode/show_openvpn.py | 6 | 
6 files changed, 41 insertions, 23 deletions
| diff --git a/src/conf_mode/protocols_bfd.py b/src/conf_mode/protocols_bfd.py index dab784662..37421efb4 100755 --- a/src/conf_mode/protocols_bfd.py +++ b/src/conf_mode/protocols_bfd.py @@ -72,6 +72,9 @@ def verify(bfd):                  if 'source' in peer_config and 'interface' in peer_config['source']:                      raise ConfigError('BFD multihop and source interface cannot be used together') +            if 'minimum_ttl' in peer_config and 'multihop' not in peer_config: +                raise ConfigError('Minimum TTL is only available for multihop BFD sessions!') +              if 'profile' in peer_config:                  profile_name = peer_config['profile']                  if 'profile' not in bfd or profile_name not in bfd['profile']: diff --git a/src/conf_mode/service_dhcp-server.py b/src/conf_mode/service_dhcp-server.py index 9632b91fc..91ea354b6 100755 --- a/src/conf_mode/service_dhcp-server.py +++ b/src/conf_mode/service_dhcp-server.py @@ -246,19 +246,21 @@ def verify(dhcp):                              raise ConfigError(f'Either MAC address or Client identifier (DUID) is required for '                                                f'static mapping "{mapping}" within shared-network "{network}, {subnet}"!') -                        if mapping_config['ip_address'] in used_ips: -                            raise ConfigError(f'Configured IP address for static mapping "{mapping}" already exists on another static mapping') -                        used_ips.append(mapping_config['ip_address']) - -                    if 'mac' in mapping_config: -                        if mapping_config['mac'] in used_mac: -                            raise ConfigError(f'Configured MAC address for static mapping "{mapping}" already exists on another static mapping') -                        used_mac.append(mapping_config['mac']) - -                    if 'duid' in mapping_config: -                        if mapping_config['duid'] in used_duid: -                            raise ConfigError(f'Configured DUID for static mapping "{mapping}" already exists on another static mapping') -                        used_duid.append(mapping_config['duid']) +                        if 'disable' not in mapping_config: +                            if mapping_config['ip_address'] in used_ips: +                                raise ConfigError(f'Configured IP address for static mapping "{mapping}" already exists on another static mapping') +                            used_ips.append(mapping_config['ip_address']) + +                    if 'disable' not in mapping_config: +                        if 'mac' in mapping_config: +                            if mapping_config['mac'] in used_mac: +                                raise ConfigError(f'Configured MAC address for static mapping "{mapping}" already exists on another static mapping') +                            used_mac.append(mapping_config['mac']) + +                        if 'duid' in mapping_config: +                            if mapping_config['duid'] in used_duid: +                                raise ConfigError(f'Configured DUID for static mapping "{mapping}" already exists on another static mapping') +                            used_duid.append(mapping_config['duid'])              # There must be one subnet connected to a listen interface.              # This only counts if the network itself is not disabled! diff --git a/src/conf_mode/system_option.py b/src/conf_mode/system_option.py index d92121b3d..3b5b67437 100755 --- a/src/conf_mode/system_option.py +++ b/src/conf_mode/system_option.py @@ -1,6 +1,6 @@  #!/usr/bin/env python3  # -# Copyright (C) 2019-2023 VyOS maintainers and contributors +# Copyright (C) 2019-2024 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 @@ -22,6 +22,7 @@ from time import sleep  from vyos.config import Config  from vyos.configverify import verify_source_interface +from vyos.system import grub_util  from vyos.template import render  from vyos.utils.process import cmd  from vyos.utils.process import is_systemd_service_running @@ -39,7 +40,6 @@ time_format_to_locale = {      '24-hour': 'en_GB.UTF-8'  } -  def get_config(config=None):      if config:          conf = config @@ -87,6 +87,13 @@ def verify(options):  def generate(options):      render(curlrc_config, 'system/curlrc.j2', options)      render(ssh_config, 'system/ssh_config.j2', options) + +    cmdline_options = [] +    if 'kernel' in options: +        if 'disable_mitigations' in options['kernel']: +            cmdline_options.append('mitigations=off') +    grub_util.update_kernel_cmdline_options(' '.join(cmdline_options)) +      return None  def apply(options): diff --git a/src/migration-scripts/https/5-to-6 b/src/migration-scripts/https/5-to-6 index 6d6efd32c..0090adccb 100755 --- a/src/migration-scripts/https/5-to-6 +++ b/src/migration-scripts/https/5-to-6 @@ -43,11 +43,11 @@ if not config.exists(base):      # Nothing to do      sys.exit(0) -if config.exists(base + ['certificates']): +if config.exists(base + ['certificates', 'certbot']):      # both domain-name and email must be set on CLI - ensured by previous verify()      domain_names = config.return_values(base + ['certificates', 'certbot', 'domain-name'])      email = config.return_value(base + ['certificates', 'certbot', 'email']) -    config.delete(base + ['certificates']) +    config.delete(base + ['certificates', 'certbot'])      # Set default certname based on domain-name      cert_name = 'https-' + domain_names[0].split('.')[0] diff --git a/src/op_mode/image_installer.py b/src/op_mode/image_installer.py index fad6face7..501e9b804 100755 --- a/src/op_mode/image_installer.py +++ b/src/op_mode/image_installer.py @@ -69,8 +69,8 @@ MSG_WARN_ISO_SIGN_INVALID: str = 'Signature is not valid. Do you want to continu  MSG_WARN_ISO_SIGN_UNAVAL: str = 'Signature is not available. Do you want to continue with installation?'  MSG_WARN_ROOT_SIZE_TOOBIG: str = 'The size is too big. Try again.'  MSG_WARN_ROOT_SIZE_TOOSMALL: str = 'The size is too small. Try again' -MSG_WARN_IMAGE_NAME_WRONG: str = 'The suggested name is unsupported!\n' -'It must be between 1 and 32 characters long and contains only the next characters: .+-_ a-z A-Z 0-9' +MSG_WARN_IMAGE_NAME_WRONG: str = 'The suggested name is unsupported!\n'\ +'It must be between 1 and 64 characters long and contains only the next characters: .+-_ a-z A-Z 0-9'  CONST_MIN_DISK_SIZE: int = 2147483648  # 2 GB  CONST_MIN_ROOT_SIZE: int = 1610612736  # 1.5 GB  # a reserved space: 2MB for header, 1 MB for BIOS partition, 256 MB for EFI @@ -812,7 +812,11 @@ def add_image(image_path: str, vrf: str = None, username: str = '',                  f'Adding image would downgrade image tools to v.{cfg_ver}; disallowed')          if not no_prompt: -            image_name: str = ask_input(MSG_INPUT_IMAGE_NAME, version_name) +            while True: +                image_name: str = ask_input(MSG_INPUT_IMAGE_NAME, version_name) +                if image.validate_name(image_name): +                    break +                print(MSG_WARN_IMAGE_NAME_WRONG)              set_as_default: bool = ask_yes_no(MSG_INPUT_IMAGE_DEFAULT, default=True)          else:              image_name: str = version_name @@ -867,7 +871,7 @@ def add_image(image_path: str, vrf: str = None, username: str = '',      except Exception as err:          # unmount an ISO and cleanup          cleanup([str(iso_path)]) -        exit(f'Whooops: {err}') +        exit(f'Error: {err}')  def parse_arguments() -> Namespace: diff --git a/src/op_mode/show_openvpn.py b/src/op_mode/show_openvpn.py index e29e594a5..6abafc8b6 100755 --- a/src/op_mode/show_openvpn.py +++ b/src/op_mode/show_openvpn.py @@ -63,9 +63,11 @@ def get_vpn_tunnel_address(peer, interface):          # filter out subnet entries          lst = [l for l in lst[1:] if '/' not in l.split(',')[0]] -        tunnel_ip = lst[0].split(',')[0] +        if lst: +            tunnel_ip = lst[0].split(',')[0] +            return tunnel_ip -        return tunnel_ip +        return 'n/a'  def get_status(mode, interface):      status_file = '/var/run/openvpn/{}.status'.format(interface) | 
