diff options
Diffstat (limited to 'python')
| -rw-r--r-- | python/vyos/config_mgmt.py | 11 | ||||
| -rw-r--r-- | python/vyos/ifconfig/interface.py | 2 | ||||
| -rw-r--r-- | python/vyos/kea.py | 17 | ||||
| -rw-r--r-- | python/vyos/remote.py | 2 | ||||
| -rw-r--r-- | python/vyos/system/disk.py | 5 | ||||
| -rw-r--r-- | python/vyos/system/grub.py | 2 | ||||
| -rw-r--r-- | python/vyos/system/raid.py | 31 | ||||
| -rw-r--r-- | python/vyos/utils/file.py | 4 | ||||
| -rw-r--r-- | python/vyos/utils/io.py | 9 | 
9 files changed, 54 insertions, 29 deletions
| diff --git a/python/vyos/config_mgmt.py b/python/vyos/config_mgmt.py index 2de3d1831..ff078649d 100644 --- a/python/vyos/config_mgmt.py +++ b/python/vyos/config_mgmt.py @@ -404,15 +404,8 @@ Proceed ?'''              _, _, netloc = url.netloc.rpartition("@")              redacted_location = urlunsplit(url._replace(netloc=netloc))              print(f"  {redacted_location}", end=" ", flush=True) -            try: -                upload(archive_config_file, f'{location}/{remote_file}', -                       source_host=source_address, raise_error=True) -                print("OK") -            except Exception as e: -                print("FAILED!") -                print() -                print(indent(str(e), "   > ")) -                print() +            upload(archive_config_file, f'{location}/{remote_file}', +                   source_host=source_address)      # op-mode functions      # diff --git a/python/vyos/ifconfig/interface.py b/python/vyos/ifconfig/interface.py index 1586710db..56dcde214 100644 --- a/python/vyos/ifconfig/interface.py +++ b/python/vyos/ifconfig/interface.py @@ -115,7 +115,7 @@ class Interface(Control):          },          'vrf': {              'shellcmd': 'ip -json -detail link list dev {ifname}', -            'format': lambda j: jmespath.search('[*].master | [0]', json.loads(j)), +            'format': lambda j: jmespath.search('[?linkinfo.info_slave_kind == `vrf`].master | [0]', json.loads(j)),          },      } diff --git a/python/vyos/kea.py b/python/vyos/kea.py index cb341e0f2..4a517da5f 100644 --- a/python/vyos/kea.py +++ b/python/vyos/kea.py @@ -23,7 +23,9 @@ from vyos.template import is_ipv6  from vyos.template import isc_static_route  from vyos.template import netmask_from_cidr  from vyos.utils.dict import dict_search_args +from vyos.utils.file import file_permissions  from vyos.utils.file import read_file +from vyos.utils.process import cmd  kea4_options = {      'name_server': 'domain-name-servers', @@ -119,10 +121,14 @@ def kea_parse_subnet(subnet, config):              if 'disable' in host_config:                  continue -            reservations.append({ -                'hw-address': host_config['mac_address'], -                'ip-address': host_config['ip_address'] -            }) +            obj = { +                'hw-address': host_config['mac_address'] +            } + +            if 'ip_address' in host_config: +                obj['ip-address'] = host_config['ip_address'] + +            reservations.append(obj)          out['reservations'] = reservations      unifi_controller = dict_search_args(config, 'vendor_option', 'ubiquiti', 'unifi_controller') @@ -275,6 +281,9 @@ def _ctrl_socket_command(path, command, args=None):      if not os.path.exists(path):          return None +    if file_permissions(path) != '0775': +        cmd(f'sudo chmod 775 {path}') +      with socket.socket(socket.AF_UNIX, socket.SOCK_STREAM) as sock:          sock.connect(path) diff --git a/python/vyos/remote.py b/python/vyos/remote.py index fec44b571..b1efcd10b 100644 --- a/python/vyos/remote.py +++ b/python/vyos/remote.py @@ -452,7 +452,7 @@ def upload(local_path, urlstring, progressbar=False,             source_host='', source_port=0, timeout=10.0):      try:          progressbar = progressbar and is_interactive() -        urlc(urlstring, progressbar, source_host, source_port, timeout).upload(local_path) +        urlc(urlstring, progressbar, False, source_host, source_port, timeout).upload(local_path)      except Exception as err:          print_error(f'Unable to upload "{urlstring}": {err}')      except KeyboardInterrupt: diff --git a/python/vyos/system/disk.py b/python/vyos/system/disk.py index f8e0fd1bf..b8a2c0f35 100644 --- a/python/vyos/system/disk.py +++ b/python/vyos/system/disk.py @@ -31,12 +31,17 @@ class DiskDetails:  def disk_cleanup(drive_path: str) -> None:      """Clean up disk partition table (MBR and GPT) +    Remove partition and device signatures.      Zeroize primary and secondary headers - first and last 17408 bytes      (512 bytes * 34 LBA) on a drive      Args:          drive_path (str): path to a drive that needs to be cleaned      """ +    partitions: list[str] = partition_list(drive_path) +    for partition in partitions: +        run(f'wipefs -af {partition}') +    run(f'wipefs -af {drive_path}')      run(f'sgdisk -Z {drive_path}') diff --git a/python/vyos/system/grub.py b/python/vyos/system/grub.py index 0ac16af9a..2692aaea1 100644 --- a/python/vyos/system/grub.py +++ b/python/vyos/system/grub.py @@ -138,6 +138,8 @@ def version_list(root_dir: str = '') -> list[str]:      versions_list: list[str] = []      for file in versions_files:          versions_list.append(file.stem) +    versions_list.sort(reverse=True) +      return versions_list diff --git a/python/vyos/system/raid.py b/python/vyos/system/raid.py index 13b99fa69..5b33d34da 100644 --- a/python/vyos/system/raid.py +++ b/python/vyos/system/raid.py @@ -19,7 +19,7 @@ from pathlib import Path  from shutil import copy  from dataclasses import dataclass -from vyos.utils.process import cmd +from vyos.utils.process import cmd, run  from vyos.system import disk @@ -44,18 +44,11 @@ def raid_create(raid_members: list[str],      """      raid_devices_num: int = len(raid_members)      raid_members_str: str = ' '.join(raid_members) -    if Path('/sys/firmware/efi').exists(): -        for part in raid_members: -            drive: str = disk.partition_parent(part) -            command: str = f'sgdisk --typecode=3:A19D880F-05FC-4D3B-A006-743F0F84911E {drive}' -            cmd(command) -    else: -        for part in raid_members: -            drive: str = disk.partition_parent(part) -            command: str = f'sgdisk --typecode=3:A19D880F-05FC-4D3B-A006-743F0F84911E {drive}' -            cmd(command)      for part in raid_members: -        command: str = f'mdadm --zero-superblock {part}' +        drive: str = disk.partition_parent(part) +        # set partition type GUID for raid member; cf. +        # https://en.wikipedia.org/wiki/GUID_Partition_Table#Partition_type_GUIDs +        command: str = f'sgdisk --typecode=3:A19D880F-05FC-4D3B-A006-743F0F84911E {drive}'          cmd(command)      command: str = f'mdadm --create /dev/{raid_name} -R --metadata=1.0 \          --raid-devices={raid_devices_num} --level={raid_level} \ @@ -72,6 +65,20 @@ def raid_create(raid_members: list[str],      return raid +def clear(): +    """Deactivate all RAID arrays""" +    command: str = 'mdadm --examine --scan' +    raid_config = cmd(command) +    if not raid_config: +        return +    command: str = 'mdadm --run /dev/md?*' +    run(command) +    command: str = 'mdadm --assemble --scan --auto=yes --symlink=no' +    run(command) +    command: str = 'mdadm --stop --scan' +    run(command) + +  def update_initramfs() -> None:      """Update initramfs"""      mdadm_script = '/etc/initramfs-tools/scripts/local-top/mdadm' diff --git a/python/vyos/utils/file.py b/python/vyos/utils/file.py index 2af87a0ca..70ac1753b 100644 --- a/python/vyos/utils/file.py +++ b/python/vyos/utils/file.py @@ -149,6 +149,10 @@ def chmod_775(path):                S_IROTH | S_IXOTH      chmod(path, bitmask) +def file_permissions(path): +    """ Return file permissions in string format, e.g '0755' """ +    return oct(os.stat(path).st_mode)[4:] +  def makedir(path, user=None, group=None):      if os.path.exists(path):          return diff --git a/python/vyos/utils/io.py b/python/vyos/utils/io.py index 74099b502..0afaf695c 100644 --- a/python/vyos/utils/io.py +++ b/python/vyos/utils/io.py @@ -26,13 +26,18 @@ def print_error(str='', end='\n'):      sys.stderr.write(end)      sys.stderr.flush() -def ask_input(question, default='', numeric_only=False, valid_responses=[]): +def ask_input(question, default='', numeric_only=False, valid_responses=[], +              no_echo=False): +    from getpass import getpass      question_out = question      if default:          question_out += f' (Default: {default})'      response = ''      while True: -        response = input(question_out + ' ').strip() +        if not no_echo: +            response = input(question_out + ' ').strip() +        else: +            response = getpass(question_out + ' ').strip()          if not response and default:              return default          if numeric_only: | 
